WPDrill is a WordPress Plugin Development Framework for human. It's designed to simplify the process of creating and managing WordPress plugins.
⚠️ Caution: This package is in alpha stage. Expect bugs and changes. Test thoroughly before use.
-
Menu Management: WPDrill provides an easy way to add and manage menus in your WordPress plugin. You can easily add a new menu with an icon and position. For example, in
menu.php
, a new menu 'WPDrill' is added with a smiley icon and positioned at 3. -
Routing: WPDrill provides a simple and intuitive way to manage routes in your WordPress plugin. You can define GET routes, apply middleware, and even group routes with a common prefix or middleware. For example, in
api.php
, a GET route '/wpdrill' is defined with a middleware. -
Middleware: WPDrill allows you to add middleware to your routes, providing a way to perform actions before the route handler is executed.
-
WPDrill CLI Tools: WPDrill comes with a set of command-line tools that help in automating tasks such as scaffolding, migrations, and testing.
-
ServiceProvider: WPDrill uses a service provider pattern for managing class dependencies and performing dependency injection.
-
Config: WPDrill provides a central place to manage configuration settings for your plugin.
-
Migrations: WPDrill supports database migrations, allowing you to version control your database schema and apply changes incrementally.
-
View: WPDrill provides a simple way to manage views in your WordPress plugin. You can easily create, edit, and manage views for your plugin.
-
Query Builder: WPDrill provides a simple way to manage database operations in your WordPress plugin. You can easily create, read, update, and delete records in your database.
-
Shortcode: The Shortcode feature in WPDrill allows developers to create reusable pieces of content that can be inserted into posts or pages using a simple tag. This feature is implemented using a combination of PHP classes and views.
The installation and configuration process of WPDrill can be done in the following steps:
- Download WPDrill: You can download WPDrill from its official GitHub repository into
plugins
directory. Use the following command in your terminal to clone the repository:
git clone https://github.com/WPDrill/framework.git
- Navigate to the WPDrill directory: After cloning the repository, navigate to the WPDrill directory using the following command:
cd wpdrill
- Install Dependencies: WPDrill uses Composer for managing PHP dependencies. Run the following command to install these dependencies:
composer install
After installing the necessary dependencies, the next step is to initialize the plugin. Execute the following command in your terminal:
bashCopy code
./wpdrill plugin:init
That's all! Now, proceed to your WordPress admin dashboard and activate your freshly created plugin.
To add a new menu in WPDrill, you need to follow the steps below:
Open the Menu Configuration File: Navigate to the bootstrap/menu.php
file in your WPDrill plugin directory.
Define the New Menu: In the menu.php file, use the Menu::add()
method to define a new menu. Here's an example of how you can create a new menu:
use WPDrill\Facades\Menu;
use App\Handlers\ReviewXDashboardMenu;
Menu::add('ReviewX Dashboard', new ReviewXDashboardMenu(), 'manage_options')
->icon('dashicons-smiley')
->position(3);
You can use different types of approach to bind handler, the previous example was an invokable handler instance(That means it should contain __invoke()
method.
use WPDrill\Facades\Menu;
use App\Handlers\ReviewXDashboardMenu;
Menu::add('ReviewX Dashboard', ReviewXDashboardMenu::class , 'manage_options')
->icon('dashicons-smiley')
->position(3);
use WPDrill\Facades\Menu;
use App\Handlers\ReviewXDashboardMenu;
Menu::add('ReviewX Dashboard', [ReviewXDashboardMenu::class, 'dashboard'] , 'manage_options')
->icon('dashicons-smiley')
->position(3);
use WPDrill\Facades\Menu;
use App\Handlers\ReviewXDashboardMenu;
Menu::add('ReviewX Dashboard', function() {
echo "Dashboard";
} , 'manage_options')
->icon('dashicons-smiley')
->position(3);
To create a route in WPDrill, you need to define it in the routes/api.php
file. Here is an example of how you can do it:
<?php
use WPDrill\Routing\Router;
Router::get('/wpdrill', [\App\Rest\Controllers\WPDrillController::class, 'show']);
In this example, a GET route '/wpdrill' is defined. When this route is accessed, the show
method of the WPDrillController
class is executed. Please replace the WPDrillController
and show
with the actual controller and method that should handle the request for this route.
The route controller support the following
-
Invokable Controller Instance (should contains
__invoke()
method in the class instance) -
Invokable class binding, ex:
\App\Rest\Controllers\WPDrillController::class
) (should contains__invoke()
method in the class) -
Class and method mapping, ex:
[\App\Rest\Controllers\WPDrillController::class, 'method_name'
]` -
Closure
WPDrill also support route grouping, here is the example
Route::group(['prefix' => '/info'], function() {
Route::get('/about', function () {
return [
'title' => 'About WPDrill',
'content' => 'A WordPress Plugin development framework for humans',
];
});
});
WPDrill helps you to develop high level templating option, it comes with Twig template engine by default. Here is an example
//app/Handlers
use WPDrill\Contracts\InvokableContract;
use WPDrill\Facades\View;
class WPDrillMenuHandler implements InvokableContract {
public function __invoke()
{
View::output('wpdrill', [
'title' => 'Welcome to WPDrill',
'content' => 'A WordPress Plugin development framework for humans',
]);
}
}
Here is the view(twig) file
<!-- resources/views/wpdrill.html -->
<h1>{{ title }}</h1>
<p>
{{ content }}
</p>
To add a new shortcode in WPDrill, you need to follow these steps:
- Create a new Shortcode Class: Create a new PHP class that implements the
ShortcodeContract
. This class should define arender
method that returns the output of the shortcode. Here's an example:
namespace App\Shortcodes;
use WPDrill\Contracts\ShortcodeContract;
use WPDrill\Facades\View;
class MyNewShortcode implements ShortcodeContract
{
public function render(array $attrs, string $content = null): string
{
// Default attributes can be defined here
$attrs = shortcode_atts(
[
'title' => 'Default Title',
],
$attrs
);
// Use the View facade to render a view for this shortcode
return View::render('shortcode/mynewshortcode', [
'title' => $attrs['title'],
'content' => $content,
]);
}
}
- Register the Shortcode: In the
bootstrap/shortcodes.php
file, use theShortcode::add
method to register the new shortcode. Here's how you can do it:
use WPDrill\Facades\Shortcode;
use WPDrill\Plugin;
return function(Plugin $plugin) {
Shortcode::add('mynewshortcode', \App\Shortcodes\MyNewShortcode::class);
// Existing shortcodes...
};
In this example, a new shortcode [mynewshortcode]
is registered. When this shortcode is used in a post or page, the render
method of the MyNewShortcode
class is executed.
- Create the View: Create a new PHP file in the
views/shortcode
directory for the view of this shortcode. This file should return the HTML that you want to display when the shortcode is used.
Please replace MyNewShortcode
, mynewshortcode
, and shortcode/mynewshortcode
with the actual class name, shortcode tag, and view file path for your shortcode.
To get started with WPDrill, you need to have a basic understanding of WordPress plugin development as well as familiarity with PHP, JavaScript, Composer, NPM.
For more detailed information on how to use WPDrill, refer to the individual PHP files in the wp-content/plugins/reviewx
directory. Each file contains code that demonstrates how to use various features of WPDrill.
Contributions to WPDrill are welcome. Please ensure that you follow the coding standards and guidelines of the project.
WPDrill is open-source software.