| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334 |
- <?php
- namespace App\Services;
- use App\Helpers\DateHelper;
- use App\Helpers\ExcelHelper;
- use App\Models\Contract;
- use App\Models\Order;
- use Exception;
- use Illuminate\Support\Facades\Storage;
- use Illuminate\Support\Str;
- use PhpOffice\PhpSpreadsheet\Cell\Cell;
- use PhpOffice\PhpSpreadsheet\IOFactory;
- use PhpOffice\PhpSpreadsheet\Worksheet\Drawing;
- use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
- class GenerateDocumentsService
- {
- const INSTALL_FILENAME = 'Монтаж ';
- const HANDOVER_FILENAME = 'Сдача ';
- /**
- * @param Order $order
- * @param int $userId
- * @return string
- * @throws Exception
- */
- public function generateInstallationPack(Order $order, int $userId): string
- {
- $techDocsPath = base_path('/tech-docs/');
- $products_sku = $order->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('<div>', '', $order->products_with_count);
- $str = Str::replace('</div>', "\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;
- @dump($photo->original_name);
- $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);
- }
- }
|