webframe-docs
v0.0.2
Published
Automatic Documentation Generator for React Components
Downloads
8
Maintainers
Readme
Automatic Docs Generator for React Components (WIP)
:warning: this package is under development! (pending
@webframer/compiler
release)
Webframe Docs is a CLI tool for generating documentation of React components, with automatic:
- PropTypes parsing of code comments into descriptions with
<PropsTable>
- Source code generation for component examples wrapped inside
<CodeExample>
.
Demo & Examples
These documentation sites were built using webframe-docs
CLI:
Key Benefits
Webframe Docs compiler is:
- An alternative to Docz (partially inspired by Docz concepts)
- Package and project agnostic (works for any setup, without reliance on Webpack)
- Extendable beyond basic React PropTypes with custom type system
Setup & Usage
- Optionally create a
webframe.docs.json
config file in your project. Directory paths use glob patterns, which are relative to the location of the config file, and can be outside the project root directory. This is the default config when no config file exists:
{
"projects": [
{
// Directory containing React Components to document
"inputComponents": [
"!**/node_modules",
"./components/**/*.{js,jsx}"
],
// Directory containing source .mdx files to compile (or glob pattern)
"inputDocs": "./docs",
// Directory path where to save compiled doc files
"outputDocs": "./pages/docs",
// Where to save parsed React Component PropTypes
"outputPropTypes": "./src/propTypes.json",
},
],
}
- Run the docs compiler command in Terminal (with optional
--watch
mode)
# Runs this command inside project root,
# or where there is webframe.docs.json config file.
npx webframe-docs compile --watch
How It Works
Currently, webframe-docs
supports documentation generated with Nextra using Next.js.
It watches for changes in the input directories and compiles files with .mdx
extension into output directories (
ex. pages/docs
). Other files in the inputDocs
directory also sync with the outputDocs
directory.
Then it's up to Nextra (ex. using nextra-theme-docs package) to build the files for production bundle.