No puede seleccionar más de 25 temas Los temas deben comenzar con una letra o número, pueden incluir guiones ('-') y pueden tener hasta 35 caracteres de largo.

224 líneas
8.7KB

  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 domain\Communication\Email\ContactListResolver;
  41. use domain\Communication\Email\Email;
  42. use domain\Communication\Email\EmailGenerator;
  43. use domain\PointSale\PointSale\PointSale;
  44. use kartik\mpdf\Pdf;
  45. use yii\filters\AccessControl;
  46. use yii\filters\VerbFilter;
  47. /**
  48. * UserController implements the CRUD actions for User model.
  49. */
  50. class CommunicateController extends BackendController
  51. {
  52. public function behaviors()
  53. {
  54. return [
  55. 'verbs' => [
  56. 'class' => VerbFilter::class,
  57. 'actions' => [
  58. 'delete' => ['post'],
  59. ],
  60. ],
  61. 'access' => [
  62. 'class' => AccessControl::class,
  63. 'rules' => [
  64. [
  65. 'allow' => true,
  66. 'roles' => ['@'],
  67. 'matchCallback' => function ($rule, $action) {
  68. return $this->getUserModule()
  69. ->getAuthorizationChecker()
  70. ->isGrantedAsProducer($this->getUserCurrent());
  71. }
  72. ]
  73. ],
  74. ],
  75. ];
  76. }
  77. public function actionEmail(
  78. $idPointSale = 0,
  79. $sectionSubscribers = 0,
  80. $sectionInactiveUsers = 0,
  81. $usersPointSaleLink = 0,
  82. $usersPointSaleHasOrder = 0,
  83. $idDistribution = 0,
  84. $newsletterType = null
  85. ) {
  86. $emailModule = $this->getEmailModule();
  87. $mailForm = new MailForm();
  88. // Sujet et message par défaut
  89. $mailForm->subject = $this->getProducerModule()->getSolver()->getConfig('option_communicate_email_default_subject');
  90. $mailForm->message = $this->getProducerModule()->getSolver()->getConfig('option_communicate_email_default_message');
  91. $pointSale = $idPointSale ? $this->getPointSaleModule()->getRepository()->findOnePointSaleById($idPointSale) : null;
  92. $distribution = $idDistribution ? $this->getDistributionModule()->getRepository()->findOneDistributionById($idDistribution) : null;
  93. if($distribution) {
  94. $mailForm->id_distribution = $distribution->id;
  95. }
  96. $usersArray = $emailModule->getContactListResolver()->search(
  97. $this->getProducerCurrent(),
  98. $newsletterType,
  99. $distribution,
  100. $pointSale,
  101. $usersPointSaleLink,
  102. $usersPointSaleHasOrder,
  103. $sectionSubscribers,
  104. $sectionInactiveUsers
  105. );
  106. if ($mailForm->load(\Yii::$app->request->post()) && $mailForm->validate()) {
  107. if($this->getProducerCurrent()->isDemoAccount()) {
  108. $this->setFlash('error', "Fonctionnalité désactivée sur le compte de démo.");
  109. }
  110. else {
  111. $distribution = $mailForm->id_distribution
  112. ? $this->getDistributionModule()->getRepository()->findOneDistributionById($mailForm->id_distribution)
  113. : null;
  114. $email = $emailModule->getGenerator()->createEmail(
  115. $mailForm->subject,
  116. $mailForm->message,
  117. (bool) $mailForm->integrate_product_list,
  118. $this->getProducerCurrent(),
  119. $distribution
  120. );
  121. $emailModule->getBulkMailer()->sendEmail($email, $usersArray);
  122. $this->setFlash('success', 'Votre email a bien été envoyé.');
  123. }
  124. return $this->redirect(['email', 'idPointSale' => $idPointSale]);
  125. }
  126. $pointsSaleArray = PointSale::find()->where(['id_producer' => GlobalParam::getCurrentProducerId(), 'status' => 1])->all();
  127. $incomingDistributionsArray = $this->getDistributionModule()->getRepository()->findDistributionsIncoming();
  128. $incomingDistributionsDatesArray = ['0' => '--'];
  129. foreach ($incomingDistributionsArray as $distribution) {
  130. $incomingDistributionsDatesArray[$distribution->id] = strftime('%A %d %B %Y', strtotime($distribution->date));
  131. }
  132. return $this->render('email', [
  133. 'usersArray' => $usersArray,
  134. 'pointsSaleArray' => $pointsSaleArray,
  135. 'pointSale' => $pointSale,
  136. 'mailForm' => $mailForm,
  137. 'idPointSaleActive' => $idPointSale,
  138. 'idDistributionActive' => $idDistribution,
  139. 'incomingDistributionsArray' => $incomingDistributionsArray,
  140. 'incomingDistributionsDatesArray' => $incomingDistributionsDatesArray,
  141. 'sectionSubscribers' => $sectionSubscribers,
  142. 'sectionInactiveUsers' => $sectionInactiveUsers,
  143. 'usersPointSaleLink' => $usersPointSaleLink,
  144. 'usersPointSaleHasOrder' => $usersPointSaleHasOrder,
  145. 'newsletterType' => $newsletterType,
  146. ]);
  147. }
  148. public function actionPaper()
  149. {
  150. $producer = $this->getProducerCurrent();
  151. return $this->render('paper', [
  152. 'producer' => $producer,
  153. ]);
  154. }
  155. /**
  156. * Génére un PDF contenant le mode d'emploi d'utilisation de la plateforme
  157. * à destination des clients des producteurs.
  158. *
  159. * @return string
  160. */
  161. public function actionInstructions()
  162. {
  163. $producer = $this->getProducerCurrent();
  164. // get your HTML raw content without any layouts or scripts
  165. $content = $this->renderPartial('instructions_multi', [
  166. 'pdf' => true,
  167. 'producer' => $producer
  168. ]);
  169. $pdf = new Pdf([
  170. // set to use core fonts only
  171. 'mode' => Pdf::MODE_UTF8,
  172. // A4 paper format
  173. 'format' => Pdf::FORMAT_A4,
  174. // portrait orientation
  175. 'orientation' => Pdf::ORIENT_PORTRAIT,
  176. // stream to browser inline
  177. 'destination' => Pdf::DEST_BROWSER,
  178. // your html content input
  179. 'content' => $content,
  180. 'marginRight' => 0,
  181. 'marginLeft' => 0,
  182. 'marginTop' => 0,
  183. 'marginBottom' => 0,
  184. // format content from your own css file if needed or use the
  185. // enhanced bootstrap css built by Krajee for mPDF formatting
  186. //'cssFile' => '@vendor/kartik-v/yii2-mpdf/assets/kv-mpdf-bootstrap.min.css',
  187. 'cssFile' => '@app/web/css/screen.css',
  188. // any css to be embedded if required
  189. //'cssInline' => '.kv-heading-1{font-size:18px}',
  190. // set mPDF properties on the fly
  191. //'options' => ['title' => 'Krajee Report Title'],
  192. // call mPDF methods on the fly
  193. /* 'methods' => [
  194. 'SetHeader'=>['Commandes du '.$date_str],
  195. 'SetFooter'=>['{PAGENO}'],
  196. ] */
  197. ]);
  198. // return the pdf output as per the destination setting
  199. return $pdf->render();
  200. }
  201. }