Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

SubscriptionController.php 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325
  1. <?php
  2. /**
  3. * Copyright distrib (2018)
  4. *
  5. * contact@opendistrib.net
  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 common\forms\SubscriptionForm;
  39. use common\helpers\GlobalParam;
  40. use common\logic\Config\Unit\Service\UnitDefinition;
  41. use common\logic\Product\Product\Model\Product;
  42. use common\logic\Subscription\Subscription\Model\SubscriptionSearch;
  43. use yii\filters\AccessControl;
  44. use yii\web\NotFoundHttpException;
  45. class SubscriptionController extends BackendController
  46. {
  47. var $enableCsrfValidation = false;
  48. public function behaviors()
  49. {
  50. return [
  51. 'access' => [
  52. 'class' => AccessControl::class,
  53. 'rules' => [
  54. [
  55. 'allow' => true,
  56. 'roles' => ['@'],
  57. 'matchCallback' => function ($rule, $action) {
  58. return $this->getUserModule()
  59. ->getAuthorizationChecker()
  60. ->isGrantedAsProducer($this->getUserCurrent());
  61. }
  62. ]
  63. ],
  64. ],
  65. ];
  66. }
  67. /**
  68. * Liste les commandes récurrente du producteur.
  69. *
  70. * @return string
  71. */
  72. public function actionIndex()
  73. {
  74. $this->checkProductsPointsSale();
  75. $searchModel = new SubscriptionSearch();
  76. $dataProvider = $searchModel->search(\Yii::$app->request->queryParams);
  77. return $this->render('index', [
  78. 'searchModel' => $searchModel,
  79. 'dataProvider' => $dataProvider
  80. ]);
  81. }
  82. /**
  83. * Crée un abonnement.
  84. */
  85. public function actionCreate($idOrder = 0)
  86. {
  87. $orderModule = $this->getOrderModule();
  88. $producerModule = $this->getProducerModule();
  89. $productModule = $this->getProductModule();
  90. $subscriptionManger = $this->getSubscriptionModule();
  91. $distributionModule = $this-> getDistributionModule();
  92. $model = new SubscriptionForm();
  93. $model->isAdmin = true;
  94. $model->id_producer = GlobalParam::getCurrentProducerId();
  95. if ($idOrder) {
  96. $order = $orderModule->findOneOrderById($idOrder);
  97. if ($order) {
  98. $model->id_user = $order->id_user;
  99. $model->username = $order->username;
  100. $model->id_point_sale = $order->id_point_sale;
  101. $model->date_begin = date('d/m/Y');
  102. $dateDay = strtolower(date('l', strtotime($order->distribution->date)));
  103. $model->$dateDay = 1;
  104. $model->week_frequency = 1;
  105. if ($model->id_user && $producerModule->getConfig('credit')) {
  106. $model->auto_payment = 1;
  107. }
  108. foreach ($order->productOrder as $productOrder) {
  109. $model->products['product_' . $productOrder->id_product] = $productOrder->quantity;
  110. }
  111. } else {
  112. throw new NotFoundHttpException('La commande est introuvable.', 404);
  113. }
  114. }
  115. // produits
  116. $productsArray = $productModule->findProducts();
  117. if ($model->load(\Yii::$app->request->post()) && $model->validate() && $model->save()) {
  118. $this->setFlash('success', 'Abonnement ajouté');
  119. $subscription = $subscriptionManger->findOneSubscriptionById($model->id);
  120. $matchedDistributionsArray = $distributionModule->findDistributionsIncomingMatchWithSubscrtiption($subscription);
  121. if (count($matchedDistributionsArray)) {
  122. return $this->redirect(['subscription/update-distributions', 'idSubscription' => $subscription->id]);
  123. } else {
  124. return $this->redirect(['subscription/index']);
  125. }
  126. }
  127. return $this->render('create', [
  128. 'model' => $model,
  129. 'productsArray' => $productsArray
  130. ]);
  131. }
  132. /**
  133. * Modifie un abonnement.
  134. */
  135. public function actionUpdate($id)
  136. {
  137. $subscriptionModule = $this->getSubscriptionModule();
  138. $productSubscriptionModule = $this->getProductSubscriptionModule();
  139. $productModule = $this->getProductModule();
  140. $distributionModule = $this-> getDistributionModule();
  141. $orderModule = $this->getOrderModule();
  142. $model = new SubscriptionForm;
  143. $model->isAdmin = true;
  144. $subscription = $subscriptionModule->findOneSubscriptionById($id);
  145. if ($subscription) {
  146. $model->id = $id;
  147. $model->id_producer = $subscription->id_producer;
  148. $model->id_user = $subscription->id_user;
  149. $model->username = $subscription->username;
  150. $model->id_point_sale = $subscription->id_point_sale;
  151. $model->monday = $subscription->monday;
  152. $model->tuesday = $subscription->tuesday;
  153. $model->wednesday = $subscription->wednesday;
  154. $model->thursday = $subscription->thursday;
  155. $model->friday = $subscription->friday;
  156. $model->saturday = $subscription->saturday;
  157. $model->sunday = $subscription->sunday;
  158. $model->auto_payment = $subscription->auto_payment;
  159. $model->week_frequency = $subscription->week_frequency;
  160. $model->date_begin = date('d/m/Y', strtotime($subscription->date_begin));
  161. if ($subscription->date_end) {
  162. $model->date_end = date('d/m/Y', strtotime($subscription->date_end));
  163. }
  164. if (strlen($subscription->comment)) {
  165. $model->comment = $subscription->comment;
  166. }
  167. $arrayProductsSubscription = $productSubscriptionModule->findProductSubscriptionsBySubscription($subscription);
  168. foreach ($arrayProductsSubscription as $productSubscription) {
  169. $model->products['product_' . $productSubscription->id_product] = $productSubscription->quantity;
  170. }
  171. } else {
  172. throw new NotFoundHttpException('L\'abonnement est introuvable.', 404);
  173. }
  174. // produits
  175. $productsArray = $productModule->findProducts();
  176. if ($model->load(\Yii::$app->request->post()) && $model->validate()) {
  177. if (!$model->date_end) {
  178. $model->date_end = null;
  179. }
  180. if ($model->save()) {
  181. $subscription = $subscriptionModule->findOneSubscriptionById($model->id);
  182. $messageOrdersDeleted = '';
  183. if ($model->date_end) {
  184. $countOrdersDeleted = $subscriptionModule->getOrderManager()
  185. ->deleteOrdersIncomingDistributionsFromSubscription($subscription, true);
  186. if ($countOrdersDeleted) {
  187. $messageOrdersDeleted = '<br />' . $countOrdersDeleted . ' commandes supprimées';
  188. }
  189. }
  190. $this->setFlash('success', 'Abonnement modifié' . $messageOrdersDeleted);
  191. $matchedDistributionsArray = $distributionModule->findDistributionsIncomingMatchWithSubscrtiption($subscription);
  192. if (count($matchedDistributionsArray)) {
  193. return $this->redirect(['subscription/update-distributions', 'idSubscription' => $subscription->id, 'update' => true]);
  194. } else {
  195. return $this->redirect(['subscription/index']);
  196. }
  197. }
  198. }
  199. return $this->render('update', [
  200. 'model' => $model,
  201. 'productsArray' => $productsArray
  202. ]);
  203. }
  204. /**
  205. * Supprime une commande récurrente.
  206. */
  207. public function actionDelete(int $id)
  208. {
  209. $subscriptionModule = $this->getSubscriptionModule();
  210. $orderModule = $this->getOrderModule();
  211. $subscription = $subscriptionModule->getRepository()->findOneSubscriptionById($id);
  212. if($subscription) {
  213. $subscriptionModule->getOrderManager()->deleteOrdersIncomingDistributionsFromSubscription($subscription);
  214. $subscriptionModule->deleteSubscription($subscription);
  215. $this->setFlash('success', 'Abonnement supprimé');
  216. }
  217. else {
  218. $this->setFlash('danger', 'Abonnement introuvable');
  219. }
  220. return $this->redirect(['subscription/index']);
  221. }
  222. public function actionUpdateDistributions(int $idSubscription, bool $generate = false, bool $update = false)
  223. {
  224. $subscriptionModule = $this->getSubscriptionModule();
  225. $distributionModule = $this-> getDistributionModule();
  226. $subscription = $subscriptionModule->findOneSubscriptionById($idSubscription);
  227. if($subscription) {
  228. $matchedDistributionsArray = $distributionModule->findDistributionsIncomingMatchWithSubscrtiption($subscription, true);
  229. if ($generate) {
  230. if ($update) {
  231. $subscriptionModule->getOrderManager()
  232. ->deleteOrdersIncomingDistributionsFromSubscription($subscription);
  233. }
  234. foreach ($matchedDistributionsArray as $distribution) {
  235. $subscriptionModule->createOrderFromSubscription($subscription, $distribution->date);
  236. }
  237. $this->setFlash('success', 'Commandes ' . ($update ? 're-' : '') . 'générées dans les distributions futures.');
  238. return $this->redirect(['subscription/index']);
  239. }
  240. return $this->render('update_distributions', [
  241. 'matchedDistributionsArray' => $matchedDistributionsArray,
  242. 'idSubscription' => $idSubscription,
  243. 'update' => $update
  244. ]);
  245. }
  246. else {
  247. $this->setFlash('error', 'Abonnement introuvable');
  248. return $this->redirect(['subscription/index']);
  249. }
  250. }
  251. public function actionAjaxInfos(int $idSubscription = 0)
  252. {
  253. \Yii::$app->response->format = \yii\web\Response::FORMAT_JSON;
  254. $unitModule = $this->getUnitModule();
  255. $productModule = $this->getProductModule();
  256. $productsQuery = Product::find()
  257. ->where(['id_producer' => GlobalParam::getCurrentProducerId()])
  258. ->andWhere('status >= :status')
  259. ->addParams(['status' => Product::STATUS_OFFLINE]);
  260. if ($idSubscription) {
  261. $productsQuery->joinWith(['productSubscription' => function ($query) use ($idSubscription) {
  262. $query->andOnCondition('product_subscription.id_subscription = ' . ((int)$idSubscription));
  263. }]);
  264. }
  265. $productsArray = $productsQuery->asArray()->orderBy('order ASC')->all();
  266. foreach ($productsArray as &$theProduct) {
  267. $theProduct['wording_unit'] = $unitModule->getSolver()->strUnit($theProduct['unit']);
  268. if (isset($theProduct['productSubscription'][0])) {
  269. $theProduct['quantity'] = $theProduct['productSubscription'][0]['quantity'] * Product::$unitsArray[$theProduct['unit']]['coefficient'];
  270. } else {
  271. $theProduct['quantity'] = '';
  272. }
  273. }
  274. return [
  275. 'products' => $productsArray
  276. ];
  277. }
  278. }