Filament PHP Blocks Builder is a plugin that adds a BlockBuilder
form component, enabling you to design layouts using blocks on any resource you like. This flexible tool is suitable for building layouts, managing content, structuring data, and more.
Check out screenshots of the form components offerend by this package in the screenshots directory.
Install the plugin via Composer:
composer require skyraptor/filament-blocks-builder
The Blocks Builder is a form component that can be added to any Filament PHP resource or form. Here’s how to use the BlocksInput
:
use SkyRaptor\FilamentBlocksBuilder\Blocks;
use SkyRaptor\FilamentBlocksBuilder\Forms\Components\BlocksInput;
BlocksInput::make('content')
->blocks(fn () => [
Blocks\Layout\Card::block($form),
Blocks\Typography\Heading::block($form),
Blocks\Typography\Paragraph::block($form)
])
A Block itself is a combination of a Filament PHP Form definition as well as the view required to render the Block on the frontend.
- A Filament PHP Form schema for Block data definiton
- A Blade view for frontend rendering
The package does include basic example Blocks, however it is recommended that you do create and maintain your own library of Blocks - this can be done in your project as well as in a package.
Create a new class for your Block, extend the Block
Contract and implement the required methods:
<?php
namespace App\Filament\Blocks;
use Filament\Forms\Components;
use Filament\Forms\Form;
class Example extends \SkyRaptor\FilamentBlocksBuilder\Blocks\Contracts\Block
{
public static function block(Form $form): Components\Builder\Block
{
return parent::block($form)->schema([
Components\Textarea::make('content')
->required(),
]);
}
public static function view(): string
{
return 'example';
}
}
Note the responsibilities of the methods shown in the implementation above:
block()
: This method initializes and configures a Filament PHP Form Component that represents this Block.view
: This method does define the name of the view to be used on rendering the Block to the frontend.
Create a Blade view (e.g., resources/views/example.blade.php
) to render the block's output. The schema data will be accessible within the view:
<p>{{ $content }}</p>
Add your custom block to the BlocksInput
:
->blocks(fn () => [
Blocks\Layout\Card::block($form),
Blocks\Typography\Heading::block($form),
Blocks\Typography\Paragraph::block($form),
// ...
App\Filament\Blocks\Example::block($form)
])
Contributions are welcome! Submit a pull request on GitHub. Before submitting, ensure all tests pass.
The project includes a DevContainer configuration for streamlined development. Open the .code-workspace
file, and use the Reopen in Container option from the Remote Development menu in Visual Studio Code in order to use the DevContainer.
Debug test cases directly using the Debug Tests configuration in Visual Studio Code. It runs PHPUnit with xDebug support.
The Orchestral Workbench used for functional and browser based tests can also be previewed as well as debugged.
The Orchestral Testbench is used for functional and browser-based tests, but can also be previewd and debugged. Follow these steps to set up the environment:
-
Use the following Orchestral Workbench command to generate an empty, persistent SQlite database in the Laravel skeleton.
vendor/bin/testbench package:create-sqlite-db
-
Next you will have to run the Migrations defined in the Workbench using the command below.
vendor/bin/testbench migrate
-
Now that the Orchestral Workbench environment has a functional database, you will have to create a user using the following command.
vendor/bin/testbench make:filament-user
Use the Debug Workbench configuration in Visual Studio Code to preview and debug the workbench. It launches Laravel’s built-in server with xDebug.
The following features and quality of life improvements have yet to be implemented and added to the library:
- Basic layout Blocks (flexbox, grid, ...)
- Block update / upgrade migrations
- Block asset / dependency management
This project is licensed under the GNU GPL v3 License.
Happy Building! 🎉