承接 outerweb/filament-layout-builder 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

outerweb/filament-layout-builder

最新稳定版本:v2.1.0

Composer 安装命令:

composer require outerweb/filament-layout-builder

包简介

Layout builder for Laravel Filament

README 文档

README

Filament Layout Builder

Filament Layout Builder

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

This Filament plugins adds a LayoutBuilder Form Component to build layouts using custom building blocks.

Table of Contents

Installation

You can install the package via composer:

composer require outerweb/filament-layout-builder

Add the plugin to your panel:

use Outerweb\FilamentLayoutBuilder\LayoutBuilderPlugin;

public function panel(Panel $panel): Panel
{
    return $panel
        // ...
        ->plugins([
            // ...
            LayoutBuilderPlugin::make(),
        ]);
}

Usage

Creating LayoutBuilder Blocks

You can easily create a LayoutBuilder block by running the following command:

php artisan make:filament-layout-builder-block

This will generate the following:

  • A View Component class in App\Views\Components\LayoutBuilder
  • A Blade view file in resources/views/components/layout-builder

The View Component class

The generated View Component class will look like this:

<?php

declare(strict_types=1);

namespace App\View\Components\LayoutBuilder;

use Filament\Schemas\Schema;
use Outerweb\FilamentLayoutBuilder\View\Components\Block;

class Article extends Block
{
    protected string $view = 'components.layout-builder.article';

    public static function schema(Schema $schema): Schema
    {
        return $schema->components([

        ]);
    }

    public function dehydrateData(): array
    {
        return $this->data;
    }

    public function formatData(): array
    {
        return $this->data;
    }
}

You can define the schema for your block in the schema method using Filament's form components. The dehydrateData method is used to prepare the data for storage, while the formatData method is used to format the data for rendering in the view.

The Blade view file

The generated Blade view file will look like this:

<section {{ $attributes }}>
	{{-- Build something beautiful! --}}
</section>

All array keys returned from the formatData method will be available as variables in this view.

Adding the LayoutBuilder to your forms

You can add the LayoutBuilder to your Filament resource forms like this:

use Outerweb\FilamentLayoutBuilder\Form\Components\LayoutBuilder;

public static function form(Form $form): Form
{
    return $form
        ->schema([
            LayoutBuilder::make('layout'),
        ]);
}

The blocks will automatically discovered and made available in the LayoutBuilder.

You can also include/exclude specific blocks like this:

// Only include specific blocks
LayoutBuilder::make('layout')
    ->filteredBlocks(
        include: [
            \App\View\Components\LayoutBuilder\Article::class,
        ],
    ),

// Exclude specific blocks
LayoutBuilder::make('layout')
    ->filteredBlocks(
        exclude: [
            \App\View\Components\LayoutBuilder\Article::class,
        ],
    ),

Rendering the LayoutBuilder in your views

You can render the LayoutBuilder in your views like this:

<x-filament-layout-builder-container :blocks="$record->layout" />

Changelog

Please see CHANGELOG for more information on what has changed recently.

License

The MIT License (MIT). Please see License File for more information.

统计信息

  • 总下载量: 399
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 0
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-03-03

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固