2013-06-11 17:28:29 -05:00
**Daux.io** is an documentation generator that uses a simple folder structure and Markdown files to create custom documentation on the fly. It helps you create great looking documentation in a developer friendly way.
2013-06-03 08:32:55 -05:00
2016-04-12 08:38:52 +02:00
[TOC]
2013-06-04 12:26:14 -05:00
## Features
2013-06-03 08:32:55 -05:00
2015-12-12 00:22:43 +01:00
### For Authors
2016-07-04 20:33:44 +02:00
* [Auto Generated Navigation / Page sorting ](01_Features/Navigation_and_Sorting.md )
* [Internal documentation links ](01_Features/Internal_links.md )
2017-05-18 22:51:59 +02:00
* [CommonMark compliant ](01_Features/CommonMark_compliant.md )
2016-07-04 20:33:44 +02:00
* [Auto created homepage/landing page ](01_Features/Landing_page.md )
* [Multiple Output Formats ](01_Features/Multiple_Output_Formats.md )
* [Multiple Languages Support ](01_Features/Multilanguage.md )
* [No Build Step ](01_Features/Live_mode.md )
* [Static Output Generation ](01_Features/Static_Site_Generation.md )
* [Table of Contents ](01_Features/Table_of_contents.md )
2015-12-12 00:22:43 +01:00
### For Developers
2016-07-04 20:33:44 +02:00
* [Auto Syntax Highlighting ](01_Features/Auto_Syntax_Highlight.md )
* [Extend Daux.io with Processors ](01_For_Developers/Creating_a_Processor.md )
2015-12-12 00:22:43 +01:00
* Full access to the internal API to create new pages programatically
* Work with pages metadata
### For Marketing
2013-06-21 14:38:03 -05:00
* 100% Mobile Responsive
2013-06-11 17:28:29 -05:00
* 4 Built-In Themes or roll your own
2013-06-21 14:38:03 -05:00
* Functional, Flat Design Style
2015-12-12 00:22:43 +01:00
* Optional code float layout
2013-06-04 12:26:14 -05:00
* Shareable/Linkable SEO Friendly URLs
2013-07-22 10:38:04 -05:00
* Supports Google Analytics and Piwik Analytics
2013-06-04 12:26:14 -05:00
2013-06-04 13:23:01 -05:00
## Demos
2013-06-11 17:28:29 -05:00
This is a list of sites using Daux.io:
2013-06-04 13:23:01 -05:00
2018-09-30 11:01:34 +02:00
- With a custom theme:
* [Crafty ](https://swissquote.github.io/crafty )
* [Pixolution flow ](https://docs.pixolution.org )
* [Soisy ](https://doc.soisy.it/ )
* [Vulkan Tutorial ](https://vulkan-tutorial.com )
2019-05-28 21:28:55 +02:00
* [3Q ](https://docs.3q.video/ )
2018-09-30 11:01:34 +02:00
- With the default Theme
* [Daux.io ](https://daux.io/ )
* [DoctrineWatcher ](https://dsentker.github.io/WatcherDocumentation/ )
* [DrupalGap ](http://docs.drupalgap.org/8/ )
* [ICADMIN: An admin panel powered by CodeIgniter. ](http://istocode.com/shared/ic-admin/ )
* [Munee: Standalone PHP 5.3 Asset Optimisation & Manipulation ](http://mun.ee )
* [Nuntius: A PHP framework for bots ](https://roysegall.github.io/nuntius-bot/ )
2013-06-04 13:23:01 -05:00
2017-09-13 21:43:40 +02:00
Do you use Daux.io? Send us a pull request or open an [issue ](https://github.com/dauxio/daux.io/issues ) and I will add you to the list.
2013-06-04 13:23:01 -05:00
2015-12-12 00:22:43 +01:00
## Getting Started
2016-07-29 23:20:01 +02:00
### Install
2013-06-04 12:26:14 -05:00
2017-09-13 22:47:53 +02:00
#### PHP and Composer
If you have PHP and Composer installed, you can install the dependency
```bash
2017-10-13 21:18:00 -07:00
composer global require daux/daux.io
2017-09-13 22:47:53 +02:00
# Next to your `docs` folder, run
daux generate
2016-07-29 23:20:01 +02:00
```
2015-07-21 09:49:49 +02:00
2016-07-29 23:20:01 +02:00
You can then use the `daux` command line to generate your documentation.
2015-07-21 09:49:49 +02:00
2018-06-22 15:24:07 +02:00
If the command isn't found, ensure your `$PATH` contains `~/.composer/vendor/bin` or `~/.config/composer/vendor/bin` .
2013-06-04 12:26:14 -05:00
2017-09-13 22:47:53 +02:00
#### Docker
Or if you wish to use Docker, the start of the command will be :
```bash
docker run --rm -it -w /build -v "$PWD":/build daux/daux.io daux
```
Any parameter valid in the PHP version is valid in the Docker version
2015-12-12 00:22:43 +01:00
### Writing pages
2015-07-19 16:36:59 +02:00
2015-12-12 00:22:43 +01:00
Creating new pages is very easy:
1. Create a markdown file (`*.md` or `*.markdown` )
2. Start writing
2013-06-04 13:23:01 -05:00
2015-12-12 00:22:43 +01:00
By default, the generator will look for folders in the `docs` folder.
Add your folders inside the `docs` folder. This project contains some example folders and files to get you started.
2013-06-04 12:26:14 -05:00
2015-12-12 00:22:43 +01:00
You can nest folders any number of levels to get the exact structure you want.
The folder structure will be converted to the nested navigation.
2013-06-04 12:26:14 -05:00
2014-07-12 16:01:57 +05:30
You must use underscores instead of spaces. Here are some example file names and what they will be converted to:
2013-06-04 12:26:14 -05:00
2013-06-04 13:23:01 -05:00
**Good:**
2013-06-04 12:26:14 -05:00
2013-06-04 13:23:01 -05:00
* 01_Getting_Started.md = Getting Started
* API_Calls.md = API Calls
* 200_Something_Else-Cool.md = Something Else-Cool
2014-07-12 16:01:57 +05:30
* _5_Ways_to_Be_Happy.md = 5 Ways To Be Happy
2013-06-04 13:23:01 -05:00
**Bad:**
* File Name With Space.md = FAIL
2013-06-04 12:26:14 -05:00
2015-12-12 00:22:43 +01:00
### See your pages
2013-06-11 17:28:29 -05:00
2015-12-12 00:22:43 +01:00
Now you can see your pages. you have two options for that : serve them directly, or generate to various formats.
2013-06-04 12:26:14 -05:00
2015-12-12 00:22:43 +01:00
We recommend the first one while you write your documentation, you get a much quicker feedback while writing.
2013-06-04 12:26:14 -05:00
2015-12-12 00:22:43 +01:00
#### Serving files
2013-06-04 12:26:14 -05:00
2015-12-12 00:22:43 +01:00
You can use PHP's embedded web server by running the following command in the root of your documentation
2013-06-04 12:26:14 -05:00
2013-07-28 20:58:19 -05:00
```
2015-12-12 00:22:43 +01:00
./serve
2013-07-28 20:58:19 -05:00
```
2013-06-21 14:36:50 -05:00
2015-12-12 00:22:43 +01:00
Upload your files to an apache / nginx server and see your documentation
2013-07-22 10:38:04 -05:00
2016-07-04 20:33:44 +02:00
[More informations here ](01_Features/Live_mode.md )
2013-10-22 16:50:46 -04:00
2015-12-12 00:22:43 +01:00
#### Export to other formats
2014-05-30 22:43:07 -07:00
2015-12-12 00:22:43 +01:00
Daux.io is extendable and comes by default with three export formats:
2013-07-29 11:58:04 -07:00
2015-12-12 00:22:43 +01:00
- Export to HTML, same as the website, but can be hosted without PHP.
- Export all documentation in a single HTML page
- Upload to your Atlassian Confluence server.
2015-07-19 16:36:59 +02:00
2016-07-04 20:33:44 +02:00
[See a detailed feature comparison matrix ](01_Features/Multiple_Output_Formats.md )
2015-07-19 16:36:59 +02:00
2016-07-29 23:20:01 +02:00
To export, run the `daux` command and your documentation will be generated in `static` (you can change the destination with the `--destination` option)
2015-08-15 17:24:09 +02:00
2016-07-04 20:33:44 +02:00
[See here for all options ](01_Features/Static_Site_Generation.md )
2015-08-15 17:24:09 +02:00
2015-12-12 00:22:43 +01:00
## Configuration
2015-08-15 17:24:09 +02:00
2016-07-04 20:33:44 +02:00
Now that you got the basics, you can also [see what you can configure ](05_Configuration/_index.md )
2013-07-30 08:56:16 -05:00
2016-08-10 08:57:51 +02:00
## PHP Requirements
2019-11-28 22:36:26 +01:00
Daux.io is compatible with PHP 7.2.0 and up.
2016-08-10 08:57:51 +02:00
2019-09-09 19:53:59 +02:00
The reason is because some dependencies we have (mainly Symfony and Guzzle) do not support PHP 5.6 anymore.
2016-08-10 08:57:51 +02:00
### Extensions
PHP Needs the following extension to work : `php-mbstring` and `php-xml` .
If you encounter an error similar to `utf8_decode() not found` this means that you're missing the `php-xml` package. (We've seen it happen only on PHP 7)
2013-07-30 08:56:16 -05:00
2015-08-15 16:31:36 +02:00
## Known Issues
2017-01-23 22:14:59 +01:00
- __Windows UTF-8 files support__ Files with UTF-8 characters cannot be handled on windows with PHP5, PHP7 should work fine.
2015-08-15 16:31:36 +02:00
2013-06-04 13:23:01 -05:00
## Support
2013-06-04 12:26:14 -05:00
2017-09-13 21:43:40 +02:00
If you need help using Daux.io, or have found a bug, please create an issue on the < a href = "https://github.com/dauxio/daux.io/issues" target = "_blank" > GitHub repo< / a > .