258 lines
9.9KB

  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 backend\models\MailForm;
  39. use common\helpers\GlobalParam;
  40. use kartik\mpdf\Pdf;
  41. use domain\PointSale\PointSale\PointSale;
  42. use yii\filters\AccessControl;
  43. use yii\filters\VerbFilter;
  44. /**
  45. * UserController implements the CRUD actions for User model.
  46. */
  47. class CommunicateController extends BackendController
  48. {
  49. public function behaviors()
  50. {
  51. return [
  52. 'verbs' => [
  53. 'class' => VerbFilter::class,
  54. 'actions' => [
  55. 'delete' => ['post'],
  56. ],
  57. ],
  58. 'access' => [
  59. 'class' => AccessControl::class,
  60. 'rules' => [
  61. [
  62. 'allow' => true,
  63. 'roles' => ['@'],
  64. 'matchCallback' => function ($rule, $action) {
  65. return $this->getUserModule()
  66. ->getAuthorizationChecker()
  67. ->isGrantedAsProducer($this->getUserCurrent());
  68. }
  69. ]
  70. ],
  71. ],
  72. ];
  73. }
  74. public function actionEmail(
  75. $idPointSale = 0,
  76. $sectionSubscribers = 0,
  77. $sectionInactiveUsers = 0,
  78. $usersPointSaleLink = 0,
  79. $usersPointSaleHasOrder = 0,
  80. $idDistribution = 0)
  81. {
  82. $producerCurrent = $this->getProducerCurrent();
  83. $userModule = $this->getUserModule();
  84. $distributionModule = $this->getDistributionModule();
  85. $mailForm = new MailForm();
  86. if ($idPointSale && !$usersPointSaleLink && !$usersPointSaleHasOrder) {
  87. $usersPointSaleLink = 1;
  88. }
  89. if ($idDistribution && !$usersPointSaleLink && !$usersPointSaleHasOrder) {
  90. $usersPointSaleLink = 1;
  91. }
  92. if($idDistribution) {
  93. $users = [];
  94. $distribution = $distributionModule->getRepository()->findOneDistributionById($idDistribution);
  95. if($distribution) {
  96. $mailForm->id_distribution = $idDistribution;
  97. foreach($distribution->pointSaleDistribution as $pointSaleDistribution) {
  98. if($pointSaleDistribution->delivery) {
  99. $usersPointSaleArray = $userModule->getRepository()->queryUsersBy([
  100. 'id_producer' => $producerCurrent->id,
  101. 'id_point_sale' => $pointSaleDistribution->id_point_sale,
  102. 'users_point_sale_link' => $usersPointSaleLink,
  103. 'users_point_sale_has_order' => $usersPointSaleHasOrder,
  104. 'newsletter' => true
  105. ])->all();
  106. foreach($usersPointSaleArray as $user) {
  107. $users[$user['id']] = $user;
  108. }
  109. }
  110. }
  111. }
  112. }
  113. else {
  114. $users = $userModule->queryUsersBy([
  115. 'id_producer' => GlobalParam::getCurrentProducerId(),
  116. 'id_point_sale' => $idPointSale,
  117. 'users_point_sale_link' => $usersPointSaleLink,
  118. 'users_point_sale_has_order' => $usersPointSaleHasOrder,
  119. 'subscribers' => $sectionSubscribers,
  120. 'inactive' => $sectionInactiveUsers,
  121. 'newsletter' => true
  122. ])->all();
  123. }
  124. $usersArray = [];
  125. foreach ($users as $key => $user) {
  126. if (isset($user['email']) && strlen($user['email']) > 0) {
  127. $usersArray[] = $user['email'];
  128. } else {
  129. unset($users[$key]);
  130. }
  131. }
  132. $pointsSaleArray = PointSale::find()->where(['id_producer' => GlobalParam::getCurrentProducerId(), 'status' => 1])->all();
  133. $pointSale = null;
  134. if ($idPointSale) {
  135. $pointSale = PointSale::findOne(['id' => $idPointSale]);
  136. }
  137. if ($mailForm->load(\Yii::$app->request->post()) && $mailForm->validate()) {
  138. $responseSendMail = $mailForm->sendEmail($users);
  139. if ($responseSendMail->success()) {
  140. $this->setFlash('success', 'Votre email a bien été envoyé.');
  141. } else {
  142. $bodyResponseSendMail = $responseSendMail->getBody();
  143. $emailsErrorArray = [];
  144. if (isset($bodyResponseSendMail['Messages'])) {
  145. foreach ($bodyResponseSendMail['Messages'] as $message) {
  146. if ($message['Status'] != 'success') {
  147. $emailsErrorArray[] = $message['Errors'][0]['ErrorMessage'];
  148. }
  149. }
  150. }
  151. $messageError = 'Un problème est survenu lors de l\'envoi de votre email.';
  152. if (count($emailsErrorArray) > 0) {
  153. $messageError .= '<br />Problème détecté : ' . implode(',', $emailsErrorArray);
  154. }
  155. $this->setFlash('error', $messageError);
  156. }
  157. return $this->redirect(['email', 'idPointSale' => $idPointSale]);
  158. }
  159. $incomingDistributionsArray = $distributionModule->findDistributionsIncoming();
  160. $incomingDistributionsDatesArray = ['0' => '--'];
  161. foreach ($incomingDistributionsArray as $distribution) {
  162. $incomingDistributionsDatesArray[$distribution->id] = strftime('%A %d %B %Y', strtotime($distribution->date));
  163. }
  164. return $this->render('email', [
  165. 'usersArray' => $usersArray,
  166. 'pointsSaleArray' => $pointsSaleArray,
  167. 'pointSale' => $pointSale,
  168. 'mailForm' => $mailForm,
  169. 'idPointSaleActive' => $idPointSale,
  170. 'idDistributionActive' => $idDistribution,
  171. 'incomingDistributionsArray' => $incomingDistributionsArray,
  172. 'incomingDistributionsDatesArray' => $incomingDistributionsDatesArray,
  173. 'sectionSubscribers' => $sectionSubscribers,
  174. 'sectionInactiveUsers' => $sectionInactiveUsers,
  175. 'usersPointSaleLink' => $usersPointSaleLink,
  176. 'usersPointSaleHasOrder' => $usersPointSaleHasOrder,
  177. ]);
  178. }
  179. public function actionPaper()
  180. {
  181. $producer = $this->getProducerCurrent();
  182. return $this->render('paper', [
  183. 'producer' => $producer,
  184. ]);
  185. }
  186. /**
  187. * Génére un PDF contenant le mode d'emploi d'utilisation de la plateforme
  188. * à destination des clients des producteurs.
  189. *
  190. * @return string
  191. */
  192. public function actionInstructions()
  193. {
  194. $producer = $this->getProducerCurrent();
  195. // get your HTML raw content without any layouts or scripts
  196. $content = $this->renderPartial('instructions_multi', [
  197. 'pdf' => true,
  198. 'producer' => $producer
  199. ]);
  200. $pdf = new Pdf([
  201. // set to use core fonts only
  202. 'mode' => Pdf::MODE_UTF8,
  203. // A4 paper format
  204. 'format' => Pdf::FORMAT_A4,
  205. // portrait orientation
  206. 'orientation' => Pdf::ORIENT_PORTRAIT,
  207. // stream to browser inline
  208. 'destination' => Pdf::DEST_BROWSER,
  209. // your html content input
  210. 'content' => $content,
  211. 'marginRight' => 0,
  212. 'marginLeft' => 0,
  213. 'marginTop' => 0,
  214. 'marginBottom' => 0,
  215. // format content from your own css file if needed or use the
  216. // enhanced bootstrap css built by Krajee for mPDF formatting
  217. //'cssFile' => '@vendor/kartik-v/yii2-mpdf/assets/kv-mpdf-bootstrap.min.css',
  218. 'cssFile' => '@app/web/css/screen.css',
  219. // any css to be embedded if required
  220. //'cssInline' => '.kv-heading-1{font-size:18px}',
  221. // set mPDF properties on the fly
  222. //'options' => ['title' => 'Krajee Report Title'],
  223. // call mPDF methods on the fly
  224. /* 'methods' => [
  225. 'SetHeader'=>['Commandes du '.$date_str],
  226. 'SetFooter'=>['{PAGENO}'],
  227. ] */
  228. ]);
  229. // return the pdf output as per the destination setting
  230. return $pdf->render();
  231. }
  232. }