|
- <?php
-
- /**
- Copyright La boîte à pain (2018)
-
- contact@laboiteapain.net
-
- Ce logiciel est un programme informatique servant à aider les producteurs
- à distribuer leur production en circuits courts.
-
- Ce logiciel est régi par la licence CeCILL soumise au droit français et
- respectant les principes de diffusion des logiciels libres. Vous pouvez
- utiliser, modifier et/ou redistribuer ce programme sous les conditions
- de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
- sur le site "http://www.cecill.info".
-
- En contrepartie de l'accessibilité au code source et des droits de copie,
- de modification et de redistribution accordés par cette licence, il n'est
- offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
- seule une responsabilité restreinte pèse sur l'auteur du programme, le
- titulaire des droits patrimoniaux et les concédants successifs.
-
- A cet égard l'attention de l'utilisateur est attirée sur les risques
- associés au chargement, à l'utilisation, à la modification et/ou au
- développement et à la reproduction du logiciel par l'utilisateur étant
- donné sa spécificité de logiciel libre, qui peut le rendre complexe à
- manipuler et qui le réserve donc à des développeurs et des professionnels
- avertis possédant des connaissances informatiques approfondies. Les
- utilisateurs sont donc invités à charger et tester l'adéquation du
- logiciel à leurs besoins dans des conditions permettant d'assurer la
- sécurité de leurs systèmes et ou de leurs données et, plus généralement,
- à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
-
- Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
- pris connaissance de la licence CeCILL, et que vous en avez accepté les
- termes.
- */
- /**
- Copyright La boîte à pain (2018)
-
- contact@laboiteapain.net
-
- Ce logiciel est un programme informatique servant à aider les producteurs
- à distribuer leur production en circuits courts.
-
- Ce logiciel est régi par la licence CeCILL soumise au droit français et
- respectant les principes de diffusion des logiciels libres. Vous pouvez
- utiliser, modifier et/ou redistribuer ce programme sous les conditions
- de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
- sur le site "http://www.cecill.info".
-
- En contrepartie de l'accessibilité au code source et des droits de copie,
- de modification et de redistribution accordés par cette licence, il n'est
- offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
- seule une responsabilité restreinte pèse sur l'auteur du programme, le
- titulaire des droits patrimoniaux et les concédants successifs.
-
- A cet égard l'attention de l'utilisateur est attirée sur les risques
- associés au chargement, à l'utilisation, à la modification et/ou au
- développement et à la reproduction du logiciel par l'utilisateur étant
- donné sa spécificité de logiciel libre, qui peut le rendre complexe à
- manipuler et qui le réserve donc à des développeurs et des professionnels
- avertis possédant des connaissances informatiques approfondies. Les
- utilisateurs sont donc invités à charger et tester l'adéquation du
- logiciel à leurs besoins dans des conditions permettant d'assurer la
- sécurité de leurs systèmes et ou de leurs données et, plus généralement,
- à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
-
- Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
- pris connaissance de la licence CeCILL, et que vous en avez accepté les
- termes.
- */
-
- namespace backend\controllers;
-
- class CommandeautoController extends BackendController {
-
- var $enableCsrfValidation = false;
-
- public function behaviors() {
- return [
- '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;
- }
- ]
- ],
- ],
- ];
- }
-
- public function actionIndex() {
- $dataProvider = new ActiveDataProvider([
- 'query' => CommandeAuto::find()
- ->with(['user', 'etablissement', 'pointVente', 'commandeAutoProduit'])
- ->joinWith(['user'])
- ->where(['commande_auto.id_etablissement' => Yii::$app->user->identity->id_etablissement])
- ->orderBy('commande_auto.id_point_vente ASC, CASE `commande_auto`.`username` WHEN "" THEN `user`.`nom` ELSE `commande_auto`.`username` END ASC'),
- 'pagination' => [
- 'pageSize' => 1000,
- ],
- ]);
-
- return $this->render('index', [
- 'dataProvider' => $dataProvider
- ]);
- }
-
- public function actionCreate() {
- // form
- $model = new CommandeAutoForm;
- $model->id_etablissement = Yii::$app->user->identity->id_etablissement;
-
- // produits
- $produits = Produit::find()
- ->where(['id_etablissement' => $model->id_etablissement])
- ->orderBy('order ASC')
- ->all();
-
- if ($model->load(Yii::$app->request->post()) && $model->validate() && $model->save()) {
-
- $this->redirect(['commandeauto/index']);
- }
-
- return $this->render('create', [
- 'model' => $model,
- 'produits' => $produits
- ]);
- }
-
- public function actionUpdate($id) {
- // form
- $model = new CommandeAutoForm;
- $commandeauto = CommandeAuto::findOne($id);
- if ($commandeauto) {
- $model->id = $id;
- $model->id_etablissement = $commandeauto->id_etablissement;
- $model->id_user = $commandeauto->id_user;
- $model->username = $commandeauto->username;
- $model->id_point_vente = $commandeauto->id_point_vente;
- $model->date_debut = date('d/m/Y', strtotime($commandeauto->date_debut));
- if (strlen($commandeauto->date_fin))
- $model->date_fin = date('d/m/Y', strtotime($commandeauto->date_fin));
- $model->lundi = $commandeauto->lundi;
- $model->lundi = $commandeauto->lundi;
- $model->mardi = $commandeauto->mardi;
- $model->mercredi = $commandeauto->mercredi;
- $model->jeudi = $commandeauto->jeudi;
- $model->vendredi = $commandeauto->vendredi;
- $model->samedi = $commandeauto->samedi;
- $model->dimanche = $commandeauto->dimanche;
- $model->paiement_automatique = $commandeauto->paiement_automatique;
- $model->periodicite_semaine = $commandeauto->periodicite_semaine;
-
-
- // produits
- $commandeauto_produits = CommandeAutoProduit::find()->where(['id_commande_auto' => $model->id])->all();
- foreach ($commandeauto_produits as $commandeauto_produit) {
- $model->produits['produit_' . $commandeauto_produit->id_produit] = $commandeauto_produit->quantite;
- }
- } else {
- throw new NotFoundHttpException('La commande récurrente est introuvable.', 404);
- }
-
- // produits
- $produits = Produit::find()
- ->where(['id_etablissement' => $model->id_etablissement])
- ->orderBy('order ASC')
- ->all();
-
- if ($model->load(Yii::$app->request->post()) && $model->validate()) {
-
- if (!strlen($model->date_fin)) {
- $model->date_fin = null;
- }
-
- if ($model->save()) {
- $this->redirect(['commandeauto/index']);
- }
- }
-
- return $this->render('update', [
- 'model' => $model,
- 'produits' => $produits
- ]);
- }
-
- public function actionDelete($id) {
- CommandeAutoProduit::deleteAll(['id_commande_auto' => $id]);
- CommandeAuto::findOne($id)->delete();
- $this->redirect(['commandeauto/index']);
- }
-
- }
|