schema([ Forms\Components\Select::make('plant_id') ->relationship('plant', 'name') ->required() ->reactive() // When plant changes, reset the dependent fields ->afterStateUpdated(function (callable $set) { $set('line_id', null); $set('item_id', null); $set('machine_id', null); }), Forms\Components\Select::make('line_id') ->label('Line') ->options(function (callable $get) { $plantId = $get('plant_id'); if (!$plantId) { return []; } return Line::where('plant_id', $plantId) ->pluck('name', 'id') ->toArray(); }) ->required() ->reactive() ->afterStateUpdated(fn (callable $set) => $set('item_id', null)), Forms\Components\Select::make('item_id') ->label('Item') ->options(function (callable $get) { $plantId = $get('plant_id'); if (!$plantId) { return []; } // Adjust this query as per your item-plant relationship return Item::where('plant_id', $plantId) ->pluck('code', 'id') ->toArray(); }) ->required() ->searchable() ->reactive(), Forms\Components\Select::make('machine_id') ->label('Machine') ->options(function (callable $get) { $lineId = $get('line_id'); if (!$lineId) { return []; } // Only show machines for the selected line return Machine::where('line_id', $lineId) ->pluck('name', 'id') ->toArray(); }) ->required() ->reactive(), Forms\Components\TextInput::make('output') ->label('Output') ->required(), Forms\Components\TextInput::make('serial_number') ->label('Serial Number') ->required(), Forms\Components\TextInput::make('before_fr_volt') ->label('Before FR Volt'), Forms\Components\TextInput::make('before_fr_cur') ->label('Before FR Current'), Forms\Components\TextInput::make('before_fr_pow') ->label('Before FR Power'), Forms\Components\TextInput::make('before_fr_res_ry') ->label('Before FR Resistance RY'), Forms\Components\TextInput::make('before_fr_res_yb') ->label('Before FR Resistance YB'), Forms\Components\TextInput::make('before_fr_res_br') ->label('Before FR Resistance BR'), Forms\Components\TextInput::make('before_fr_ir') ->label('Before FR IR'), Forms\Components\TextInput::make('before_fr_ir_r') ->label('Before FR IR R'), Forms\Components\TextInput::make('before_fr_ir_y') ->label('Before FR IR Y'), Forms\Components\TextInput::make('before_fr_ir_b') ->label('Before FR IR B'), Forms\Components\TextInput::make('before_fr_freq') ->label('Before FR Frequency'), Forms\Components\TextInput::make('before_fr_speed') ->label('Before FR Speed'), Forms\Components\TextInput::make('after_fr_vol') ->label('After FR Volt'), Forms\Components\TextInput::make('after_fr_cur') ->label('After FR Current'), Forms\Components\TextInput::make('after_fr_pow') ->label('After FR Power'), Forms\Components\TextInput::make('after_fr_ir_hot') ->label('After FR IR Hot'), Forms\Components\TextInput::make('after_fr_ir_hot_r') ->label('After FR IR Hot R'), Forms\Components\TextInput::make('after_fr_ir_hot_y') ->label('After FR IR Hot Y'), Forms\Components\TextInput::make('after_fr_ir_hot_b') ->label('After FR IR Hot B'), Forms\Components\TextInput::make('after_fr_ir_cool') ->label('After FR IR Cool'), Forms\Components\TextInput::make('after_fr_ir_cool_r') ->label('After FR IR Cool R'), Forms\Components\TextInput::make('after_fr_ir_cool_y') ->label('After FR IR Cool Y'), Forms\Components\TextInput::make('after_fr_ir_cool_b') ->label('After FR IR Cool B'), Forms\Components\TextInput::make('after_fr_freq') ->label('After FR Frequency'), Forms\Components\TextInput::make('after_fr_speed') ->label('After FR Speed'), Forms\Components\TextInput::make('after_fr_leak_cur') ->label('After FR Leak Current'), Forms\Components\TextInput::make('locked_rt_volt') ->label('Locked RT Volt'), Forms\Components\TextInput::make('locked_rt_cur') ->label('Locked RT Current'), Forms\Components\TextInput::make('locked_rt_pow') ->label('Locked RT Power'), Forms\Components\TextInput::make('no_load_pickup_volt') ->label('No Load Pickup Volt'), Forms\Components\TextInput::make('room_temperature') ->label('Room Temperature'), Forms\Components\TextInput::make('hv_test') ->label('HV Test'), Forms\Components\TextInput::make('batch_number') ->label('Batch Number'), Forms\Components\TextInput::make('batch_count') ->label('Batch Count') ->default('0'), Forms\Components\TextInput::make('result') ->label('Result'), Forms\Components\TextInput::make('remark') ->label('Remark'), Forms\Components\TextInput::make('rework_count') ->label('Rework Count') ->default('0'), Forms\Components\TextInput::make('update_count') ->label('Update Count') ->default('0'), Forms\Components\TextInput::make('output_flag') ->label('Output Flag') ->default('0'), Forms\Components\TextInput::make('tested_by') ->label('Tested By'), Forms\Components\TextInput::make('updated_by') ->label('Updated By'), ]); } public static function table(Table $table): Table { return $table ->columns([ // Tables\Columns\TextColumn::make('id') // ->label('ID') // ->numeric() // ->sortable(), 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(), Tables\Columns\TextColumn::make('line.name') ->label('Line') ->alignCenter(), Tables\Columns\TextColumn::make('motorTestingMaster.item.code') ->label('Item Code') ->alignCenter(), Tables\Columns\TextColumn::make('motorTestingMaster.item.description') ->label('Model') ->alignCenter(), Tables\Columns\TextColumn::make('output') ->label('Output') ->alignCenter(), Tables\Columns\TextColumn::make('serial_number') ->label('Serial Number') ->alignCenter() ->sortable(), Tables\Columns\TextColumn::make('motorTestingMaster.kw') ->label('KW') ->alignCenter(), Tables\Columns\TextColumn::make('motorTestingMaster.hp') ->label('HP') ->alignCenter(), Tables\Columns\TextColumn::make('motorTestingMaster.phase') ->label('Phase') ->alignCenter(), Tables\Columns\TextColumn::make('motorTestingMaster.connection') ->label('Connection') ->alignCenter(), Tables\Columns\IconColumn::make('motorTestingMaster.isi_model') ->label('ISI Model') ->alignCenter() ->boolean(), Tables\Columns\TextColumn::make('before_fr_volt') ->label('Before FR Volt') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_cur') ->label('Before FR Current') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_pow') ->label('Before FR Power') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_res_ry') ->label('Before FR Resistance RY') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_res_yb') ->label('Before FR Resistance YB') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_res_br') ->label('Before FR Resistance BR') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_ir') ->label('Before FR IR') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_ir_r') ->label('Before FR IR R') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_ir_y') ->label('Before FR IR Y') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_ir_b') ->label('Before FR IR B') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_freq') ->label('Before FR Frequency') ->alignCenter(), Tables\Columns\TextColumn::make('before_fr_speed') ->label('Before FR Speed') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_vol') ->label('After FR Volt') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_cur') ->label('After FR Current') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_pow') ->label('After FR Power') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_ir_hot') ->label('After FR IR Hot') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_ir_hot_r') ->label('After FR IR Hot R') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_ir_hot_y') ->label('After FR IR Hot Y') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_ir_hot_b') ->label('After FR IR Hot B') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_ir_cool') ->label('After FR IR Cool') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_ir_cool_r') ->label('After FR IR Cool R') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_ir_cool_y') ->label('After FR IR Cool Y') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_ir_cool_b') ->label('After FR IR Cool B') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_freq') ->label('After FR Frequency') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_speed') ->label('After FR Speed') ->alignCenter(), Tables\Columns\TextColumn::make('after_fr_leak_cur') ->label('After FR Leak Current') ->alignCenter(), Tables\Columns\TextColumn::make('locked_rt_volt') ->label('Locked RT Volt') ->alignCenter(), Tables\Columns\TextColumn::make('locked_rt_cur') ->label('Locked RT Current') ->alignCenter(), Tables\Columns\TextColumn::make('locked_rt_pow') ->label('Locked RT Power') ->alignCenter(), Tables\Columns\TextColumn::make('no_load_pickup_volt') ->label('No Load Pickup Volt') ->alignCenter(), Tables\Columns\TextColumn::make('room_temperature') ->label('Room Temperature') ->alignCenter(), Tables\Columns\TextColumn::make('hv_test') ->label('Hv Test') ->alignCenter(), Tables\Columns\TextColumn::make('batch_number') ->label('Batch Number') ->alignCenter(), Tables\Columns\TextColumn::make('batch_count') ->label('Batch Count') ->alignCenter(), Tables\Columns\TextColumn::make('result') ->label('Result') ->alignCenter(), Tables\Columns\TextColumn::make('remark') ->label('Remark') ->alignCenter(), Tables\Columns\TextColumn::make('update_count') ->label('Updated Count') ->alignCenter(), Tables\Columns\TextColumn::make('rework_count') ->label('Rework Count') ->alignCenter(), Tables\Columns\TextColumn::make('scanned_at') ->label('Scanned At') ->alignCenter() ->sortable() ->dateTime(), Tables\Columns\TextColumn::make('created_at') ->label('Created At') ->alignCenter() ->dateTime() ->sortable(), Tables\Columns\TextColumn::make('tested_by') ->label('Tested By') ->alignCenter() ->numeric(), Tables\Columns\TextColumn::make('updated_at') ->label('Updated At') ->alignCenter() ->sortable() ->dateTime(), Tables\Columns\TextColumn::make('updated_by') ->label('Updated By') ->alignCenter() ->numeric(), Tables\Columns\TextColumn::make('deleted_at') ->label('Deleted At') ->alignCenter() ->sortable() ->dateTime() ->toggleable(isToggledHiddenByDefault: true), ]) ->filters([ Tables\Filters\TrashedFilter::make(), Filter::make('advanced_filters') ->label('Advanced Filters') ->form([ Select::make('Plant') ->label('Select Plant') ->nullable() ->options(function () { return Plant::pluck('name', 'id'); }) ->reactive() ->afterStateUpdated(function ($state, callable $set, callable $get) { $set('Line', null); $set('item_code', null); }), Select::make('Line') ->label('Select Line') ->nullable() ->options(function (callable $get) { $plantId = $get('Plant'); if (!$plantId) { return []; } return Line::where('plant_id', $plantId) ->pluck('name', 'id') ->toArray(); }) ->reactive() ->afterStateUpdated(function ($state, callable $set, callable $get) { $set('item_code', null); }), Select::make('item_code') ->label('Item Code') ->searchable() ->options(function (callable $get) { $plantId = $get('Plant'); $query = Item::query(); if ($plantId) { $query->where('plant_id', $plantId); } return $query->pluck('code', 'id')->toArray(); }) ->reactive(), Select::make('machine_name') ->label('Machine Name') ->options(function (callable $get) { $plantId = $get('Plant'); $lineId = $get('Line'); if (!$plantId || !$lineId) { return []; } return Machine::where('plant_id', $plantId) ->where('line_id', $lineId) ->pluck('name', 'id') ->toArray(); }) ->reactive(), TextInput::make('serial_number') ->label('Serial Number') ->reactive() ->placeholder(placeholder: 'Enter Serial Number'), Select::make('item_description') ->label('Model') ->searchable() ->options(function (callable $get) { $plantId = $get('Plant'); $query = Item::query(); if ($plantId) { $query->where('plant_id', $plantId); } return $query->pluck('description', 'description')->toArray(); }) ->reactive(), Select::make('output') ->label('Output') ->searchable() ->options(function () { return TestingPanelReading::query() ->select('output') ->distinct() ->whereNotNull('output') ->orderBy('output') ->pluck('output', 'output') // key and label are both the output value ->toArray(); }) ->reactive(), // TextInput::make('phase') // ->label('Phase'), // Select::make('phase') // ->label('Phase') // ->searchable() // ->options(function (callable $get) { // $plantId = $get('Plant'); // $lineId = $get('Line'); // // if (!$plantId || !$lineId) // // { // // return []; // // } // if ($plantId && $lineId) // { // return Configuration::where('plant_id', $plantId) // ->where('line_id', $lineId) // ->where('c_name', 'MOTOR_PHASE') // ->pluck('c_value', 'id') // ->toArray(); // } // else // { // return Configuration::where('c_name', 'MOTOR_PHASE') // ->pluck('c_value', 'c_value') // ->toArray(); // } // }) // ->reactive(), //... Select::make('connection') ->label('Connection') ->required() ->default('Star') ->options(function (callable $get) { $plantId = $get('Plant'); if ($plantId) { return Configuration::where('plant_id', $plantId) ->where('c_name', 'MOTOR_CONNECTION') ->pluck('c_value', 'id') ->toArray(); } else { return Configuration::where('c_name', 'MOTOR_CONNECTION') ->pluck('c_value', 'c_value') ->toArray(); } }) ->selectablePlaceholder(false) ->reactive(), //.. TextInput::make('remark') ->label('Remark') ->reactive(), TextInput::make('batch_number') ->label('Batch Number') ->reactive() ->placeholder(placeholder: 'Enter Batch Number'), Select::make('result') ->label('Result') ->searchable() ->options(function () { return TestingPanelReading::query() ->whereNotNull('result') ->pluck('result') // just get the column ->unique() ->filter() // filters out nulls and empty automatically ->mapWithKeys(fn ($value) => [$value => $value]) ->toArray(); }) ->reactive(), 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) { // dd($data); // Hide all records initially if no filters are applied if (empty($data['Plant']) && empty($data['Line']) && empty($data['item_code']) && empty($data['machine_name']) && empty($data['item_description']) && empty($data['serial_number']) && empty($data['output']) && empty($data['phase']) && empty($data['connection']) && empty($data['remark']) && empty($data['batch_no'])&& empty($data['result']) && empty($data['created_from']) && empty($data['created_to'])) { return $query->whereRaw('1 = 0'); } // if (empty($data['Plant']) && empty($data['Line']) && empty($data['item_code']) && empty($data['machine_name']) && empty($data['item_description']) && empty($data['serial_number']) && empty($data['output']) && empty($data['phase']) && !empty($data['connection']) && empty($data['remark']) && empty($data['batch_no'])&& empty($data['result']) && 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_code'])) { // $query->where('item_id', $data['item_code']); $query->whereHas('motorTestingMaster', function ($subQuery) use ($data) { $subQuery->where('item_id', $data['item_code']); }); } if (!empty($data['machine_name'])) { $query->where('machine_id', $data['machine_name']); } if (!empty($data['serial_number'])) { $query->where('serial_number', $data['serial_number']); } if (!empty($data['item_description'])) { $item = Item::where('description', $data['item_description'])->first(); if ($item) { $query->whereHas('motorTestingMaster', function ($subQuery) use ($item) { $subQuery->where('item_id', $item->id); }); } else { $query->whereRaw('1 = 0'); } } if (!empty($data['output'])) { $query->where('output',$data['output']); } // if (!empty($data['phase'])) // { // //$query->where('phase',$data['phase']); // $query->whereHas('motorTestingMaster', function ($subQuery) use ($data) { // $subQuery->where('phase', $data['phase']); // }); // } if (!empty($data['connection'])) { //$query->where('connection',$data['connection']); $query->whereHas('motorTestingMaster', function ($subQuery) use ($data) { $subQuery->where('connection', $data['connection']); }); } if (!empty($data['remark'])) { $query->where('remark',$data['remark']); } if (!empty($data['batch_number'])) { $query->where('batch_number',$data['batch_number']); } if (!empty($data['result'])) { $query->where('result', $data['result']); } if (!empty($data['created_from'])) { $query->where('created_at', '>=', $data['created_from']); } if (!empty($data['created_to'])) { $query->where('created_at', '<=', $data['created_to']); } }) ->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_code'])) { $indicators[] = 'Item Code: ' . Item::where('id', $data['item_code'])->value('code'); } if (!empty($data['machine_name'])) { $indicators[] = 'Machine: ' . Machine::where('id', $data['machine_name'])->value('name'); } if (!empty($data['output'])) { $indicators[] = 'Output: ' . $data['output']; } if (!empty($data['item_description'])) { $indicators[] = 'Model: ' . $data['item_description']; } // if (!empty($data['phase'])) { // $indicators[] = 'Phase: ' . $data['phase']; // } // if (!empty($data['connection'])) { // $indicators[] = 'Connection: ' . $data['connection']; // } if (!empty($data['remark'])) { $indicators[] = 'Remark: ' . $data['remark']; } if (!empty($data['batch_number'])) { $indicators[] = 'Batch Number: ' . $data['batch_number']; } if (!empty($data['result'])) { $indicators[] = 'Result: ' . $data['result']; } if (!empty($data['serial_number'])) { $indicators[] = 'Serial Number: ' . $data['serial_number']; } 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(), BulkAction::make('export_pdf') ->label('Export Readings PDF') ->action(function ($records) { //$records->load('item'); $records->load('motorTestingMaster.item'); $plantId = $records->first()?->plant_id; $plant = $plantId ? Plant::find($plantId) : null; // Check if all records are Star-Delta type $isAllStarDelta = $records->every(function ($record) { return $record->motorTestingMaster?->connection === 'Star-Delta'; }); // $hasStarDelta = $records->contains(function ($record) { // return $record->motorTestingMaster?->connection === 'Star-Delta'; // }); //dd($isAllStarDelta); if(!$isAllStarDelta) { $mappedData = collect($records)->map(function ($record) { return [ 'Date' => $record['created_at'] ?? '', 'Output' => $record['output'] ?? '', 'Motor SNo' => $record['serial_number'] ?? '', 'Item Code' => $record->motorTestingMaster->item->code ?? '', 'Motor Type' => $record->motorTestingMaster->item->description ?? '', 'kw' => $record->motorTestingMaster->kw ?? '', 'hp' => $record->motorTestingMaster->hp ?? '', 'phase' => $record->motorTestingMaster->phase ?? '', 'isi_model' => $record->motorTestingMaster->isi_model ?? '', // BEFORE FREE RUN 'Voltage_Before' => $record['before_fr_volt'] ?? '', 'Current_Before' => $record['before_fr_cur'] ?? '', 'Power_Before' => $record['before_fr_pow'] ?? '', 'Resistance_RY' => $record['before_fr_res_ry'] ?? '', 'Resistance_YB' => $record['before_fr_res_yb'] ?? '', 'Resistance_BR' => $record['before_fr_res_br'] ?? '', 'Insulation_Resistance' => $record['before_fr_ir'] ?? '', 'Frequency_Before' => $record['before_fr_freq'] ?? '', 'Speed_Before' => $record['before_fr_speed'] ?? '', // AFTER FREE RUN 'Voltage_After' => $record['after_fr_vol'] ?? '', 'Current_After' => $record['after_fr_cur'] ?? '', 'Power_After' => $record['after_fr_pow'] ?? '', 'IR_Hot' => $record['after_fr_ir_hot'] ?? '', 'IR_Cool' => $record['after_fr_ir_cool'] ?? '', 'Leakage_Current' => $record['after_fr_leak_cur'] ?? '', 'Frequency_After' => $record['after_fr_freq'] ?? '', 'Speed_After' => $record['after_fr_speed'] ?? '', // LOCKED ROTOR TEST 'Voltage_Locked' => $record['locked_rt_volt'] ?? '', 'Current_Locked' => $record['locked_rt_cur'] ?? '', 'Power_Locked' => $record['locked_rt_pow'] ?? '', // Last 8 columns 'No_Load_Pickup_Voltage' => $record['no_load_pickup_volt'] ?? '', 'Room_Temp' => $record['room_temperature'] ?? '', 'High_Voltage_Test' => $record['hv_test'] ?? '', 'Batch_Number' => $record['batch_number'] ?? '', 'Batch_Count' => $record['batch_count'] ?? '', 'Result' => $record['result'] ?? '', 'Remark' => $record['remark'] ?? '', 'Tested_By' => $record['tested_by'] ?? '', ]; }); } else { $mappedData = collect($records)->map(function ($record) { return [ 'Date' => $record['created_at'] ?? '', 'Output' => $record['output'] ?? '', 'Motor SNo' => $record['serial_number'] ?? '', 'Item Code' => $record->motorTestingMaster->item->code ?? '', 'Motor Type' => $record->motorTestingMaster->item->description ?? '', 'kw' => $record->motorTestingMaster->kw ?? '', 'hp' => $record->motorTestingMaster->hp ?? '', 'phase' => $record->motorTestingMaster->phase ?? '', 'isi_model' => $record->motorTestingMaster->isi_model ?? '', // BEFORE FREE RUN 'Voltage_Before' => $record['before_fr_volt'] ?? '', 'Current_Before' => $record['before_fr_cur'] ?? '', 'Power_Before' => $record['before_fr_pow'] ?? '', 'Resistance_RY' => $record['before_fr_res_ry'] ?? '', 'Resistance_YB' => $record['before_fr_res_yb'] ?? '', 'Resistance_BR' => $record['before_fr_res_br'] ?? '', 'Insulation_Resistance_R' => $record['before_fr_ir_r'] ?? '', 'Insulation_Resistance_Y' => $record['before_fr_ir_y'] ?? '', 'Insulation_Resistance_B' => $record['before_fr_ir_b'] ?? '', 'Frequency_Before' => $record['before_fr_freq'] ?? '', 'Speed_Before' => $record['before_fr_speed'] ?? '', // AFTER FREE RUN 'Voltage_After' => $record['after_fr_vol'] ?? '', 'Current_After' => $record['after_fr_cur'] ?? '', 'Power_After' => $record['after_fr_pow'] ?? '', 'IR_Hot_R' => $record['after_fr_ir_hot_r'] ?? '', 'IR_Hot_Y' => $record['after_fr_ir_hot_y'] ?? '', 'IR_Hot_B' => $record['after_fr_ir_hot_b'] ?? '', 'IR_Cool_R' => $record['after_fr_ir_cool_r'] ?? '', 'IR_Cool_Y' => $record['after_fr_ir_cool_y'] ?? '', 'IR_Cool_B' => $record['after_fr_ir_cool_b'] ?? '', 'Leakage_Current' => $record['after_fr_leak_cur'] ?? '', 'Frequency_After' => $record['after_fr_freq'] ?? '', 'Speed_After' => $record['after_fr_speed'] ?? '', // LOCKED ROTOR TEST 'Voltage_Locked' => $record['locked_rt_volt'] ?? '', 'Current_Locked' => $record['locked_rt_cur'] ?? '', 'Power_Locked' => $record['locked_rt_pow'] ?? '', // Last 8 columns 'No_Load_Pickup_Voltage' => $record['no_load_pickup_volt'] ?? '', 'Room_Temp' => $record['room_temperature'] ?? '', 'High_Voltage_Test' => $record['hv_test'] ?? '', 'Batch_Number' => $record['batch_number'] ?? '', 'Batch_Count' => $record['batch_count'] ?? '', 'Result' => $record['result'] ?? '', 'Remark' => $record['remark'] ?? '', 'Tested_By' => $record['tested_by'] ?? '', ]; }); } $view = $isAllStarDelta ? 'exports.export-three-phase-pdf' : 'exports.testingpanel-pdf'; $pdf = Pdf::loadView($view, [ 'records' => $mappedData, 'plant' => $plant, ]); // $pdf = Pdf::loadView('exports.testingpanel-pdf',[ // // ['records' => $mappedData] // 'records' => $mappedData, // 'plant' => $plant, // ]); return response()->streamDownload( fn () => print($pdf->stream()), 'TestingPanelReading.pdf' ); }) ->icon('heroicon-o-document-arrow-down'), BulkAction::make('export_isi_pdf') ->label('Export ISI Readings PDF') ->action(function ($records) { $records->load('motorTestingMaster.item'); $plantId = $records->first()?->plant_id; $plant = $plantId ? Plant::find($plantId) : null; $isAllStarDelta = $records->every(function ($record) { return $record->motorTestingMaster?->connection === 'Star-Delta'; }); // $hasStarDelta = $records->contains(function ($record) { // return $record->motorTestingMaster?->connection === 'Star-Delta'; // }); //dd($isAllStarDelta); if(!$isAllStarDelta) { $mappedData = collect($records)->map(function ($record) { return [ 'Date' => $record['created_at'] ?? '', 'Output' => $record['output'] ?? '', 'Motor SNo' => $record['serial_number'] ?? '', 'Item Code' => $record->motorTestingMaster->item->code ?? '', 'Motor Type' => $record->motorTestingMaster->item->description ?? '', 'kw' => $record->motorTestingMaster->kw ?? '', 'hp' => $record->motorTestingMaster->hp ?? '', 'phase' => $record->motorTestingMaster->phase ?? '', 'isi_model' => $record->motorTestingMaster->isi_model ?? '', // AFTER FREE RUN 'Voltage_After' => $record['after_fr_vol'] ?? '', 'Current_After' => $record['after_fr_cur'] ?? '', 'Power_After' => $record['after_fr_pow'] ?? '', 'IR_Hot' => $record['after_fr_ir_hot'] ?? '', 'IR_Cool' => $record['after_fr_ir_cool'] ?? '', 'Leakage_Current' => $record['after_fr_leak_cur'] ?? '', 'Frequency_After' => $record['after_fr_freq'] ?? '', 'Speed_After' => $record['after_fr_speed'] ?? '', // LOCKED ROTOR TEST 'Voltage_Locked' => $record['locked_rt_volt'] ?? '', 'Current_Locked' => $record['locked_rt_cur'] ?? '', 'Power_Locked' => $record['locked_rt_pow'] ?? '', // Last 8 columns 'No_Load_Pickup_Voltage' => $record['no_load_pickup_volt'] ?? '', 'Room_Temp' => $record['room_temperature'] ?? '', 'High_Voltage_Test' => $record['hv_test'] ?? '', 'Result' => $record['result'] ?? '', 'Remark' => $record['remark'] ?? '', ]; }); } else { $mappedData = collect($records)->map(function ($record) { return [ 'Date' => $record['created_at'] ?? '', 'Output' => $record['output'] ?? '', 'Motor SNo' => $record['serial_number'] ?? '', 'Item Code' => $record->motorTestingMaster->item->code ?? '', 'Motor Type' => $record->motorTestingMaster->item->description ?? '', 'kw' => $record->motorTestingMaster->kw ?? '', 'hp' => $record->motorTestingMaster->hp ?? '', 'phase' => $record->motorTestingMaster->phase ?? '', 'isi_model' => $record->motorTestingMaster->isi_model ?? '', // AFTER FREE RUN 'Voltage_After' => $record['after_fr_vol'] ?? '', 'Current_After' => $record['after_fr_cur'] ?? '', 'Power_After' => $record['after_fr_pow'] ?? '', 'IR_Hot_R' => $record['after_fr_ir_hot_r'] ?? '', 'IR_Hot_Y' => $record['after_fr_ir_hot_y'] ?? '', 'IR_Hot_B' => $record['after_fr_ir_hot_b'] ?? '', 'IR_Cool_R' => $record['after_fr_ir_cool_r'] ?? '', 'IR_Cool_Y' => $record['after_fr_ir_cool_y'] ?? '', 'IR_Cool_B' => $record['after_fr_ir_cool_b'] ?? '', 'Leakage_Current' => $record['after_fr_leak_cur'] ?? '', 'Frequency_After' => $record['after_fr_freq'] ?? '', 'Speed_After' => $record['after_fr_speed'] ?? '', // LOCKED ROTOR TEST 'Voltage_Locked' => $record['locked_rt_volt'] ?? '', 'Current_Locked' => $record['locked_rt_cur'] ?? '', 'Power_Locked' => $record['locked_rt_pow'] ?? '', // Last 8 columns 'No_Load_Pickup_Voltage' => $record['no_load_pickup_volt'] ?? '', 'Room_Temp' => $record['room_temperature'] ?? '', 'High_Voltage_Test' => $record['hv_test'] ?? '', 'Result' => $record['result'] ?? '', 'Remark' => $record['remark'] ?? '', ]; }); } $view = $isAllStarDelta ? 'exports.export-isi-three-phase-pdf' : 'exports.export-isi-pdf'; $pdf = Pdf::loadView($view, [ 'records' => $mappedData, 'plant' => $plant, ]); // $pdf = Pdf::loadView('exports.export-isi-pdf',[ // // ['records' => $mappedData] // 'records' => $mappedData, // 'plant' => $plant, // ]); return response()->streamDownload( fn () => print($pdf->stream()), 'TestingPanelReading.pdf' ); }) ->icon('heroicon-o-document-arrow-down'), ]), ]) ->headerActions([ ImportAction::make() ->importer(TestingPanelReadingImporter::class) ->visible(function() { return Filament::auth()->user()->can('view import testing panel reading'); }), ExportAction::make() ->exporter(TestingPanelReadingExporter::class) ->visible(function() { return Filament::auth()->user()->can('view export testing panel reading'); }), ]); } public static function getRelations(): array { return [ // ]; } public static function getPages(): array { return [ 'index' => Pages\ListTestingPanelReadings::route('/'), 'create' => Pages\CreateTestingPanelReading::route('/create'), 'view' => Pages\ViewTestingPanelReading::route('/{record}'), 'edit' => Pages\EditTestingPanelReading::route('/{record}/edit'), ]; } public static function getEloquentQuery(): Builder { return parent::getEloquentQuery() ->withoutGlobalScopes([ SoftDeletingScope::class, ]); } }