From 01cbfc9391f769fbc3f1ebbe2eb89c87c6f330f8 Mon Sep 17 00:00:00 2001 From: dhanabalan Date: Wed, 4 Feb 2026 14:57:35 +0530 Subject: [PATCH] Add VehicleEntry resource and associated pages for CRUD operations --- .../Resources/VehicleEntryResource.php | 163 ++++++++++++++++++ .../Pages/CreateVehicleEntry.php | 12 ++ .../Pages/EditVehicleEntry.php | 22 +++ .../Pages/ListVehicleEntries.php | 19 ++ .../Pages/ViewVehicleEntry.php | 19 ++ 5 files changed, 235 insertions(+) create mode 100644 app/Filament/Resources/VehicleEntryResource.php create mode 100644 app/Filament/Resources/VehicleEntryResource/Pages/CreateVehicleEntry.php create mode 100644 app/Filament/Resources/VehicleEntryResource/Pages/EditVehicleEntry.php create mode 100644 app/Filament/Resources/VehicleEntryResource/Pages/ListVehicleEntries.php create mode 100644 app/Filament/Resources/VehicleEntryResource/Pages/ViewVehicleEntry.php diff --git a/app/Filament/Resources/VehicleEntryResource.php b/app/Filament/Resources/VehicleEntryResource.php new file mode 100644 index 0000000..963038d --- /dev/null +++ b/app/Filament/Resources/VehicleEntryResource.php @@ -0,0 +1,163 @@ +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\TextInput::make('vehicle_number') + ->label('Vehicle Number') + ->required(), + Forms\Components\DateTimePicker::make('entry_time') + ->label('Entry Time') + ->required(), + Forms\Components\DateTimePicker::make('exit_time') + ->label('Exit Time') + ->required(), + Forms\Components\TextInput::make('duration') + ->label('Duration') + ->required(), + Forms\Components\TextInput::make('type') + ->label('Type') + ->required(), + Forms\Components\Hidden::make('created_by') + ->label('Created By'), + Forms\Components\Hidden::make('updated_by') + ->label('Updated By'), + ]); + } + + public static function table(Table $table): Table + { + return $table + ->columns([ + Tables\Columns\TextColumn::make('No.') + ->label('No.') + ->alignCenter() + ->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() + ->searchable(), + Tables\Columns\TextColumn::make('vehicle_number') + ->label('Vehicle Number') + ->alignCenter() + ->sortable() + ->searchable(), + Tables\Columns\TextColumn::make('entry_time') + ->label('Entry Time') + ->alignCenter() + ->dateTime() + ->sortable() + ->searchable(), + Tables\Columns\TextColumn::make('exit_time') + ->label('Exit Time') + ->alignCenter() + ->dateTime() + ->sortable() + ->searchable(), + Tables\Columns\TextColumn::make('duration') + ->label('Duration') + ->alignCenter() + ->searchable(), + Tables\Columns\TextColumn::make('type') + ->label('Type') + ->alignCenter() + ->searchable(), + Tables\Columns\TextColumn::make('created_at') + ->label('Created At') + ->alignCenter() + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + Tables\Columns\TextColumn::make('updated_at') + ->label('Updated At') + ->alignCenter() + ->dateTime() + ->sortable() + ->toggleable(isToggledHiddenByDefault: true), + Tables\Columns\TextColumn::make('deleted_at') + ->label('Deleted At') + ->alignCenter() + ->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\ListVehicleEntries::route('/'), + 'create' => Pages\CreateVehicleEntry::route('/create'), + 'view' => Pages\ViewVehicleEntry::route('/{record}'), + 'edit' => Pages\EditVehicleEntry::route('/{record}/edit'), + ]; + } + + public static function getEloquentQuery(): Builder + { + return parent::getEloquentQuery() + ->withoutGlobalScopes([ + SoftDeletingScope::class, + ]); + } +} diff --git a/app/Filament/Resources/VehicleEntryResource/Pages/CreateVehicleEntry.php b/app/Filament/Resources/VehicleEntryResource/Pages/CreateVehicleEntry.php new file mode 100644 index 0000000..faa0284 --- /dev/null +++ b/app/Filament/Resources/VehicleEntryResource/Pages/CreateVehicleEntry.php @@ -0,0 +1,12 @@ +