products_sku; $articles = []; Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp/Схемы сборки/'); foreach ($products_sku as $sku) { if (!in_array($sku->product->article, $articles)) { $articles[] = $sku->product->article; // find and copy scheme files to installation directory if (file_exists($techDocsPath . $sku->product->article . '/')) { foreach (Storage::disk('base')->allFiles('tech-docs/' . $sku->product->article) as $p) { $content = Storage::disk('base')->get($p); Storage::disk('public')->put('orders/' . $order->id . '/tmp/Схемы сборки/' . basename($p), $content); } } } } // generate xlsx order file $this->generateOrderForMount($order); // create zip archive $fileModel = (new FileService())->createZipArchive('orders/' . $order->id . '/tmp', self::INSTALL_FILENAME . $order->common_name . '.zip', $userId); // remove temp files Storage::disk('public')->deleteDirectory('orders/' . $order->id . '/tmp'); $order->documents()->syncWithoutDetaching($fileModel); // return link return $fileModel?->link ?? ''; } private function generateOrderForMount(Order $order): void { $inputFileType = 'Xlsx'; // Xlsx - Xml - Ods - Slk - Gnumeric - Csv $inputFileName = './templates/OrderForMount.xlsx'; $reader = IOFactory::createReader($inputFileType); $spreadsheet = $reader->load($inputFileName); $sheet = $spreadsheet->getActiveSheet(); // менеджер $sheet->setCellValue('F8', $order->user->name); $sheet->setCellValue('X8', $order->user->phone); // округ и район $sheet->setCellValue('L10', $order->district->shortname); $sheet->setCellValue('W10', $order->area->name); if ($order->area->responsible) { // ответственный $sheet->setCellValue('C12', $order->area->responsible?->name . ', ' . $order->area->responsible?->phone . ', ' . $order->area->responsible?->post); } else { $sheet->setCellValue('C12', ''); } // адрес $sheet->setCellValue('L14', $order->object_address); $str = Str::replace('
', '', $order->products_with_count); $str = Str::replace('
', "\n", $str); // мафы $sheet->setCellValue('G33', Str::trim($str)); // $fileName = 'Заявка на монтаж - ' . $order->object_address . '.xlsx'; $writer = new Xlsx($spreadsheet); Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp'); $writer->save(storage_path('app/public/orders/') . $order->id . '/tmp/' . $fileName); } /** * @throws Exception */ public function generateHandoverPack(Order $order, int $userId): string { $articles = []; Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp/ПАСПОРТ/'); Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp/СЕРТИФИКАТ/'); Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp/ФОТО ПСТ/'); Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp/ФОТО ТН/'); // copy app photos foreach ($order->photos as $photo) { $from = $photo->path; $to = 'orders/' . $order->id . '/tmp/ФОТО ПСТ/' . $photo->original_name; if (!Storage::disk('public')->exists($to)) { Storage::disk('public')->copy($from, $to); } } foreach ($order->products_sku as $sku) { // copy certificates if ($sku->product->certificate_id) { $from = $sku->product->certificate->path; $to = 'orders/' . $order->id . '/tmp/СЕРТИФИКАТ/' . $sku->product->certificate->original_name; if (!Storage::disk('public')->exists($to)) { Storage::disk('public')->copy($from, $to); } } // copy passport if ($sku->passport_id) { $from = $sku->passport->path; $to = 'orders/' . $order->id . '/tmp/ПАСПОРТ/'; if (!Storage::disk('public')->exists($to . $sku->passport->original_name)) { $f = Storage::disk('public')->get($from); $ext = \File::extension($sku->passport->original_name); $targetName = $to . 'Паспорт ' . $sku->factory_number . ' арт. ' . $sku->product->article . '.' . $ext; Storage::disk('public')->put($targetName, $f); } } } // generate xlsx order files $this->generateStatement($order); $this->generateQualityDeclaration($order); $this->generateInventory($order); $this->generatePassport($order); // create zip archive $fileModel = (new FileService())->createZipArchive('orders/' . $order->id . '/tmp', self::HANDOVER_FILENAME . $order->common_name . '.zip', $userId); // remove temp files Storage::disk('public')->deleteDirectory('orders/' . $order->id . '/tmp'); $order->documents()->syncWithoutDetaching($fileModel); // return link return $fileModel?->link ?? ''; } private function generateStatement(Order $order): void { $inputFileType = 'Xlsx'; $inputFileName = './templates/Statement.xlsx'; $reader = IOFactory::createReader($inputFileType); $spreadsheet = $reader->load($inputFileName); $sheet = $spreadsheet->getActiveSheet(); $contract = Contract::query()->where('contracts.year', $order->year)->first(); $contract_number = $contract->contract_number ?? 'заполнить договор за ' . $order->year . ' год!'; $contract_date = DateHelper::getHumanDate($contract->contract_date ?? '1970-01-01', true); $s = 'по Договору №' . $contract_number . ' от ' . $contract_date . ' г. Между ГБУ "Мосремонт" и ООО "НАШ ДВОР-СТ"'; $sheet->setCellValue('B5', $s); // менеджер $sheet->setCellValue('G21', $order->user->name); // округ и район $sheet->setCellValue('C6', $order->district->shortname); $sheet->setCellValue('F6', $order->area->name); $i = 9; // start of table $nn = 1; // string number foreach ($order->products_sku as $sku) { if ($nn > 1) { // inset row $sheet->insertNewRowBefore($i); } $sheet->setCellValue('A' . $i, $nn++); $sheet->setCellValue('B' . $i, $sku->product->statement_name); $sheet->setCellValue('C' . $i, $sku->product->passport_name); $sheet->setCellValue('D' . $i, 'шт'); $sheet->setCellValue('E' . $i, '1'); $sheet->setCellValue('F' . $i, $order->name); $sheet->setCellValue('G' . $i, $sku->factory_number); $sheet->setCellValue('H' . $i++, $sku->rfid); } // save file $fileName = '1.Ведомость.xlsx'; $writer = new Xlsx($spreadsheet); Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp'); $writer->save(storage_path('app/public/orders/') . $order->id . '/tmp/' . $fileName); } private function generateQualityDeclaration(Order $order): void { $inputFileType = 'Xlsx'; $inputFileName = './templates/QualityDeclaration.xlsx'; $reader = IOFactory::createReader($inputFileType); $spreadsheet = $reader->load($inputFileName); $sheet = $spreadsheet->getActiveSheet(); $address = 'г. Москва, ' . $order->district->shortname . ', район ' . $order->area->name . ', по адресу: ' . $order->object_address; $i = 1; // start of table $n = 1; foreach ($order->products_sku as $sku) { if ($n++ > 1) { $range = 'A' . $i . ':I' . $i + 56; $i = $i + 57; ExcelHelper::copyRows($sheet, $range, 'A' . $i); // add header img $drawing = new Drawing(); $drawing->setName('Header'); $drawing->setDescription('Header'); $drawing->setPath('templates/header.png'); $drawing->setCoordinates('A' . $i); $drawing->setOffsetX(16); $drawing->setOffsetY(8); $drawing->setResizeProportional(true); $drawing->setWidth(680); $drawing->setWorksheet($sheet); } // document date? $sheet->setCellValue('A' . $i + 7, DateHelper::getHumanDate(date('Y-m-d'), true)); $sheet->setCellValue('B' . $i + 16, $sku->product->passport_name); $sheet->setCellValue('C' . $i + 18, $sku->rfid); $sheet->setCellValue('C' . $i + 20, $address); // add page break and copy prev page } // save file $fileName = '2.Декларация качества.xlsx'; $writer = new Xlsx($spreadsheet); Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp'); $writer->save(storage_path('app/public/orders/') . $order->id . '/tmp/' . $fileName); } private function generateInventory(Order $order): void { $inputFileType = 'Xlsx'; $inputFileName = './templates/Inventory.xlsx'; $reader = IOFactory::createReader($inputFileType); $spreadsheet = $reader->load($inputFileName); $sheet = $spreadsheet->getActiveSheet(); $address = 'Округ: ' . $order->district->shortname . ' Район ' . $order->area->name; $sheet->setCellValue('C4', $order->name); $sheet->setCellValue('C5', $address); $sheet->setCellValue('C13', $order->user->name); $i = 8; // start of table $n = 1; foreach ($order->products_sku as $sku) { if ($n++ > 1) { $sheet->insertNewRowBefore($i + 3, 3); $range = 'A' . $i . ':E' . $i + 2; $i = $i + 3; ExcelHelper::copyRows($sheet, $range, 'A' . $i); } $sheet->setCellValue('A' . $i, $n - 1); $sheet->setCellValue('B' . $i, $sku->product->passport_name); $sheet->setCellValue('B' . $i + 2, $sku->rfid); } // save file $fileName = '3.Опись.xlsx'; $writer = new Xlsx($spreadsheet); Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp'); $writer->save(storage_path('app/public/orders/') . $order->id . '/tmp/' . $fileName); } private function generatePassport(Order $order): void { $inputFileType = 'Xlsx'; $inputFileName = './templates/Passport.xlsx'; $reader = IOFactory::createReader($inputFileType); $spreadsheet = $reader->load($inputFileName); $sheet = $spreadsheet->getActiveSheet(); $i = 3; // start of table $n = 1; foreach ($order->products_sku as $sku) { if ($n++ > 1) { $sheet->insertNewRowBefore($i + 1, 1); $range = 'A' . $i . ':J' . $i; $i++; ExcelHelper::copyRows($sheet, $range, 'A' . $i); } $sheet->setCellValue('A' . $i, $n - 1); $sheet->setCellValue('B' . $i, $sku->product->passport_name); $sheet->setCellValue('C' . $i, $sku->product->type_tz); $sheet->setCellValue('D' . $i, $sku->rfid); $sheet->setCellValue('E' . $i, $sku->product->certificate_number); $sheet->setCellValue('G' . $i, $sku->factory_number); $sheet->setCellValue('H' . $i, DateHelper::getHumanDate($sku->manufacture_date, true)); } // save file $fileName = '4.Паспорт объекта - ' . $order->object_address . '.xlsx'; $writer = new Xlsx($spreadsheet); Storage::disk('public')->makeDirectory('orders/' . $order->id . '/tmp'); $writer->save(storage_path('app/public/orders/') . $order->id . '/tmp/' . $fileName); } /** * @param Reclamation $reclamation * @param int $userId * @return string * @throws Exception */ public function generateReclamationPack(Reclamation $reclamation, int $userId): string { Storage::disk('public')->makeDirectory('reclamations/' . $reclamation->id . '/tmp/' . $reclamation->order->object_address . '/ФОТО НАРУШЕНИЯ/'); // copy photos foreach ($reclamation->photos_before as $photo) { $from = $photo->path; $to = 'reclamations/' . $reclamation->id . '/tmp/' . $reclamation->order->object_address . '/ФОТО НАРУШЕНИЯ/' . $photo->original_name; if (!Storage::disk('public')->exists($to)) { Storage::disk('public')->copy($from, $to); } } // create xls and pdf $this->generateReclamationOrder($reclamation); $this->generateReclamationAct($reclamation); $this->generateReclamationGuarantee($reclamation); // create zip archive $fileModel = (new FileService())->createZipArchive('reclamations/' . $reclamation->id . '/tmp', self::RECLAMATION_FILENAME . $reclamation->order->object_address . '.zip', $userId); // remove temp files Storage::disk('public')->deleteDirectory('reclamations/' . $reclamation->id . '/tmp'); $reclamation->documents()->syncWithoutDetaching($fileModel); // return link return $fileModel?->link ?? ''; } /** * @throws Exception */ private function generateReclamationOrder(Reclamation $reclamation): void { $inputFileType = 'Xlsx'; $inputFileName = './templates/ReclamationOrder.xlsx'; $reader = IOFactory::createReader($inputFileType); $spreadsheet = $reader->load($inputFileName); $sheet = $spreadsheet->getActiveSheet(); $articles = []; foreach ($reclamation->skus as $p) { $articles[] = $p->product->article; } $sheet->setCellValue('J4', DateHelper::getHumanDate($reclamation->create_date, true)); $sheet->setCellValue('L10', $reclamation->order->common_name); $sheet->setCellValue('L11', $reclamation->order->area?->responsible?->name); $sheet->setCellValue('W11', $reclamation->order->area?->responsible?->phone); $sheet->setCellValue('L12', $reclamation->order->year); $sheet->setCellValue('G13', $reclamation->guarantee); $sheet->setCellValue('G14', implode(', ', $articles)); $sheet->setCellValue('Y15', DateHelper::getHumanDate($reclamation->finish_date, true)); $sheet->setCellValue('U20', DateHelper::getHumanDate($reclamation->create_date, true)); // save file $fileName = 'Монтажная заявка - ' . $reclamation->order->object_address . '.xlsx'; $writer = new Xlsx($spreadsheet); $fd = 'reclamations/' . $reclamation->id . '/tmp/' . $reclamation->order->object_address; Storage::disk('public')->makeDirectory($fd); $fp = storage_path('app/public/reclamations/') . $reclamation->id . '/tmp/' . $reclamation->order->object_address . '/' . $fileName; Storage::disk('public')->delete($fd . '/' . $fileName); $writer->save($fp); PdfConverterClient::convert($fp); } /** * @throws Exception */ private function generateReclamationAct(Reclamation $reclamation): void { $inputFileType = 'Xlsx'; $inputFileName = './templates/ReclamationAct.xlsx'; $reader = IOFactory::createReader($inputFileType); $spreadsheet = $reader->load($inputFileName); $sheet = $spreadsheet->getActiveSheet(); $mafs = []; foreach ($reclamation->skus as $p) { $mafs[] = $p->product->passport_name . ', тип ' . $p->product->nomenclature_number; } $sheet->setCellValue('A17', $reclamation->order->object_address); $sheet->setCellValue('A22', implode('; ', $mafs)); $sheet->setCellValue('A27', $reclamation->whats_done); $i = 24; $n = 1; foreach ($reclamation->skus as $p) { if ($n++ > 1) { $i++; $sheet->insertNewRowBefore($i, 1); $range = 'D' . $i . ':I' . $i; $sheet->mergeCells($range); } $sheet->setCellValue('D' . $i, $p->rfid); } // save file $fileName = 'Акт - ' . $reclamation->order->object_address . '.xlsx'; $writer = new Xlsx($spreadsheet); $fd = 'reclamations/' . $reclamation->id . '/tmp/' . $reclamation->order->object_address; Storage::disk('public')->makeDirectory($fd); $fp = storage_path('app/public/reclamations/') . $reclamation->id . '/tmp/' . $reclamation->order->object_address . '/' . $fileName; Storage::disk('public')->delete($fd . '/' . $fileName); $writer->save($fp); PdfConverterClient::convert($fp); } /** * @throws Exception */ private function generateReclamationGuarantee(Reclamation $reclamation): void { $inputFileType = 'Xlsx'; $inputFileName = './templates/ReclamationGuarantee.xlsx'; $reader = IOFactory::createReader($inputFileType); $spreadsheet = $reader->load($inputFileName); $sheet = $spreadsheet->getActiveSheet(); $mafs = []; foreach ($reclamation->skus as $p) { $mafs[] = 'Тип ' . $p->product->nomenclature_number . ' (' . $p->product->passport_name . ')' ; } $contract = Contract::query()->where('contracts.year', $reclamation->order->year)->first(); $text = "ООО «НАШ ДВОР-СТ» в рамках обязательств по Договору №{$contract?->contract_number}" . " от " . DateHelper::getHumanDate($contract?->contract_date ?? '1970-01-01', true) . " г. на выполнение комплекса работ по поставке, монтажу устанавливаемых на городских территориях малых архитектурных форм гарантирует " . $reclamation->guarantee . " на оборудовании «" . implode('; ', $mafs) . "» установленному по адресу г. Москва, " . $reclamation->order->object_address . " в срок до " . DateHelper::getHumanDate($reclamation->finish_date, true). " г. в связи с отсутствием детали в наличии и ее производством."; $sheet->setCellValue('B9', $reclamation->id); $sheet->setCellValue('D9', DateHelper::getHumanDate($reclamation->create_date, true)); $sheet->setCellValue('A19', $text); // save file $fileName = 'Гарантийное письмо - ' . $reclamation->order->object_address . '.xlsx'; $writer = new Xlsx($spreadsheet); $fd = 'reclamations/' . $reclamation->id . '/tmp/' . $reclamation->order->object_address; Storage::disk('public')->makeDirectory($fd); $fp = storage_path('app/public/reclamations/') . $reclamation->id . '/tmp/' . $reclamation->order->object_address . '/' . $fileName; Storage::disk('public')->delete($fd . '/' . $fileName); $writer->save($fp); PdfConverterClient::convert($fp); } public function generateFilePack(Collection $files, int $userId, string $name = 'files'): \App\Models\File { $dir = Str::random(2); Storage::disk('public')->makeDirectory('files/' . $dir . '/tmp/'); // copy files foreach ($files as $file) { $from = $file->path; $to = 'files/' . $dir . '/tmp/' . $file->original_name; if (!Storage::disk('public')->exists($to)) { Storage::disk('public')->copy($from, $to); } } // create zip archive $fileModel = (new FileService())->createZipArchive('files/' . $dir . '/tmp', $name .'_' . date('Y-m-d_h-i-s') . '.zip', $userId); // remove temp files Storage::disk('public')->deleteDirectory('files/' . $dir . '/tmp'); // return link return $fileModel; } public function generateTtnPack(Ttn $ttn, int $userId): string { $skus = ProductSKU::query()->whereIn('id', json_decode($ttn->skus))->get(); $volume = $weight = $places = 0; foreach ($skus as $sku) { if(!isset($order)) { $order = $sku->order; } $volume += $sku->product->volume; $weight += $sku->product->weight; $places += $sku->product->places; } $installationDate = ($order->installation_date) ? DateHelper::getHumanDate($order->installation_date, true) : '-'; $ttnNumber = ($ttn->ttn_number_suffix) ? $ttn->ttn_number . '-' . $ttn->ttn_number_suffix : $ttn->ttn_number; $inputFileType = 'Xlsx'; $inputFileName = './templates/Ttn.xlsx'; $reader = IOFactory::createReader($inputFileType); $spreadsheet = $reader->load($inputFileName); $sheet = $spreadsheet->getActiveSheet(); $sheet->setCellValue('D8', $installationDate); $sheet->setCellValue('R8', $ttnNumber); $sheet->setCellValue('AF8', DateHelper::getHumanDate($ttn->order_date, true)); $sheet->setCellValue('AT8', $ttn->order_number); $sheet->setCellValue('B19', $order->object_address ?? ''); $sheet->setCellValue('AD22', CountHelper::humanCount($places, 'место', 'места', 'мест') . ', способ упаковки: поддон, ящик, картон, полиэтилен'); $sheet->setCellValue('B24', $weight . ' кг, ' . $volume . ' м.куб'); $sheet->setCellValue('B36', $installationDate); $sheet->setCellValue('AB57', $installationDate . ' 8-00'); $sheet->setCellValue('B59', $installationDate . ' 8-10'); $sheet->setCellValue('AB59', $installationDate . ' 8-40'); $sheet->setCellValue('B61', $weight . ' кг'); $sheet->setCellValue('B63', CountHelper::humanCount($places, 'место', 'места', 'мест')); $sheet->setCellValue('B75', $order->object_address ?? ''); $sheet->setCellValue('AB75', $installationDate); $sheet->setCellValue('B77', $installationDate); $sheet->setCellValue('AB77', $installationDate); $sheet->setCellValue('AB79', CountHelper::humanCount($places, 'место', 'места', 'мест')); $sheet->setCellValue('B81', $weight . ' кг'); $sheet->setCellValue('B83', $order->brigadier?->name ?? ''); $sheet->setCellValue('B89', $ttn->order_sum); $sheet->setCellValue('AD89', $ttn->order_sum); $sheet->setCellValue('AS89', $ttn->order_sum); // save file $fileName = 'ТТН №' . $ttn->ttn_number . ' от ' . DateHelper::getHumanDate($ttn->order_date) . '.xlsx'; $writer = new Xlsx($spreadsheet); $fd = 'ttn/' . $ttn->year; Storage::disk('public')->makeDirectory($fd); $fp = storage_path('app/public/ttn/') . $ttn->year . '/' . $fileName; Storage::disk('public')->delete($fd . '/' . $fileName); $writer->save($fp); $fileModel = File::query()->updateOrCreate([ 'link' => url('/storage/') . '/ttn/' . $ttn->year . '/' .$fileName, 'path' => $fp . '/' .$fileName, 'user_id' => $userId, 'original_name' => $fileName, 'mime_type' => 'application/xlsx', ]); $ttn->file_id = $fileModel->id; $ttn->save(); $order->documents()->attach($fileModel->id); return $fileModel->link ?? ''; } }