* feat(v2): add remark-admonitions * feat(v2): add admonitions to style guide * style: cleanup changes * docs(v2): document how to use admonitions * docs(v2): use proper package name * docs(v2): add link to remark-admonitions docs * style(v2): clean up addAdmonitions
4 KiB
id | title |
---|---|
presets | Presets |
Presets are collections of plugins and themes.
Using Presets
A preset is usually a npm package, so you install them like other npm packages using npm.
npm install --save docusaurus-preset-name
Then, add it in your site's docusaurus.config.js
's presets
option:
// docusaurus.config.js
module.exports = {
// ...
presets: ['@docusaurus/preset-xxxx'],
};
To load presets from your local directory, specify how to resolve them:
// docusaurus.config.js
const path = require('path');
module.exports = {
// ...
presets: [path.resolve(__dirname, '/path/to/docusaurus-local-presets')],
};
Presets -> Themes and Plugins
Presets in some way are a shorthand function to add plugins and themes to your docusaurus config. For example, you can specify a preset that includes the following themes and plugins,
module.exports = function preset(context, opts = {}) {
return {
themes: ['@docusaurus/themes-cool', '@docusaurus/themes-bootstrap'],
plugins: ['@docusaurus/plugin-blog'],
};
};
then in your Docusaurus config, you may configure the preset instead:
// docusaurus.config.js
module.exports = {
// ...
presets: ['@docusaurus/preset-a'],
};
This is equivalent of doing:
// docusaurus.config.js
module.exports = {
themes: ['@docusaurus/themes-cool', '@docusaurus/themes-bootstrap'],
plugins: ['@docusaurus/plugin-blog'],
};
This is especially useful when some plugins and themes are intended to be used together.
Official Presets
@docusaurus/preset-classic
The classic preset that is usually shipped by default to new docusaurus website. It is a set of plugins and themes.
Themes | Plugins |
---|---|
@docusaurus/theme-classic | @docusaurus/plugin-content-docs |
@docusaurus/theme-search-algolia | @docusaurus/plugin-content-blog |
@docusaurus/plugin-content-pages | |
@docusaurus/plugin-google-analytics | |
@docusaurus/plugin-google-gtag | |
@docusaurus/plugin-sitemap |
To specify plugin options individually, you can provide the necessary fields to certain plugins, i.e. customCss
for @docusaurus/theme-classic
, pass them in the preset field, like this:
// docusaurus.config.js
module.exports = {
presets: [
[
'@docusaurus/preset-classic',
{
// Will be passed to @docusaurus/theme-classic.
theme: {
customCss: require.resolve('./src/css/custom.css'),
},
// Will be passed to @docusaurus/plugin-content-docs
docs: {},
// Will be passed to @docusaurus/plugin-content-blog
blog: {},
// Will be passed to @docusaurus/plugin-content-pages
pages: {},
// Will be passed to @docusaurus/plugin-content-sitemap
sitemap: {},
},
],
],
};
In addition to these plugins and themes, @docusaurus/theme-classic
adds remark-admonitions
as a remark plugin to @docusaurus/plugin-content-blog
and @docusaurus/plugin-content-docs
.
The admonitions
key will be passed as the options to remark-admonitions
. Passing false
will prevent the plugin from being added to MDX.
// docusaurus.config.js
module.exports = {
presets: [
[
'@docusaurus/preset-classic',
{
docs: {
// options for remark-admonitions
admonitions: {},
},
},
],
],
};