Skip to main content
Version: v4.11

Docs Readme Markdown File Auto-Generation

Stencil is able to auto-generate readme.md files in markdown. This feature will save the readme files as a sibling to the component's source file within the same directory. This can help you to maintain consistently formatted documentation for your components which live right next to them and render in GitHub.

To auto-generate readme files, add the docs-readme output target to your stencil.config.ts like so:

stencil.config.ts
import { Config } from '@stencil/core';

export const config: Config = {
outputTargets: [
{ type: 'docs-readme' }
]
};

Another option would be to use the --docs CLI flag as a part of the build task, like so:

stencil build --docs

This will cause the Stencil compiler to perform a one-time generation of README files as a part of the build process.

note

If you don't add the docs-readme output target to your Stencil configuration, the --docs flag must be applied to regenerate documentation.

Alternatively, the docs task can be used to perform a one time generation of the documentation:

stencil docs

Adding Custom Markdown to Auto-Generated Files

Once you've generated a readme.md file you can customize it with your own markdown content. Simply add your own markdown above the comment that reads: <!-- Auto Generated Below -->.

Removing or customizing the footer can be done by adding a footer property to the output target. This string is added to the generated Markdown files without modification, so you can use Markdown syntax in it for rich formatting.

stencil.config.ts
import { Config } from '@stencil/core';

export const config: Config = {
outputTargets: [
{
type: 'docs-readme',
footer: '*Built with love!*',
}
]
};

Generating to a Directory

By default, a readme file will be generated in the same directory as the component corresponds to. This behavior can be changed by setting the dir property on the output target configuration. Specifying a directory will create the structure {dir}/{component}/readme.md.

stencil.config.ts
import { Config } from '@stencil/core';

export const config: Config = {
outputTargets: [
{
type: 'docs-readme',
dir: 'output'
}
]
};

Strict Mode

Adding strict: true to the output target configuration will cause Stencil to output a warning whenever the project is built with missing documentation.

stencil.config.ts
import { Config } from '@stencil/core';

export const config: Config = {
outputTargets: [
{
type: 'docs-readme',
strict: true
}
]
};