文件生成
简介
Filament 包含许多用于生成文件的 CLI 命令。本指南解释如何自定义生成的文件。
Filament 生成的绝大多数文件是 PHP 类。Filament 使用 nette/php-generator 来程序化生成类,而不是使用模板文件。这样做的优势是生成的文件有更大的灵活性,这对于需要支持 Filament 所具有的众多不同配置选项来说非常重要。
每种类型的类都由一个 ClassGenerator 类生成。以下是 Filament 使用的 ClassGenerator 类列表:
Filament\Actions\Commands\FileGenerators\ExporterClassGenerator由make:filament-exporter命令使用。Filament\Actions\Commands\FileGenerators\ImporterClassGenerator由make:filament-importer命令使用。Filament\Forms\Commands\FileGenerators\FieldClassGenerator由make:filament-form-field命令使用。Filament\Forms\Commands\FileGenerators\FormSchemaClassGenerator由make:filament-form命令使用。Filament\Forms\Commands\FileGenerators\LivewireFormComponentClassGenerator由make:filament-livewire-form命令使用。Filament\Infolists\Commands\FileGenerators\EntryClassGenerator由make:filament-infolist-entry命令使用。Filament\Commands\FileGenerators\Resources\Pages\ResourceCreateRecordPageClassGenerator由make:filament-resource和make:filament-page命令使用。Filament\Commands\FileGenerators\Resources\Pages\ResourceCustomPageClassGenerator由make:filament-resource和make:filament-page命令使用。Filament\Commands\FileGenerators\Resources\Pages\ResourceEditRecordPageClassGenerator由make:filament-resource和make:filament-page命令使用。Filament\Commands\FileGenerators\Resources\Pages\ResourceListRecordsPageClassGenerator由make:filament-resource和make:filament-page命令使用。Filament\Commands\FileGenerators\Resources\Pages\ResourceManageRecordsPageClassGenerator由make:filament-resource和make:filament-page命令使用。Filament\Commands\FileGenerators\Resources\Pages\ResourceManageRelatedRecordsPageClassGenerator由make:filament-resource和make:filament-page命令使用。Filament\Commands\FileGenerators\Resources\Pages\ResourceViewRecordPageClassGenerator由make:filament-resource和make:filament-page命令使用。Filament\Commands\FileGenerators\Resources\SchemasResourceFormSchemaClassGenerator由make:filament-resource命令使用。Filament\Commands\FileGenerators\Resources\SchemasResourceInfolistSchemaClassGenerator由make:filament-resource命令使用。Filament\Commands\FileGenerators\Resources\SchemasResourceTableClassGenerator由make:filament-resource命令使用。Filament\Commands\FileGenerators\Resources\RelationManagerClassGenerator由make:filament-relation-manager命令使用。Filament\Commands\FileGenerators\Resources\ResourceClassGenerator由make:filament-resource命令使用。Filament\Commands\FileGenerators\ClusterClassGenerator由make:filament-cluster命令使用。Filament\Commands\FileGenerators\CustomPageClassGenerator由make:filament-page命令使用。Filament\Commands\FileGenerators\PanelProviderClassGenerator由filament:install和make:filament-panel命令使用。Filament\Schemas\Commands\FileGenerators\ComponentClassGenerator由make:filament-schema-component命令使用。Filament\Schemas\Commands\FileGenerators\LivewireSchemaComponentClassGenerator由make:filament-livewire-schema命令使用。Filament\Schemas\Commands\FileGenerators\SchemaClassGenerator由make:filament-schema命令使用。Filament\Tables\Commands\FileGenerators\ColumnClassGenerator由make:filament-table-column命令使用。Filament\Tables\Commands\FileGenerators\LivewireTableComponentClassGenerator由make:filament-livewire-table命令使用。Filament\Tables\Commands\FileGenerators\TableClassGenerator由make:filament-table命令使用。Filament\Widgets\Commands\FileGenerators\ChartWidgetClassGenerator由make:filament-widget命令使用。Filament\Widgets\Commands\FileGenerators\CustomWidgetClassGenerator由make:filament-widget命令使用。Filament\Widgets\Commands\FileGenerators\StatsOverviewWidgetClassGenerator由make:filament-widget命令使用。Filament\Widgets\Commands\FileGenerators\TableWidgetClassGenerator由make:filament-widget命令使用。
类生成器的结构
了解类生成器的最佳方式是查看它们的源代码。它们都遵循非常相似的模式,并使用 nette/php-generator 的功能。
以下是一些需要注意的方法:
__construct()接受传递给生成器的参数。这是你作为生成类上下文所能访问的所有信息。getImports()返回正在生成的类中使用的导入。这不是一个排他性列表,在生成属性和方法时也可以添加导入,如果这比预先提供更容易的话。getExtends()返回正在被继承的类的完全限定名称。addTraitsToClass()用于向正在生成的类添加 trait。来自nette/php-generator的Class对象作为参数传入。addPropertiesToClass()用于向正在生成的类添加属性。来自nette/php-generator的Class对象作为参数传入。add*PropertyToClass()方法用于向正在生成的类添加单个属性。来自nette/php-generator的Class对象作为参数传入。它们通常从addPropertiesToClass()中调用。addMethodsToClass()用于向正在生成的类添加方法。来自nette/php-generator的Class对象作为参数传入。add*MethodToClass()方法用于向正在生成的类添加单个方法。来自nette/php-generator的Class对象作为参数传入。它们通常从addMethodsToClass()中调用。
替换类生成器
要能够更改文件的生成方式,你需要识别正确的类生成器(见上面的列表)并替换它。
要替换它,创建一个新类来继承你要替换的类生成器。例如,如果你想替换 ResourceClassGenerator,创建一个如下所示的新类:
namespace App\Filament\Commands\FileGenerators\Resources;
use Filament\Commands\FileGenerators\Resources\ResourceClassGenerator as BaseResourceClassGenerator;
class ResourceClassGenerator extends BaseResourceClassGenerator
{
// ...
}
你还需要在服务容器中将其注册为绑定。你可以在服务提供者(如 AppServiceProvider)中完成此操作:
use App\Filament\Commands\FileGenerators\Resources\ResourceClassGenerator;
use Filament\Commands\FileGenerators\Resources\ResourceClassGenerator as BaseResourceClassGenerator;
use Illuminate\Support\ServiceProvider;
class AppServiceProvider extends ServiceProvider
{
public function register()
{
// ...
$this->app->bind(BaseResourceClassGenerator::class, ResourceClassGenerator::class);
// ...
}
}
自定义类中的现有属性或方法
查看类生成器的源代码时,找到你想要自定义的属性或方法。你可以通过在类生成器中定义一个同名的新方法来覆盖它。例如,以下是一个你可以找到的用于向资源类添加 $navigationIcon 属性的方法:
use BackedEnum;
use Filament\Support\Icons\Heroicon;
use Nette\PhpGenerator\ClassType;
use Nette\PhpGenerator\Literal;
protected function addNavigationIconPropertyToClass(ClassType $class): void
{
$this->namespace->addUse(BackedEnum::class);
$this->namespace->addUse(Heroicon::class);
$property = $class->addProperty('navigationIcon', new Literal('Heroicon::OutlinedRectangleStack'))
->setProtected()
->setStatic()
->setType('string|BackedEnum|null');
$this->configureNavigationIconProperty($property);
}
你可以覆盖该方法来更改其行为,或者你可以只覆盖 configureNavigationIconProperty() 方法来钩入属性的配置方式。例如,将属性从 protected 改为 public:
use Nette\PhpGenerator\Property;
protected function configureNavigationIconProperty(Property $property): void
{
$property->setPublic();
}
向类中添加新属性或方法
要向类中添加新属性或方法,你可以在 addPropertiesToClass() 或 addMethodsToClass() 方法中完成。要继承现有属性而不是替换它们,请确保在方法开头调用 parent::addPropertiesToClass() 或 parent::addMethodsToClass()。例如,以下是如何向资源类添加新属性:
use Nette\PhpGenerator\ClassType;
use Nette\PhpGenerator\Literal;
protected function addPropertiesToClass(ClassType $class): void
{
parent::addPropertiesToClass($class);
$class->addProperty('navigationSort', 10)
->setProtected()
->setStatic()
->setType('?int');
}