From 3ec4cd3c3b1ff01a8939684ffef718583e17b653 Mon Sep 17 00:00:00 2001 From: dhanabalan Date: Sat, 31 May 2025 09:39:13 +0530 Subject: [PATCH] Added testing_panel_readings migration, model, resource with dependencies, importer, exporter --- .../Exports/TestingPanelReadingExporter.php | 85 ++ .../Imports/TestingPanelReadingImporter.php | 116 ++ .../Resources/TestingPanelReadingResource.php | 1099 +++++++++++++++++ .../Pages/CreateTestingPanelReading.php | 12 + .../Pages/EditTestingPanelReading.php | 22 + .../Pages/ListTestingPanelReadings.php | 19 + .../Pages/ViewTestingPanelReading.php | 19 + app/Models/TestingPanelReading.php | 89 ++ ...14_create_testing_panel_readings_table.php | 94 ++ 9 files changed, 1555 insertions(+) create mode 100644 app/Filament/Exports/TestingPanelReadingExporter.php create mode 100644 app/Filament/Imports/TestingPanelReadingImporter.php create mode 100644 app/Filament/Resources/TestingPanelReadingResource.php create mode 100644 app/Filament/Resources/TestingPanelReadingResource/Pages/CreateTestingPanelReading.php create mode 100644 app/Filament/Resources/TestingPanelReadingResource/Pages/EditTestingPanelReading.php create mode 100644 app/Filament/Resources/TestingPanelReadingResource/Pages/ListTestingPanelReadings.php create mode 100644 app/Filament/Resources/TestingPanelReadingResource/Pages/ViewTestingPanelReading.php create mode 100644 app/Models/TestingPanelReading.php create mode 100644 database/migrations/2025_05_28_095114_create_testing_panel_readings_table.php diff --git a/app/Filament/Exports/TestingPanelReadingExporter.php b/app/Filament/Exports/TestingPanelReadingExporter.php new file mode 100644 index 000000000..d8018d9ca --- /dev/null +++ b/app/Filament/Exports/TestingPanelReadingExporter.php @@ -0,0 +1,85 @@ +label('ID'), + ExportColumn::make('plant.name'), + ExportColumn::make('line.name'), + ExportColumn::make('item.id'), + ExportColumn::make('machine.name'), + ExportColumn::make('output'), + ExportColumn::make('serial_number'), + ExportColumn::make('before_fr_volt'), + ExportColumn::make('before_fr_cur'), + ExportColumn::make('before_fr_pow'), + ExportColumn::make('before_fr_res_ry'), + ExportColumn::make('before_fr_res_yb'), + ExportColumn::make('before_fr_res_br'), + ExportColumn::make('before_fr_ir'), + ExportColumn::make('before_fr_ir_r'), + ExportColumn::make('before_fr_ir_y'), + ExportColumn::make('before_fr_ir_b'), + ExportColumn::make('before_fr_freq'), + ExportColumn::make('before_fr_speed'), + ExportColumn::make('after_fr_vol'), + ExportColumn::make('after_fr_cur'), + ExportColumn::make('after_fr_pow'), + ExportColumn::make('after_fr_ir_hot'), + ExportColumn::make('after_fr_ir_hot_r'), + ExportColumn::make('after_fr_ir_hot_y'), + ExportColumn::make('after_fr_ir_hot_b'), + ExportColumn::make('after_fr_ir_cool'), + ExportColumn::make('after_fr_ir_cool_r'), + ExportColumn::make('after_fr_ir_cool_y'), + ExportColumn::make('after_fr_ir_cool_b'), + ExportColumn::make('after_fr_freq'), + ExportColumn::make('after_fr_speed'), + ExportColumn::make('after_fr_leak_cur'), + ExportColumn::make('locked_rt_volt'), + ExportColumn::make('locked_rt_cur'), + ExportColumn::make('locked_rt_pow'), + ExportColumn::make('no_load_pickup_volt'), + ExportColumn::make('room_temperature'), + ExportColumn::make('hv_test'), + ExportColumn::make('batch_number'), + ExportColumn::make('batch_count'), + ExportColumn::make('result'), + ExportColumn::make('remark'), + ExportColumn::make('rework_count'), + ExportColumn::make('update_count'), + ExportColumn::make('output_flag'), + ExportColumn::make('pds_status'), + ExportColumn::make('pds_description'), + ExportColumn::make('tested_by'), + ExportColumn::make('updated_by'), + ExportColumn::make('created_at'), + ExportColumn::make('updated_at'), + ExportColumn::make('scanned_at'), + ExportColumn::make('deleted_at'), + ]; + } + + public static function getCompletedNotificationBody(Export $export): string + { + $body = 'Your testing panel reading export has completed and ' . number_format($export->successful_rows) . ' ' . str('row')->plural($export->successful_rows) . ' exported.'; + + if ($failedRowsCount = $export->getFailedRowsCount()) { + $body .= ' ' . number_format($failedRowsCount) . ' ' . str('row')->plural($failedRowsCount) . ' failed to export.'; + } + + return $body; + } +} diff --git a/app/Filament/Imports/TestingPanelReadingImporter.php b/app/Filament/Imports/TestingPanelReadingImporter.php new file mode 100644 index 000000000..bb2427699 --- /dev/null +++ b/app/Filament/Imports/TestingPanelReadingImporter.php @@ -0,0 +1,116 @@ +requiredMapping() + ->relationship() + ->rules(['required']), + ImportColumn::make('line') + ->requiredMapping() + ->relationship() + ->rules(['required']), + ImportColumn::make('item') + ->requiredMapping() + ->relationship() + ->rules(['required']), + ImportColumn::make('machine') + ->requiredMapping() + ->relationship() + ->rules(['required']), + ImportColumn::make('output') + ->requiredMapping() + ->rules(['required']), + ImportColumn::make('serial_number') + ->requiredMapping() + ->rules(['required']), + ImportColumn::make('before_fr_volt'), + ImportColumn::make('before_fr_cur'), + ImportColumn::make('before_fr_pow'), + ImportColumn::make('before_fr_res_ry'), + ImportColumn::make('before_fr_res_yb'), + ImportColumn::make('before_fr_res_br'), + ImportColumn::make('before_fr_ir'), + ImportColumn::make('before_fr_ir_r'), + ImportColumn::make('before_fr_ir_y'), + ImportColumn::make('before_fr_ir_b'), + ImportColumn::make('before_fr_freq'), + ImportColumn::make('before_fr_speed'), + ImportColumn::make('after_fr_vol'), + ImportColumn::make('after_fr_cur'), + ImportColumn::make('after_fr_pow'), + ImportColumn::make('after_fr_ir_hot'), + ImportColumn::make('after_fr_ir_hot_r'), + ImportColumn::make('after_fr_ir_hot_y'), + ImportColumn::make('after_fr_ir_hot_b'), + ImportColumn::make('after_fr_ir_cool'), + ImportColumn::make('after_fr_ir_cool_r'), + ImportColumn::make('after_fr_ir_cool_y'), + ImportColumn::make('after_fr_ir_cool_b'), + ImportColumn::make('after_fr_freq'), + ImportColumn::make('after_fr_speed'), + ImportColumn::make('after_fr_leak_cur'), + ImportColumn::make('locked_rt_volt'), + ImportColumn::make('locked_rt_cur'), + ImportColumn::make('locked_rt_pow'), + ImportColumn::make('no_load_pickup_volt'), + ImportColumn::make('room_temperature'), + ImportColumn::make('hv_test'), + ImportColumn::make('batch_number'), + ImportColumn::make('batch_count') + ->requiredMapping() + ->rules(['required']), + ImportColumn::make('result'), + ImportColumn::make('remark'), + ImportColumn::make('rework_count') + ->requiredMapping() + ->rules(['required']), + ImportColumn::make('update_count') + ->requiredMapping() + ->rules(['required']), + ImportColumn::make('output_flag') + ->requiredMapping() + ->rules(['required']), + ImportColumn::make('pds_status'), + ImportColumn::make('pds_description'), + ImportColumn::make('tested_by'), + ImportColumn::make('updated_by'), + ImportColumn::make('scanned_at') + ->requiredMapping() + ->rules(['required', 'datetime']), + ]; + } + + public function resolveRecord(): ?TestingPanelReading + { + // return TestingPanelReading::firstOrNew([ + // // Update existing records, matching them by `$this->data['column_name']` + // 'email' => $this->data['email'], + // ]); + + return new TestingPanelReading(); + } + + public static function getCompletedNotificationBody(Import $import): string + { + $body = 'Your testing panel reading import has completed and ' . number_format($import->successful_rows) . ' ' . str('row')->plural($import->successful_rows) . ' imported.'; + + if ($failedRowsCount = $import->getFailedRowsCount()) { + $body .= ' ' . number_format($failedRowsCount) . ' ' . str('row')->plural($failedRowsCount) . ' failed to import.'; + } + + return $body; + } +} diff --git a/app/Filament/Resources/TestingPanelReadingResource.php b/app/Filament/Resources/TestingPanelReadingResource.php new file mode 100644 index 000000000..dd273470d --- /dev/null +++ b/app/Filament/Resources/TestingPanelReadingResource.php @@ -0,0 +1,1099 @@ +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() + ->sortable(), + Tables\Columns\TextColumn::make('line.name') + ->label('Line') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('motorTestingMaster.item.code') + ->label('Item Code') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('motorTestingMaster.item.description') + ->label('Model') + ->alignCenter() + ->numeric() + ->sortable(), + Tables\Columns\TextColumn::make('output') + ->label('Output') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('serial_number') + ->label('Serial Number') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('motorTestingMaster.kw') + ->label('KW') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('motorTestingMaster.hp') + ->label('HP') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('motorTestingMaster.phase') + ->label('Phase') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('motorTestingMaster.connection') + ->label('Connection') + ->alignCenter() + ->sortable(), + Tables\Columns\IconColumn::make('motorTestingMaster.isi_model') + ->label('ISI Model') + ->alignCenter() + ->boolean(), + Tables\Columns\TextColumn::make('before_fr_volt') + ->label('Before FR Volt') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_cur') + ->label('Before FR Current') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_pow') + ->label('Before FR Power') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_res_ry') + ->label('Before FR Resistance RY') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_res_yb') + ->label('Before FR Resistance YB') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_res_br') + ->label('Before FR Resistance BR') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_ir') + ->label('Before FR IR') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_ir_r') + ->label('Before FR IR R') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_ir_y') + ->label('Before FR IR Y') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_ir_b') + ->label('Before FR IR B') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_freq') + ->label('Before FR Frequency') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('before_fr_speed') + ->label('Before FR Speed') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_vol') + ->label('After FR Volt') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_cur') + ->label('After FR Current') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_pow') + ->label('After FR Power') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_ir_hot') + ->label('After FR IR Hot') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_ir_hot_r') + ->label('After FR IR Hot R') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_ir_hot_y') + ->label('After FR IR Hot Y') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_ir_hot_b') + ->label('After FR IR Hot B') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_ir_cool') + ->label('After FR IR Cool') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_ir_cool_r') + ->label('After FR IR Cool R') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_ir_cool_y') + ->label('After FR IR Cool Y') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_ir_cool_b') + ->label('After FR IR Cool B') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_freq') + ->label('After FR Frequency') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_speed') + ->label('After FR Speed') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('after_fr_leak_cur') + ->label('After FR Leak Current') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('locked_rt_volt') + ->label('Locked RT Volt') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('locked_rt_cur') + ->label('Locked RT Current') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('locked_rt_pow') + ->label('Locked RT Power') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('no_load_pickup_volt') + ->label('No Load Pickup Volt') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('room_temperature') + ->label('Room Temperature') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('hv_test') + ->label('Hv Test') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('batch_number') + ->label('Batch Number') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('batch_count') + ->label('Batch Count') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('result') + ->label('Result') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('remark') + ->label('Remark') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('rework_count') + ->label('Rework Count') + ->alignCenter() + ->sortable(), + Tables\Columns\TextColumn::make('scanned_at') + ->label('Scanned At') + ->alignCenter() + ->dateTime() + ->sortable(), + Tables\Columns\TextColumn::make('created_at') + ->label('Created At') + ->alignCenter() + ->dateTime() + ->sortable(), + Tables\Columns\TextColumn::make('tested_by') + ->label('Tested By') + ->alignCenter() + ->numeric() + ->sortable(), + Tables\Columns\TextColumn::make('updated_at') + ->label('Updated At') + ->alignCenter() + ->dateTime() + ->sortable(), + Tables\Columns\TextColumn::make('updated_by') + ->label('Updated By') + ->alignCenter() + ->numeric() + ->sortable(), + 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('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, + ]); + } +} diff --git a/app/Filament/Resources/TestingPanelReadingResource/Pages/CreateTestingPanelReading.php b/app/Filament/Resources/TestingPanelReadingResource/Pages/CreateTestingPanelReading.php new file mode 100644 index 000000000..a772cee08 --- /dev/null +++ b/app/Filament/Resources/TestingPanelReadingResource/Pages/CreateTestingPanelReading.php @@ -0,0 +1,12 @@ +belongsTo(Plant::class); + } + + public function line(): BelongsTo + { + return $this->belongsTo(Line::class); + } + public function machine(): BelongsTo + { + return $this->belongsTo(Machine::class); + } + + public function item(): BelongsTo + { + return $this->belongsTo(Item::class); + } + + public function motorTestingMaster() + { + return $this->belongsTo(MotorTestingMaster::class); + } +} diff --git a/database/migrations/2025_05_28_095114_create_testing_panel_readings_table.php b/database/migrations/2025_05_28_095114_create_testing_panel_readings_table.php new file mode 100644 index 000000000..f6ee482fa --- /dev/null +++ b/database/migrations/2025_05_28_095114_create_testing_panel_readings_table.php @@ -0,0 +1,94 @@ +