-
Notifications
You must be signed in to change notification settings - Fork 407
Creating Plugins
Plugin support is still in alpha. Try it out and provide feedback!
You can find the first Node plugin at https://github.com/pattern-lab/plugin-node-tab which is well-commented and covers both frontend and backend needs. It will be used as an example throughout the rest of this page.
To add the Tab Plugin to your project using npm type:
npm install plugin-node-tab --save
Or add it directly to your project's package.json
file and run npm install
if you author your own plugin, they need to be on npm or locally
npm link
ed
postinstall instructions are fed to patternlab-core to look for any plugins installed within node_modules/
//determine if any plugins are already installed
var plugin_manager = new pm(config, configPath);
var foundPlugins = plugin_manager.detect_plugins();
if (foundPlugins && foundPlugins.length > 0) {
for (var i = 0; i < foundPlugins.length; i++) {
console.log('Found plugin', foundPlugins[i]);
plugin_manager.install_plugin(foundPlugins[i]);
}
}
"Installing" ultimately adds an entry to the patternlab-config.json
file, which will look like this:
{
...
"plugin-node-tab": false
...
}
This config entry is also what let's us disable the plugin if we want to momentarily turn it off (by deleting this entry).
Plugins are then loaded similarly to installation during patternlab.js
startup:
/**
* Finds and calls the main method of any found plugins.
* @param patternlab - global data store
*/
function initializePlugins(patternlab) {
var plugin_manager = new pm(patternlab.config, path.resolve(__dirname, '../../patternlab-config.json'));
var foundPlugins = plugin_manager.detect_plugins();
if (foundPlugins && foundPlugins.length > 0) {
for (var i = 0; i < foundPlugins.length; i++) {
var plugin = plugin_manager.load_plugin(foundPlugins[i]);
plugin(patternlab);
}
}
}
plugin(patternlab)
calls the plugin's pluginInit()
method inside index.js
, having full access to the the patternlab object
. It shuffles files to the frontend when needed, and most importantly, registers events.
Events are registered in one place within the index.js
file, and the following code works together:
const tab_loader = require('./src/tab-loader');
function onPatternIterate(patternlab, pattern) {
tab_loader(patternlab, pattern);
}
/**
* Define what events you wish to listen to here
* For a full list of events - check out https://github.com/pattern-lab/patternlab-node/wiki/Creating-Plugins#events
* @param patternlab - global data store which has the handle to the event emitter
*/
function registerEvents(patternlab) {
//register our handler at the appropriate time of execution
patternlab.events.on('patternlab-pattern-write-end', onPatternIterate);
}
tab_loader()
does all our heavy lifting after this point.
Here is a list of all current events. Search the source code for patternlab.events.emit
is also a good bet.
-
patternlab-build-pattern-start
- parameters: patternlab [object]
- invoked: First thing inside
buildPatterns()
, which is the entry point for single builds, pattern-only builds, run singly or when watched.
-
patternlab-build-global-data-end
- parameters: patternlab [object]
- invoked: After global
data.json
andlistitems.json
are read, and the supporting patternlab templates are loaded into memory (header, footer, patternSection, patternSectionSubType, viewall). Right before patterns are iterated over to gather data about them.
-
patternlab-pattern-iteration-end
- parameters: patternlab [object]
- invoked: After patterns are iterated over to gather data about them. Right before Pattern Lab recursively builds the patterns into markup.
-
patternlab-pattern-write-begin
- parameters: patternlab [object], pattern [object]
- invoked: Right before a pattern's template, HTML, and encoded HTML files are written to their output location.
-
patternlab-pattern-write-end
- parameters: patternlab [object], pattern [object]
- invoked: Right after a pattern's template, HTML, and encoded HTML files are written to their output location.
Any more events may be considered and assed via pull request
This plugin has a postinstall script defined in its package.json
file because it requires user-input. Know that not all plugins will require this.
Plugins need to output their configuration and files to the Pattern Lab frontend in order to be found and initialized. Study plugin-loader.js to better understand how to load templates, stylesheets, and javascript from your plugin.
Plugins will be installed into the public/patternlab-components/pattern-lab/
directory.
Let's discuss both files and how they got there.
{
"name": "pattern-lab/plugin-node-tab",
"templates": [],
"stylesheets": [],
"javascripts": [
"patternlab-components/pattern-lab/plugin-node-tab/js/plugin-node-tab.js"
],
"onready": "PluginTab.init()",
"callback": ""
}
This file is heart of the configuration. It is output here and inside the plugins array for consumption alongside other plugins.
-
name: The name of the plugin, (for this case) the github org and repo name
-
templates: An array of template files to load. These are expected to be mustache files. Will be available to javascript as
<<plugin-name>>-filename-template
-
stylesheets: An array of css files to load.
-
Because of the way stylesheets are programmatically loaded via plugin, you must the path carefully. Try the following (for a fictional css file included in the plugin. You won't find one in the reference implementation):
-
"stylesheets": [ "/../../../pattern-lab/plugin-node-tab/css/plugin-node-tab.css" ], ```
-
javacripts: An array of javascript files to load. Any
callback
oronready
functions you reference need to be defined within a file here.-
Because of the way javascripts are programmaticaly loaded via plugin, you must specify the path carefully. Try the following:
"javascripts": [ "patternlab-components/pattern-lab/plugin-node-tab/js/plugin-node-tab.js" ],
-
-
onready: The function to be called when the plugin is finished loading all of its assets.
-
callback: The function to be called when the plugin is finished executing. testing needed
This file is copied from the plugin's dist/
folder and placed under patternlab-components/pattern-lab/<<plugin-name>>/
Any other files or structure under dist/
will be copied in similar fashion during plugin backend processing. This is done in the plugin's index.js
file.