Instant PHP Documentation pages
We all document our code with PHP DocBlocks but we never seem to actually generate the documentation and add it to our project. Why? It simply takes too much time (over a minute), so we put it off till later, and later never comes.
But with PHPFUI/InstaDoc, you can document your site in about a minute (OK, maybe 2). The steps involved:
Create document page (1 minute, 6 lines of code)
Two minutes to usable documentation with the following features:
composer require phpfui/InstaDoc
Once installed, you need to run an installation script to copy static files to your public directory. From your project root, run the following:
php vendor/phpfui/instadoc/install.php yourPublicDirectory/subDirectory
Example: php vendor/phpfui/instadoc/install.php public/PHPFUI will add all needed files to public/PHPFUI, which will avoid any conflicts with your current files. You can specify any directory by using \PHPFUI\Page::setResourcePath, but PHPFUI is recomended to keep things simple.
PHPFUI/InstaDoc does not reply on any framework and can run on a standalone page. It is recommended that you do not make your documentation public, as PHPFUI/InstaDoc will display PHP source files. How you restrict access to the page is up to you. The following does not restrict access and is simply an example:
<?php
include 'yourAutoLoader.php';
// pass the directory containing your composer.json file
$fileManager = new \PHPFUI\InstaDoc\FileManager('../');
// add your App class tree in, pass true as the last parameter if this namespace is in your local git repo.
$fileManager->addNamespace('App', '../App', true);
// load your cached files
$fileManager->load();
// load child classes if you want to display them, if you don't do this step, docs will not show classes that extend the displayed class
\PHPFUI\InstaDoc\ChildClasses::load();
// get the controller
$controller = new \PHPFUI\InstaDoc\Controller($fileManager);
// display will return a fully formed page
echo $controller->display();
That is it. You are done!
PHPFUI/InstaDoc saves the classes to display in PHP serialized files. Delete those files (.serial extension) when you want to display new classes. PHPFUI/InstaDoc will regenerate automatically if the files are missing.
\PHPFUI\InstaDoc\ChildClasses::load('../ChildClasses.serial');
The git repo path defaults to the composer directory, but you can change the path by calling:
$fileManager->addGlobalNameSpaceClass(__DIR__ . '/global/FPDF.php');
$fileManager->excludeNamespace('Carbon');
The git repo path defaults to the composer directory, but you can change the path by calling:
$controller->setGitRoot(getcwd() . '/../');
$controller->addHomePageMarkdown('../PHPFUI/InstaDoc/README.md');
You may want users to get back into your system easily. Clicking on the top left menu bar will take them here:
$controller->setHomeUrl('/');
If you have a lot of source code, you might want to break it into sections, so you will need a separate file to store the index in per section:
$fileManager->setBaseFile('SubProject');
Just the doc and file pages, no git!
$controller->generate('static/file/path', [\PHPFUI\InstaDoc\Controller::DOC_PAGE, \PHPFUI\InstaDoc\Controller::FILE_PAGE, ]));