morningtrain / wp-blocks
A package for loading WordPress blocks with support for Blade templates
Installs: 1 045
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 5
Forks: 0
Open Issues: 0
Requires
- php: ^8.0
- morningtrain/php-loader: ^0.3.2
Requires (Dev)
- brain/monkey: ~2.0.0
- pestphp/pest: ^1.21
Suggests
- morningtrain/wp-view: Allows rendering Blade Views as block templates
README
A Morningtrain package for working with WordPress blocks more easily.
📋 Table of Contents
[[TOC]]
Introduction
This tool is made for organizing WordPress Gutenberg blocks!
This tool lets you:
- Load all blocks found in a directory
- Render Blade views by defining them as
renderView
in block meta - Load PHP dependencies by placing
*.php
files next to theblock.json
files
Getting Started
To get started install the package as described below in Installation.
To use the tool have a look at Usage
Installation
Install with composer
composer require morningtrain/wp-blocks
Dependencies
morningtrain/php-loader
PHP Loader is used to load and initialize all Hooks
Usage
Loading the block directory
To initialize the package and/or to load blocks from a path use Blocks::setup
use Morningtrain\WP\Blocks\Blocks; // Tell Blocks where the built/compiled files are located Blocks::setup(__DIR__ . "/public/build/blocks"); // To add another directory Blocks::registerBlockDirectory(__DIR__ . "/public/build/blocks");
Using a View
To serverside render a block using a Blade View set the custom renderView
property.
You can also have custom PHP code dependency. By declaring phpScript
the given script will be loaded alongside the
registration of your block.
This is especially useful when needing a View Composer.
Note the custom schema url!
{ "$schema": "https://wp.cdn.mtra.in/default/schemas/block.json", "apiVersion": 3, "name": "foo/bar", "version": "0.1.0", "title": "Bar", "textdomain": "foo", "editorScript": "file:./index.js", "editorStyle": "file:./index.css", "style": "file:./style-index.css", "renderView": "my-view", "phpScript": "file:./script.php", "viewPhpScript": [ "file:./view-script.php", "file:./view-script2.php" ], "editorPhpScript": "file:./editor-script.php" }
The view will have the following vars: $block
, $attributes
, $content
and $blockProps
Example:
<div {!! $blockProps !!}>
<h2>{{$attributes['title']}}</h2>
<div>{!! $content !!}</div>
</div>
If you wish to view compose you may create a *.php
file within your block folder.
As long as it is a sibling to the block.json
file and is not named *.asset.php
then it will automatically be loaded.
Caching
If your environment is production
then a cache containing all block files and their dependencies will be generated and
used so that the server doesn't have to look for them on every request.
To clear this cache you can use the CLI command:
wp wp-blocks deleteCacheFiles
Credits
Testing
composer test
License
The MIT License (MIT). Please see License File for more information.