[ 'class' => VerbFilter::className(), 'actions' => [ ], ], 'access' => [ 'class' => AccessControl::className(), 'rules' => [ [ 'allow' => true, 'roles' => ['@'], 'matchCallback' => function ($rule, $action) { return Yii::$app->user->identity->status == USER::STATUS_ADMIN || Yii::$app->user->identity->status == USER::STATUS_BOULANGER; } ] ], ], ]; } /** * Liste les modèles Produit. * * @return mixed */ public function actionIndex() { $dataProvider = new ActiveDataProvider([ 'query' => Produit::find() ->where('(vrac IS NULL OR vrac = 0)') ->andWhere(['id_etablissement' => Yii::$app->user->identity->id_etablissement]) ->orderBy('order ASC'), 'pagination' => [ 'pageSize' => 1000, ], ]); return $this->render('index', [ 'dataProvider' => $dataProvider, ]); } /** * Crée un modèle Produit. * Si la création réussit, le navigateur est redirigé vers la page 'index'. * * @return mixed */ public function actionCreate() { $model = new Produit(); $model->actif = 1; $model->id_etablissement = Yii::$app->user->identity->id_etablissement; $model->saison = 'all'; if ($model->load(Yii::$app->request->post()) && $model->save()) { Upload::uploadFile($model, 'illustration'); Upload::uploadFile($model, 'photo'); $model->save(); // on ajoute un enregistrement ProductionProduit pour chaque production $productions = Production::find() ->where('date > ' . date('Y-m-d')) ->andWhere(['id_etablissement' => Yii::$app->user->identity->id_etablissement]) ->all(); foreach ($productions as $prod) { $production_produit = new ProductionProduit; $production_produit->id_production = $prod->id; $production_produit->id_produit = $model->id; $production_produit->actif = 0; $production_produit->save(); } return $this->redirect(['index']); } else { return $this->render('create', [ 'model' => $model, ]); } } /** * Modifie un modèle Produit existant. * Si la modification réussit, le navigateur est redirigé vers la page 'index'. * * @param integer $id * @return mixed */ public function actionUpdate($id) { $request = Yii::$app->request; $model = $this->findModel($id); $illustration_filename_old = $model->illustration; $photo_filename_old = $model->photo; if ($model->load(Yii::$app->request->post()) && $model->save()) { Upload::uploadFile($model, 'illustration', $illustration_filename_old); Upload::uploadFile($model, 'photo', $photo_filename_old); $delete_illustration = $request->post('delete_illustration', 0); if ($delete_illustration) { $model->illustration = ''; $model->save(); } $delete_photo = $request->post('delete_photo', 0); if ($delete_photo) { $model->photo = ''; $model->save(); } return $this->redirect(['index']); } else { return $this->render('update', [ 'model' => $model, ]); } } /** * Supprime un modèle Produit. * Si la suppression réussit, le navigateur est redirigé vers la page * 'index'. * * @param integer $id * @return mixed */ public function actionDelete($id) { $this->findModel($id)->delete(); $productions_produits = ProductionProduit::find()->where(['id_produit' => $id])->all(); foreach ($productions_produits as $pp) { $pp->delete(); } return $this->redirect(['index']); } /** * Modifie l'ordre des produits. * * @param array $tab */ public function actionOrdre($tab) { $tab_ordre = json_decode(stripslashes($tab)); foreach ($tab_ordre as $id => $o) { $produit = $this->findModel($id); $produit->order = $o; $produit->save(); } } /** * Recherche un produit en fonction de son ID. * * @param integer $id * @return Produit * @throws NotFoundHttpException si le modèle n'est pas trouvé */ protected function findModel($id) { if (($model = Produit::findOne($id)) !== null) { return $model; } else { throw new NotFoundHttpException('The requested page does not exist.'); } } }