Вы не можете выбрать более 25 тем Темы должны начинаться с буквы или цифры, могут содержать дефисы(-) и должны содержать не более 35 символов.

AccessoryController.php 5.8KB

7 месяцев назад
7 месяцев назад
7 месяцев назад
7 месяцев назад
7 месяцев назад
7 месяцев назад
7 месяцев назад
7 месяцев назад
7 месяцев назад
7 месяцев назад
7 месяцев назад
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162
  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\Product\Accessory\Accessory;
  39. use yii\base\Response;
  40. use yii\db\StaleObjectException;
  41. use yii\filters\AccessControl;
  42. use yii\web\NotFoundHttpException;
  43. class AccessoryController extends BackendController
  44. {
  45. public function behaviors()
  46. {
  47. return [
  48. 'access' => [
  49. 'class' => AccessControl::class,
  50. 'rules' => [
  51. [
  52. 'allow' => true,
  53. 'roles' => ['@'],
  54. 'matchCallback' => function ($rule, $action) {
  55. return $this->getUserModule()
  56. ->getAuthorizationChecker()
  57. ->isGrantedAsProducer($this->getUserCurrent());
  58. }
  59. ]
  60. ],
  61. ],
  62. ];
  63. }
  64. public function actionIndex()
  65. {
  66. return $this->render('index', [
  67. 'dataProvider' => $this->getAccessoryModule()->getRepository()
  68. ->queryAccessories()->getDataProvider(20),
  69. ]);
  70. }
  71. public function actionCreate()
  72. {
  73. $accessoryModule = $this->getAccessoryModule();
  74. $accessoryModel = $accessoryModule->getBuilder()->instanciateAccessory($this->getProducerCurrent());
  75. if ($accessoryModel->load(\Yii::$app->request->post()) && $accessoryModel->validate()) {
  76. $accessory = $accessoryModule->getManager()->createAccessory(
  77. $this->getProducerCurrent(),
  78. $accessoryModel->getName(),
  79. $accessoryModel->getQuantity()
  80. );
  81. $this->afterSave($accessory, $accessoryModel->getSelectedProductsIds());
  82. $this->setFlash('success', "Accessoire ajouté");
  83. return $this->redirectAfterSave('accessory', $accessory->getId());
  84. }
  85. return $this->render('create', [
  86. 'accessory' => $this->initFormModel($accessoryModel),
  87. 'productsArray' => $this->findProducts()
  88. ]);
  89. }
  90. /**
  91. * @throws NotFoundHttpException
  92. */
  93. public function actionUpdate(int $id)
  94. {
  95. $accessory = $this->findAccessory($id);
  96. if ($accessory->load(\Yii::$app->request->post()) && $accessory->validate() && $accessory->save()) {
  97. $this->afterSave($accessory, $accessory->getSelectedProductsIds());
  98. return $this->redirectAfterSave('accessory', $accessory->getId());
  99. }
  100. return $this->render('update', [
  101. 'accessory' => $this->initFormModel($accessory),
  102. 'productsArray' => $this->findProducts()
  103. ]);
  104. }
  105. /**
  106. * @throws \Throwable
  107. * @throws StaleObjectException
  108. * @throws NotFoundHttpException
  109. */
  110. public function actionDelete(int $id): Response
  111. {
  112. $accessory = $this->findAccessory($id);
  113. if($accessory->delete()) {
  114. $this->setFlash('success', "Accessoire supprimé");
  115. }
  116. return $this->redirect('index');
  117. }
  118. public function afterSave(Accessory $accessory, $selectedProductsIdsArray): void
  119. {
  120. if(!is_array($selectedProductsIdsArray)) {
  121. $selectedProductsIdsArray = [];
  122. }
  123. $this->getAccessoryModule()->getManager()->manageProducts($accessory, $selectedProductsIdsArray);
  124. }
  125. public function findProducts(): array
  126. {
  127. return $this->getProductModule()->getRepository()->findProducts(true);
  128. }
  129. /**
  130. * @throws NotFoundHttpException
  131. */
  132. protected function findAccessory($id): Accessory
  133. {
  134. if (($accessory = $this->getAccessoryModule()->getRepository()->findOneAccessoryById($id)) !== null) {
  135. return $accessory;
  136. } else {
  137. throw new NotFoundHttpException("L'accessoire n'a pas été trouvé.");
  138. }
  139. }
  140. public function initFormModel(Accessory $accessoryModel)
  141. {
  142. $this->getAccessoryModule()->getBuilder()->initSelectedProductsIds($accessoryModel);
  143. return $accessoryModel;
  144. }
  145. }