You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

184 lines
7.2KB

  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 domain\User\User;
  38. use common\helpers\GlobalParam;
  39. use domain\Producer\Producer\ProducerModule;
  40. use yii\data\ActiveDataProvider;
  41. class UserSearch extends User
  42. {
  43. var $id_point_sale;
  44. var $subscribers;
  45. var $inactive;
  46. var $username;
  47. var $contacts;
  48. var $id_user_user_group;
  49. public function rules()
  50. {
  51. return [
  52. [['no_mail', 'mail_distribution_monday', 'mail_distribution_tuesday', 'mail_distribution_wednesday', 'mail_distribution_thursday', 'mail_distribution_friday', 'mail_distribution_saturday', 'mail_distribution_sunday'], 'boolean'],
  53. [['lastname', 'name', 'phone', 'address', 'type', 'newsletter', 'contacts'], 'string'],
  54. [['id_point_sale', 'inactive', 'subscribers', 'id_user_user_group'], 'integer'],
  55. [['date_last_connection', 'id_point_sale', 'username'], 'safe'],
  56. ];
  57. }
  58. public function search($params = [])
  59. {
  60. $userModule = UserModule::getInstance();
  61. $producerModule = ProducerModule::getInstance();
  62. $producer = GlobalParam::getCurrentProducer();
  63. $query = User::find()
  64. ->select(
  65. '`user`.id, '
  66. . '`user`.username,'
  67. . '`user`.email, '
  68. . '`user`.status, '
  69. . '`user`.created_at, '
  70. . '`user`.updated_at, '
  71. . '`user`.lastname, '
  72. . '`user`.name, '
  73. . '`user`.phone, '
  74. . '`user`.address, '
  75. . '`user`.no_mail, '
  76. . '`user`.mail_distribution_monday, '
  77. . '`user`.mail_distribution_tuesday, '
  78. . '`user`.mail_distribution_wednesday, '
  79. . '`user`.mail_distribution_thursday, '
  80. . '`user`.mail_distribution_friday, '
  81. . '`user`.mail_distribution_saturday, '
  82. . '`user`.mail_distribution_sunday, '
  83. . '`user`.id_producer, '
  84. . '`user`.date_last_connection, '
  85. . '`user`.name_legal_person, '
  86. . '`user`.type, '
  87. . '(SELECT COUNT(*) FROM `order` WHERE `user`.id = `order`.id_user) AS count_orders');
  88. $query->innerJoin('user_producer', 'user.id = user_producer.id_user AND user_producer.id_producer = :id_producer AND user_producer.active = 1', [':id_producer' => $producer->id]);
  89. $dataProvider = new ActiveDataProvider([
  90. 'query' => $query,
  91. 'sort' => [
  92. 'attributes' => ['username', 'credit', 'orders'],
  93. 'defaultOrder' => ['created_at' => SORT_DESC]
  94. ],
  95. 'pagination' => [
  96. 'pageSize' => $producerModule->getConfig('option_pagesize_user', $producer),
  97. ],
  98. ]);
  99. $dataProvider->sort->attributes['created_at'] = [
  100. 'asc' => ['user.created_at' => SORT_ASC],
  101. 'desc' => ['user.created_at' => SORT_DESC],
  102. ];
  103. $dataProvider->sort->attributes['username'] = [
  104. 'asc' => ['user.lastname' => SORT_ASC, 'user.name' => SORT_ASC],
  105. 'desc' => ['user.lastname' => SORT_DESC, 'user.name' => SORT_DESC],
  106. ];
  107. $dataProvider->sort->attributes['credit'] = [
  108. 'asc' => ['user_producer.credit' => SORT_ASC],
  109. 'desc' => ['user_producer.credit' => SORT_DESC],
  110. ];
  111. $this->load($params);
  112. if (!$this->validate()) {
  113. return $dataProvider;
  114. }
  115. if (isset($this->id_point_sale) && $this->id_point_sale) {
  116. $query->innerJoin('user_point_sale', 'user.id = user_point_sale.id_user AND user_point_sale.id_point_sale = :id_point_sale', [':id_point_sale' => $this->id_point_sale]);
  117. }
  118. if (isset($this->subscribers) && $this->subscribers) {
  119. $query->innerJoin(
  120. 'subscription',
  121. 'user.id = subscription.id_user AND subscription.id_producer = :id_producer',
  122. [':id_producer' => GlobalParam::getCurrentProducerId()]
  123. )->groupBy('user.id');
  124. }
  125. if (isset($this->inactive) && $this->inactive) {
  126. $query->having([
  127. 'count_orders' => 0
  128. ]);
  129. }
  130. if (isset($this->newsletter) && is_numeric($this->newsletter)) {
  131. $query->andWhere([
  132. 'user_producer.newsletter' => $this->newsletter
  133. ]);
  134. }
  135. if (isset($this->id_user_user_group) && is_numeric($this->id_user_user_group)) {
  136. $query->innerJoin(
  137. 'user_user_group',
  138. 'user.id = user_user_group.id_user AND user_user_group.id_user_group = :id_user_group',
  139. ['id_user_group' => $this->id_user_user_group]
  140. )->groupBy('user.id');
  141. }
  142. if ($userModule->isTypeValid($this->type)) {
  143. $query->andWhere(['user.type' => $this->type]);
  144. }
  145. if(strlen($this->username)) {
  146. $query->andFilterWhere([
  147. 'or',
  148. ['like', 'user.lastname', $this->username],
  149. ['like', 'user.name', $this->username],
  150. ['like', 'user.name_legal_person', $this->username],
  151. ]);
  152. }
  153. if(strlen($this->contacts)) {
  154. $query->andFilterWhere([
  155. 'or',
  156. ['like', 'user.email', $this->contacts],
  157. ['like', 'user.phone', $this->contacts],
  158. ]);
  159. }
  160. return $dataProvider;
  161. }
  162. }