CustomConverter.php
4.3 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
<?php
namespace common\components\parsers;
use common\components\CustomVarDamp;
use yii\multiparser\Converter;
use backend\models\Details;
class CustomConverter extends Converter {
/**
* @param $value_arr - двумерный массив значений, которому нужно присвоить ключи
* @param $key_array - ключи для вложенного массива
* @return array - таблица с проименованными колонками
*/
public static $sign;
public static $multiplier;
public static function convertToAssocArray ( array $value_arr, array $key_array, $key_prefix = '' )
{
// очистка служебного префикса в массиве заголовков
if ($key_prefix) {
// @todo оптимизировать - два переворота массива - избыточно
$key_array = array_flip( $key_array );
array_walk( $key_array, function ( &$value, $key, $key_prefix ){ $value = str_replace( $key_prefix, '',$value ); }, $key_prefix );
$key_array = array_flip( $key_array );
//уберем пустые элементы
$key_array = array_filter($key_array, function ($value){ return $value !==''; });
}
array_walk( $value_arr,
function ( &$value, $key, $key_array ) {
$res = $value;
foreach ($res as $sub_key => $sub_value) {
if (isset($key_array[$sub_key])) {
// если такой ключ в базовом массиве (массиве ключей) есть, то заменим новым, иначе просто удалим
$new_key = $key_array[$sub_key];
if( !array_key_exists( $new_key , $res ) ){
$res[ $new_key ] = $value[$sub_key];
}
}
unset( $res[$sub_key] );
$value = $res;
}
},
$key_array);
return $value_arr;
}
/**
* @param $value_arr - двумерный массив к которому нужно добавить колонки
* @param $add_array - массив с колонками (ключи) и значениями колонок
* @return mixed
*/
public function addColumns ( array $value_arr , array $add_array )
{
$i = 0;
while ($i < count($value_arr)) {
foreach ($add_array as $add_key => $add_value) {
$value_arr[$i][$add_key] = $add_value;
}
$i++;
}
return $value_arr;
}
public static function convertToDetails ( array $row )
{
// присвоим полный артикул
$row['FULL_ARTICLE'] = $row['ARTICLE'];
$details_model = new Details();
// проверим все ли обязательные колонки были указаны пользователем
$details_model->load(['Details' => $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;
}
public function ConvertToMultiply ( array $row )
{
$PRICE = $row[ 'PRICE' ];
$sign = self::$sign;
$multiplier = self::$multiplier;
//CustomVarDamp::dumpAndDie(self);
if (isset($sign)) {
if ($sign == '+') {
if ($multiplier > 0) {
$PRICE += $multiplier;
}
}
else if ($sign == '-') {
if ($multiplier > 0) {
$PRICE -= $multiplier;
}
}
else if ($sign == '*') {
if ($multiplier > 0) {
$PRICE *= $multiplier;
}
}
else if ($sign == '/') {
if ($multiplier > 0) {
$PRICE /= $multiplier;
}
}
}
$row[ 'PRICE' ] = $PRICE;
return $row;
}
}