/bemdoc-gen

generate visual and interactive documentation for CSS components

Primary LanguageJavaScriptMIT LicenseMIT

(logo) bemdoc-gen

Contributor Covenant NPM Version

bemdoc-gen is a lightweight tool for generating visual and interactive documentation pages for CSS components.

When creating a web project with many CSS files, it is easy to lose track of content and interdependencies. Often, these CSS files are organized within a bunch of folders, called components or blocks. bemdoc-gen parses the CSS files and adds an HTML documentation file to each block.

Originally, this project was made with the BEM methodology in mind, but it works really well without it too.

Try the Online Demo!

⚠️ Attention: This project is work-in-progress – some features won't work yet.

(bemdoc-gen result example visualization)

🖊️ Annotating your CSS files

bemdoc-gen requires some simple annotation at any place in your CSS files to work, for example:

/**
 * This is a simple button block.
 * @tree
 *   .button.botton--image : div | span
 *     .button__icon : img
 *     .button__text : button
 * @variable {color} [--button--color=black] foreground/text color
 */

If you want to, feel free to take a look at the complete annotation syntax.

💻 Usage

Use the package manager npm to install and run bemdoc-gen.

If you just want to try the program once without installing it globally, just run

> npx bemdoc-gen <folder>

where <folder> is the folder that contains the block folders. Your output files will land in the block folders and will have the format *.bemdoc.html. If you want to, you can add that to your .gitignore file.

If you like bemdoc-gen and want to keep it, install it with

> npm install -g bemdoc-gen

and whenever you need it, just run

> bemdoc-gen <folder>

If you need example data, clone goldst/goldst.github.io and run bemdoc-gen on the blocks folder.

:octocat: Contributing

bemdoc-gen is far from being done. Even though the state of code and ideas is a bit messy right now, you are invited to participate! For more information on how you can help, have a look at the contribution page and the code of conduct.

If you use bemdoc-gen in your own project, I'd love to hear from you! You can drop me an e-mail at 𝕝𝕖𝕠𝕟𝕒𝕣𝕕-𝕘𝕠𝕝𝕕𝕤𝕥𝕖𝕚𝕟@𝕠𝕦𝕥𝕝𝕠𝕠𝕜.𝕕𝕖 (if you can read it, you are probably not a 🤖) or even better, just file an issue.

📃 License

MIT