upgrade to filament v4
This commit is contained in:
@@ -1,14 +1,20 @@
|
||||
<?php
|
||||
|
||||
namespace App\Filament\Resources;
|
||||
namespace App\Filament\Resources\Branches;
|
||||
|
||||
use Filament\Schemas\Schema;
|
||||
use Filament\Actions\EditAction;
|
||||
use Filament\Actions\BulkActionGroup;
|
||||
use Filament\Actions\DeleteBulkAction;
|
||||
use App\Filament\Resources\Branches\Pages\ListBranches;
|
||||
use App\Filament\Resources\Branches\Pages\CreateBranch;
|
||||
use App\Filament\Resources\Branches\Pages\EditBranch;
|
||||
use App\Filament\Resources\BranchResource\Pages;
|
||||
use App\Filament\Resources\BranchResource\RelationManagers\BalancesRelationManager;
|
||||
use App\Filament\Resources\BranchResource\RelationManagers\ExpenseRelationManager;
|
||||
use App\Filament\Resources\Branches\RelationManagers\BalancesRelationManager;
|
||||
use App\Filament\Resources\Branches\RelationManagers\ExpenseRelationManager;
|
||||
use App\Models\Branch;
|
||||
use Filament\Forms\Components\Select;
|
||||
use Filament\Forms\Components\TextInput;
|
||||
use Filament\Forms\Form;
|
||||
use Filament\Resources\Resource;
|
||||
use Filament\Support\RawJs;
|
||||
use Filament\Tables;
|
||||
@@ -19,16 +25,16 @@ class BranchResource extends Resource
|
||||
{
|
||||
protected static ?string $model = Branch::class;
|
||||
|
||||
protected static ?string $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
protected static string | \BackedEnum | null $navigationIcon = 'heroicon-o-rectangle-stack';
|
||||
|
||||
protected static bool $shouldRegisterNavigation = false;
|
||||
|
||||
protected static ?string $recordTitleAttribute = 'code';
|
||||
|
||||
public static function form(Form $form): Form
|
||||
public static function form(Schema $schema): Schema
|
||||
{
|
||||
return $form
|
||||
->schema([
|
||||
return $schema
|
||||
->components([
|
||||
Select::make('client_id')->relationship('client', 'id')
|
||||
->getOptionLabelFromRecordUsing(fn ($record) => $record->company)
|
||||
->disabled()
|
||||
@@ -63,12 +69,12 @@ class BranchResource extends Resource
|
||||
->filters([
|
||||
//
|
||||
])
|
||||
->actions([
|
||||
Tables\Actions\EditAction::make(),
|
||||
->recordActions([
|
||||
EditAction::make(),
|
||||
])
|
||||
->bulkActions([
|
||||
Tables\Actions\BulkActionGroup::make([
|
||||
Tables\Actions\DeleteBulkAction::make(),
|
||||
->toolbarActions([
|
||||
BulkActionGroup::make([
|
||||
DeleteBulkAction::make(),
|
||||
]),
|
||||
]);
|
||||
}
|
||||
@@ -85,9 +91,9 @@ class BranchResource extends Resource
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
'index' => Pages\ListBranches::route('/'),
|
||||
'create' => Pages\CreateBranch::route('/create'),
|
||||
'edit' => Pages\EditBranch::route('/{record}/edit'),
|
||||
'index' => ListBranches::route('/'),
|
||||
'create' => CreateBranch::route('/create'),
|
||||
'edit' => EditBranch::route('/{record}/edit'),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
<?php
|
||||
|
||||
namespace App\Filament\Resources\BranchResource\Pages;
|
||||
namespace App\Filament\Resources\Branches\Pages;
|
||||
|
||||
use App\Filament\Resources\BranchResource;
|
||||
use App\Filament\Resources\Branches\BranchResource;
|
||||
use Filament\Actions;
|
||||
use Filament\Resources\Pages\CreateRecord;
|
||||
|
||||
|
||||
@@ -1,9 +1,10 @@
|
||||
<?php
|
||||
|
||||
namespace App\Filament\Resources\BranchResource\Pages;
|
||||
namespace App\Filament\Resources\Branches\Pages;
|
||||
|
||||
use App\Filament\Resources\BranchResource;
|
||||
use App\Filament\Resources\ClientResource;
|
||||
use Filament\Actions\DeleteAction;
|
||||
use App\Filament\Resources\Branches\BranchResource;
|
||||
use App\Filament\Resources\Clients\ClientResource;
|
||||
use Filament\Actions;
|
||||
use Filament\Resources\Pages\EditRecord;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
@@ -30,7 +31,7 @@ class EditBranch extends EditRecord
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\DeleteAction::make(),
|
||||
DeleteAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,8 +1,9 @@
|
||||
<?php
|
||||
|
||||
namespace App\Filament\Resources\BranchResource\Pages;
|
||||
namespace App\Filament\Resources\Branches\Pages;
|
||||
|
||||
use App\Filament\Resources\BranchResource;
|
||||
use Filament\Actions\CreateAction;
|
||||
use App\Filament\Resources\Branches\BranchResource;
|
||||
use Filament\Actions;
|
||||
use Filament\Resources\Pages\ListRecords;
|
||||
|
||||
@@ -13,7 +14,7 @@ class ListBranches extends ListRecords
|
||||
protected function getHeaderActions(): array
|
||||
{
|
||||
return [
|
||||
Actions\CreateAction::make(),
|
||||
CreateAction::make(),
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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(),
|
||||
]),
|
||||
]);
|
||||
}
|
||||
|
||||
@@ -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),
|
||||
];
|
||||
|
||||
@@ -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)
|
||||
),
|
||||
]);
|
||||
|
||||
Reference in New Issue
Block a user