Plugin Method References
Esta seção está em progresso. Anchor links or even URLs are not guaranteed to be stable.
Plugin APIs are shared by themes and plugins—themes are loaded just like plugins.
Plugin module
Every plugin is imported as a module. The module is expected to have the following members:
- A default export: the constructor function for the plugin.
- Named exports: the static methods called before plugins are initialized.
Plugin constructor
The plugin module's default export is a constructor function with the signature (context: LoadContext, options: PluginOptions) => Plugin | Promise<Plugin>.
context
context é plugin-agnostic, e o mesmo objeto será passado para todos os plugins usados em um site do Docusaurus. O objeto context contém os seguintes campos:
type LoadContext = {
  siteDir: string;
  generatedFilesDir: string;
  siteConfig: DocusaurusConfig;
  outDir: string;
  baseUrl: string;
};
options
options are the second optional parameter when the plugins are used. options são específicas do plugin e são especificadas pelos usuários quando os usam em docusaurus.config.js. If there's a validateOptions function exported, the options will be validated and normalized beforehand.
Alternatively, if a preset contains the plugin, the preset will then be in charge of passing the correct options into the plugin. It is up to the individual plugin to define what options it takes.
Exemplo
Here's a mental model for a presumptuous plugin implementation.
// A JavaScript function that returns an object.
// `context` is provided by Docusaurus. Example: siteConfig can be accessed from context.
// `opts` is the user-defined options.
export default async function myPlugin(context, opts) {
  return {
    // A compulsory field used as the namespace for directories to cache
    // the intermediate data for each plugin.
    // If you're writing your own local plugin, you will want it to
    // be unique in order not to potentially conflict with imported plugins.
    // A good way will be to add your own project name within.
    name: 'docusaurus-my-project-cool-plugin',
    async loadContent() {
      // The loadContent hook is executed after siteConfig and env has been loaded.
      // You can return a JavaScript object that will be passed to contentLoaded hook.
    },
    async contentLoaded({content, actions}) {
      // The contentLoaded hook is done after loadContent hook is done.
      // `actions` are set of functional API provided by Docusaurus (e.g. addRoute)
    },
    async postBuild(props) {
      // After docusaurus <build> finish.
    },
    // TODO
    async postStart(props) {
      // docusaurus <start> finish
    },
    // TODO
    afterDevServer(app, server) {
      // https://webpack.js.org/configuration/dev-server/#devserverbefore
    },
    // TODO
    beforeDevServer(app, server) {
      // https://webpack.js.org/configuration/dev-server/#devserverafter
    },
    configureWebpack(config, isServer, utils, content) {
      // Modify internal webpack config. If returned value is an Object, it
      // will be merged into the final config using webpack-merge;
      // If the returned value is a function, it will receive the config as the 1st argument and an isServer flag as the 2nd argument.
    },
    getPathsToWatch() {
      // Paths to watch.
    },
    getThemePath() {
      // Returns the path to the directory where the theme components can
      // be found.
    },
    getClientModules() {
      // Return an array of paths to the modules that are to be imported
      // in the client bundle. These modules are imported globally before
      // React even renders the initial UI.
    },
    extendCli(cli) {
      // Register an extra command to enhance the CLI of Docusaurus
    },
    injectHtmlTags({content}) {
      // Inject head and/or body HTML tags.
    },
    async getTranslationFiles({content}) {
      // Return translation files
    },
    translateContent({content, translationFiles}) {
      // translate the plugin content here
    },
    translateThemeConfig({themeConfig, translationFiles}) {
      // translate the site themeConfig here
    },
    async getDefaultCodeTranslationMessages() {
      // return default theme translations here
    },
  };
}
export function validateOptions({options, validate}) {
  const validatedOptions = validate(myValidationSchema, options);
  return validatedOptions;
}
export function validateThemeConfig({themeConfig, validate}) {
  const validatedThemeConfig = validate(myValidationSchema, options);
  return validatedThemeConfig;
}