From 7e498727608cc6c2a94c155b76f4d9a08372a844 Mon Sep 17 00:00:00 2001 From: dhanabalan Date: Tue, 10 Mar 2026 09:12:47 +0530 Subject: [PATCH] Added not in stock resource pages --- app/Filament/Resources/NotInStockResource.php | 263 ++++++++++++++++++ .../Pages/CreateNotInStock.php | 12 + .../Pages/EditNotInStock.php | 22 ++ .../Pages/ListNotInStocks.php | 19 ++ .../Pages/ViewNotInStock.php | 19 ++ 5 files changed, 335 insertions(+) create mode 100644 app/Filament/Resources/NotInStockResource.php create mode 100644 app/Filament/Resources/NotInStockResource/Pages/CreateNotInStock.php create mode 100644 app/Filament/Resources/NotInStockResource/Pages/EditNotInStock.php create mode 100644 app/Filament/Resources/NotInStockResource/Pages/ListNotInStocks.php create mode 100644 app/Filament/Resources/NotInStockResource/Pages/ViewNotInStock.php diff --git a/app/Filament/Resources/NotInStockResource.php b/app/Filament/Resources/NotInStockResource.php new file mode 100644 index 0000000..8db1b43 --- /dev/null +++ b/app/Filament/Resources/NotInStockResource.php @@ -0,0 +1,263 @@ +schema([ + Forms\Components\Select::make('plant_id') + ->label('Plant') + ->reactive() + ->relationship('plant', 'name') + ->required(), + Forms\Components\Select::make('sticker_master_id') + ->label('Item Code') + ->reactive() + ->required() + ->searchable() + ->options(function ($get) { + if (!$get('plant_id')) { + return []; + } + + return StickerMaster::with('item') + ->where('plant_id', $get('plant_id')) + ->get() + ->pluck('item.code', 'id') + ->toArray(); + }), + Forms\Components\TextInput::make('location') + ->label('Location'), + Forms\Components\TextInput::make('bin') + ->label('Bin'), + Forms\Components\TextInput::make('serial_number') + ->label('Serial Number'), + Forms\Components\TextInput::make('batch') + ->label('Batch'), + Forms\Components\TextInput::make('quantity') + ->label('Quantity'), + Forms\Components\TextInput::make('doc_no') + ->label('Doc No'), + Forms\Components\Select::make('type') + ->label('Type') + ->options([ + '0' => 'FG', + '1' => 'SFG', + ]), + Forms\Components\TextInput::make('motor_scanned_status') + ->label('Motor Scanned Status'), + Forms\Components\TextInput::make('pump_scanned_status') + ->label('Pump Scanned Status'), + Forms\Components\TextInput::make('capacitor_scanned_status') + ->label('Capacitor Scanned Status'), + Forms\Components\TextInput::make('scanned_status_set') + ->label('Scanned Status Set'), + Forms\Components\TextInput::make('panel_box_item_code') + ->label('Panel Box Item Code'), + Forms\Components\TextInput::make('panel_box_supplier') + ->label('Panel Box Supplier'), + Forms\Components\TextInput::make('panel_box_sno') + ->label('Panel Box Sno'), + Forms\Components\TextInput::make('scanned_status') + ->label('Scanned Status'), + Forms\Components\TextInput::make('scanned_count') + ->label('Scanned Count'), + 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('plant.name') + ->label('Plant') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('stickerMaster.item.code') + ->label('Item Code') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('type') + ->label('Type') + ->alignCenter() + ->searchable() + ->formatStateUsing(fn ($state) => match ($state) { + '0' => 'FG', + '1' => 'SFG', + default => '-', + }) + ->sortable(), + Tables\Columns\TextColumn::make('location') + ->label('Location') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('bin') + ->label('Bin') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('serial_number') + ->label('Serial Number') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('batch') + ->label('Batch') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('quantity') + ->label('Quantity') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('doc_no') + ->label('Document Number') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('motor_scanned_status') + ->label('Motor Scanned Status') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('pump_scanned_status') + ->label('Pump Scanned Status') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('capacitor_scanned_status') + ->label('Capacitor Scanned Status') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('scanned_status_set') + ->label('Scanned Status Set') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('panel_box_item_code') + ->label('Panel Box Item Code') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('panel_box_supplier') + ->label('Panel Box Supplier') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('panel_box_sno') + ->label('Panel Box Serial Number') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('scanned_status') + ->label('Scanned Status') + ->alignCenter() + ->searchable() + ->sortable(), + Tables\Columns\TextColumn::make('scanned_quantity') + ->label('Scanned Quantity') + ->alignCenter() + ->searchable() + ->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\ListNotInStocks::route('/'), + 'create' => Pages\CreateNotInStock::route('/create'), + 'view' => Pages\ViewNotInStock::route('/{record}'), + 'edit' => Pages\EditNotInStock::route('/{record}/edit'), + ]; + } + + public static function getEloquentQuery(): Builder + { + return parent::getEloquentQuery() + ->withoutGlobalScopes([ + SoftDeletingScope::class, + ]); + } +} diff --git a/app/Filament/Resources/NotInStockResource/Pages/CreateNotInStock.php b/app/Filament/Resources/NotInStockResource/Pages/CreateNotInStock.php new file mode 100644 index 0000000..85e542f --- /dev/null +++ b/app/Filament/Resources/NotInStockResource/Pages/CreateNotInStock.php @@ -0,0 +1,12 @@ +