lorenzschaef / help-pages-bundle
This Bundle provides a simple way of including end user documentation in your Symfony application.
Installs: 14
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Type:symfony-bundle
Requires
- php: >=5.3.2
- knplabs/knp-markdown-bundle: ^1.4
- symfony/framework-bundle: ~2.3
- symfony/twig-bundle: ~2.3
This package is not auto-updated.
Last update: 2025-01-04 20:14:51 UTC
README
This is a Symfony Bundle that provides a simple way of including end user documentation in your application. It takes markdown files stored on the server and renders them in a template, together with an automatically generated menu.
Installation
Step 1: Download the Bundle
Open a command console, enter your project directory and execute the following command to download the latest stable version of this bundle:
$ composer require lorenzschaef/help-pages-bundle "~1"
This command requires you to have Composer installed globally, as explained in the installation chapter of the Composer documentation.
Step 2: Enable the Bundle
Then, enable the bundle by adding it to the list of registered bundles
in the app/AppKernel.php
file of your project.
The bundle depends on the KnpMarkdownBundle, so you have to register that as well, if you haven't already.
<?php // app/AppKernel.php // ... class AppKernel extends Kernel { public function registerBundles() { $bundles = array( // ... new Knp\Bundle\MarkdownBundle\KnpMarkdownBundle(), new Lorenzschaef\HelpPagesBundle\LorenzschaefHelpPagesBundle(), ); // ... } // ... }
Step 3: Configure the Routes
Add the following line to your app/config/routing.yml and change the prefix as you like.
help_pages: resource: "@LorenzschaefHelpPagesBundle/Controller/" type: annotation prefix: /help
Step 4: Add the Bundle to the Assetic Configuration
In your app/config/config.yml add the Bundle to the Assetic config.
assetic: bundles: [AppBundle, LorenzschaefHelpPagesBundle, ...]
Step 4: Change the Base Directory (optional)
By default, the bundle looks for your Help Pages in app/Resources/HelpPages. You can change this in your config like so:
lorenzschaef_help_pages: basedir: your/directory
The directory is specified relative to your AppKernel.php, which normally resides in the app folder.
Usage
Add your Documents
Put your Help Pages in the configured folder (app/Resources/HelpPages by default). The files have to end with .md and can be organized in subfolders. To define the sorting order, you may prepend a number followed by an underscore to the filename.
|- 01_gettingstarted.md
|- 02_basics
|- index.md
|- 01_accountcreation.md
|- 02_profile.md
...
These pages can then be accessed through the following URLs:
http:://www.example.com/help/gettingstarted
http:://www.example.com/help/basics <- This displays the index.md
http:://www.example.com/help/basics/accountcreation
http:://www.example.com/help/basics/profile
The menu generator looks for the first level one title of each document to display it as the link text. Currently only the syntax with the hash (#) is supported. If it can't find any level 1 title in the document, it will use the string "Untitled".
Change the Appearance
The original templates are located in the bundle folder under Resources/views.
- layout.html.twig: defines the general layout.
- toc.html.twig: defines a twig macro that renders the table of contents which is used in layout.html.twig
In order to override one of these, just put a template with the same name in app/Resources/LorenzschaefHelpPagesBundle/views.