With this package you have a new Filament field (like Builder) but with a visual ui and dynamic types.
Please not that this is a pre-production package, there are many things potentially still bugged and it may not work together with some other packages (like translations).
Methods and flow may still change before a first release, so if you use it, keep in mind that a composer update may break it.
If you encounter issues, please provide a pull request.
To see a demo:
You can install the package via composer:
composer require sevendays/filament-page-builder
You can publish and run the migrations with:
php artisan vendor:publish --tag="filament-page-builder-migrations"
php artisan migrate
You can publish the config file with (currently no config):
php artisan vendor:publish --tag="filament-page-builder-config"
Optionally, you can publish the views using
php artisan vendor:publish --tag="filament-page-builder-views"
This is the contents of the published config file:
return [
];
Filament page builder is a custom Filament field that adds functionality on top of the Builder field.
13-11-2023 Preview is now opt-in via config.
- Preview can interfere with forms configured within blocks
- Preview sets all block fields to reactive, for the 'live' preview part
If you are ok with that, you can enable the preview via:
return [
'enablePreview' => true,
];
To use this, create a Model and Resource as per the Filament documentation then do the following:
You can use the command below to generate a block:
php artisan make:page-builder-block DemoBlock
This will create 2 files:
app/Filament/Blocks/DemoBlock.php
: This is where you define the form fields and render view.
resources/views/filament/blocks/demo-block.blade.php
: This is how your block is supposed to be rendered.
The default generator provides just a 'title' field.
NOTE: All fields are translatable by default. However you can have shared fields by adding the following method with the field id's:
public static function getSharedFields(): array
{
return ['show'];
}
public function form(): array
{
return [
TextInput::make('title'),
Toggle::make('show')
];
}
In order to save blocks, you need to add the Blockable interface and HasBlocks trait to your model.
<?php
namespace App\Models;
use Sevendays\FilamentPageBuilder\Models\Contracts\Blockable;
use Sevendays\FilamentPageBuilder\Models\Traits\HasBlocks;
use Illuminate\Database\Eloquent\Model;
class Page extends Model implements Blockable
{
use HasBlocks;
protected $fillable = [
'title'
];
}
In your resource form we can now add the field:
<?php
use Sevendays\FilamentPageBuilder\Forms\Components\BlockEditor;
use App\Filament\Blocks\DemoBlock;
public static function form(Form $form): Form
{
return $form
->schema([
BlockEditor::make('blocks')
->blocks([ // You can add more blocks here.
DemoBlock::class,
])
->renderInView('blocks.preview'), // Optional: To render the preview in a different view.
]);
}
If all goes well, you should now have the block builder on your page. Do not forget to run migrations.
There are not many tools for this yet but basic rendering works like this:
@foreach($page->blocks as $block)
{!! \Sevendays\FilamentPageBuilder\Facades\BlockRenderer::renderBlock($block) !!}
@endforeach
$page
is your model that has blocks.
Not done yet.
composer test
Please see CHANGELOG for more information on what has changed recently.
Please see CONTRIBUTING for details.
Please review our security policy on how to report security vulnerabilities.
The MIT License (MIT). Please see License File for more information.