React Static ships with a plugin API to extend React Static's functionality.
- CSS & Style Tooling
- react-static-plugin-emotion - Adds SSR support for Emotion components.
- react-static-plugin-styled-components - Adds SSR support for Styled-Components
- react-static-plugin-sass - Adds SSR and general support for SASS
- react-static-plugin-less - Adds SSR and general support for LESS
- react-static-plugin-jss - Adds SSR support for JSS
- react-static-plugin-css-modules - Adds SSR support for CSS modules
- React Alternatives
- react-static-plugin-preact - Adds preact support
- Routing
- react-static-plugin-react-location - Adds react-location support
- react-static-plugin-reach-router - Adds @reach/router support
- react-static-plugin-react-router - Adds react-router support
- Content
- react-static-plugin-source-filesystem - Creates routes from files in a directory
- react-static-plugin-mdx - Adds support for MDX
- Type checking
- react-static-plugin-typescript - Allows you to write your components in TypeScript
- Assets
- react-static-plugin-sitemap - Exports sitemap information as XML
- Assets
- react-static-plugin-favicons - Generate (fav)icons in many different sizes for many different platforms, and add them to your site's metadata
If you have a custom plugin or are developing a plugin locally, you can place your plugin directory in the /plugins
directory in your project root. It can then be used by React Static.
If you simply need direct access to the the plugin API for a project, you can create a node.api.js
and/or browser.api.js
file in the root of your project. These files are treated just like plugins themselves, but do not receive plugin options and are executed very last in the plugin cycle.
After installation, configure it by adding it to the plugins
array in static.config.js
:
// static.config.js
export default {
plugins: ['react-static-plugin-emotion', 'my-custom-plugin'],
}
Order of execution:
- Plugins in
plugins: []
, starting from the first element of array. - Any
node.api.js
andbrowser.api.js
files at the project root.
Plugins are resolved in this order:
- Plugins with an absolute path. Eg.
~/path/to/my/my-plugin
would resolve to that path. - Plugins found in the
/plugins
directory of your project root. Eg.my-plugin
would resolve to/plugins/my-plugin
. - Plugins found in
node_modules
. Eg.react-static-plugin-emotion
would resolve tonode_modules/react-static-plugin-emotion
.
Plugins can be passed options by using an array (similar to how babel and eslint work).
- The first item in the array is the
plugin name string
- The second item in the array is the
options object
that will be passed to the plugin
// static.config.js
export default {
plugins: [
[
'react-static-plugin-awesomeness',
{
isAwesome: true,
},
],
],
}
All plugins contains at least one of:
node.api.js
- Exposes the Node Plugin APIbrowser.api.js
- Exposes the Browser Plugin API
Separating plugin entrypoints avoids creating conflict with imported modules that may not be supported in both environments.
The file (for either environment) must:
- Provide a
function
as thedefault export
- That function receives an optional user plugin options argument
- Return an
object
providing any API methods to implement
Basic plugin example:
export default pluginOptions => ({
myCustomAPIMethod: options => {
console.log('hello world')
},
})
- Modify your
static.config.js
- Transform your webpack config
- Append JSX to the Head of the app
- Customize your App's router
- and more!
View the browser API docs and the node API docs for full list of API methods that can be implemented.
Only the plugins
directory will be transformed by react-static's babel runtime.
Hence, when distributing your plugin, your plugin must be ES5 compatible.
- An example of a plugin compiled before distribution is react-static-plugin-styled-components.