@rspress/plugin-typedoc

Integration of TypeDoc's Rspress Plugin for Automatically Generating API Documentation for TS Modules.

Installation

npm
yarn
pnpm
bun
npm add @rspress/plugin-typedoc -D

Usage

import { defineConfig } from 'rspress/config';
import { pluginTypeDoc } from '@rspress/plugin-typedoc';
import path from 'path';

export default defineConfig({
  plugins: [
    pluginTypeDoc({
      entryPoints: [
        path.join(__dirname, 'src', 'foo.ts'),
        path.join(__dirname, 'src', 'bar.ts'),
      ],
    }),
  ],
});
src/foo.ts
/**
 * This is an add function.
 */
export function add(
  /**
   * This is param1.
   */
  param1: string,
  /**
   * This is param2.
   */
  param2: number,
) {
  return 1;
}
src/bar.ts
/**
 * This is a multi function.
 */
export function multi(
  /**
   * This is param1.
   */
  param1?: string,
  /**
   * This is param2.
   */
  param2?: number,
) {
  return 1;
}

When you start/build the project, the plugin will automatically generate an api directory in your document root directory. The directory structure is as follows:

api
├── README.md
├── documentation.json
├── functions
│   ├── bar.multi.md
│   └── foo.add.md
├── interfaces
│   ├── foo.RunTestsOptions.md
│   └── foo.TestMessage.md
└── modules
    ├── bar.md
    └── foo.md

This means that the plugin will internally call TypeDoc to automatically generate API documentation for your modules, including module lists, Interface details, function details (parameters, return values, description), etc. It will also generate a documentation.json file for subsequent sidebar rendering.

Note that the documentation is regenerated every time you start the project to reflect the latest module content. Therefore, we recommend adding the api directory to .gitignore. If you customize the output directory with the outDir parameter below, you should also add it to .gitignore.

Also, we do not recommend modifying or adding documents in the api directory because these documents will be overwritten each time the project is started due to changes in module content.

Parameter description

entryPoints

  • Type: string[]
  • Default: []

Specifies the absolute path of the TS modules for which documentation should be generated.

outDir

  • Type: string
  • Default: api

Customize the output directory for the documentation. You need to provide a relative path, such as api/custom.