ImportMafsService.php 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. <?php
  2. namespace App\Services;
  3. use App\Helpers\DateHelper;
  4. use App\Models\Import;
  5. use App\Models\MafOrder;
  6. use App\Models\Order;
  7. use App\Models\Product;
  8. use App\Models\ProductSKU;
  9. use App\Services\OrderPaymentStatusService;
  10. use Exception;
  11. class ImportMafsService extends ImportBaseService
  12. {
  13. private ?int $year;
  14. const HEADERS = [
  15. 'ID' => 'products_sku.id',
  16. 'Год' => 'products_sku.year',
  17. 'Округ' => 'districts.shortname',
  18. 'Район' => 'areas.name',
  19. 'Адрес площадки' => 'orders.object_address',
  20. '№ заказа МАФ' => 'maf_orders.order_number',
  21. 'Статус' => 'products_sku.status',
  22. 'RFID' => 'products_sku.rfid',
  23. 'Номер фабрики' => 'products_sku.factory_number',
  24. 'Дата производства' => 'products_sku.manufacture_date',
  25. 'Номер ведомости' => 'products_sku.statement_number',
  26. 'Дата ведомости' => 'products_sku.statement_date',
  27. 'Номер УПД' => 'products_sku.upd_number',
  28. 'Номер номенклатуры' => 'products.nomenclature_number',
  29. 'Артикул' => 'products.article',
  30. 'Наименование по ТЗ' => 'products.name_tz',
  31. 'Тип по ТЗ' => 'products.type_tz',
  32. 'Тип' => 'products.type',
  33. 'Наименование производителя' => 'products.manufacturer_name',
  34. 'Примечания' => 'products_sku.comment',
  35. // заголовки из файла для проверки и маппинга
  36. ];
  37. public function __construct(Import $import, ?int $year = null)
  38. {
  39. parent::__construct($import);
  40. $this->year = $year;
  41. $this->headers = self::HEADERS;
  42. }
  43. public function handle(): bool
  44. {
  45. if(!$this->prepare()) {
  46. return false;
  47. }
  48. $strNumber = 0;
  49. $result = [
  50. 'mafsUpdated' => 0,
  51. ];
  52. foreach($this->rowIterator as $row){
  53. $strNumber++;
  54. $r = $this->rowToArray($row);
  55. if($strNumber === 1) {
  56. echo $this->import->log('Skip headers Row: ' . $strNumber);
  57. continue;
  58. }
  59. try {
  60. $logMessage = "Row $strNumber: " . $r['orders.object_address'] . '. ';
  61. $id = (int) $r['products_sku.id'];
  62. $data = [
  63. 'rfid' => (string) $r['products_sku.rfid'],
  64. 'factory_number' => (string) $r['products_sku.factory_number'],
  65. 'manufacture_date' => $this->parseDate($r['products_sku.manufacture_date']),
  66. 'statement_number' => (string) $r['products_sku.statement_number'],
  67. 'statement_date' => $this->parseDate($r['products_sku.statement_date']),
  68. 'upd_number' => (string) $r['products_sku.upd_number'],
  69. 'comment' => (string) $r['products_sku.comment'],
  70. ];
  71. $logMessage .= $r['products_sku.statement_date'] . ' ' . $r['products_sku.manufacture_date'] .' ';
  72. $productSKU = ProductSKU::query()
  73. ->withoutGlobalScope(\App\Models\Scopes\YearScope::class)
  74. ->where('id', $id)
  75. ->when($this->year, fn ($q) => $q->where('year', $this->year))
  76. ->first();
  77. if ($productSKU) {
  78. $logMessage .= 'Found and updated product with id: ' . $productSKU->id;
  79. $productSKU->update($data);
  80. $productSKU->save();
  81. app(OrderPaymentStatusService::class)->markPaidIfAllMafsHavePaymentData($productSKU->order_id);
  82. } else {
  83. echo $this->import->log('Product sku with id ' . $id . ' NOT FOUND!', 'WARNING');
  84. }
  85. echo $this->import->log($logMessage);
  86. } catch (\Exception $e) {
  87. echo $this->import->log($e->getMessage(), 'WARNING');
  88. }
  89. }
  90. echo $this->import->log(print_r($result, true));
  91. $this->import->status = 'DONE';
  92. $this->import->save();
  93. return true;
  94. }
  95. private function parseDate(mixed $value): ?string
  96. {
  97. if ($value === null) {
  98. return null;
  99. }
  100. $value = trim((string) $value);
  101. if ($value === '') {
  102. return null;
  103. }
  104. if (is_numeric($value)) {
  105. return DateHelper::excelDateToISODate((int) $value);
  106. }
  107. try {
  108. return DateHelper::getDateForDB($value);
  109. } catch (\Throwable) {
  110. return null;
  111. }
  112. }
  113. }