Yeoman generator for WordPress plugins.
Check out an example of a generated plugin.
Pre-requisites: You'll need node which comes with npm.
If you don't have Yeoman installed:
npm install -g yo
To install generator-plugin-wp from npm, run:
npm install -g generator-plugin-wp
To use generator-plugin-wp, cd
to your WordPress plugins folder and:
yo plugin-wp
You'll be prompted with steps for creating your plugin.
Once your nifty new plugin has been generated, cd
into your new plugin's
directory. While in the plugin directory, you can run additional commands
called sub-generators to automatically generate files to enhance your plugin.
yo plugin-wp:include include-name
Basic Includeyo plugin-wp:cpt cpt-name
Custom Post Typeyo plugin-wp:taxonomy taxonomy-name
Taxonomyyo plugin-wp:options options-name
Option Pageyo plugin-wp:widget widget-name
Widgetyo plugin-wp:pagebuilder class-name
Simple Page Builderyo plugin-wp:endpoint class-name
WP-API Endpointyo plugin-wp:js
Javascriptyo plugin-wp:css
Styles
For the names of the include, cpt, options, and widget subgenerators remember that the plugin prefix will be added to the class name so no need to include the original plugin name there! Think of it as the file name for each instead.
By default the plugin generator adds some built in tests for you to add on to as
you develop your plugin! To run these tests run the install-wp-tests.sh
script
in the bin folder with the proper database details for your local setup.
Once you've run the install-wp-tests.sh
script you can run just phpunit
in
the main folder of your plugin.
If you don't want tests included in your plugin when it is generated run the
main generator with the --notests
option.
If you chose composer as the autoloader option during the plugin's initiation, you can use composer to add additional dependencies.
Let's cd
into our new plugin's directory and add CMB2:
composer require webdevstudios/cmb2
CMB2 will now appear under vendor
-plugins
-wds-foo-plugin
-vendor
-webdevstudios
-cmb2
See the complete list of WebDevStudios packages: https://packagist.org/packages/webdevstudios/