schema([ Forms\Components\Select::make('plant_id') ->label('Plant Name') ->relationship('plant', 'name') ->searchable() ->options(function (callable $get) { $userHas = Filament::auth()->user()->plant_id; return ($userHas && strlen($userHas) > 0) ? Plant::where('id', $userHas)->pluck('name', 'id')->toArray() : Plant::orderBy('code')->pluck('name', 'id')->toArray(); }) ->disabled(fn (Get $get) => ! empty($get('id'))) ->default(function () { $userHas = Filament::auth()->user()->plant_id; return ($userHas && strlen($userHas) > 0) ? $userHas : optional(ProcessOrder::latest()->first())->plant_id; }) ->reactive() ->afterStateUpdated(function ($state, $set, callable $get, $livewire) { $plantId = $get('plant_id'); $set('item_id', null); $set('line_id', null); $set('item_description', null); $set('item_uom', null); $set('process_order', null); $set('coil_number', '0'); $set('order_quantity', '0'); $set('received_quantity', '0'); $set('scrap_quantity', '0'); $set('sfg_number', null); $set('machine_name', null); if (! $plantId) { $set('poPlantError', 'Please select a plant first.'); $set('coilNumberError', null); $set('sfgNumberError', null); } else { $set('poPlantError', null); } $set('updated_by', Filament::auth()->user()?->name); }) ->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 Name') ->reactive() ->searchable() ->options(function (callable $get) { $plantId = $get('plant_id'); if (empty($plantId)) { return []; } return Line::where('plant_id', $plantId)->pluck('name', 'id'); }) ->disabled(fn (Get $get) => ! empty($get('id'))) ->afterStateUpdated(function (callable $set, callable $get, ?string $state) { $set('item_id', null); $set('item_description', null); $set('item_uom', null); $set('process_order', null); $set('coil_number', '0'); $set('order_quantity', '0'); $set('received_quantity', '0'); $set('scrap_quantity', '0'); $set('sfg_number', null); $set('machine_name', null); $set('updated_by', Filament::auth()->user()?->name); }) ->required(), Forms\Components\Select::make('item_id') ->label('Item Code') // ->relationship('item', 'id') // ->required(), ->searchable() ->reactive() ->options(function (callable $get) { $plantId = $get('plant_id'); if (empty($plantId)) { return []; } return Item::where('plant_id', $plantId)->pluck('code', 'id'); }) ->disabled(fn (Get $get) => ! empty($get('id'))) ->afterStateUpdated(function (callable $set, callable $get, ?string $state) { $plantId = $get('plant_id'); $itemId = $get('item_id'); $set('process_order', null); $set('coil_number', '0'); $set('order_quantity', '0'); $set('received_quantity', '0'); $set('scrap_quantity', '0'); $set('sfg_number', null); $set('machine_name', null); if ($plantId && $itemId) { // Get the item code using item_id $itemCode = Item::where('id', $itemId)->value('code'); if ($itemCode) { // Now get the item description using plant_id + code $item = Item::where('plant_id', $plantId) ->where('code', $itemCode) ->first(); $set('item_description', $item?->description); $set('item_uom', $item?->uom); } else { $set('item_description', null); $set('item_uom', null); } } else { $set('item_description', null); $set('item_uom', null); } $set('updated_by', Filament::auth()->user()?->name); }) ->required(), Forms\Components\TextInput::make('item_description') ->label('Item Description') ->readOnly() ->required() ->reactive() ->afterStateHydrated(function ($component, $state, Get $get, Set $set) { $itemId = $get('item_id'); if ($get('id')) { $item = Item::where('id', $itemId)->first()?->description; if ($item) { $set('item_description', $item); } else { $set('item_description', null); } } }) ->afterStateUpdated(function (callable $set, callable $get, ?string $state) { $set('updated_by', Filament::auth()->user()?->name); }), Forms\Components\TextInput::make('item_uom') ->label('Item UOM') ->readOnly() ->required() ->reactive() ->afterStateHydrated(function ($component, $state, Get $get, Set $set) { $itemId = $get('item_id'); if ($get('id')) { $item = Item::where('id', $itemId)->first()?->uom; if ($item) { $set('item_uom', $item); } else { $set('item_uom', null); } } }) ->afterStateUpdated(function (callable $set, callable $get, ?string $state) { $set('updated_by', Filament::auth()->user()?->name); }), Forms\Components\TextInput::make('process_order') ->label('Process Order') ->reactive() ->numeric() ->length(12) ->readOnly(fn ($get) => ($get('plant_id') == null || $get('item_id') == null || $get('line_id') == null)) ->afterStateUpdated(function ($state, $set, callable $get, $livewire) { $plantId = $get('plant_id'); $set('coil_number', '0'); $set('order_quantity', '0'); $set('received_quantity', '0'); $set('scrap_quantity', '0'); $set('sfg_number', null); $set('machine_name', null); // if (! $plantId) { // $set('poPlantError', 'Please select a plant first.'); // $set('process_order', null); // $set('coilNumberError', null); // $set('sfgNumberError', null); // return; // } $itemId = $get('item_id'); $processOrder = trim($get('process_order')); if (! $itemId || ! $processOrder) { return; } $orderExist = ProcessOrder::where('plant_id', $plantId) ->where('process_order', $processOrder) ->where('item_id', $itemId)->latest()->first(); // ->value('order_quantity') ?? 0; if ($orderExist) { $set('order_quantity', $orderExist->order_quantity ?? 0); } $set('updated_by', Filament::auth()->user()?->name); }) ->rule(function (callable $get) { return function (string $attribute, $value, Closure $fail) use ($get) { $plantId = $get('plant_id'); $itemId = $get('item_id'); $processOrder = $value; // $currentId = $get('id'); // current editing record id if (! $plantId || ! $processOrder) { return; } $existing = ProcessOrder::where('plant_id', $plantId) ->where('process_order', $processOrder) ->where('item_id', '!=', $itemId) ->first(); if ($existing) { // Notification::make() // ->title('Duplicate Process Order!') // ->body("Process Order '{$value}' is already exist with item code '{$existing->item->code}'.") // ->danger() // ->send(); $fail("process order already exists for this plant and item code '{$existing->item->code}'."); } }; }) ->required(), Forms\Components\TextInput::make('coil_number') ->label('Coil Number') ->default('0') ->required() ->reactive() ->numeric() ->readOnly(fn ($get) => ($get('process_order') == null)) ->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.'); $set('coil_number', '0'); } elseif (! $processOrder) { $set('poPlantError', null); $set('coil_number', '0'); } $set('received_quantity', '0'); $set('scrap_quantity', '0'); $set('sfg_number', null); $set('machine_name', null); $set('coilNumberError', null); $set('sfgNumberError', null); // elseif ($coilNo || $coilNo == 0) { // $existing = ProcessOrder::where('plant_id', $plantId) // ->where('process_order', $processOrder) // ->where('coil_number', $coilNo) // ->first(); // if ($existing) { // $set('poPlantError', null); // $set('coil_number', '0'); // $set('coilNumberError', "Duplicate Coil : '{$coilNo}' found!"); // } else { // $set('poPlantError', null); // $set('coilNumberError', null); // } // } $set('updated_by', Filament::auth()->user()?->name); }) ->rules([ function (callable $get) { return Rule::unique('process_orders', 'coil_number') ->where('plant_id', $get('plant_id')) ->where('process_order', $get('process_order')) ->ignore($get('id')); }, function (callable $get): Closure { return function (string $attribute, $value, Closure $fail) use ($get) { $rework = $get('rework_status'); if ($value && Str::contains($value, '.') && $rework == 0) { $fail("Rework status should be 'Yes' for rework coil number '{$value}'!"); } }; }, ]) // ->rule(function (callable $get) { // return Rule::unique('process_orders', 'coil_number') // ->where('plant_id', $get('plant_id')) // ->where('process_order', $get('process_order')) // ->ignore($get('id')); // }) ->extraAttributes(fn ($get) => [ 'class' => $get('coilNumberError') ? 'border-red-500' : '', ]) ->hint(fn ($get) => $get('coilNumberError') ? $get('coilNumberError') : null) ->hintColor('danger'), Forms\Components\TextInput::make('order_quantity') ->label('Order Quantity') ->default('1.000') ->required() ->reactive() ->numeric() ->readOnly(fn ($get) => ($get('process_order') == null)) ->afterStateUpdated(function (callable $set, callable $get, ?string $state) { $plantId = $get('plant_id'); $itemId = $get('item_id'); $processOrder = trim($get('process_order')); $set('received_quantity', '0'); $set('scrap_quantity', '0'); if (! $plantId || ! $itemId || ! $processOrder) { $set('order_quantity', '0'); } $query = ProcessOrder::where('plant_id', $plantId) ->where('process_order', $processOrder) ->where('item_id', $itemId); $orderExist = $query->latest()->first(); // Latest record (reuse base query) if ($query->count() == 1 && $orderExist && ! $get('id')) { $set('order_quantity', $orderExist->order_quantity ?? 0); } elseif ($query->count() > 1 && $orderExist) { $set('order_quantity', $orderExist->order_quantity ?? 0); } $set('updated_by', Filament::auth()->user()?->name); }), Forms\Components\TextInput::make('received_quantity') ->label('Received Quantity') ->default('0.000') ->required() ->reactive() ->numeric() ->readOnly(fn ($get) => ($get('process_order') == null)) ->afterStateUpdated(function (callable $set, callable $get, ?string $state) { $set('scrap_quantity', '0'); $set('updated_by', Filament::auth()->user()?->name); }), Forms\Components\TextInput::make('scrap_quantity') ->label('Scrap Quantity') ->default('0.000') ->required() ->readOnly(fn ($get) => ($get('rework_status') == 0 || $get('process_order') == null)) ->reactive() ->numeric() ->afterStateUpdated(function (callable $set, callable $get, ?string $state) { $rework = $get('rework_status'); if ($rework == 0) { $set('scrap_quantity', '0'); } $set('updated_by', Filament::auth()->user()?->name); }) ->rule(function (callable $get) { return function (string $attribute, $value, Closure $fail) use ($get) { $rework = $get('rework_status'); $scrapQty = $value; // $currentId = $get('id'); // current editing record id if ($rework == 0 && $scrapQty != 0) { $fail("Scrap Quanity value should be '0'!"); return; } }; }), Forms\Components\TextInput::make('sfg_number') ->label('SFG Number') ->reactive() ->readOnly(fn ($get) => ($get('process_order') == null)) ->afterStateUpdated(function ($state, $set, callable $get, $livewire) { $plantId = $get('plant_id'); $sfgNo = $get('sfg_number'); if (! $plantId) { $set('poPlantError', 'Please select a plant first.'); $set('sfg_number', null); $set('machine_name', null); $set('sfgNumberError', null); // 'Please select a plant first.' } elseif ($sfgNo) { $existing = ProcessOrder::where('plant_id', $plantId) ->where('sfg_number', $sfgNo) ->first(); if ($existing) { $set('poPlantError', null); $set('sfg_number', null); $set('machine_name', null); $set('sfgNumberError', "Duplicate SFG : '{$sfgNo}' found!"); } else { $set('poPlantError', null); $set('sfgNumberError', null); } } $set('updated_by', Filament::auth()->user()?->name); }) ->extraAttributes(fn ($get) => [ 'class' => $get('sfgNumberError') ? 'border-red-500' : '', ]) ->hint(fn ($get) => $get('sfgNumberError') ? $get('sfgNumberError') : null) ->hintColor('danger'), Forms\Components\TextInput::make('machine_name') ->label('Machine Name') ->reactive() ->readOnly(fn ($get) => ($get('process_order') == null)) ->afterStateUpdated(function (callable $set, callable $get, ?string $state) { $set('updated_by', Filament::auth()->user()?->name); }), Forms\Components\Select::make('rework_status') ->label('Rework Status') ->default(0) ->reactive() ->options([0 => 'No', 1 => 'Yes']) ->reactive() ->afterStateUpdated(function (callable $set, callable $get, ?string $state) { if ($state == 0) { $set('scrap_quantity', '0'); } $set('updated_by', Filament::auth()->user()?->name); }) ->rule(function (callable $get, callable $set) { return function (string $attribute, $value, Closure $fail) use ($get, $set) { $plantId = $get('plant_id'); $lineId = $get('line_id'); $processOrder = trim($get('process_order')); $coilNo = trim($get('coil_number')); $status = $value; // $currentId = $get('id'); // current editing record id if (! $plantId || ! $lineId || ! $processOrder || Str::length($coilNo) <= 0) { $set('rework_status', 0); return; } elseif ($status == 0) { $existingCoil = ProcessOrder::where('plant_id', $plantId) ->where('line_id', $lineId) ->where('process_order', $processOrder) ->where('coil_number', $coilNo) ->first(); if ($existingCoil && $existingCoil->rework_status == 1 && $get('id')) { $fail("Rework coil number '{$coilNo}' exist against plant and process order!"); return; } } if (Str::length($coilNo) > 0 && ($status == 1 || Str::contains($coilNo, '.'))) { $coilMain = explode('.', $coilNo)[0]; // 333 $existingCoil = ProcessOrder::where('plant_id', $plantId) ->where('line_id', $lineId) ->where('process_order', $processOrder) ->where('coil_number', $coilMain) ->first(); if (! $existingCoil) { $fail("Coil number '{$coilMain}' not exist against plant and process order!"); } elseif ($existingCoil->rework_status == 0 && ! $get('id')) { $fail("Rework coil number '{$coilMain}' not exist against plant and process order!"); } } }; }) ->visible(function () { return Filament::auth()->user()->hasRole('Super Admin'); // || Filament::auth()->user()->can('update process order rework status') }) ->required(), Forms\Components\FileUpload::make('attachment') ->label('PDF Upload') ->acceptedFileTypes(['application/pdf']) ->storeFiles(false) ->disk('local') ->directory('uploads/temp') ->preserveFilenames() ->visible(function () { return Filament::auth()->user()->can('view process order packing slip'); }) ->reactive(), Forms\Components\Actions::make([ Action::make('uploadNow') ->label('Upload PDF Now') ->visible(function () { return Filament::auth()->user()->can('view process order packing slip'); }) ->action(function ($get, callable $set) { $uploadedFiles = $get('attachment'); $set('updated_by', Filament::auth()->user()?->name); if (is_array($uploadedFiles) && count($uploadedFiles) > 0) { $uploaded = reset($uploadedFiles); if ($uploaded instanceof TemporaryUploadedFile) { $originalName = $uploaded->getClientOriginalName(); $path = 'uploads/ProcessOrder/'.$originalName; // Check if file already exists if (Storage::disk('local')->exists($path)) { Notification::make() ->title('Duplicate File') ->body("The file '{$originalName}' already exists in uploads/ProcessOrder.") ->warning() ->send(); return; // Stop here } $storedPath = $uploaded->storeAs( 'uploads/ProcessOrder', $originalName, 'local' ); // $fullPath = storage_path('app/' . $storedPath); $fullPath = storage_path('app/'.$storedPath); // Parse PDF using smalot/pdfparser $parser = new Parser; $pdf = $parser->parseContent(file_get_contents($uploaded->getRealPath())); $text = $pdf->getText(); // if (preg_match('/Batch ID:\s*(\d+)\s*--/i', $text, $matches)) // { // $batchId = $matches[1]; // } if (preg_match('/Batch ID:\s*(\d+)(?:\s*--)?/i', $text, $matches)) { $batchId = $matches[1]; } else { $batchId = null; } // Get the value of process_order field $processOrder = $get('process_order'); if ($batchId != $processOrder) { Notification::make() ->title('Mismatch') ->body("Batch ID ($batchId) does not match Process Order ($processOrder)") ->danger() ->send(); return; } if ($batchId == $processOrder) { // If batch matches, store the PDF permanently $storedPath = $uploaded->storeAs( 'uploads/ProcessOrder', $originalName, 'local' ); Notification::make() ->title('Success') ->body("Batch ID matches Process Order: $batchId. PDF uploaded successfully.") ->success() ->send(); return; } } } else { Notification::make() ->title('No file selected to upload') ->warning() ->send(); return; } }), Action::make('downloadAttachment') ->label('Download PDF') ->visible(function () { return Filament::auth()->user()->can('view process order packing slip'); }) ->action(function ($get, callable $set) { $equipmentNumber = $get('process_order'); $set('updated_by', Filament::auth()->user()?->name); if (! $equipmentNumber) { Notification::make() ->title('No process order entered') ->danger() ->send(); return; } $files = Storage::disk('local')->files('uploads/ProcessOrder'); $fileToDownload = null; foreach ($files as $file) { if (str_contains($file, $equipmentNumber)) { $fileToDownload = $file; break; } } if (! $fileToDownload) { Notification::make() ->title('PDF not found for this process order') ->danger() ->send(); return; } return response()->download(Storage::disk('local')->path($fileToDownload)); }), ]), 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), Forms\Components\TextInput::make('id') ->hidden() ->readOnly(), ]); } 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 Name') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('line.name') ->label('Line Name') ->searchable() ->alignCenter() ->sortable(), Tables\Columns\TextColumn::make('item.code') ->label('Item Code') ->searchable() ->alignCenter() ->sortable(), Tables\Columns\TextColumn::make('item.description') ->label('Item Description') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('item.uom') ->label('Item UOM') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('process_order') ->label('Process Order') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('coil_number') ->label('Coil Number') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('order_quantity') ->label('Order Quantity') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('received_quantity') ->label('Received Quantity') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('scrap_quantity') ->label('Scrap Quantity') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('sfg_number') ->label('SFG Number') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('machine_name') ->label('Machine Name') ->alignCenter() ->searchable() ->sortable(), Tables\Columns\TextColumn::make('rework_status') ->label('Rework Status') ->alignCenter() ->searchable() ->formatStateUsing(fn ($state) => $state == 1 ? 'Yes' : 'No') ->sortable(), Tables\Columns\TextColumn::make('created_at') ->label('Created At') ->alignCenter() ->dateTime() ->sortable(), Tables\Columns\TextColumn::make('created_by') ->label('Created By') ->alignCenter() ->sortable(), Tables\Columns\TextColumn::make('updated_at') ->label('Updated At') ->alignCenter() ->dateTime() ->sortable() ->toggleable(isToggledHiddenByDefault: true), Tables\Columns\TextColumn::make('updated_by') ->label('Updated By') ->alignCenter() ->sortable() ->toggleable(isToggledHiddenByDefault: true), Tables\Columns\TextColumn::make('deleted_at') ->label('Deleted At') ->alignCenter() ->dateTime() ->sortable() ->toggleable(isToggledHiddenByDefault: true), ]) ->filters([ Tables\Filters\TrashedFilter::make(), Filter::make('advanced_filters') ->label('Advanced Filters') ->form([ Select::make('Plant') ->label('Search by Plant Name') ->nullable() ->searchable() ->reactive() ->options(function (callable $get) { $userHas = Filament::auth()->user()->plant_id; return ($userHas && strlen($userHas) > 0) ? Plant::where('id', $userHas)->pluck('name', 'id')->toArray() : Plant::orderBy('code')->pluck('name', 'id')->toArray(); }) ->afterStateUpdated(function ($state, callable $set, callable $get) { $set('Item', null); $set('Line', null); }), Select::make('Line') ->label('Search by Line Name') ->nullable() ->searchable() ->reactive() ->options(function (callable $get) { $plantId = $get('Plant'); return Line::whereHas('processOrders', function ($query) use ($plantId) { if ($plantId) { $query->where('plant_id', $plantId); } })->pluck('name', 'id'); }) ->afterStateUpdated(function ($state, callable $set, callable $get) { $set('process_order', null); }), Select::make('Item') ->label('Search by Item Code') ->nullable() ->searchable() ->reactive() ->options(function (callable $get) { $plantId = $get('Plant'); return Item::whereHas('processOrders', function ($query) use ($plantId) { if ($plantId) { $query->where('plant_id', $plantId); } })->pluck('code', 'id'); }) ->afterStateUpdated(function ($state, callable $set, callable $get) { $set('process_order', null); }), TextInput::make('process_order') ->label('Process Order') ->reactive() ->placeholder('Enter Process Order') ->afterStateUpdated(function ($state, callable $set, callable $get) { $set('Rework', null); }), TextInput::make('coil_number') ->label('Coil Number') ->reactive() ->placeholder('Enter Coil Number'), TextInput::make('sfg_number') ->label('SFG Number') ->reactive() ->placeholder('Enter SFG Number'), TextInput::make('machine_name') ->label('Machine Name') ->reactive() ->placeholder('Enter Machine Name'), Select::make('rework_status') ->label('Search by Rework Status') ->nullable() ->searchable() ->reactive() ->options([ 1 => 'Yes', 0 => 'No', ]), DateTimePicker::make(name: 'created_from') ->label('Created From') ->placeholder('Select From DateTime') ->reactive() ->native(false), DateTimePicker::make('created_to') ->label('Created To') ->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['process_order']) && Str::length($data['coil_number']) <= 0 && empty($data['sfg_number']) && empty($data['machine_name']) && ($data['rework_status'] == null || $data['rework_status'] == '') && empty($data['created_from']) && empty($data['created_to'])) { return $query->whereRaw('1 = 0'); } if (! empty($data['Plant'])) { $query->where('plant_id', $data['Plant']); } else { $userHas = Filament::auth()->user()->plant_id; if ($userHas && strlen($userHas) > 0) { return $query->whereRaw('1 = 0'); } } if (! empty($data['Line'])) { $query->where('line_id', $data['Line']); } if (! empty($data['Item'])) { $query->where('item_id', $data['Item']); } if (! empty($data['process_order'])) { $query->where('process_order', 'like', '%'.$data['process_order'].'%'); } if (Str::length($data['coil_number']) > 0) { // $query->where('machine_name', $data['machine_name']); $query->where('coil_number', 'like', '%'.$data['coil_number'].'%'); } if (! empty($data['sfg_number'])) { $query->where('sfg_number', 'like', '%'.$data['sfg_number'].'%'); } if (! empty($data['machine_name'])) { // $query->where('machine_name', $data['machine_name']); $query->where('machine_name', 'like', '%'.$data['machine_name'].'%'); } if ($data['rework_status'] != null && $data['rework_status'] != '') { $query->where('rework_status', $data['rework_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'); } else { $userHas = Filament::auth()->user()->plant_id; if ($userHas && strlen($userHas) > 0) { return 'Plant Name: Choose plant to filter records.'; } } if (! empty($data['Line'])) { $indicators[] = 'Line Name: '.Line::where('id', $data['Line'])->value('name'); } if (! empty($data['Item'])) { $indicators[] = 'Item Code: '.Item::where('id', $data['Item'])->value('code'); } if (! empty($data['process_order'])) { $indicators[] = 'Process Order: '.$data['process_order']; } if (Str::length($data['coil_number']) > 0) { $indicators[] = 'Coil Number: '.$data['coil_number']; } if (! empty($data['sfg_number'])) { $indicators[] = 'SFG Number: '.$data['sfg_number']; } if (! empty($data['machine_name'])) { $indicators[] = 'Machine Name: '.$data['machine_name']; } if ($data['rework_status'] != null && $data['rework_status'] != '') { $indicators[] = ($data['rework_status'] == 1) ? 'Rework Status: Yes' : 'Rework Status: No'; } 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([ Tables\Actions\Action::make('reprint_process') ->label('Re-Print Process Order') ->form([ Forms\Components\Section::make() ->schema([ Forms\Components\Select::make('plant') ->label('Select Plant') // ->options(Plant::pluck('name', 'id')->toArray()) ->options(function (callable $get) { $userHas = Filament::auth()->user()->plant_id; return ($userHas && strlen($userHas) > 0) ? Plant::where('id', $userHas)->pluck('name', 'id')->toArray() : Plant::orderBy('code')->pluck('name', 'id')->toArray(); }) ->required() ->reactive() ->afterStateUpdated(function ($state, callable $set, callable $get) { $set('Item', null); $set('process_order', null); $set('coil_number', null); $set('received_quantity', null); $set('machine_name', null); }), Select::make('Item') ->label('Item Code') ->nullable() ->required() ->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); $set('coil_number', null); $set('received_quantity', null); $set('machine_name', null); }), TextInput::make('process_order') ->label('Process Order') ->required() ->placeholder('Enter Process Order') ->reactive() ->afterStateUpdated(function ($state, callable $set, callable $get) { $set('coil_number', null); $set('received_quantity', null); $set('machine_name', null); }), Select::make('coil_number') ->label('Coil Number') ->nullable() ->required() ->searchable() ->options(function (callable $get) { $plantId = $get('plant'); $itemId = $get('Item'); $processOrder = $get('process_order'); if (empty($plantId) || empty($itemId) || empty($processOrder)) { return []; } return ProcessOrder::where('plant_id', $plantId) ->where('item_id', $itemId) ->where('process_order', $processOrder) ->pluck('coil_number', 'coil_number'); // return $plantId ? Item::where('plant_id', $plantId)->pluck('code', 'id') : []; }) ->reactive() ->afterStateUpdated(function ($state, callable $set, callable $get) { $plantId = $get('plant'); $itemId = $get('Item'); $processOrder = $get('process_order'); if (! $plantId || ! $itemId || ! $processOrder || ! $state) { $set('received_quantity', null); $set('machine_name', null); return; } $processOrderData = ProcessOrder::where('plant_id', $plantId) ->where('item_id', $itemId) ->where('process_order', $processOrder) ->where('coil_number', $state) ->first(); $set('received_quantity', $processOrderData?->received_quantity); $set('machine_name', $processOrderData?->machine_name); }), TextInput::make('received_quantity') ->label('Received Quantity') ->readOnly(), TextInput::make('machine_name') ->label('Machine ID') ->readOnly(), ]) ->columns(['default' => 1, 'sm' => 3]), ]) // ->action(function (array $data) { // $selectedPalletNumber = $data['pallet_list']; // return redirect()->route('download-reprint-qr-pdf', ['palletNo' => $selectedPalletNumber]); // }) ->action(function (array $data) { $username = Filament::auth()->user()->name; return redirect()->route('download-reprint-process-pdf', [ 'plant' => $data['plant'], 'item' => $data['Item'], 'process_order' => $data['process_order'], 'coil_number' => $data['coil_number'], 'name' => $username, ]); }) ->visible(function () { return Filament::auth()->user()->can('view reprint process order'); }), ImportAction::make() ->label('Import Process Order') ->color('warning') ->importer(ProcessOrderImporter::class) ->visible(function () { return Filament::auth()->user()->can('view import process order'); }), ExportAction::make() ->label('Export Process Order') ->color('warning') ->exporter(ProcessOrderExporter::class) ->visible(function () { return Filament::auth()->user()->can('view export process order'); }), ]); } public static function getRelations(): array { return [ // ]; } public static function getPages(): array { return [ 'index' => Pages\ListProcessOrders::route('/'), 'create' => Pages\CreateProcessOrder::route('/create'), 'view' => Pages\ViewProcessOrder::route('/{record}'), 'edit' => Pages\EditProcessOrder::route('/{record}/edit'), ]; } public static function getEloquentQuery(): Builder { return parent::getEloquentQuery() ->withoutGlobalScopes([ SoftDeletingScope::class, ]); } }