schema([ Forms\Components\Select::make('vehicle_master_id') ->label('Name') //->relationship('vehicleMaster', 'driverMaster.name') ->relationship('vehicleMaster', 'id') // this will fetch vehicles ->getOptionLabelFromRecordUsing(fn ($record) => $record->driverMaster?->name ?? 'No Driver') ->required(), Forms\Components\TextInput::make('latitude') ->label('Latitude') ->required(), Forms\Components\TextInput::make('longitude') ->label('Longitude') ->required(), Forms\Components\TextInput::make('accuracy') ->label('Accuracy') ->required(), Forms\Components\TextInput::make('status') ->label('Status') ->required(), Forms\Components\TextInput::make('distance_covered_km') ->label('Distance Covered') ->default(0), Forms\Components\Hidden::make('created_by') ->default(Filament::auth()->user()?->name) ->required(), 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.') ->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('vehicleMaster.id') ->label('Vehicle Master') ->alignCenter() ->sortable(), Tables\Columns\TextColumn::make('latitude') ->label('Latitude') ->alignCenter() ->sortable(), Tables\Columns\TextColumn::make('longitude') ->label('Longitude') ->alignCenter() ->sortable(), Tables\Columns\TextColumn::make('accuracy') ->label('Accuracy') ->alignCenter() ->sortable(), Tables\Columns\TextColumn::make('distance_covered_km') ->label('Distance Covered') ->alignCenter() ->sortable(), 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\ListVehicleTrackings::route('/'), 'create' => Pages\CreateVehicleTracking::route('/create'), 'view' => Pages\ViewVehicleTracking::route('/{record}'), 'edit' => Pages\EditVehicleTracking::route('/{record}/edit'), ]; } public static function getEloquentQuery(): Builder { return parent::getEloquentQuery() ->withoutGlobalScopes([ SoftDeletingScope::class, ]); } }