diff --git a/app/Filament/Exports/ProductionCharacteristicExporter.php b/app/Filament/Exports/ProductionCharacteristicExporter.php new file mode 100644 index 0000000..dbca67b --- /dev/null +++ b/app/Filament/Exports/ProductionCharacteristicExporter.php @@ -0,0 +1,69 @@ +label('NO') + ->state(function ($record) use (&$rowNumber) { + // Increment and return the row number + return ++$rowNumber; + }), + ExportColumn::make('plant.code') + ->label('PLANT CODE'), + ExportColumn::make('line.name') + ->label('LINE NAME'), + ExportColumn::make('item.code') + ->label('ITEM CODE'), + ExportColumn::make('machine.work_center') + ->label('WORK CENTER'), + ExportColumn::make('production_order') + ->label('PRODUCTION ORDER'), + ExportColumn::make('serial_number') + ->label('SERIAL NUMBER'), + ExportColumn::make('characteristic_name') + ->label('CHARACTERISTIC NAME'), + ExportColumn::make('observed_value') + ->label('OBSERVED VALUE'), + ExportColumn::make('status') + ->label('STATUS'), + ExportColumn::make('inspection_status') + ->label('INSPECTION STATUS'), + ExportColumn::make('remark') + ->label('REMARK'), + ExportColumn::make('created_at') + ->label('CREATED AT'), + ExportColumn::make('updated_at') + ->label('UPDATED AT'), + ExportColumn::make('created_by') + ->label('CREATED BY'), + ExportColumn::make('updated_by') + ->label('UPDATED BY'), + ExportColumn::make('deleted_at') + ->label('DELETED AT'), + ]; + } + + public static function getCompletedNotificationBody(Export $export): string + { + $body = 'Your production characteristic 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/ProductionCharacteristicImporter.php b/app/Filament/Imports/ProductionCharacteristicImporter.php new file mode 100644 index 0000000..6814510 --- /dev/null +++ b/app/Filament/Imports/ProductionCharacteristicImporter.php @@ -0,0 +1,65 @@ +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('production_order'), + ImportColumn::make('serial_number'), + ImportColumn::make('characteristic_name'), + ImportColumn::make('observed_value'), + ImportColumn::make('status'), + ImportColumn::make('inspection_status'), + ImportColumn::make('remark'), + ImportColumn::make('created_by'), + ImportColumn::make('updated_by'), + ]; + } + + public function resolveRecord(): ?ProductionCharacteristic + { + // return ProductionCharacteristic::firstOrNew([ + // // Update existing records, matching them by `$this->data['column_name']` + // 'email' => $this->data['email'], + // ]); + + return new ProductionCharacteristic(); + } + + public static function getCompletedNotificationBody(Import $import): string + { + $body = 'Your production characteristic 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; + } +}