Download the PHP package sevendays/filament-page-builder without Composer
On this page you can find all versions of the php package sevendays/filament-page-builder. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download sevendays/filament-page-builder
More information about sevendays/filament-page-builder
Files in sevendays/filament-page-builder
Package filament-page-builder
Short Description A visual page builder for Filament
License MIT
Homepage https://github.com/sevendays-digital/filament-page-builder
Informations about the package filament-page-builder
A visual page builder for Filament
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:
Installation
You can install the package via composer:
You can publish and run the migrations with:
You can publish the config file with (currently no config):
Optionally, you can publish the views using
This is the contents of the published config file:
Usage
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:
To use this, create a Model and Resource as per the Filament documentation then do the following:
1. Generate a block
You can use the command below to generate a block:
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:
2. Add the contract and trait to your model
In order to save blocks, you need to add the Blockable interface and HasBlocks trait to your model.
3. Add the field to your resource form
In your resource form we can now add the field:
If all goes well, you should now have the block builder on your page. Do not forget to run migrations.
4. Rendering on the front-end
There are not many tools for this yet but basic rendering works like this:
$page
is your model that has blocks.
Testing
Not done yet.
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
- Harings Rob
- All Contributors
License
The MIT License (MIT). Please see License File for more information.
All versions of filament-page-builder with dependencies
filament/filament Version ^3.0.75
filament/spatie-laravel-translatable-plugin Version ^3.0
illuminate/contracts Version ^9.0|^10.0|^11.0
spatie/laravel-package-tools Version ^1.13.5
wire-elements/modal Version ^2.0