Skip to content

WordPress Plugin Boilerplate utilizing modern web technologies and tools such as React, TypeScript, SASS, Tailwind CSS, Shadcn UI, Vite, Grunt.js, Storybook, HMR and more.

License

Notifications You must be signed in to change notification settings

prappo/wordpress-plugin-boilerplate

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 

History

88 Commits
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

WordPress Plugin Boilerplate

Create your WordPress plugin in weeks, not months. Rapidly prototype and deliver your plugin with confidence!

Preview

Wordpress

Screenshots

Light Mode Dark Mode

Get Started

The plugin consists of two main components: the frontend, built with React, and the backend, which communicates via an API.

To get started, you need to clone the repository and install the dependencies. Then you can rename the plugin and start development. It's that simple!

Clone the repository

git clone https://github.com/prappo/wordpress-plugin-boilerplate.git

Install dependencies

npm install
composer install

Plugin renaming

You can easly rename the plugin by changing data in plugin-config.json file.

{
    "plugin_name":"WordPress Plugin Boilerplate",
    "plugin_description":"A boilerplate for WordPress plugins.",
    "plugin_version":"1.0.0",
    "plugin_file_name":"wordpress-plugin-boilerplate.php",
    "author_name":"Prappo",
    "author_uri":"https://prappo.github.io",
    "text_domain":"wordpress-plugin-boilerplate",
    "domain_path":"/languages",
    "main_class_name":"WordPressPluginBoilerplate",
    "main_function_name":"wordpress_plugin_boilerplate_init",
    "namespace":"WordPressPluginBoilerplate",
    "plugin_prefix":"wpb",
    "constant_prefix":"WPB"
}

Then run the following command to rename the plugin

npm run rename

Structure

πŸ“‚ wordpress-plugin-boilerplate
  • πŸ“‚ config
    • πŸ“„ plugin.php
  • πŸ“‚ database
    • πŸ“‚ Migrations
      • πŸ“„ create_posts_table.php
      • πŸ“„ create_users_table.php
    • πŸ“‚ Seeders
      • πŸ“„ PostSeeder.php
      • πŸ“„ UserSeeder.php
  • πŸ“‚ includes
    • πŸ“‚ Admin
    • πŸ“‚ Controllers
    • πŸ“‚ Core
    • πŸ“‚ Frontend
    • πŸ“‚ Interfaces
    • πŸ“‚ Models
    • πŸ“‚ Routes
    • πŸ“‚ Traits
    • πŸ“„ functions.php
  • πŸ“‚ src
    • πŸ“‚ admin
    • πŸ“‚ frontend
    • πŸ“‚ blocks
  • πŸ“‚ libs
  • πŸ“‚ views
  • πŸ“‚ vendor
  • πŸ“„ plugin.php
  • πŸ“„ uninstall.php
  • πŸ“„ wordpress-plugin-boilerplate.php

API Route

Add your API route in includes/Routes/Api.php

Route::get( $prefix, $endpoint, $callback, $auth = false );
Route::post( $prefix, $endpoint, $callback, $auth = false );

// Route grouping.
Route::prefix( $prefix, function( Route $route ) {
    $route->get( $endpoint, $callback, $auth = false );
    $route->post( $endpoint, $callback, $auth = false );
});

API Example

// Get All posts
$route->get( '/posts/get', '\WordPressPluginBoilerplate\Controllers\Posts\Actions@get_all_posts' );

// Get Single Posts
$route->get( '/posts/get/{id}', '\WordPressPluginBoilerplate\Controllers\Posts\Actions@get_post' );

ORM ( Object Relational Mapping )

If you are familiar with Laravel, you will find this ORM very familiar. It is a simple and easy-to-use ORM for WordPress.

You can find the ORM documentation here

Create your model in includes/Models folder.

Example: includes/Models/Posts.php

<?php

namespace WordPressPluginBoilerplate\Models;

use Prappo\WpEloquent\Database\Eloquent\Model;

class Posts extends Model {
	/**
	 * The table associated with the model.
	 *
	 * @var string
	 */
	protected $table = 'posts';

	/**
	 * The attributes that are mass assignable.
	 *
	 * @var array
	 */
	protected $fillable = array( 'post_title', 'post_content' );
}

You can access all your posts like this:

$posts = Posts::all();

You can also create a new post like this:

$post = Posts::create( array( 'post_title' => 'Hello World', 'post_content' => 'This is a test post' ) );

You can also update a post like this:

$post = Posts::find( 1 );
$post->post_title = 'Hello World';
$post->save();

You can also delete a post like this:

$post = Posts::find( 1 );
$post->delete();

You can also use the where method to filter your posts.

$posts = Posts::where( 'post_title', 'like', '%hello%' )->get();

You can also use the orderBy method to sort your posts.

$posts = Posts::orderBy( 'post_title', 'desc' )->get();

Passing data from backend to frontend

Just pass your data to the array in the Asset file.

For example: For admin:

return array(
'developer' => 'prappo',
'isAdmin' => is_admin(),
'apiUrl' => rest_url(),
'userInfo' => $this->get_user_data(),
);

And access data on react like this

let showApplicationLayout = !wordpressPluginBoilerplateFrontend.isAdmin;

Remember the object wordpressPluginBoilerplateFrontend name can be defined here

const OBJ_NAME = 'wordpressPluginBoilerplateFrontend';

Development

npm run dev

Development with server

npm run dev:server

Build

npm run build

Start block

npm run block:start

Build block

npm run block:build

Release

npm run release

It will create a relase plugin in release folder

About

WordPress Plugin Boilerplate utilizing modern web technologies and tools such as React, TypeScript, SASS, Tailwind CSS, Shadcn UI, Vite, Grunt.js, Storybook, HMR and more.

Topics

Resources

License

Stars

Watchers

Forks

Sponsor this project

Packages

No packages published