upgrade to filament v4

This commit is contained in:
Jp
2026-02-19 01:26:02 +08:00
parent 90c92650b7
commit b95f23f223
122 changed files with 3615 additions and 3379 deletions

View File

@@ -1,10 +1,17 @@
<?php
namespace App\Filament\Resources\BranchResource\RelationManagers;
namespace App\Filament\Resources\Branches\RelationManagers;
use Filament\Schemas\Schema;
use Filament\Forms\Components\TextInput;
use Filament\Tables\Columns\TextColumn;
use Filament\Actions\CreateAction;
use Filament\Actions\EditAction;
use Filament\Actions\DeleteAction;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\DeleteBulkAction;
use App\Models\Account;
use Filament\Forms;
use Filament\Forms\Form;
use Filament\Resources\RelationManagers\RelationManager;
use Filament\Tables;
use Filament\Tables\Table;
@@ -22,11 +29,11 @@ class AccountsRelationManager extends RelationManager
});
}
public function form(Form $form): Form
public function form(Schema $schema): Schema
{
return $form
->schema([
Forms\Components\TextInput::make('branch_id')
return $schema
->components([
TextInput::make('branch_id')
->required()
->maxLength(255),
]);
@@ -37,25 +44,25 @@ class AccountsRelationManager extends RelationManager
return $table
->recordTitleAttribute('branch_id')
->columns([
Tables\Columns\TextColumn::make('account'),
Tables\Columns\TextColumn::make('branch_id'),
Tables\Columns\TextColumn::make('normal_balance'),
Tables\Columns\TextColumn::make('starting_balance'),
Tables\Columns\TextColumn::make('current_balance'),
TextColumn::make('account'),
TextColumn::make('branch_id'),
TextColumn::make('normal_balance'),
TextColumn::make('starting_balance'),
TextColumn::make('current_balance'),
])
->filters([
//
])
->headerActions([
Tables\Actions\CreateAction::make(),
CreateAction::make(),
])
->actions([
Tables\Actions\EditAction::make(),
Tables\Actions\DeleteAction::make(),
->recordActions([
EditAction::make(),
DeleteAction::make(),
])
->bulkActions([
Tables\Actions\BulkActionGroup::make([
Tables\Actions\DeleteBulkAction::make(),
->toolbarActions([
BulkActionGroup::make([
DeleteBulkAction::make(),
]),
]);
}

View File

@@ -1,13 +1,23 @@
<?php
namespace App\Filament\Resources\BranchResource\RelationManagers;
namespace App\Filament\Resources\Branches\RelationManagers;
use Filament\Tables\Columns\TextColumn;
use Filament\Actions\CreateAction;
use Filament\Actions\EditAction;
use Filament\Actions\DeleteAction;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\DeleteBulkAction;
use Filament\Schemas\Schema;
use Filament\Schemas\Components\Grid;
use Filament\Forms\Components\Select;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Components\Textarea;
use App\DataObjects\CreateAccountDTO;
use App\Models\Account;
use App\Models\AccountType;
use App\Processes\Account\CreateAccountProcess;
use Filament\Forms;
use Filament\Forms\Form;
use Filament\Resources\RelationManagers\RelationManager;
use Filament\Tables;
use Filament\Tables\Table;
@@ -32,8 +42,8 @@ class BalancesRelationManager extends RelationManager
return $table
->recordTitleAttribute('branch_id')
->columns([
Tables\Columns\TextColumn::make('account')->sortable(),
Tables\Columns\TextColumn::make('accountType.normal_balance')
TextColumn::make('account')->sortable(),
TextColumn::make('accountType.normal_balance')
->badge()
->color(fn (string $state): string => match ($state) {
'Debit' => 'success',
@@ -41,23 +51,23 @@ class BalancesRelationManager extends RelationManager
})
->sortable()
->formatStateUsing(fn ($state): string => ucfirst($state)),
Tables\Columns\TextColumn::make('starting_balance')->label('Starting Balance'),
Tables\Columns\TextColumn::make('current_balance')->label('Current Balance'),
TextColumn::make('starting_balance')->label('Starting Balance'),
TextColumn::make('current_balance')->label('Current Balance'),
])
->filters([
//
])
->headerActions([
Tables\Actions\CreateAction::make()
CreateAction::make()
->using(fn (array $data) => $this->saveAccount($data)),
])
->actions([
Tables\Actions\EditAction::make(),
Tables\Actions\DeleteAction::make(),
->recordActions([
EditAction::make(),
DeleteAction::make(),
])
->bulkActions([
Tables\Actions\BulkActionGroup::make([
Tables\Actions\DeleteBulkAction::make(),
->toolbarActions([
BulkActionGroup::make([
DeleteBulkAction::make(),
]),
]);
}
@@ -72,24 +82,24 @@ class BalancesRelationManager extends RelationManager
return app(CreateAccountProcess::class)->run($payload);
}
public function form(Form $form): Form
public function form(Schema $schema): Schema
{
return $form
->schema($this->getAccountForm())
return $schema
->components($this->getAccountForm())
->columns(1);
}
public function getAccountForm(): array
{
return [
Forms\Components\Grid::make()
Grid::make()
->schema([
Forms\Components\Select::make('account_type_id')
Select::make('account_type_id')
->label('Account Type')
->relationship('accountType', 'type'),
Forms\Components\TextInput::make('account'),
Forms\Components\Textarea::make('description'),
Forms\Components\TextInput::make('starting_balance')
TextInput::make('account'),
Textarea::make('description'),
TextInput::make('starting_balance')
->integer(),
])->columns(1),
];

View File

@@ -1,21 +1,22 @@
<?php
namespace App\Filament\Resources\BranchResource\RelationManagers;
namespace App\Filament\Resources\Branches\RelationManagers;
use App\Filament\Resources\ExpenseResource;
use Filament\Forms\Form;
use Filament\Schemas\Schema;
use Filament\Actions\CreateAction;
use App\Filament\Resources\Expenses\Pages\CreateExpense;
use App\Filament\Resources\Expenses\ExpenseResource;
use Filament\Resources\RelationManagers\RelationManager;
use Filament\Tables\Actions\CreateAction;
use Filament\Tables\Table;
class ExpenseRelationManager extends RelationManager
{
protected static string $relationship = 'expenses';
public function form(Form $form): Form
public function form(Schema $schema): Schema
{
return $form
->schema(ExpenseResource::getExpenseFormFields());
return $schema
->components(ExpenseResource::getExpenseFormFields());
}
public function table(Table $table): Table
@@ -25,8 +26,8 @@ class ExpenseRelationManager extends RelationManager
->columns(ExpenseResource::getTableColumns())
->headerActions([
CreateAction::make()
->mutateFormDataUsing(
fn (array $data): array => app(ExpenseResource\Pages\CreateExpense::class)
->mutateDataUsing(
fn (array $data): array => app(CreateExpense::class)
->getFormDataMutation($data)
),
]);