From e53fb15c015ee13cc60b507a703ce026b3b700ba Mon Sep 17 00:00:00 2001 From: dhanabalan Date: Fri, 23 Jan 2026 12:40:53 +0530 Subject: [PATCH] Added spot rate transport master resource pages --- .../SpotRateTransportMasterResource.php | 130 ++++++++++++++++++ .../Pages/CreateSpotRateTransportMaster.php | 43 ++++++ .../Pages/EditSpotRateTransportMaster.php | 56 ++++++++ .../Pages/ListSpotRateTransportMasters.php | 19 +++ .../Pages/ViewSpotRateTransportMaster.php | 19 +++ 5 files changed, 267 insertions(+) create mode 100644 app/Filament/Resources/SpotRateTransportMasterResource.php create mode 100644 app/Filament/Resources/SpotRateTransportMasterResource/Pages/CreateSpotRateTransportMaster.php create mode 100644 app/Filament/Resources/SpotRateTransportMasterResource/Pages/EditSpotRateTransportMaster.php create mode 100644 app/Filament/Resources/SpotRateTransportMasterResource/Pages/ListSpotRateTransportMasters.php create mode 100644 app/Filament/Resources/SpotRateTransportMasterResource/Pages/ViewSpotRateTransportMaster.php diff --git a/app/Filament/Resources/SpotRateTransportMasterResource.php b/app/Filament/Resources/SpotRateTransportMasterResource.php new file mode 100644 index 0000000..187de7e --- /dev/null +++ b/app/Filament/Resources/SpotRateTransportMasterResource.php @@ -0,0 +1,130 @@ +schema([ + Forms\Components\TextInput::make('group_name') + ->label('Group Name') + ->required(), + Forms\Components\Select::make('user_name') + ->label('User') + ->multiple() + ->preload() + ->reactive() + ->options( + User::pluck('name', 'name')->toArray() + ) + ->searchable() + ->required(), + Forms\Components\Hidden::make('id') + ->label('id'), + Forms\Components\Hidden::make('created_by') + ->label('Created By') + ->default(Filament::auth()->user()?->name), + Forms\Components\Hidden::make('updated_by') + ->label('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('group_name') + ->label('Group Name') + ->sortable(), + Tables\Columns\TextColumn::make('user_name') + ->label('User Name') + ->sortable(), + Tables\Columns\TextColumn::make('created_at') + ->label('Created At') + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + Tables\Columns\TextColumn::make('updated_at') + ->label('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(), + ]), + ]); + } + + public static function getRelations(): array + { + return [ + // + ]; + } + + public static function getPages(): array + { + return [ + 'index' => Pages\ListSpotRateTransportMasters::route('/'), + 'create' => Pages\CreateSpotRateTransportMaster::route('/create'), + 'view' => Pages\ViewSpotRateTransportMaster::route('/{record}'), + 'edit' => Pages\EditSpotRateTransportMaster::route('/{record}/edit'), + ]; + } + + public static function getEloquentQuery(): Builder + { + return parent::getEloquentQuery() + ->withoutGlobalScopes([ + SoftDeletingScope::class, + ]); + } +} diff --git a/app/Filament/Resources/SpotRateTransportMasterResource/Pages/CreateSpotRateTransportMaster.php b/app/Filament/Resources/SpotRateTransportMasterResource/Pages/CreateSpotRateTransportMaster.php new file mode 100644 index 0000000..21c0d8f --- /dev/null +++ b/app/Filament/Resources/SpotRateTransportMasterResource/Pages/CreateSpotRateTransportMaster.php @@ -0,0 +1,43 @@ +data['group_name'] ?? null; + $userNames = $this->data['user_name'] ?? []; + + foreach ($userNames as $userName) { + + $query = SpotRateTransportMaster::where('group_name', $groupName) + ->whereJsonContains('user_name', $userName); + + if ($query->exists()) { + + Notification::make() + ->title('Duplicate User') + ->body("User {$userName} already exists in this group.") + ->danger() + ->persistent() + ->send(); + + // Prevent create + $this->halt(); + return; + } + } + } + + + +} diff --git a/app/Filament/Resources/SpotRateTransportMasterResource/Pages/EditSpotRateTransportMaster.php b/app/Filament/Resources/SpotRateTransportMasterResource/Pages/EditSpotRateTransportMaster.php new file mode 100644 index 0000000..5818615 --- /dev/null +++ b/app/Filament/Resources/SpotRateTransportMasterResource/Pages/EditSpotRateTransportMaster.php @@ -0,0 +1,56 @@ +data['group_name'] ?? null; + $userNames = $this->data['user_name'] ?? []; + $recordId = $this->record->id ?? null; + + foreach ($userNames as $userName) { + + $query = SpotRateTransportMaster::where('group_name', $groupName) + ->whereJsonContains('user_name', $userName); + + // Exclude current record for update + if ($recordId) { + $query->where('id', '!=', $recordId); + } + + if ($query->exists()) { + + Notification::make() + ->title('Duplicate User') + ->body("User {$userName} already exists in this group.") + ->danger() + ->persistent() + ->send(); + + // Prevent save/update + $this->halt(); + return; + } + } + } + + protected function getHeaderActions(): array + { + return [ + Actions\ViewAction::make(), + Actions\DeleteAction::make(), + Actions\ForceDeleteAction::make(), + Actions\RestoreAction::make(), + ]; + } +} diff --git a/app/Filament/Resources/SpotRateTransportMasterResource/Pages/ListSpotRateTransportMasters.php b/app/Filament/Resources/SpotRateTransportMasterResource/Pages/ListSpotRateTransportMasters.php new file mode 100644 index 0000000..93d9afe --- /dev/null +++ b/app/Filament/Resources/SpotRateTransportMasterResource/Pages/ListSpotRateTransportMasters.php @@ -0,0 +1,19 @@ +