Filament:TALL Stack 管理面板

发布时间:作者:

Filament: the TALL Stack Admin Panel image

Filament 是为 Laravel 工匠打造的优雅 TALL Stack 管理面板。V1 已经开发了一年多,我们很高兴发布它!

管理面板以纯 Livewire 组件为基础,并拥有强大的表单和表格构建器,高度依赖 Alpine.js。UI 是使用 Tailwind CSS v2 构建的自定义设计。

设置

安装很简单

composer require filament/filament
php artisan migrate

通过运行以下命令创建管理面板的用户帐户

php artisan make:filament-user

并回答输入提示。

创建资源

资源与您的应用中的 Eloquent 模型相关联。要为 App\Models\Customer 模型创建资源

php artisan make:filament-resource Customer

这将在 app/Filament/Resources 目录中创建几个文件

.
+-- CustomerResource.php
+-- CustomerResource
| +-- Pages
| | +-- CreateCustomer.php
| | +-- EditCustomer.php
| | +-- ListCustomers.php

新的资源类位于 CustomerResource.php 中。资源类注册与该模型关联的表单、表格、授权设置和页面。

Pages 目录中的类用于自定义管理面板中与您的资源交互的页面。

构建表单

Filament 带有强大的表单构建器,可用于在管理面板中创建直观、动态和上下文感知的表单。

表单具有模式,该模式是一个包含许多表单组件的数组。让我们为 CustomerResource 定义一个表单模式

use Filament\Resources\Forms\Components;
use Filament\Resources\Forms\Form;
 
public static function form(Form $form)
{
return $form
->schema([
Components\TextInput::make('name')->autofocus()->required(),
Components\TextInput::make('email')->email()->required(),
Components\Select::make('type')
->placeholder('Select a type')
->options([
'individual' => 'Individual',
'organization' => 'Organization',
]),
Components\DatePicker::make('birthday'),
])
->columns(2);
}

有关构建表单的更多信息,请参见 文档

构建表格

Filament 包含一个表格构建器,可用于在管理面板中创建交互式表格。

表格具有列和过滤器,它们在表格对象的两个方法中定义。让我们为 CustomerResource 构建一个表格

use Filament\Resources\Tables\Columns;
use Filament\Resources\Tables\Filter;
use Filament\Resources\Tables\Table;
 
public static function table(Table $table)
{
return $table
->columns([
Columns\Text::make('name')->primary(),
Columns\Text::make('email')->url(fn ($customer) => "mailto:{$customer->email}"),
Columns\Text::make('type')
->options([
'individual' => 'Individual',
'organization' => 'Organization',
]),
Columns\Text::make('birthday')->date(),
])
->filters([
Filter::make('individuals', fn ($query) => $query->where('type', 'individual')),
Filter::make('organizations', fn ($query) => $query->where('type', 'organization')),
]);
}

有关表格构建器的更多信息,请参见 文档

总结

有关 Filament 项目的更多信息,请访问 我们的网站。我们很想了解您将如何使用它,并希望收到任何建议 - 在 Twitter 上给我们留言 @danjharrin@ryanscherler

Dan Harrin photo

Kirschbaum 的首席开发人员。构建 Filament。

归档于
Cube

Laravel 新闻资讯

加入 40,000 多名其他开发者,绝不错过新的提示、教程等。

Laravel Forge logo

Laravel Forge

轻松创建和管理您的服务器,并在几秒钟内部署您的 Laravel 应用程序。

Laravel Forge
Tinkerwell logo

Tinkerwell

Laravel 开发人员必备的代码运行器。使用 AI、自动完成和对本地和生产环境的即时反馈进行调试。

Tinkerwell
No Compromises logo

No Compromises

Joel 和 Aaron,来自 No Compromises 播客的两位经验丰富的开发者,现已开放接受您的 Laravel 项目的雇佣。⬧ 固定价格 $7500/月。 ⬧ 没有冗长的销售流程。 ⬧ 没有合同。 ⬧ 100% 退款保证。

No Compromises
Kirschbaum logo

Kirschbaum

提供创新和稳定性,确保您的 Web 应用程序成功。

Kirschbaum
Shift logo

Shift

正在运行旧版本的 Laravel?即时、自动化的 Laravel 升级和代码现代化,让您的应用程序保持新鲜。

Shift
Bacancy logo

Bacancy

让您的项目充满活力,聘用经验丰富的 Laravel 开发人员,拥有 4-6 年经验,每月仅需 $2500。获得 160 小时的专业知识和 15 天的无风险试用。立即预约通话!

Bacancy
Lucky Media logo

Lucky Media

现在就来试试 Lucky - Laravel 开发的理想选择,拥有十多年的经验!

Lucky Media
Lunar: Laravel E-Commerce logo

Lunar:Laravel 电子商务

Laravel 的电子商务。一个开源软件包,将现代无头电子商务功能的功能带入 Laravel。

Lunar:Laravel 电子商务
LaraJobs logo

LaraJobs

官方 Laravel 职位招聘网站

LaraJobs
SaaSykit: Laravel SaaS Starter Kit logo

SaaSykit:Laravel SaaS 启动套件

SaaSykit 是一个 Laravel SaaS 启动套件,包含运行现代 SaaS 所需的所有功能。支付、漂亮的结账、管理面板、用户仪表板、身份验证、现成组件、统计数据、博客、文档等等。

SaaSykit:Laravel SaaS 启动套件
Rector logo

Rector

您无缝升级 Laravel、降低成本和加速创新的合作伙伴,助力企业成功

Rector
MongoDB logo

MongoDB

使用 MongoDB 和 Laravel 的强大集成来增强您的 PHP 应用程序,使开发人员能够轻松高效地构建应用程序。支持事务、搜索、分析和移动用例,同时使用熟悉的 Eloquent API。探索 MongoDB 的灵活、现代数据库如何改变您的 Laravel 应用程序。

MongoDB
Maska is a Simple Zero-dependency Input Mask Library image

Maska 是一个简单的零依赖输入掩码库

阅读文章
Add Swagger UI to Your Laravel Application image

在您的 Laravel 应用程序中添加 Swagger UI

阅读文章
Assert the Exact JSON Structure of a Response in Laravel 11.19 image

在 Laravel 11.19 中断言响应的精确 JSON 结构

阅读文章
Build SSH Apps with PHP and Laravel Prompts image

使用 PHP 和 Laravel Prompts 构建 SSH 应用程序

阅读文章
Building fast, fuzzy site search with Laravel and Typesense image

使用 Laravel 和 Typesense 构建快速、模糊的网站搜索

阅读文章
Add Comments to your Laravel Application with the Commenter Package image

使用 Commenter 软件包在您的 Laravel 应用程序中添加评论

阅读文章