123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  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 common\models;
  38. use common\helpers\GlobalParam;
  39. use common\models\User;
  40. class UserSearch extends User
  41. {
  42. var $id_point_sale;
  43. var $subscribers;
  44. var $inactive;
  45. var $username;
  46. public function rules()
  47. {
  48. return [
  49. [['no_mail', 'mail_distribution_monday', 'mail_distribution_tuesday', 'mail_distribution_wednesday', 'mail_distribution_thursday', 'mail_distribution_friday', 'mail_distribution_saturday', 'mail_distribution_sunday'], 'boolean'],
  50. [['lastname', 'name', 'phone', 'address'], 'string'],
  51. [['id_point_sale', 'inactive', 'subscribers'], 'integer'],
  52. [['date_last_connection', 'id_point_sale', 'username'], 'safe'],
  53. ];
  54. }
  55. public function search($params = [])
  56. {
  57. $optionsSearch = self::defaultOptionsSearch();
  58. $query = User::find()
  59. ->select(
  60. '`user`.id, '
  61. . '`user`.username,'
  62. . '`user`.email, '
  63. . '`user`.status, '
  64. . '`user`.created_at, '
  65. . '`user`.updated_at, '
  66. . '`user`.lastname, '
  67. . '`user`.name, '
  68. . '`user`.phone, '
  69. . '`user`.address, '
  70. . '`user`.no_mail, '
  71. . '`user`.mail_distribution_monday, '
  72. . '`user`.mail_distribution_tuesday, '
  73. . '`user`.mail_distribution_wednesday, '
  74. . '`user`.mail_distribution_thursday, '
  75. . '`user`.mail_distribution_friday, '
  76. . '`user`.mail_distribution_saturday, '
  77. . '`user`.mail_distribution_sunday, '
  78. . '`user`.id_producer, '
  79. . '`user`.date_last_connection, '
  80. . '`user`.name_legal_person, '
  81. . '(SELECT COUNT(*) FROM `order` WHERE `user`.id = `order`.id_user) AS count_orders');
  82. $dataProvider = new ActiveDataProvider([
  83. 'query' => $query,
  84. 'sort' => ['attributes' => ['username', 'credit', 'orders']],
  85. 'pagination' => [
  86. 'pageSize' => 20,
  87. ],
  88. ]);
  89. $dataProvider->sort->attributes['username'] = [
  90. 'asc' => ['user.lastname' => SORT_ASC, 'user.name' => SORT_ASC],
  91. 'desc' => ['user.lastname' => SORT_DESC, 'user.name' => SORT_DESC],
  92. ];
  93. $dataProvider->sort->attributes['credit'] = [
  94. 'asc' => ['user_producer.credit' => SORT_ASC],
  95. 'desc' => ['user_producer.credit' => SORT_DESC],
  96. ];
  97. $this->load($params);
  98. if (!$this->validate()) {
  99. return $dataProvider;
  100. }
  101. $query->innerJoin('user_producer', 'user.id = user_producer.id_user AND user_producer.id_producer = :id_producer AND user_producer.active = 1', [':id_producer' => GlobalParam::getCurrentProducerId()]);
  102. if (isset($this->id_point_sale) && $this->id_point_sale) {
  103. $pointSale = PointSale::findOne(['id' => $this->id_point_sale]);
  104. $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]);
  105. }
  106. if (isset($this->subscribers) && $this->subscribers) {
  107. $query->innerJoin(
  108. 'subscription',
  109. 'user.id = subscription.id_user AND subscription.id_producer = :id_producer',
  110. [':id_producer' => GlobalParam::getCurrentProducerId()]
  111. )->groupBy('user.id');
  112. }
  113. if (isset($this->inactive) && $this->inactive) {
  114. $query->having([
  115. 'count_orders' => 0
  116. ]);
  117. }
  118. $query->andFilterWhere([
  119. 'or',
  120. ['like', 'user.lastname', $this->username],
  121. ['like', 'user.name', $this->username],
  122. ['like', 'user.name_legal_person', $this->username],
  123. ]);
  124. return $dataProvider;
  125. }
  126. }