Community Plugins
Learn how to create or contribute to community plugins.
- What are community plugins
- How to create or contribute to community plugins
In order to follow this guide, you must use Webiny version 5.20.0 or greater.
Introductiondata:image/s3,"s3://crabby-images/72d9b/72d9be500fc922f6d150d074671412c5ee303e2a" alt="anchor"
Community plugins are 3rd party supported plugins for Webiny. These plugins are created and managed by the Webiny community.
Here is the repository for community managed plugins.
Contribute a New Plugindata:image/s3,"s3://crabby-images/72d9b/72d9be500fc922f6d150d074671412c5ee303e2a" alt="anchor"
1. Clone the Plugins Repositorydata:image/s3,"s3://crabby-images/72d9b/72d9be500fc922f6d150d074671412c5ee303e2a" alt="anchor"
All the community-supported 3rd party plugins are maintained at the plugins repository .
Clone the plugins repository in the Webiny project root.
git clone https://github.com/webiny-contrib/plugins
2. Create a React Component Packagedata:image/s3,"s3://crabby-images/72d9b/72d9be500fc922f6d150d074671412c5ee303e2a" alt="anchor"
We will use the React Component Package scaffold to create the plugin. From your project root, simply run the yarn webiny scaffold
command:
yarn webiny scaffold
Then, from the list of all available scaffolds, select React Component Package and follow the on-screen instructions.
Enter the name of the component (in pascal-case)
e.g.IFrame
Enter the package location (packages/iframe)
Based on your plugin type, i.e. whether you are building a plugin for Page Builder or Headless CMS, select the respective directory, e.g. if you are creating an iframe plugin for Page Builder, the location will look something like thisplugins/pageBuilder/iframe
Enter the package name (@custom-components/iframe)
Please follow this pattern for package name@webiny-contrib/name-of-your-plugin
e.g.@webiny-contrib/iframe
3. Plugin Implementationdata:image/s3,"s3://crabby-images/72d9b/72d9be500fc922f6d150d074671412c5ee303e2a" alt="anchor"
To implement your plugin, based on the plugin you want to create, please refer to the following tutorials:
Please place your code under the src
directory e.g. plugins/pageBuilder/iframe/src
.
4. Raise the Pull Requestdata:image/s3,"s3://crabby-images/72d9b/72d9be500fc922f6d150d074671412c5ee303e2a" alt="anchor"
Once the plugin is ready, please create a pull request to https://github.com/webiny-contrib/plugins repository.
Webiny team will take care of publishing the community plugins to
npm
at @webiny-contrib .
Contribute to Existing Pluginsdata:image/s3,"s3://crabby-images/72d9b/72d9be500fc922f6d150d074671412c5ee303e2a" alt="anchor"
You can find all the community managed plugins in this repository , and every plugin has a contribution guide.
Here is a process to set up and contribute to the secretText Headless CMS plugin .
Please follow the respective contribution guide for contributing to the existing plugins.
If you need additional help or information on community plugins contribution, feel free to contact us over Slack .