Blame view

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