Plugins
Quokka.js is easily extensible via user defined plugins. Plugins may be used to add additional functionality, for example to load environment variables, to set up a specific environment, or to provide some utility functions.
If you want to extend Quokka.js default runtime, you may use the plugins setting:
{  "plugins": ["./my-plugin", "dotenv-quokka-plugin"]}Note that this may either install node modules plugins locally to your project or to the
global Quokka folder, if you don’t like to pollute your project’s node
modules. For example, to install the dotenv-quokka-plugin plugin to the global Quokka folder, you may run
cd ~/.quokkanpm install dotenv-quokka-pluginAPI
Quokka plugin is a CommonJS module that should expose an object with a couple of functions:
module.exports = {  before: (config) => {},
  beforeEach: (config) => {},};When possible, Quokka.js re-uses the same node.js process for running your code. The before function code is
executed once per process, and is the best place to initialize things once per process. For example, Quokka uses the
function to set up Babel and ts-node register hooks.
The beforeEach function gets executed before every run, potentially every key stroke. This is the best place to
run some cleanup code, or some initialization code required every run (ideally it needs to be fast).
The config argument object passed to the both of the functions is the
final configuration object (the result of merging Quokka settings from various locations).
If your plugin requires some configuration options from a user, you may allow users to specify the options under your plugin’s setting name in the configuration:
{  "myPlugin": {    "mySetting": "myValue"  }}and then access it in your plugin:
// myPluginmodule.exports = {  before: (config) => {    console.log(config.myPlugin.mySetting); // myValue  },};You may also change the config object, for example, you could write a plugin that adds an alternative babel support
and prevent Quokka from running the built-in one, it is possible to write:
module.exports = {  before: (config) => {    delete config.babel;  },};Plugin ideas and recommendations
If you think that your plugin may be useful to others, you may create and publish a node module with it. The suggested
module naming convention is quokka-plugin-purpose, where purpose is the one-two words description of what the module
is adding to the quokka’s default workflow.
Some examples of the plugins that may be useful for everyone are environment setups for popular frameworks and libraries, such as Angular, React, Express, etc.
If you find yourself adding some code to run before every new Quokka file that you create, it’s probably a good candidate for a plugin as well.
If you would like to expose some API from your plugin, the recommended way to do it is via a namespace in the global
object. While globals are not great in real apps, in a playground they allow users to experiment with less ceremony
involve. So for example a simple benchmarking plugin named time may look like:
 module.exports = {
   before: config => {     global.time = func => {       console.time('Execution time');       func();       console.timeEnd('Execution time');     };     global.time.repeat = (times, func) => {       ...     };   }; };so a user may write a Quokka file like:
time(() => {  // code to measure the execution time for});
time.repeat(10, () => {  // ...});If you wrote a Quokka plugin and would like to let others know about it, please feel free to share it in our repo.
Development hints
- The dotenv-quokka-pluginis a good example of a Quokka plugin, you may also find more plugin examples in the relevant docs section.
- When writing a Quokka plugin, you may do some logging with console.log from your plugin. The result will be displayed in the Quokka Output.
- To quickly restart Quokka on the current file, you may use the Quokka.js: Start on Current Filecommand (Ctrl/Cmd + K, Q).
Notable plugins
- Plugin to load .envenvironment variables.
- Plugin to automatically import reflect-metadatafor Angular projects.
- Plugin for providing module import aliases.
- Plugin for providing module import aliases via Babel.
- Plugin for resolving node_moduleimports from subdirectories (great for monorepo kind of scenarios).
- Plugin to run any command before each Quokka file execution.
- Plugin to load jQuery before each Quokka file execution.
- Plugin for exploring API endpoints to identify function signatures and API property types via signet.