A visual page builder plugin for Filament that uses GrapeJS v3 to let admins create and edit pages with a drag-and-drop interface.
In a Laravel/Filament app:
# Install the package
composer require cybertroniankelvin/graper
# Option A: one-step install (recommended) — publishes config, runs migrations
php artisan graper:install
# Option B: manual
php artisan migrate
php artisan vendor:publish --tag=graper-config # optional — to customise configRegister the plugin (in app/Providers/Filament/AdminPanelProvider.php):
use CybertronianKelvin\Graper\GraperPlugin;
public function panel(Panel $panel): Panel
{
return $panel
->plugins([
GraperPlugin::make(),
]);
}Once installed, admins can:
- Navigate to Pages in Filament sidebar
- Create Page → Enter title, slug, publish status
- Use the visual editor:
- Drag blocks from the left panel (Hero, CTA, Stats, Testimonials, etc.)
- Edit text, images, colors directly on the canvas
- Rearrange blocks by dragging
- Save → Content stored in graper_pages table
- Publish → Page accessible at yourapp.test/pages/{slug}
In your app's service provider:
use CybertronianKelvin\Graper\Blocks\BlockRegistry;
use App\Blocks\NewsletterSignupBlock;
public function boot(): void
{
BlockRegistry::make()->register(NewsletterSignupBlock::class);
}Create a block class:
namespace App\Blocks;
use CybertronianKelvin\Graper\Blocks\Block;
class NewsletterSignupBlock extends Block
{
public static function getId(): string => 'newsletter-signup';
public static function getName(): string => 'Newsletter Signup';
public static function getCategory(): string => 'Marketing';
public static function getOrder(): int => 50;
public function getTemplate(): string
{
return <<<'HTML'
<section class="bg-indigo-600 py-16">
<div class="container mx-auto px-4 text-center">
<h2 class="text-3xl font-bold text-white mb-4">Subscribe to Our Newsletter</h2>
<p class="text-indigo-200 mb-8">Get the latest updates delivered to your inbox</p>
<form class="max-w-md mx-auto flex gap-2">
<input type="email" placeholder="Your email"
class="flex-1 px-4 py-3 rounded-lg border-0 focus:ring-2 focus:ring-white">
<button type="submit" class="bg-white text-indigo-600 px-6 py-3 rounded-lg font-semibold">
Subscribe
</button>
</form>
</div>
</section>
HTML;
}
}Published pages are automatically available at:
yourapp.test/pages/{slug} # Default prefix
yourapp.test/{slug} # If prefix configured as empty
In a custom Blade view:
@php
$page = \CybertronianKelvin\Graper\Models\GraperPage::where('slug', 'about-us')->first();
@endphp
{!! $page->html !!}
<style>{!! $page->css !!}</style>Or via the controller:
use CybertronianKelvin\Graper\Http\Controllers\GraperPageController;
Route::get('/landing/{slug}', [GraperPageController::class, 'display']);Create a page programmatically:
use CybertronianKelvin\Graper\Models\GraperPage;
GraperPage::create([
'title' => 'Black Friday Landing',
'slug' => 'black-friday-2026',
'is_published' => true,
'html' => '<section>...</section>',
'css' => '.section { color: red; }',
'project_data' => $grapejsProjectData,
]);Load page content:
$page = GraperPage::where('slug', 'black-friday-2026')->first();
// Access individual fields
$html = $page->html;
$css = $page->css;
// Or get JSON envelope
$content = $page->content; // {"html": "...", "css": "...", "project_data": {...}}Publish and edit config:
php artisan vendor:publish --tag=graper-configconfig/graper.php:
return [
'page_route_prefix' => 'pages', // Change URL prefix
// Other options...
];| Use Case | How |
|---|---|
| Marketing landing pages | Admin creates via Filament, publishes at /pages/{slug} |
| Custom homepages per campaign | Create multiple pages, swap slug in routing |
| Email templates | Use editor to design, export HTML via API |
| Client-editable content | Give clients Filament access to edit their pages |
| A/B test variants | Duplicate pages, different slugs, split traffic |
| Endpoint | Method | Purpose |
|---|---|---|
| /graper/api/blocks | GET | List all available blocks |
| /graper/api/page/{id} | GET | Load page content for editor |
| /graper/api/page/{id} | PUT | Save page content |
| /graper/edit/{id} | GET | Open inline editor |
| /pages/{slug} | GET | Display published page |
composer testPlease 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.