guild/backend/modules/balance/controllers/BalanceController.php

133 lines
3.6 KiB
PHP
Raw Permalink Normal View History

2019-06-21 18:05:58 +03:00
<?php
namespace backend\modules\balance\controllers;
use backend\modules\balance\models\Balance;
use backend\modules\balance\models\BalanceSearch;
use common\classes\Debug;
2019-06-25 12:37:09 +03:00
use common\models\FieldsValue;
use common\models\FieldsValueNew;
2019-06-25 18:28:20 +03:00
use DateTime;
2019-06-21 18:05:58 +03:00
use Yii;
2019-06-25 12:37:09 +03:00
use yii\data\ActiveDataProvider;
2020-01-29 11:26:01 +03:00
use yii\filters\AccessControl;
use yii\filters\VerbFilter;
2019-06-21 18:05:58 +03:00
use yii\web\Controller;
use yii\web\NotFoundHttpException;
use yii\db\Query;
class BalanceController extends Controller
{
2020-01-29 11:26:01 +03:00
/**
* {@inheritdoc}
*/
public function behaviors()
{
return [
'verbs' => [
'class' => VerbFilter::className(),
'actions' => [
'delete' => ['POST'],
],
],
2022-12-28 11:45:57 +03:00
'as AccessBehavior' => [
'class' => \developeruz\db_rbac\behaviors\AccessBehavior::className(),
2020-01-29 11:26:01 +03:00
],
];
}
2019-06-21 18:05:58 +03:00
public function actionIndex()
{
$searchModel = new BalanceSearch();
2019-06-25 18:28:20 +03:00
if(\Yii::$app->request->get('month'))
{
$searchModel->dt_from = date('Y-m-01');
$searchModel->dt_to = date('Y-m-t');
}
2019-06-26 14:03:42 +03:00
if(\Yii::$app->request->get('previous_month'))
{
$searchModel->dt_from = date('Y-m-d', strtotime('first day of previous month'));
$searchModel->dt_to = date('Y-m-d', strtotime('last day of previous month'));
}
2019-06-25 12:37:09 +03:00
$dataProvider = $searchModel->search(Yii::$app->request->queryParams);
2019-06-28 12:29:54 +03:00
$summ_info = $searchModel->getSummInfo();
2019-06-21 18:05:58 +03:00
2019-06-28 12:29:54 +03:00
return $this->render('index',compact('dataProvider', 'searchModel', 'summ_info'));
2019-06-21 18:05:58 +03:00
}
public function actionView($id)
{
2019-06-25 12:37:09 +03:00
$dataProviderF = new ActiveDataProvider([
'query' => FieldsValueNew::find()
->where(['item_id' => $id, 'item_type' => FieldsValueNew::TYPE_BALANCE])
->orderBy('order'),
'pagination' => [
'pageSize' => 200,
],
]);
2020-08-06 13:19:20 +03:00
$changeDataProvider = new ActiveDataProvider([
'query' => \common\models\ChangeHistory::find()->where(['type_id' => $this->findModel($id)->id]),
'pagination' => [
'pageSize' => 200,
]
]);
2019-06-21 18:05:58 +03:00
return $this->render('view',[
'model' => $this->findModel($id),
2020-08-06 13:19:20 +03:00
'dataProviderF' => $dataProviderF,
'changeDataProvider' => $changeDataProvider,
2019-06-21 18:05:58 +03:00
]);
}
public function actionCreate()
{
$model = new Balance();
if ($model->load(Yii::$app->request->post())) {
$model->dt_add = strtotime($model->dt_add);
$model->save();
Yii::$app->session->addFlash('success', 'Баланса добавлен');
return $this->redirect(['index']);
}
return $this->render('create', [
'model' => $model,
]);
}
public function actionUpdate($id)
{
2019-06-26 14:03:42 +03:00
$model = $this->findModel($id);
2019-06-21 18:05:58 +03:00
2019-06-25 12:37:09 +03:00
if ($model->load(Yii::$app->request->post())) {
$model->dt_add = strtotime($model->dt_add);
$model->save();
2019-06-21 18:05:58 +03:00
return $this->redirect(['view', 'id' => $model->id]);
}
2019-06-26 14:03:42 +03:00
return $this->render('update', [
2019-06-21 18:05:58 +03:00
'model' => $model,
]);
}
public function actionDelete($id)
{
$this->findModel($id)->delete();
return $this->redirect(['index']);
}
protected function findModel($id)
{
if (($model = Balance::findOne($id)) !== null) {
return $model;
}
throw new NotFoundHttpException('The requested page does not exist.');
}
2019-06-25 18:28:20 +03:00
2019-06-21 18:05:58 +03:00
}