Du kannst nicht mehr als 25 Themen auswählen Themen müssen entweder mit einem Buchstaben oder einer Ziffer beginnen. Sie können Bindestriche („-“) enthalten und bis zu 35 Zeichen lang sein.

SubscriptionController.php 13KB

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