選択できるのは25トピックまでです。 トピックは、先頭が英数字で、英数字とダッシュ('-')を使用した35文字以内のものにしてください。

402 行
15KB

  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 Yii;
  40. use yii\helpers\Html;
  41. use common\models\UserPointSale;
  42. use common\models\PointSaleDistribution;
  43. use common\components\ActiveRecordCommon;
  44. /**
  45. * This is the model class for table "point_vente".
  46. *
  47. * @property integer $id
  48. * @property string $name
  49. * @property string $address
  50. * @property integer $id_producer
  51. * @property integer $default
  52. */
  53. class PointSale extends ActiveRecordCommon
  54. {
  55. var $orders = [];
  56. var $revenues = 0;
  57. var $revenues_with_tax = 0;
  58. var $data_select_orders;
  59. var $data_options_orders;
  60. var $users = [];
  61. var $users_comment = [];
  62. /**
  63. * @inheritdoc
  64. */
  65. public static function tableName()
  66. {
  67. return 'point_sale';
  68. }
  69. /**
  70. * @inheritdoc
  71. */
  72. public function rules()
  73. {
  74. return [
  75. [['name'], 'required'],
  76. [['restricted_access'], 'boolean'],
  77. [['name', 'code'], 'string', 'max' => 255],
  78. [['address', 'locality', 'infos_monday', 'infos_tuesday',
  79. 'infos_wednesday', 'infos_thursday', 'infos_friday',
  80. 'infos_saturday', 'infos_sunday', 'credit_functioning', 'bread_box_code'], 'string'],
  81. [['point_production', 'credit', 'delivery_monday', 'delivery_tuesday',
  82. 'delivery_wednesday', 'delivery_thursday', 'delivery_friday',
  83. 'delivery_saturday', 'delivery_sunday', 'default', 'is_bread_box'], 'boolean'],
  84. ['point_production', 'default', 'value' => 0],
  85. [['id_producer', 'id_user', 'maximum_number_orders'], 'integer'],
  86. ['id_producer', 'required'],
  87. [['users', 'users_comment', 'code'], 'safe'],
  88. [['product_price_percent'], 'double'],
  89. ];
  90. }
  91. /**
  92. * @inheritdoc
  93. */
  94. public function attributeLabels()
  95. {
  96. return [
  97. 'id' => 'ID',
  98. 'name' => 'Nom',
  99. 'address' => 'Adresse',
  100. 'locality' => 'Localité',
  101. 'point_production' => 'Point de production',
  102. 'infos_monday' => 'Lundi',
  103. 'infos_tuesday' => 'Mardi',
  104. 'infos_wednesday' => 'Mercredi',
  105. 'infos_thursday' => 'Jeudi',
  106. 'infos_friday' => 'Vendredi',
  107. 'infos_saturday' => 'Samedi',
  108. 'infos_sunday' => 'Dimanche',
  109. 'restricted_access' => 'Accès restreint',
  110. 'credit' => 'Activer le Crédit',
  111. 'delivery_monday' => 'Lundi',
  112. 'delivery_tuesday' => 'Mardi',
  113. 'delivery_wednesday' => 'Mercredi',
  114. 'delivery_thursday' => 'Jeudi',
  115. 'delivery_friday' => 'Vendredi',
  116. 'delivery_saturday' => 'Samedi',
  117. 'delivery_sunday' => 'Dimanche',
  118. 'code' => 'Code',
  119. 'credit_functioning' => 'Utilisation du Crédit par l\'utilisateur',
  120. 'default' => 'Point de vente par défaut',
  121. 'id_user' => 'Contact',
  122. 'product_price_percent' => 'Prix produits : pourcentage',
  123. 'maximum_number_orders' => 'Nombre maximum de commandes',
  124. 'is_bread_box' => 'Boîte à pain',
  125. 'bread_box_code' => 'Code boîte à pain',
  126. ];
  127. }
  128. /*
  129. * Relations
  130. */
  131. public function getUserPointSale()
  132. {
  133. return $this->hasMany(
  134. UserPointSale::className(),
  135. ['id_point_sale' => 'id']
  136. );
  137. }
  138. public function getPointSaleDistribution()
  139. {
  140. return $this->hasMany(
  141. PointSaleDistribution::className(),
  142. ['id_point_sale' => 'id']
  143. );
  144. }
  145. public function getUser()
  146. {
  147. return $this->hasOne(
  148. User::className(),
  149. ['id' => 'id_user']
  150. ) ;
  151. }
  152. /**
  153. * Retourne les options de base nécessaires à la fonction de recherche.
  154. *
  155. * @return array
  156. */
  157. public static function defaultOptionsSearch()
  158. {
  159. return [
  160. 'with' => [],
  161. 'join_with' => [],
  162. 'orderby' => '',
  163. 'attribute_id_producer' => 'point_sale.id_producer'
  164. ];
  165. }
  166. /**
  167. * Initialise les commandes liées au point de vente.
  168. *
  169. * @param array $ordersArray
  170. */
  171. public function initOrders($ordersArray)
  172. {
  173. $this->orders = [];
  174. $this->revenues = 0;
  175. $this->revenues_with_tax = 0;
  176. if ($ordersArray) {
  177. foreach ($ordersArray as $order) {
  178. if ($this->id == $order->id_point_sale) {
  179. $this->orders[] = $order;
  180. if (is_null($order->date_delete)) {
  181. $this->revenues += (float)$order->amount;
  182. $this->revenues_with_tax += (float)$order->amount_with_tax;
  183. }
  184. }
  185. }
  186. }
  187. }
  188. /**
  189. * Retourne les commandes liées à ce point de vente.
  190. *
  191. * @return array
  192. */
  193. public function getOrders()
  194. {
  195. return $this->orders;
  196. }
  197. /**
  198. * Enregistre le point de vente.
  199. *
  200. * @param boolean $runValidation
  201. * @param array $attributeNames
  202. * @return type
  203. */
  204. public function save($runValidation = true, $attributeNames = NULL)
  205. {
  206. $this->id_producer = GlobalParam::getCurrentProducerId();
  207. return parent::save($runValidation, $attributeNames);
  208. }
  209. /**
  210. * Traite la mise à jour de l'attribut 'point_production'.
  211. */
  212. public function processPointProduction()
  213. {
  214. if ($this->point_production) {
  215. PointSale::updateAll(
  216. ['point_production' => 0],
  217. ['id_producer' => $this->id_producer]
  218. );
  219. $this->point_production = 1;
  220. $this->save();
  221. }
  222. }
  223. /**
  224. * Traite les accès restreints d'un point de vente.
  225. */
  226. public function processRestrictedAccess()
  227. {
  228. UserPointSale::deleteAll(['id_point_sale' => $this->id]);
  229. if (is_array($this->users) && count($this->users)) {
  230. foreach ($this->users as $key => $val) {
  231. $user = User::findOne($val);
  232. if ($user) {
  233. $userPointSale = new UserPointSale;
  234. $userPointSale->id_user = $val;
  235. $userPointSale->id_point_sale = $this->id;
  236. if (isset($this->users_comment[$val]) && strlen($this->users_comment[$val])) {
  237. $userPointSale->comment = $this->users_comment[$val];
  238. }
  239. $userPointSale->save();
  240. }
  241. }
  242. }
  243. }
  244. /**
  245. * Retourne le commentaire de l'utilisateur courant lié au point de vente.
  246. *
  247. * @return string|null
  248. */
  249. public function getComment()
  250. {
  251. if (isset($this->userPointSale)) {
  252. foreach ($this->userPointSale as $userPointSale) {
  253. if ($userPointSale->id_user == User::getCurrentId()) {
  254. return $userPointSale->comment;
  255. }
  256. }
  257. }
  258. return null;
  259. }
  260. /**
  261. * Retourne le nombre de points de vente pour l'établissement courant.
  262. *
  263. * @return integer
  264. */
  265. public static function count()
  266. {
  267. return self::searchCount(['id_producer' => GlobalParam::getCurrentProducerId()]);
  268. }
  269. /**
  270. * Vérifie le code d'accès à un point de vente.
  271. *
  272. * @param string $code
  273. * @return boolean
  274. */
  275. public function validateCode($code)
  276. {
  277. if (strlen($this->code)) {
  278. if (trim(strtolower($code)) == trim(strtolower($this->code))) {
  279. return true;
  280. } else {
  281. return false;
  282. }
  283. }
  284. return true;
  285. }
  286. /**
  287. * Retourne les jours de livraison du point de vente sous forme d'une chaine
  288. * de caractères.
  289. *
  290. * @return string
  291. */
  292. public function getStrDeliveryDays()
  293. {
  294. $str = '';
  295. if ($this->delivery_monday) $str .= 'lundi, ';
  296. if ($this->delivery_tuesday) $str .= 'mardi, ';
  297. if ($this->delivery_wednesday) $str .= 'mercredi, ';
  298. if ($this->delivery_thursday) $str .= 'jeudi, ';
  299. if ($this->delivery_friday) $str .= 'vendredi, ';
  300. if ($this->delivery_saturday) $str .= 'samedi, ';
  301. if ($this->delivery_sunday) $str .= 'dimanche, ';
  302. if (strlen($str)) {
  303. return substr($str, 0, strlen($str) - 2);
  304. } else {
  305. return '';
  306. }
  307. }
  308. /**
  309. * Retourne un commentaire informant l'utilisateur sur les détails de
  310. * livraison d'un point de vente et pour un jour donné.
  311. *
  312. * @param string $jour
  313. * @return string
  314. */
  315. public function getStrInfos($day)
  316. {
  317. $str = '';
  318. $field = 'infos_' . $day;
  319. if (strlen($this->$field)) {
  320. $str = nl2br(Html::encode($this->$field));
  321. $str = preg_replace('/\[select_previous_day\](.*?)\[\/select_previous_day\]/', '<a href="javascript:void(0);" class="select-previous-day">$1</a>', $str);
  322. }
  323. return $str;
  324. }
  325. /**
  326. * Retourne le mode de fonctionnement du crédit du point de vente.
  327. *
  328. * @return string
  329. */
  330. public function getCreditFunctioning()
  331. {
  332. return strlen($this->credit_functioning) > 0 ?
  333. $this->credit_functioning :
  334. Producer::getConfig('credit_functioning');
  335. }
  336. /**
  337. * Lie un utilisateur au point de vente.
  338. *
  339. * @param integer $idUser
  340. */
  341. public function linkUser($idUser)
  342. {
  343. if ($idUser) {
  344. $userPointSale = UserPointSale::find()
  345. ->where([
  346. 'id_user' => $idUser,
  347. 'id_point_sale' => $this->id
  348. ])->one();
  349. if (!$userPointSale) {
  350. $userPointSale = new UserPointSale;
  351. $userPointSale->id_user = $idUser;
  352. $userPointSale->id_point_sale = $this->id;
  353. $userPointSale->save();
  354. }
  355. }
  356. }
  357. public static function populateDropdownList()
  358. {
  359. $pointSalesArrayDropdown = ['' => '--'] ;
  360. $pointSalesArray = PointSale::find()->where('id_producer = ' . GlobalParam::getCurrentProducerId())->all() ;
  361. foreach($pointSalesArray as $pointSale) {
  362. $pointSalesArrayDropdown[$pointSale['id']] = $pointSale['name'] ;
  363. }
  364. return $pointSalesArrayDropdown ;
  365. }
  366. }