Create or use Plugins
On this page
Plugins are Configuration
At their simplest, Eleventy plugins are a function passed to the addPlugin method. If you’re familiar with Eleventy configuration files, this will look and feel very similar!
export default function (eleventyConfig) {
	eleventyConfig.addPlugin(function(eleventyConfig) {
		// I am a plugin!
	});
};module.exports = function (eleventyConfig) {
	eleventyConfig.addPlugin(function(eleventyConfig) {
		// I am a plugin!
	});
};The plugin can be defined elsewhere in the same file:
function myPlugin(eleventyConfig) {
	// I am a plugin!
}
export default function (eleventyConfig) {
	eleventyConfig.addPlugin(myPlugin);
};function myPlugin(eleventyConfig) {
	// I am a plugin!
}
module.exports = function (eleventyConfig) {
	eleventyConfig.addPlugin(myPlugin);
};Or in a different file:
import myPlugin from "./_config/plugin.js";
export default function (eleventyConfig) {
	eleventyConfig.addPlugin(myPlugin);
};const myPlugin = require("./_config/plugin.js");
module.exports = function (eleventyConfig) {
	eleventyConfig.addPlugin(myPlugin);
};Or in an npm package:
import pluginRss from "@11ty/eleventy-plugin-rss";
export default function (eleventyConfig) {
	eleventyConfig.addPlugin(pluginRss);
};const pluginRss = require("@11ty/eleventy-plugin-rss");
module.exports = function (eleventyConfig) {
	eleventyConfig.addPlugin(pluginRss);
};Plugins are async-friendly Added in v3.0.0 but you must await the addPlugin method.
export default async function (eleventyConfig) {
	await eleventyConfig.addPlugin(async function(eleventyConfig) {
		// I am an asynchronous plugin!
	});
};module.exports = async function (eleventyConfig) {
	await eleventyConfig.addPlugin(async function(eleventyConfig) {
		// I am an asynchronous plugin!
	});
};Adding a Plugin
Installation
We use the npm command line tool (included with Node.js) to install plugins.
Looking for a plugin? Check out the official plugins or community-contributed plugins.
npm install @11ty/eleventy-plugin-rss --saveAdd the plugin to Eleventy in your config file
Your config file is probably named eleventy.config.js or .eleventy.js.
import pluginRss from "@11ty/eleventy-plugin-rss";
export default function (eleventyConfig) {
	eleventyConfig.addPlugin(pluginRss);
};const pluginRss = require("@11ty/eleventy-plugin-rss");
module.exports = function (eleventyConfig) {
	eleventyConfig.addPlugin(pluginRss);
};Plugin Configuration Options
Use an optional second argument to addPlugin to customize your plugin’s behavior. These options are specific to the plugin. Please consult the plugin’s documentation (e.g. the eleventy-plugin-syntaxhighlight README) to learn what options are available to you.
import pluginSyntaxHighlight from "@11ty/eleventy-plugin-syntaxhighlight";
export default function (eleventyConfig) {
	eleventyConfig.addPlugin(pluginSyntaxHighlight, {
		// only install the markdown highlighter
		templateFormats: ["md"],
		init: function ({ Prism }) {
			// Add your own custom language to Prism!
		},
	});
};const pluginSyntaxHighlight = require("@11ty/eleventy-plugin-syntaxhighlight");
module.exports = function (eleventyConfig) {
	eleventyConfig.addPlugin(pluginSyntaxHighlight, {
		// only install the markdown highlighter
		templateFormats: ["md"],
		init: function ({ Prism }) {
			// Add your own custom language to Prism!
		},
	});
};Advanced Usage: Namespacing a plugin
It’s unlikely you’ll need this feature but you can namespace parts of your configuration using eleventyConfig.namespace. This will add a string prefix to all filters, tags, helpers, shortcodes, collections, and transforms.
import pluginRss from "@11ty/eleventy-plugin-rss";
export default function (eleventyConfig) {
	eleventyConfig.namespace("myPrefix_", () => {
		// the rssLastUpdatedDate filter is now myPrefix_rssLastUpdatedDate
		eleventyConfig.addPlugin(pluginRss);
	});
};const pluginRss = require("@11ty/eleventy-plugin-rss");
module.exports = function (eleventyConfig) {
	eleventyConfig.namespace("myPrefix_", () => {
		// the rssLastUpdatedDate filter is now myPrefix_rssLastUpdatedDate
		eleventyConfig.addPlugin(pluginRss);
	});
};Advanced: Execute a plugin immediately Added in v3.0.0
Plugins (by default) execute in a second stage of configuration after the user’s configuration file has finished, in order to have access to the return object in the configuration callback.
You are unlikely to need this, but you can execute a plugin’s code immediately using the immediate option.
export default function (eleventyConfig, pluginOptions) {
	console.log( "first" );
	eleventyConfig.addPlugin(eleventyConfig => {
		console.log("fourth");
	});
	eleventyConfig.addPlugin(eleventyConfig => {
		console.log("second");
	}, {
		immediate: true
	});
	console.log("third");
};module.exports = function (eleventyConfig, pluginOptions) {
	console.log( "first" );
	eleventyConfig.addPlugin(eleventyConfig => {
		console.log("fourth");
	});
	eleventyConfig.addPlugin(eleventyConfig => {
		console.log("second");
	}, {
		immediate: true
	});
	console.log("third");
};Creating a Plugin
A plugin primarily provides a “configuration function.” This function is called when Eleventy is first initialized, and operates similarly to a user’s configuration function (the same eleventyConfig argument passed to the user’s eleventy.config.js file is passed here), in addition to any config passed by the user:
export default function (eleventyConfig, pluginOptions) {
	// Your plugin code goes here
};module.exports = function (eleventyConfig, pluginOptions) {
	// Your plugin code goes here
};Note that plugins run as a second stage after the user’s primary configuration file has executed (to have access to the return object values).
Advanced Usage: Custom Plugin Arguments
If you want to allow developers to use custom arguments provided by your plugin, you can export an object. Prefer using the above syntax unless you need this behavior. For an example of how this is used, see the syntax highlighting plugin
export default {
	initArguments: {},
	configFunction: function (eleventyConfig, pluginOptions) {
		// Your plugin code goes here
	},
};module.exports = {
	initArguments: {},
	configFunction: function (eleventyConfig, pluginOptions) {
		// Your plugin code goes here
	},
};export default function (eleventyConfig) {
	eleventyConfig.addPlugin(require("./fancy-plugin.js"), {
		init: function (initArguments) {
			// `this` is the eleventyConfig object
			// initArguments will be the `myInitArguments` object from above
		},
	});
};module.exports = function (eleventyConfig) {
	eleventyConfig.addPlugin(require("./fancy-plugin.js"), {
		init: function (initArguments) {
			// `this` is the eleventyConfig object
			// initArguments will be the `myInitArguments` object from above
		},
	});
};Feature Testing
If your plugin requires a specific feature in Eleventy, you should feature test it!
export default function (eleventyConfig, pluginOptions) {
	if(!("addTemplate" in eleventyConfig)) {
		console.log( `[my-test-plugin] WARN Eleventy plugin compatibility: Virtual Templates are required for this plugin, please use Eleventy v3.0 or newer.` );
	}
};module.exports = function (eleventyConfig, pluginOptions) {
	if(!("addTemplate" in eleventyConfig)) {
		console.log( `[my-test-plugin] WARN Eleventy plugin compatibility: Virtual Templates are required for this plugin, please use Eleventy v3.0 or newer.` );
	}
};Version Checking
If feature testing is not available for your specific use case, you can add this code to your plugin configuration to show a warning if the plugin consumer does not have a compatible version of Eleventy:
export default function (eleventyConfig, pluginOptions) {
	try {
		// Emit a warning message if the application is not using Eleventy 3.0 or newer (including prereleases).
		eleventyConfig.versionCheck(">=3.0");
	} catch(e) {
		console.log( `[my-test-plugin] WARN Eleventy plugin compatibility: ${e.message}` );
	}
};module.exports = function (eleventyConfig, pluginOptions) {
	try {
		// Emit a warning message if the application is not using Eleventy 3.0 or newer (including prereleases).
		eleventyConfig.versionCheck(">=3.0");
	} catch(e) {
		console.log( `[my-test-plugin] WARN Eleventy plugin compatibility: ${e.message}` );
	}
};- This uses the semverpackage and is compatible with advanced range syntax.
- Upper bounding your version number is not recommended. Eleventy works very hard to maintain backwards compatibility between major versions. Please ensure your plugin code does the same!
- The versionCheckmethod has been available in Eleventy core since v0.3.2 (~2018).
Distributing a Plugin
If you’re distributing your plugin as a package, consider following these conventions. These are not hard requirements.
- Add "eleventy-plugin"to your package.json’skeywordsfield.
- Prefix your package name with eleventy-plugin-
- Open a PR to add your plugin to our list of community plugins for publication on our community plugins directory.
