Blame view

common/components/parsers/CustomConverter.php 7.15 KB
33d902b8   Mihail   add converter as ...
1
  <?php
912e6b15   Mihail   fixed Image class
2
  namespace common\components\parsers;
a0d1ac87   Mihail   add articul filte...
3
  
ef41533d   Mihail   temp commit - wor...
4
  use common\components\CustomVarDamp;
33d902b8   Mihail   add converter as ...
5
  use yii\multiparser\Converter;
ef41533d   Mihail   temp commit - wor...
6
  use backend\models\Details;
7776ca75   Mihail   add form, model a...
7
  use backend\models\DetailsCrosses;
a0d1ac87   Mihail   add articul filte...
8
  use backend\models\ImportersPrefix;
33d902b8   Mihail   add converter as ...
9
  
a0d1ac87   Mihail   add articul filte...
10
11
  class CustomConverter extends Converter
  {
33d902b8   Mihail   add converter as ...
12
13
14
15
16
17
  
      /**
       * @param $value_arr - двумерный массив значений, которому нужно присвоить ключи
       * @param $key_array - ключи для вложенного массива
       * @return array - таблица с проименованными колонками
       */
78684ed4   Mihail   add multiply pric...
18
19
      public static $sign;
      public static $multiplier;
a0d1ac87   Mihail   add articul filte...
20
      public static $importer_id;
78684ed4   Mihail   add multiply pric...
21
  
a0d1ac87   Mihail   add articul filte...
22
      public static function convertToAssocArray(array $value_arr, array $key_array, $key_prefix = '')
33d902b8   Mihail   add converter as ...
23
      {
d7f6bdbb   Mihail   add Importers fil...
24
          // очистка служебного префикса в массиве заголовков
33d902b8   Mihail   add converter as ...
25
          if ($key_prefix) {
14ab0a80   Mihail   fixed error in Co...
26
              // @todo оптимизировать - два переворота массива - избыточно
a0d1ac87   Mihail   add articul filte...
27
              $key_array = array_flip($key_array);
14ab0a80   Mihail   fixed error in Co...
28
  
a0d1ac87   Mihail   add articul filte...
29
30
31
              array_walk($key_array, function (&$value, $key, $key_prefix) {
                  $value = str_replace($key_prefix, '', $value);
              }, $key_prefix);
14ab0a80   Mihail   fixed error in Co...
32
  
a0d1ac87   Mihail   add articul filte...
33
              $key_array = array_flip($key_array);
d7f6bdbb   Mihail   add Importers fil...
34
              //уберем пустые элементы
a0d1ac87   Mihail   add articul filte...
35
36
37
              $key_array = array_filter($key_array, function ($value) {
                  return $value !== '';
              });
33d902b8   Mihail   add converter as ...
38
39
          }
  
a0d1ac87   Mihail   add articul filte...
40
41
          array_walk($value_arr,
              function (&$value, $key, $key_array) {
33d902b8   Mihail   add converter as ...
42
                  $res = $value;
48b58a13   Mihail   finish with xml a...
43
44
                  foreach ($res as $sub_key => $sub_value) {
                      if (isset($key_array[$sub_key])) {
33d902b8   Mihail   add converter as ...
45
                          // если такой ключ в базовом массиве (массиве ключей) есть, то заменим новым, иначе просто удалим
48b58a13   Mihail   finish with xml a...
46
                          $new_key = $key_array[$sub_key];
a0d1ac87   Mihail   add articul filte...
47
48
                          if (!array_key_exists($new_key, $res)) {
                              $res[$new_key] = $value[$sub_key];
33d902b8   Mihail   add converter as ...
49
50
                          }
                      }
a0d1ac87   Mihail   add articul filte...
51
                      unset($res[$sub_key]);
48b58a13   Mihail   finish with xml a...
52
                      $value = $res;
33d902b8   Mihail   add converter as ...
53
54
                  }
  
33d902b8   Mihail   add converter as ...
55
              },
a0d1ac87   Mihail   add articul filte...
56
              $key_array);
48b58a13   Mihail   finish with xml a...
57
58
  
          return $value_arr;
33d902b8   Mihail   add converter as ...
59
60
      }
  
2fb5a757   Mihail   add menu and chec...
61
62
      /**
       * @param $value_arr - двумерный массив к которому нужно добавить колонки
48b58a13   Mihail   finish with xml a...
63
       * @param $add_array - массив с колонками (ключи) и значениями колонок
2fb5a757   Mihail   add menu and chec...
64
65
       * @return mixed
       */
a0d1ac87   Mihail   add articul filte...
66
      public function addColumns(array $value_arr, array $add_array)
d7f6bdbb   Mihail   add Importers fil...
67
68
69
      {
          $i = 0;
          while ($i < count($value_arr)) {
51514d7d   Mihail   add writing data ...
70
71
72
              foreach ($add_array as $add_key => $add_value) {
                  $value_arr[$i][$add_key] = $add_value;
              }
d7f6bdbb   Mihail   add Importers fil...
73
74
              $i++;
          }
d7f6bdbb   Mihail   add Importers fil...
75
76
          return $value_arr;
      }
ef41533d   Mihail   temp commit - wor...
77
  
a0d1ac87   Mihail   add articul filte...
78
      public static function convertToDetails(array $row)
ef41533d   Mihail   temp commit - wor...
79
80
81
82
83
84
85
86
      {
          // присвоим полный артикул
          $row['FULL_ARTICLE'] = $row['ARTICLE'];
  
          $details_model = new Details();
          // проверим все ли обязательные колонки были указаны пользователем
          $details_model->load(['Details' => $row]);
  
a0d1ac87   Mihail   add articul filte...
87
          if (!$details_model->validate()) {
ef41533d   Mihail   temp commit - wor...
88
              $errors = '';
a0d1ac87   Mihail   add articul filte...
89
90
              foreach ($details_model->errors as $key => $arr_errors) {
                  $errors .= "Аттрибут $key - " . implode(' , ', $arr_errors);
ef41533d   Mihail   temp commit - wor...
91
              }
a0d1ac87   Mihail   add articul filte...
92
              throw new \ErrorException($errors);
ef41533d   Mihail   temp commit - wor...
93
94
95
96
          }
          return $row;
      }
  
7776ca75   Mihail   add form, model a...
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
      public static function convertToCrosses( array $row )
      {
  
          $details_model = new DetailsCrosses();
          // проверим все ли обязательные колонки были указаны пользователем
          $details_model->load(['DetailsCrosses' => $row]);
  
          if (!$details_model->validate()) {
              $errors = '';
              foreach ($details_model->errors as $key => $arr_errors) {
                  $errors .= "Аттрибут $key - " . implode(' , ', $arr_errors);
              }
              throw new \ErrorException($errors);
          }
          return $row;
      }
a0d1ac87   Mihail   add articul filte...
113
      public function ConvertToMultiply(array $row)
78684ed4   Mihail   add multiply pric...
114
      {
a0d1ac87   Mihail   add articul filte...
115
          $PRICE = $row['PRICE'];
78684ed4   Mihail   add multiply pric...
116
117
118
119
120
121
122
123
          $sign = self::$sign;
          $multiplier = self::$multiplier;
          //CustomVarDamp::dumpAndDie(self);
          if (isset($sign)) {
              if ($sign == '+') {
                  if ($multiplier > 0) {
                      $PRICE += $multiplier;
                  }
a0d1ac87   Mihail   add articul filte...
124
              } else if ($sign == '-') {
78684ed4   Mihail   add multiply pric...
125
126
127
                  if ($multiplier > 0) {
                      $PRICE -= $multiplier;
                  }
a0d1ac87   Mihail   add articul filte...
128
              } else if ($sign == '*') {
78684ed4   Mihail   add multiply pric...
129
130
131
                  if ($multiplier > 0) {
                      $PRICE *= $multiplier;
                  }
a0d1ac87   Mihail   add articul filte...
132
              } else if ($sign == '/') {
78684ed4   Mihail   add multiply pric...
133
134
135
136
137
138
                  if ($multiplier > 0) {
                      $PRICE /= $multiplier;
                  }
              }
          }
  
a0d1ac87   Mihail   add articul filte...
139
140
141
142
143
144
          $row['PRICE'] = $PRICE;
  
          return $row;
  
      }
  
7776ca75   Mihail   add form, model a...
145
      public static function convertToArticle( $value, $importer_id = '' )
a0d1ac87   Mihail   add articul filte...
146
      {
7776ca75   Mihail   add form, model a...
147
148
149
150
151
          if(isset( $importer_id )){
              self::$importer_id = $importer_id;
          }
  
          if (is_array($value)) {
a0d1ac87   Mihail   add articul filte...
152
  
7776ca75   Mihail   add form, model a...
153
              $row = $value;
a0d1ac87   Mihail   add articul filte...
154
155
156
157
158
159
              // 1. Уберем префикс который разделен пробелом (если он есть)
              $words = explode(" ", $row['ARTICLE']);
              if (count($words) > 1) {
                  array_shift($words);
                  $row['ARTICLE'] = implode(" ", $words);
              }
7776ca75   Mihail   add form, model a...
160
161
162
163
164
165
166
167
  
              if( isset( $row['BRAND'] ) && isset( self::$importer_id ) ){
                  // 2. Уберем брендовый префикс (если он есть)
                  $prefix = '';
                  // запрос закешируем
                  $prefix = ImportersPrefix::getDb()->cache( function ($db, $configuration, $row ) {
                      return ImportersPrefix::find()->where([ 'importer_id' => self::$importer_id,
                          'brand' => $row['BRAND'] ])->one();
a0d1ac87   Mihail   add articul filte...
168
                  });
78684ed4   Mihail   add multiply pric...
169
  
7776ca75   Mihail   add form, model a...
170
171
172
                  if ($prefix) {
                      $row['BRAND'] = str_replace($prefix, "", $row['BRAND']);
                  }
a0d1ac87   Mihail   add articul filte...
173
              }
7776ca75   Mihail   add form, model a...
174
175
176
177
178
179
180
181
182
183
184
  
              return $row;
  
          } else {
              $words = explode( " ", $value );
              if ( count( $words ) > 1) {
                  array_shift( $words );
                  $value = implode( " ", $words );
              }
  
              return $value;
a0d1ac87   Mihail   add articul filte...
185
          }
a0d1ac87   Mihail   add articul filte...
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
      }
  
      public static function convertToBrand($value)
      {
          $res = $value;
          $res = trim(strtoupper($res));
          $res = str_replace("Ä", "A", str_replace("Ö", "O", str_replace("Ü", "U", str_replace("Ë", "E", str_replace("Ò", "O", $res)))));
          $res = str_replace(array('@', '#', '~', '"', "'", "?", "!"), '', $res);
  
          return $res;
      }
  
      public static function convertToString($value)
      {
          $value = parent::convertToString($value);
78684ed4   Mihail   add multiply pric...
201
  
a0d1ac87   Mihail   add articul filte...
202
          return str_replace(array('!', '@', '#', '$', '%', '^', '&', '*', '(', ')', '_', '+', '=', '-', '~', '`', '"', "'", ' ', '№', '%', ';', ':', '[', ']', '{', '}', '*', '?', '/', '\'', '|', '.', ',', '<', '>', '\\'), '', $value);
78684ed4   Mihail   add multiply pric...
203
      }
ef41533d   Mihail   temp commit - wor...
204
205
  
  
33d902b8   Mihail   add converter as ...
206
  }