$label ]; } else { $labelFilter = []; } if (!empty($manager)) { $managerFilter = [ 'manager_id' => $manager ]; } else { $managerFilter = []; } /** * Get labels */ $labels = Label::find() ->with('lang') ->all(); /** * Get user */ $managers = User::find() ->all(); /** * Generate statistics */ $labelStatistics = ArrayHelper::map( $labels, function(Label $model) { return $model->lang->title; }, function(Label $model) use ($dateFilter, $managerFilter) { return $model->getStatistics($dateFilter, $managerFilter); } ); /** * Data provider for table */ $dataProvider = new ActiveDataProvider( [ 'query' => Order::find() ->filterWhere($dateFilter) ->andFilterWhere($managerFilter) ->andFilterWhere($labelFilter), ] ); /** * Creating charts data */ $labelChartData1 = [ 'labels' => array_keys($labelStatistics), 'datasets' => [ [ 'label' => 'Заказов, шт.', 'data' => ArrayHelper::getColumn($labelStatistics, 'count', false), 'backgroundColor' => 'rgba(54, 162, 235, 0.2)', 'borderColor' => 'rgba(54, 162, 235, 1)', 'borderWidth' => 1, ], ], ]; $labelChartData2 = [ 'labels' => array_keys($labelStatistics), 'datasets' => [ [ 'label' => 'На сумму, грн.', 'data' => ArrayHelper::getColumn($labelStatistics, 'sum', false), 'backgroundColor' => 'rgba(255, 99, 132, 0.2)', 'borderColor' => 'rgba(255,99,132,1)', 'borderWidth' => 1, ], ], ]; $labelChartData3 = [ 'labels' => array_keys($labelStatistics), 'datasets' => [ [ 'label' => 'Заказано товаров, шт.', 'data' => ArrayHelper::getColumn($labelStatistics, 'products', false), 'backgroundColor' => 'rgba(255, 206, 86, 0.2)', 'borderColor' => 'rgba(255, 206, 86, 1)', 'borderWidth' => 1, ], [ 'label' => 'Уникальных товаров, шт.', 'data' => ArrayHelper::getColumn($labelStatistics, 'unique', false), 'backgroundColor' => 'rgba(75, 192, 192, 0.2)', 'borderColor' => 'rgba(75, 192, 192, 1)', 'borderWidth' => 1, ], ], ]; /** * Getting rejection statistics */ $rejectStatistics = Order::getRejectionStatistics($dateFilter, $managerFilter); /** * Charts data for rejects */ $rejectChartData1 = [ 'labels' => array_keys($rejectStatistics), 'datasets' => [ [ 'label' => 'Заказов, шт.', 'data' => ArrayHelper::getColumn($rejectStatistics, 'count', false), 'backgroundColor' => 'rgba(153, 102, 255, 0.2)', 'borderColor' => 'rgba(153, 102, 255, 1)', 'borderWidth' => 1, ], ], ]; $rejectChartData2 = [ 'labels' => array_keys($rejectStatistics), 'datasets' => [ [ 'label' => 'На сумму, грн.', 'data' => ArrayHelper::getColumn($rejectStatistics, 'sum', false), 'backgroundColor' => 'rgba(255, 159, 64, 0.2)', 'borderColor' => 'rgba(255, 159, 64, 1)', 'borderWidth' => 1, ], ], ]; return $this->render( 'index', [ 'labels' => $labels, 'managers' => $managers, 'labelStatistics' => $labelStatistics, 'rejectionStatistics' => $rejectStatistics, 'dataProvider' => $dataProvider, 'labelChartData1' => $labelChartData1, 'labelChartData2' => $labelChartData2, 'labelChartData3' => $labelChartData3, 'rejectChartData1' => $rejectChartData1, 'rejectChartData2' => $rejectChartData2, 'dateValue' => empty($date_range) ? '' : $date_range, 'dataLabel' => empty($label) ? false : $label, 'dataManager' => empty($manager) ? false : $manager, ] ); } }