diff --git a/app/Filament/Resources/CharacteristicValueResource.php b/app/Filament/Resources/CharacteristicValueResource.php new file mode 100644 index 0000000..48c513e --- /dev/null +++ b/app/Filament/Resources/CharacteristicValueResource.php @@ -0,0 +1,516 @@ +schema([ + Forms\Components\Select::make('plant_id') + ->label('Plant') + ->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::pluck('name', 'id')->toArray(); + }) + ->reactive() + ->afterStateUpdated(function ($state, $set, callable $get) { + $plantId = $get('plant_id'); + $set('item_id', null); + $set('line_id', null); + $set('machine_id', null); + if (! $plantId) { + $set('poPlantError', 'Please select a plant first.'); + } + }) + ->extraAttributes(fn ($get) => [ + 'class' => $get('poPlantError') ? 'border-red-500' : '', + ]) + ->hint(fn ($get) => $get('poPlantError') ? $get('poPlantError') : null) + ->hintColor('danger') + ->required(), + Forms\Components\Select::make('line_id') + ->label('Line') + ->options(function (callable $get) { + if (!$get('plant_id')) { + return []; + } + + return Line::where('plant_id', $get('plant_id')) + ->pluck('name', 'id') + ->toArray(); + }) + ->afterStateUpdated(function ($state, $set, callable $get) { + $plantId = $get('plant_id'); + $set('item_id', null); + $set('machine_id', null); + if (! $plantId) { + $set('poPlantError', 'Please select a plant first.'); + } + }) + ->reactive() + ->required(), + Forms\Components\Select::make('item_id') + ->label('Item') + ->options(function (callable $get) { + if (!$get('plant_id') || !$get('line_id')) { + return []; + } + + return Item::where('plant_id', $get('plant_id')) + ->pluck('code', 'id') + ->toArray(); + }) + ->afterStateUpdated(function ($state, $set, callable $get) { + $plantId = $get('plant_id'); + $set('machine_id', null); + if (! $plantId) { + $set('poPlantError', 'Please select a plant first.'); + } + }) + ->reactive() + ->required() + ->searchable(), + Forms\Components\Select::make('machine_id') + ->label('Machine') + ->options(function (callable $get) { + if (!$get('plant_id') || !$get('line_id') || !$get('item_id')) { + return []; + } + + return Machine::where('plant_id', $get('plant_id')) + ->where('line_id', $get('line_id')) + ->pluck('work_center', 'id') + ->toArray(); + }) + ->afterStateUpdated(function ($state, $set, callable $get) { + $plantId = $get('plant_id'); + $set('process_order', null); + $set('coil_number', null); + $set('status', null); + if (! $plantId) { + $set('poPlantError', 'Please select a plant first.'); + } + }) + ->reactive() + ->required(), + Forms\Components\TextInput::make('process_order') + ->label('Process Order') + ->reactive() + ->afterStateUpdated(function ($state, $set, callable $get) { + $plantId = $get('plant_id'); + $set('coil_number', null); + $set('status', null); + if (! $plantId) { + $set('poPlantError', 'Please select a plant first.'); + } + }) + ->required(), + Forms\Components\TextInput::make('coil_number') + ->label('Coil Number') + // ->reactive() + // ->afterStateUpdated(function ($state, $set, callable $get) { + // $plantId = $get('plant_id'); + // $set('status', null); + // if (! $plantId) { + // $set('poPlantError', 'Please select a plant first.'); + // } + // }) + // ->required(), + ->label('Coil Number') + ->default('0') + ->reactive() + ->afterStateUpdated(function ($state, $set, callable $get, $livewire) { + $plantId = $get('plant_id'); + $processOrder = $get('process_order'); + $coilNo = $get('coil_number'); + if (! $plantId) { + $set('poPlantError', 'Please select a plant first.'); + } elseif (! $processOrder) { + $set('coil_number', null); + $set('poPlantError', null); + } elseif ($coilNo || $coilNo == '0') { + $existing = CharacteristicValue::where('plant_id', $plantId) + ->where('process_order', $processOrder) + ->where('coil_number', $coilNo) + ->first(); + + if ($existing) { + $set('poPlantError', null); + $set('coil_number', null); + $set('coilNumberError', "Duplicate Coil : '{$coilNo}' found!"); + } else { + $set('poPlantError', null); + $set('coilNumberError', null); + } + } + }) + ->extraAttributes(fn ($get) => [ + 'class' => $get('coilNumberError') ? 'border-red-500' : '', + ]) + ->hint(fn ($get) => $get('coilNumberError') ? $get('coilNumberError') : null) + ->hintColor('danger') + ->required(), + Forms\Components\Select::make('status') + ->label('Status') + ->options([ + 'Ok' => 'OK', + 'NotOk' => 'Not Ok' + ]) + ->reactive() + ->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('plant.name') + ->label('Plant') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('line.name') + ->label('Line') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('item.code') + ->label('Item') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('machine.work_center') + ->label('Machine') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('process_order') + ->label('Process Order') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('coil_number') + ->label('Coil Number') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('status') + ->label('Status') + ->searchable() + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('created_by') + ->label('Created By') + ->searchable() + ->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(), + // ]) + ->filters([ + + Tables\Filters\TrashedFilter::make(), + Filter::make('advanced_filters') + ->label('Advanced Filters') + ->form([ + Select::make('Plant') + ->label('Select Plant') + ->nullable() + ->options(function (callable $get) { + $userHas = Filament::auth()->user()->plant_id; + return ($userHas && strlen($userHas) > 0) ? Plant::where('id', $userHas)->pluck('name', 'id')->toArray() : Plant::pluck('name', 'id')->toArray(); + }) + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get) { + $set('Item', null); + }), + Select::make('Line') + ->label('Select Line') + ->nullable() + ->options(function (callable $get) { + $plantId = $get('Plant'); + + if(empty($plantId)) { + return []; + } + + return Line::where('plant_id', $plantId)->pluck('name', 'id'); + + //return $plantId ? Item::where('plant_id', $plantId)->pluck('code', 'id') : []; + }) + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get) { + $set('Item', null); + }), + Select::make('Item') + ->label('Item Code') + ->nullable() + ->searchable() + ->options(function (callable $get) { + $plantId = $get('Plant'); + + if(empty($plantId)) { + return []; + } + + return Item::where('plant_id', $plantId)->pluck('code', 'id'); + + //return $plantId ? Item::where('plant_id', $plantId)->pluck('code', 'id') : []; + }) + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get) { + $set('process_order', null); + }), + Select::make('Machine') + ->label('Select Machine') + ->nullable() + ->options(function (callable $get) { + $plantId = $get('Plant'); + $lineId = $get('Line'); + + if(empty($plantId) || empty($lineId)) { + return []; + } + + return Machine::where('plant_id', $plantId)->where('line_id', $lineId)->pluck('work_center', 'id'); + + //return $plantId ? Item::where('plant_id', $plantId)->pluck('code', 'id') : []; + }) + ->reactive() + ->afterStateUpdated(function ($state, callable $set, callable $get) { + $set('process_order', null); + }), + TextInput::make('process_order') + ->label('Process Order') + ->placeholder('Enter Process Order'), + TextInput::make('coil_number') + ->label('Coil Number') + ->placeholder(placeholder: 'Enter Coil Number'), + Select::make('status') + ->label('Status') + ->options([ + 'Ok' => 'OK', + 'NotOk' => 'Not Ok' + ]), + DateTimePicker::make(name: 'created_from') + ->label('Created From') + ->placeholder(placeholder: 'Select From DateTime') + ->reactive() + ->native(false), + DateTimePicker::make('created_to') + ->label('Created To') + ->placeholder(placeholder: 'Select To DateTime') + ->reactive() + ->native(false), + ]) + ->query(function ($query, array $data) { + // Hide all records initially if no filters are applied + if (empty($data['Plant']) && empty($data['Line']) && empty($data['Item']) && empty($data['Machine']) && empty($data['process_order']) && empty($data['coil_number']) && empty($data['status']) && empty($data['created_from']) && empty($data['created_to'])) { + return $query->whereRaw('1 = 0'); + } + + if (!empty($data['Plant'])) { + $query->where('plant_id', $data['Plant']); + } + + if (!empty($data['Line'])) { + $query->where('line_id', $data['Line']); + } + + if (!empty($data['Item'])) { + $query->where('item_id', $data['Item']); + } + + if (!empty($data['Machine'])) { + $query->where('machine_id', $data['Machine']); + } + + if (!empty($data['process_order'])) { + $query->where('process_order', $data['process_order']); + } + + if (!empty($data['coil_number'])) { + $query->where('coil_number', $data['coil_number']); + } + + if (!empty($data['status'])) { + $query->where('status', $data['status']); + } + + if (!empty($data['created_from'])) { + $query->where('created_at', '>=', $data['created_from']); + } + + if (!empty($data['created_to'])) { + $query->where('created_at', '<=', $data['created_to']); + } + + + //$query->orderBy('created_at', 'asc'); + }) + ->indicateUsing(function (array $data) { + $indicators = []; + + if (!empty($data['Plant'])) { + $indicators[] = 'Plant: ' . Plant::where('id', $data['Plant'])->value('name'); + } + + if (!empty($data['Line'])) { + $indicators[] = 'Line: ' . Line::where('id', $data['Line'])->value('name'); + } + + if (!empty($data['Item'])) { + $indicators[] = 'Item: ' . Item::where('id', $data['Item'])->value('code'); + } + + if (!empty($data['Machine'])) { + $indicators[] = 'Machine: ' . Machine::where('id', $data['Machine'])->value('work_center'); + } + + if (!empty($data['process_order'])) { + $indicators[] = 'Process Order: ' . $data['process_order']; + } + + if (!empty($data['coil_number'])) { + $indicators[] = 'Coil Number: ' . $data['coil_number']; + } + + if (!empty($data['status'])) { + $indicators[] = 'Status: ' . $data['status']; + } + + if (!empty($data['created_from'])) { + $indicators[] = 'From: ' . $data['created_from']; + } + + if (!empty($data['created_to'])) { + $indicators[] = 'To: ' . $data['created_to']; + } + + return $indicators; + }) + ]) + ->filtersFormMaxHeight('280px') + ->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(), + ]), + ]) + ->headerActions([ + ImportAction::make() + ->importer(CharacteristicValueImporter::class) + ->label('Import Characteristic Value') + ->color('warning') + ->visible(function () { + return Filament::auth()->user()->can('view import characteristic value'); + }), + ExportAction::make() + ->exporter(CharacteristicValueExporter::class) + ->label('Export Characteristic Value') + ->color('warning') + ->visible(function () { + return Filament::auth()->user()->can('view export characteristic value'); + }), + ]); + } + + public static function getRelations(): array + { + return [ + // + ]; + } + + public static function getPages(): array + { + return [ + 'index' => Pages\ListCharacteristicValues::route('/'), + 'create' => Pages\CreateCharacteristicValue::route('/create'), + 'view' => Pages\ViewCharacteristicValue::route('/{record}'), + 'edit' => Pages\EditCharacteristicValue::route('/{record}/edit'), + ]; + } + + public static function getEloquentQuery(): Builder + { + return parent::getEloquentQuery() + ->withoutGlobalScopes([ + SoftDeletingScope::class, + ]); + } +} diff --git a/app/Filament/Resources/CharacteristicValueResource/Pages/CreateCharacteristicValue.php b/app/Filament/Resources/CharacteristicValueResource/Pages/CreateCharacteristicValue.php new file mode 100644 index 0000000..4ac8770 --- /dev/null +++ b/app/Filament/Resources/CharacteristicValueResource/Pages/CreateCharacteristicValue.php @@ -0,0 +1,12 @@ +