<?php namespace backend\modules\settings\controllers; use common\classes\Debug; use common\models\UseField; use Yii; use backend\modules\settings\models\AdditionalFields; use backend\modules\settings\models\AdditionalFieldsSearch; use yii\helpers\ArrayHelper; use yii\web\Controller; use yii\web\NotFoundHttpException; use yii\filters\VerbFilter; /** * AdditionalFieldsController implements the CRUD actions for AdditionalFields model. */ class AdditionalFieldsController extends Controller { /** * {@inheritdoc} */ public function behaviors() { return [ 'verbs' => [ 'class' => VerbFilter::className(), 'actions' => [ 'delete' => ['POST'], ], ], ]; } /** * Lists all AdditionalFields models. * @return mixed */ public function actionIndex() { $searchModel = new AdditionalFieldsSearch(); $dataProvider = $searchModel->search(Yii::$app->request->queryParams); return $this->render('index', [ 'searchModel' => $searchModel, 'dataProvider' => $dataProvider, ]); } /** * Displays a single AdditionalFields model. * @param integer $id * @return mixed * @throws NotFoundHttpException if the model cannot be found */ public function actionView($id) { return $this->render('view', [ 'model' => $this->findModel($id), ]); } /** * Creates a new AdditionalFields model. * If creation is successful, the browser will be redirected to the 'view' page. * @return mixed */ public function actionCreate() { $model = new AdditionalFields(); if ($model->load(Yii::$app->request->post()) && $model->save()) { return $this->redirect(['view', 'id' => $model->id]); } return $this->render('create', [ 'model' => $model, ]); } /** * Updates an existing AdditionalFields model. * If update is successful, the browser will be redirected to the 'view' page. * @param integer $id * @return mixed * @throws NotFoundHttpException if the model cannot be found */ public function actionUpdate($id) { $model = $this->findModel($id); if ($model->load(Yii::$app->request->post()) && $model->save()) { return $this->redirect(['view', 'id' => $model->id]); } $model->use = ArrayHelper::getColumn( \common\models\UseField::find()->where(['field_id' => $model->id])->asArray()->all(), 'use'); return $this->render('update', [ 'model' => $model, ]); } /** * Deletes an existing AdditionalFields model. * If deletion is successful, the browser will be redirected to the 'index' page. * @param integer $id * @return mixed * @throws NotFoundHttpException if the model cannot be found */ public function actionDelete($id) { UseField::deleteAll(['field_id' => $id]); $this->findModel($id)->delete(); return $this->redirect(['index']); } /** * Finds the AdditionalFields model based on its primary key value. * If the model is not found, a 404 HTTP exception will be thrown. * @param integer $id * @return AdditionalFields the loaded model * @throws NotFoundHttpException if the model cannot be found */ protected function findModel($id) { if (($model = AdditionalFields::findOne($id)) !== null) { return $model; } throw new NotFoundHttpException('The requested page does not exist.'); } }