Beispiel #1
0
 /**
  * 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;
 }
Beispiel #2
0
 /**
  * Список доходов
  * @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]);
 }
Beispiel #3
0
 /**
  * Приходы
  * @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 'Ошибка';
     }
 }