Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ionic-team/capacitor-docgen
Docs Readme Markdown and JSON Generator for Capacitor Plugins.
https://github.com/ionic-team/capacitor-docgen
capacitor capacitor-plugin docs-generator
Last synced: 2 months ago
JSON representation
Docs Readme Markdown and JSON Generator for Capacitor Plugins.
- Host: GitHub
- URL: https://github.com/ionic-team/capacitor-docgen
- Owner: ionic-team
- License: other
- Created: 2020-09-28T21:57:58.000Z (about 4 years ago)
- Default Branch: main
- Last Pushed: 2024-01-26T18:17:06.000Z (11 months ago)
- Last Synced: 2024-05-09T09:56:12.750Z (7 months ago)
- Topics: capacitor, capacitor-plugin, docs-generator
- Language: TypeScript
- Homepage: https://capacitorjs.com/
- Size: 485 KB
- Stars: 12
- Watchers: 12
- Forks: 8
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-capacitorjs - @capacitor/docgen - Docs Readme Markdown and JSON Generator for Capacitor Plugins. (Tools / Community Plugins)
- awesome-capacitor - Docgen - Docs Readme Markdown and JSON Generator for Capacitor Plugins. (Tools / Incompatible)
README
# @capacitor/docgen
Docs Readme Markdown and JSON Generator for [Capacitor](https://capacitorjs.com/) Plugins.
- Designed specifically for generating docs for Capacitor plugins using TypeScript
- Generates docs data pulled from [JSDocs](https://en.wikipedia.org/wiki/JSDoc) within source code
- Replaces placeholders within existing README.md markdown files with the generated docs
- Outputs a json file of the raw docs data
- Ideal for formatted docs within Github and NPM readme landing pages
- If you're looking for an entire docs site generator we recommend [TypeDoc](https://typedoc.org/) instead```bash
npm i @capacitor/docgen --save-dev
```## Example Readme File
```
# My Capacitor Plugin 🔌The readme file can be formatted however you'd like. Just insert
the docgen placeholder elements where the index of the API methods,
and the API docs should go.Below is an index of all the methods available.
## Custom Readme Content
Manage your readme content however, and on every `docgen` rebuild
it will leave the original content as is, but update the inner text
of the docgen placeholder elements with the updated generated docs.## Commit Your Readme 🚀
The benefit of this readme file is that is also acts as the landing
page for the Github repo and NPM package, and the anchors within the
docs can also be linked to and shared.
```- [Example Readme Output](https://github.com/ionic-team/capacitor-docgen/blob/main/src/test/README.md)
- [Example JSON Output](https://github.com/ionic-team/capacitor-docgen/blob/main/src/test/docs.json)## CLI
The easiest way to run `docgen` is to install `@capacitor/docgen` as a dev dependency
and add the command to the `package.json` scripts. In the example below,
`HapticsPlugin` is the primary interface:```bash
docgen --api HapticsPlugin --output-readme README.md
```| Flag | Alias | Description |
|-------------------|-------|------------------------------------------------------------------------------------------|
| `--api` | `-a` | The name of the primary application programming interface. **Required** |
| `--output-readme` | `-r` | Path to the markdown file to update. Note that the file must already exist. **Required** |
| `--output-json` | `-j` | Path to write the raw docs data as a json file. |
| `--project` | `-p` | Path to the project's `tsconfig.json` file, same as the [project](https://www.typescriptlang.org/docs/handbook/compiler-options.html) flag for TypeScript's CLI. By default it'll attempt to find this file. |#### package.json script
```json
{
"scripts": {
"docgen": "docgen --api HapticsPlugin --output-readme README.md"
}
}
```## API
The same API that's available to the CLI can also be imported from `@capacitor/docgen`.
## Related
- [Capacitor](https://capacitorjs.com/)
- [Capacitor Community Plugins](https://github.com/capacitor-community)