schema([ Forms\Components\Select::make('stock_data_master_id') ->relationship('stockDataMaster', 'id') ->required(), 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('stockDataMaster.plant.name') ->label('Plant Name') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.stickerMaster.item.code') ->label('Item Code') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.location') ->label('Location') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.bin') ->label('Bin') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.serial_number') ->label('Serial Number') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.batch') ->label('Batch') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.quantity') ->label('Quantity') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.doc_no') ->label('Document Number') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.type') ->label('Type') ->alignCenter() ->searchable() ->formatStateUsing(fn ($state) => match ($state) { '0' => 'FG', '1' => 'SFG', default => '-', }) ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.motor_scanned_status') ->label('Motor Scanned Status') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.pump_scanned_status') ->label('Pump Scanned Status') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.capacitor_scanned_status') ->label('Capacitor Scanned Status') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.scanned_status_set') ->label('Scanned Status Set') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('stockDataMaster.scanned_status') ->label('Scanned Status') ->alignCenter() ->searchable() ->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(), ]), ]); } public static function getRelations(): array { return [ // ]; } public static function getPages(): array { return [ 'index' => Pages\ListDuplicateStocks::route('/'), 'create' => Pages\CreateDuplicateStock::route('/create'), 'view' => Pages\ViewDuplicateStock::route('/{record}'), 'edit' => Pages\EditDuplicateStock::route('/{record}/edit'), ]; } public static function getEloquentQuery(): Builder { return parent::getEloquentQuery() ->withoutGlobalScopes([ SoftDeletingScope::class, ]); } }