fitness-web/backend/controllers/WasteController.php
2016-05-08 08:56:42 +02:00

136 lines
2.9 KiB
PHP

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