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;
    }
}