From e8a1e97bd68a45fd676128f4e5a067ffad830c68 Mon Sep 17 00:00:00 2001 From: dhanabalan Date: Sat, 24 Jan 2026 11:00:41 +0530 Subject: [PATCH] Added characteristic approve master resource page --- .../CharacteristicApproverMasterResource.php | 201 ++++++++++++++++++ .../CreateCharacteristicApproverMaster.php | 12 ++ .../EditCharacteristicApproverMaster.php | 22 ++ .../ListCharacteristicApproverMasters.php | 19 ++ .../ViewCharacteristicApproverMaster.php | 19 ++ 5 files changed, 273 insertions(+) create mode 100644 app/Filament/Resources/CharacteristicApproverMasterResource.php create mode 100644 app/Filament/Resources/CharacteristicApproverMasterResource/Pages/CreateCharacteristicApproverMaster.php create mode 100644 app/Filament/Resources/CharacteristicApproverMasterResource/Pages/EditCharacteristicApproverMaster.php create mode 100644 app/Filament/Resources/CharacteristicApproverMasterResource/Pages/ListCharacteristicApproverMasters.php create mode 100644 app/Filament/Resources/CharacteristicApproverMasterResource/Pages/ViewCharacteristicApproverMaster.php diff --git a/app/Filament/Resources/CharacteristicApproverMasterResource.php b/app/Filament/Resources/CharacteristicApproverMasterResource.php new file mode 100644 index 0000000..9a2533a --- /dev/null +++ b/app/Filament/Resources/CharacteristicApproverMasterResource.php @@ -0,0 +1,201 @@ +schema([ + Forms\Components\Select::make('plant_id') + ->label('Plant') + ->reactive() + ->relationship('plant', 'name') + ->required(), + Forms\Components\Select::make('machine_id') + ->label('Work Center') + // ->relationship('machine', 'name') + ->reactive() + ->searchable() + ->options(function (callable $get) { + $plantId = $get('plant_id'); + if (empty($plantId)) { + return []; + } + + return Machine::where('plant_id', $plantId)->pluck('work_center', 'id'); + }) + ->required(), + Forms\Components\TextInput::make('characteristic_field') + ->label('Characteristic Field'), + Forms\Components\TextInput::make('machine_name') + ->label('Machine Name'), + Forms\Components\TextInput::make('name1') + ->label('Name-1'), + Forms\Components\TextInput::make('mail1') + ->label('Mail-1'), + Forms\Components\TextInput::make('duration1') + ->label('Duration-1 (Hour.Minute)'), + Forms\Components\TextInput::make('name2') + ->label('Name-2'), + Forms\Components\TextInput::make('mail2') + ->label('Mail-2'), + Forms\Components\TextInput::make('duration2') + ->label('Duration-2 (Hour.Minute)'), + Forms\Components\TextInput::make('name3') + ->label('Name-3'), + Forms\Components\TextInput::make('mail3') + ->label('Mail-3'), + Forms\Components\TextInput::make('duration3') + ->label('Duration-3 (Hour.Minute)'), + 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() + ->sortable(), + Tables\Columns\TextColumn::make('machine.work_center') + ->label('Work Center') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('characteristic_field') + ->label('Characteristic Field') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('machine_name') + ->label('Machine Name') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('name1') + ->label('Approver Name 1') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('mail1') + ->label('Mail 1') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('duration1') + ->label('Duration 1 (Hour.Minute)') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('name2') + ->label('Approver Name 2') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('mail2') + ->label('Mail 2') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('duration2') + ->label('Duration 2 (Hour.Minute)') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('name3') + ->label('Approver Name 3') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('mail3') + ->label('Mail 3') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('duration3') + ->label('Duration 3 (Hour.Minute)') + ->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') + ->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\ListCharacteristicApproverMasters::route('/'), + 'create' => Pages\CreateCharacteristicApproverMaster::route('/create'), + 'view' => Pages\ViewCharacteristicApproverMaster::route('/{record}'), + 'edit' => Pages\EditCharacteristicApproverMaster::route('/{record}/edit'), + ]; + } + + public static function getEloquentQuery(): Builder + { + return parent::getEloquentQuery() + ->withoutGlobalScopes([ + SoftDeletingScope::class, + ]); + } +} diff --git a/app/Filament/Resources/CharacteristicApproverMasterResource/Pages/CreateCharacteristicApproverMaster.php b/app/Filament/Resources/CharacteristicApproverMasterResource/Pages/CreateCharacteristicApproverMaster.php new file mode 100644 index 0000000..f2f1b61 --- /dev/null +++ b/app/Filament/Resources/CharacteristicApproverMasterResource/Pages/CreateCharacteristicApproverMaster.php @@ -0,0 +1,12 @@ +