You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

AccessoryController.php 6.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166
  1. <?php
  2. /**
  3. * Copyright Souke (2018)
  4. *
  5. * contact@souke.fr
  6. *
  7. * Ce logiciel est un programme informatique servant à aider les producteurs
  8. * à distribuer leur production en circuits courts.
  9. *
  10. * Ce logiciel est régi par la licence CeCILL soumise au droit français et
  11. * respectant les principes de diffusion des logiciels libres. Vous pouvez
  12. * utiliser, modifier et/ou redistribuer ce programme sous les conditions
  13. * de la licence CeCILL telle que diffusée par le CEA, le CNRS et l'INRIA
  14. * sur le site "http://www.cecill.info".
  15. *
  16. * En contrepartie de l'accessibilité au code source et des droits de copie,
  17. * de modification et de redistribution accordés par cette licence, il n'est
  18. * offert aux utilisateurs qu'une garantie limitée. Pour les mêmes raisons,
  19. * seule une responsabilité restreinte pèse sur l'auteur du programme, le
  20. * titulaire des droits patrimoniaux et les concédants successifs.
  21. *
  22. * A cet égard l'attention de l'utilisateur est attirée sur les risques
  23. * associés au chargement, à l'utilisation, à la modification et/ou au
  24. * développement et à la reproduction du logiciel par l'utilisateur étant
  25. * donné sa spécificité de logiciel libre, qui peut le rendre complexe à
  26. * manipuler et qui le réserve donc à des développeurs et des professionnels
  27. * avertis possédant des connaissances informatiques approfondies. Les
  28. * utilisateurs sont donc invités à charger et tester l'adéquation du
  29. * logiciel à leurs besoins dans des conditions permettant d'assurer la
  30. * sécurité de leurs systèmes et ou de leurs données et, plus généralement,
  31. * à l'utiliser et l'exploiter dans les mêmes conditions de sécurité.
  32. *
  33. * Le fait que vous puissiez accéder à cet en-tête signifie que vous avez
  34. * pris connaissance de la licence CeCILL, et que vous en avez accepté les
  35. * termes.
  36. */
  37. namespace backend\controllers;
  38. use domain\Feature\Feature\Feature;
  39. use domain\Product\Accessory\Accessory;
  40. use yii\base\Response;
  41. use yii\db\StaleObjectException;
  42. use yii\filters\AccessControl;
  43. use yii\web\NotFoundHttpException;
  44. class AccessoryController extends BackendController
  45. {
  46. public function behaviors()
  47. {
  48. return [
  49. 'access' => [
  50. 'class' => AccessControl::class,
  51. 'rules' => [
  52. [
  53. 'allow' => true,
  54. 'roles' => ['@'],
  55. 'matchCallback' => function ($rule, $action) {
  56. return $this->getUserModule()
  57. ->getAuthorizationChecker()
  58. ->isGrantedAsProducer($this->getUserCurrent())
  59. && $this->getFeatureModule()->getChecker()
  60. ->isEnabled(Feature::ALIAS_PRODUCT_ACCESSORY);
  61. }
  62. ]
  63. ],
  64. ],
  65. ];
  66. }
  67. public function actionIndex()
  68. {
  69. return $this->render('index', [
  70. 'dataProvider' => $this->getAccessoryModule()->getRepository()
  71. ->queryAccessories()->getDataProvider(20),
  72. ]);
  73. }
  74. public function actionCreate()
  75. {
  76. $accessoryModule = $this->getAccessoryModule();
  77. $accessoryModel = $accessoryModule->getBuilder()->instanciateAccessory($this->getProducerCurrent());
  78. if ($accessoryModel->load(\Yii::$app->request->post()) && $accessoryModel->validate()) {
  79. $accessory = $accessoryModule->getManager()->createAccessory(
  80. $this->getProducerCurrent(),
  81. $accessoryModel->getName(),
  82. $accessoryModel->getQuantity()
  83. );
  84. $this->afterSave($accessory, $accessoryModel->getSelectedProductsIds());
  85. $this->setFlash('success', "Accessoire ajouté");
  86. return $this->redirectAfterSave('accessory', $accessory->getId());
  87. }
  88. return $this->render('create', [
  89. 'accessory' => $this->initFormModel($accessoryModel),
  90. 'productsArray' => $this->findProducts()
  91. ]);
  92. }
  93. /**
  94. * @throws NotFoundHttpException
  95. */
  96. public function actionUpdate(int $id)
  97. {
  98. $accessory = $this->findAccessory($id);
  99. if ($accessory->load(\Yii::$app->request->post()) && $accessory->validate() && $accessory->save()) {
  100. $this->afterSave($accessory, $accessory->getSelectedProductsIds());
  101. return $this->redirectAfterSave('accessory', $accessory->getId());
  102. }
  103. return $this->render('update', [
  104. 'accessory' => $this->initFormModel($accessory),
  105. 'productsArray' => $this->findProducts()
  106. ]);
  107. }
  108. /**
  109. * @throws \Throwable
  110. * @throws StaleObjectException
  111. * @throws NotFoundHttpException
  112. */
  113. public function actionDelete(int $id): Response
  114. {
  115. $accessory = $this->findAccessory($id);
  116. if($accessory->delete()) {
  117. $this->setFlash('success', "Accessoire supprimé");
  118. }
  119. return $this->redirect('index');
  120. }
  121. public function afterSave(Accessory $accessory, $selectedProductsIdsArray): void
  122. {
  123. if(!is_array($selectedProductsIdsArray)) {
  124. $selectedProductsIdsArray = [];
  125. }
  126. $this->getAccessoryModule()->getManager()->manageProducts($accessory, $selectedProductsIdsArray);
  127. }
  128. public function findProducts(): array
  129. {
  130. return $this->getProductModule()->getRepository()->findProducts(true);
  131. }
  132. /**
  133. * @throws NotFoundHttpException
  134. */
  135. protected function findAccessory($id): Accessory
  136. {
  137. if (($accessory = $this->getAccessoryModule()->getRepository()->findOneAccessoryById($id)) !== null) {
  138. return $accessory;
  139. } else {
  140. throw new NotFoundHttpException("L'accessoire n'a pas été trouvé.");
  141. }
  142. }
  143. public function initFormModel(Accessory $accessoryModel)
  144. {
  145. $this->getAccessoryModule()->getBuilder()->initSelectedProductsIds($accessoryModel);
  146. return $accessoryModel;
  147. }
  148. }