From 2696e9633cbff3790d3613c07575de8527b41f9b Mon Sep 17 00:00:00 2001 From: dhanabalan Date: Tue, 24 Feb 2026 13:08:12 +0530 Subject: [PATCH] Added customer po resource pages --- .../Resources/CustomerPoMasterResource.php | 176 ++++++++++++++++++ .../Pages/CreateCustomerPoMaster.php | 12 ++ .../Pages/EditCustomerPoMaster.php | 22 +++ .../Pages/ListCustomerPoMasters.php | 19 ++ .../Pages/ViewCustomerPoMaster.php | 19 ++ 5 files changed, 248 insertions(+) create mode 100644 app/Filament/Resources/CustomerPoMasterResource.php create mode 100644 app/Filament/Resources/CustomerPoMasterResource/Pages/CreateCustomerPoMaster.php create mode 100644 app/Filament/Resources/CustomerPoMasterResource/Pages/EditCustomerPoMaster.php create mode 100644 app/Filament/Resources/CustomerPoMasterResource/Pages/ListCustomerPoMasters.php create mode 100644 app/Filament/Resources/CustomerPoMasterResource/Pages/ViewCustomerPoMaster.php diff --git a/app/Filament/Resources/CustomerPoMasterResource.php b/app/Filament/Resources/CustomerPoMasterResource.php new file mode 100644 index 0000000..8b3de0c --- /dev/null +++ b/app/Filament/Resources/CustomerPoMasterResource.php @@ -0,0 +1,176 @@ +schema([ + Forms\Components\Select::make('plant_id') + ->label('Plant') + ->reactive() + ->relationship('plant', 'name') + ->options(function (callable $get) { + $userHas = Filament::auth()->user()->plant_id; + + return ($userHas && strlen($userHas) > 0) ? Plant::where('id', $userHas)->pluck('name', 'id')->toArray() : Plant::orderBy('code')->pluck('name', 'id')->toArray(); + }) + ->required(), + Forms\Components\Select::make('item_id') + ->label('Item Code') + ->reactive() + ->searchable() + ->options(function (callable $get) { + $plantId = $get('plant_id'); + if (empty($plantId)) { + return []; + } + + return Item::where('plant_id', $plantId)->pluck('code', 'id'); + }) + ->required(), + Forms\Components\TextInput::make('customer_po') + ->label('Customer PO'), + Forms\Components\TextInput::make('customer_name') + ->label('Customer Name'), + Forms\Components\TextInput::make('quantity') + ->label('Quantity'), + Forms\Components\Hidden::make('created_by') + ->label('Created By') + ->default(Filament::auth()->user()?->name), + Forms\Components\Hidden::make('updated_by') + ->default(Filament::auth()->user()?->name), + ]); + } + + public static function table(Table $table): Table + { + return $table + ->columns([ + Tables\Columns\TextColumn::make('No.') + ->label('No.') + ->getStateUsing(function ($record, $livewire, $column, $rowLoop) { + $paginator = $livewire->getTableRecords(); + $perPage = method_exists($paginator, 'perPage') ? $paginator->perPage() : 10; + $currentPage = method_exists($paginator, 'currentPage') ? $paginator->currentPage() : 1; + + return ($currentPage - 1) * $perPage + $rowLoop->iteration; + }), + Tables\Columns\TextColumn::make('plant.name') + ->label('Plant') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('item.code') + ->label('Item Code') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('customer_po') + ->label('Customer PO') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('customer_name') + ->label('Customer Name') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('quantity') + ->label('Quantity') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('created_at') + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + Tables\Columns\TextColumn::make('updated_at') + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + Tables\Columns\TextColumn::make('deleted_at') + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + ]) + ->filters([ + Tables\Filters\TrashedFilter::make(), + ]) + ->actions([ + Tables\Actions\ViewAction::make(), + Tables\Actions\EditAction::make(), + ]) + ->bulkActions([ + Tables\Actions\BulkActionGroup::make([ + Tables\Actions\DeleteBulkAction::make(), + Tables\Actions\ForceDeleteBulkAction::make(), + Tables\Actions\RestoreBulkAction::make(), + ]), + ]) + ->headerActions([ + ImportAction::make() + ->label('Import Customer PO') + ->color('warning') + ->importer(CustomerPoMasterImporter::class) + ->visible(function () { + return Filament::auth()->user()->can('view import customer po master'); + }), + ExportAction::make() + ->label('Export Customer PO') + ->color('warning') + ->exporter(CustomerPoMasterExporter::class) + ->visible(function () { + return Filament::auth()->user()->can('view export customer po master'); + }), + ]); + } + + public static function getRelations(): array + { + return [ + // + ]; + } + + public static function getPages(): array + { + return [ + 'index' => Pages\ListCustomerPoMasters::route('/'), + 'create' => Pages\CreateCustomerPoMaster::route('/create'), + 'view' => Pages\ViewCustomerPoMaster::route('/{record}'), + 'edit' => Pages\EditCustomerPoMaster::route('/{record}/edit'), + ]; + } + + public static function getEloquentQuery(): Builder + { + return parent::getEloquentQuery() + ->withoutGlobalScopes([ + SoftDeletingScope::class, + ]); + } +} diff --git a/app/Filament/Resources/CustomerPoMasterResource/Pages/CreateCustomerPoMaster.php b/app/Filament/Resources/CustomerPoMasterResource/Pages/CreateCustomerPoMaster.php new file mode 100644 index 0000000..e52dcae --- /dev/null +++ b/app/Filament/Resources/CustomerPoMasterResource/Pages/CreateCustomerPoMaster.php @@ -0,0 +1,12 @@ +