/** * Creates data provider instance with search query applied * * @param array $params * * @return ActiveDataProvider */ public function search($params) { $query = Income::find(); $dataProvider = new ActiveDataProvider(['query' => $query]); $this->load($params); if (!$this->validate()) { // uncomment the following line if you do not want to return any records when validation fails // $query->where('0=1'); return $dataProvider; } $query->andFilterWhere(['id' => $this->id, 'cost' => $this->cost, 'money' => $this->money, 'profit' => $this->profit, 'uid' => Yii::$app->user->id]); $query->andFilterWhere(['like', 'remark', $this->remark])->andFilterWhere(['like', 'who', $this->who]); return $dataProvider; }
/** * Список доходов * @return string */ public function actionList() { $purse_get = Yii::$app->request->get('purse_filter'); $category_get = Yii::$app->request->get('category_filter'); $date_before_filter = Yii::$app->request->get('date_before_filter'); $date_after_filter = Yii::$app->request->get('date_after_filter'); $empty_date = Yii::$app->request->get('empty_date'); $active_purse = null; $incomes = null; $pages = null; $sum = null; $datePayDay = null; $user_id = Yii::$app->user->getId(); $user = User::findIdentity($user_id); $purses = Purse::find()->where(['user_id' => $user_id])->orderBy('active DESC')->all(); $purse_id = $purse_get ? $purse_get : ($purses ? $purses[0]->id : null); if ($purse_id) { $active_purse = Purse::find()->where(['id' => $purse_id])->one(); $incomesQuery = Income::find()->where(['purse_id' => $active_purse->id])->orderBy('datetime desc '); if ($category_get) { $incomesQuery->andWhere(['type_income_id' => $category_get]); } if ($date_before_filter) { $date_before = DateComponent::PeopleDateToDate($date_before_filter); $incomesQuery->andWhere('date(datetime)>=:date_before', [':date_before' => $date_before]); } else { if (!$empty_date && $user->filter_payday && $user->payday) { $datePayDay = DateComponent::getDateFilterWithPayday(); $incomesQuery->andWhere('date(datetime)>=:date_before', [':date_before' => implode('-', $datePayDay)]); } } if ($date_after_filter) { $date_after = DateComponent::PeopleDateToDate($date_after_filter); $incomesQuery->andWhere('date(datetime)<=:date_after', [':date_after' => $date_after]); } // var_dump($expenses->prepare(Yii::$app->db->queryBuilder)->createCommand()->rawSql); die; // $expenses = $expenses->all(); $sum = $incomesQuery->sum('money'); $countQuery = clone $incomesQuery; $pages = new Pagination(['totalCount' => $countQuery->count()]); $pages->pageSize = 20; $incomes = $incomesQuery->offset($pages->offset)->limit($pages->limit)->all(); } $categories = TypeIncome::find()->where(['user_id' => $user_id])->orderBy('id desc')->all(); return $this->render('list', ['incomes' => $incomes, 'pages' => $pages, 'active_purse' => $active_purse, 'categories' => $categories, 'datePayDay' => $datePayDay, 'purses' => $purses, 'sum' => $sum]); }
/** * Приходы * @return string */ public function actionIncomes() { if (Yii::$app->getRequest()->getQueryParam('user')) { // $start_day = strtotime('now 00:00:00'); $user = MarkUser::findOne(Yii::$app->getRequest()->getQueryParam('user')); if (!$user) { return 'Доступ запрещен!'; } if (Yii::$app->getRequest()->getQueryParam('name') && Yii::$app->getRequest()->getQueryParam('value') !== null) { if (Income::find()->where(['name' => Yii::$app->getRequest()->getQueryParam('name')])) { $income = Income::find()->where(['name' => Yii::$app->getRequest()->getQueryParam('name')])->one(); } else { return 'Ошибка при наборе'; } $act = new DiaryActs(); $act->model_id = 9; $act->user_id = $user->id; //return var_dump($act); if ($act->save(false)) { $incomes = new Incomes(); try { $incomes->income_id = $income->id; } catch (\ErrorException $e) { return 'Такой статьи в базе нет!'; } $incomes->act_id = $act->id; $incomes->user_id = $act->user_id; $incomes->money = (double) Yii::$app->getRequest()->getQueryParam('value'); if (!$incomes->validate()) { return 'Данные введены некорректно'; } else { if ($incomes->save()) { $all_incomes_grouped = Incomes::find()->select(['income_id, COUNT(*) as cnt, SUM(money) as sum '])->groupBy('income_id')->orderBy('sum DESC')->all(); //var_dump($all_incomes_grouped); $not_curr_sum = Incomes::find()->select('SUM(money)')->where("income_id IN (1,2,7,10)")->scalar(); $dollar = Incomes::find()->select('SUM(money)')->where("income_id = 8")->scalar(); $euro = Incomes::find()->select('SUM(money)')->where("income_id = 9")->scalar(); $bal_sum = $not_curr_sum + Helper::currencyAdapter($dollar, 11) + Helper::currencyAdapter($euro, 12); return $this->renderPartial('all_incomes', ['user' => $user, 'incomes' => $all_incomes_grouped, 'bal_sum' => $bal_sum]); } else { return 'Ошибка сохранения'; } } } } $all_incomes_grouped = Incomes::find()->select(['income_id, COUNT(*) as cnt, SUM(money) as sum '])->groupBy('income_id')->orderBy('sum DESC')->all(); //var_dump($all_incomes_grouped); $not_curr_sum = Incomes::find()->select('SUM(money)')->where("income_id IN (1,2,7,10)")->scalar(); $dollar = Incomes::find()->select('SUM(money)')->where("income_id = 8")->scalar(); $euro = Incomes::find()->select('SUM(money)')->where("income_id = 9")->scalar(); $bal_sum = $not_curr_sum + Helper::currencyAdapter($dollar, 11) + Helper::currencyAdapter($euro, 12); //sreturn Helper::currencyAdapter($dollar, 11); return $this->renderPartial('income', ['user' => $user, 'incomes' => $all_incomes_grouped, 'bal_sum' => $bal_sum]); } else { return 'Ошибка'; } }