Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

287 rindas
7.0KB

  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\logic\User\CreditHistory;
  38. use common\components\ActiveRecordCommon;
  39. use common\logic\Producer\Producer\Producer;
  40. use common\logic\User\User\User;
  41. use common\logic\Order\Order\Order;
  42. use common\logic\User\UserProducer\UserProducerEventSubscriber;
  43. use yii\db\ActiveQuery;
  44. use yii\db\ActiveRecord;
  45. class CreditHistory extends ActiveRecordCommon
  46. {
  47. const EVENT_CREATE = 'creditHistory.create';
  48. const TYPE_INITIAL_CREDIT = 'initial-credit';
  49. const TYPE_CREDIT = 'credit';
  50. const TYPE_PAYMENT = 'payment';
  51. const TYPE_REFUND = 'refund';
  52. const TYPE_DEBIT = 'debit';
  53. /**
  54. * @inheritdoc
  55. */
  56. public static function tableName(): string
  57. {
  58. return 'credit_history';
  59. }
  60. /**
  61. * @inheritdoc
  62. */
  63. public function rules(): array
  64. {
  65. return [
  66. [['amount'], 'required'],
  67. [['id_user', 'id_user_action', 'id_order', 'id_producer'], 'integer'],
  68. [['date'], 'safe'],
  69. [['amount'], 'double'],
  70. [['type', 'mean_payment'], 'string', 'max' => 255],
  71. [['comment'], 'string', 'max' => 2048],
  72. ];
  73. }
  74. /**
  75. * @inheritdoc
  76. */
  77. public function attributeLabels(): array
  78. {
  79. return [
  80. 'id' => 'ID',
  81. 'id_user' => 'Utilisateur',
  82. 'id_user_action' => 'Utilisateur',
  83. 'id_order' => 'Commande',
  84. 'date' => 'Date',
  85. 'amount' => 'Montant',
  86. 'type' => 'Type',
  87. 'id_producer' => 'Producteur',
  88. 'mean_payment' => 'Moyen de paiement',
  89. 'comment' => 'Commentaire',
  90. ];
  91. }
  92. public function init()
  93. {
  94. $this->on(CreditHistory::EVENT_CREATE, function($event) {
  95. UserProducerEventSubscriber::onCreateCreditHistory($event->creditHistory);
  96. });
  97. parent::init();
  98. }
  99. /*
  100. * Relations
  101. */
  102. public function getProducer(): ActiveQuery
  103. {
  104. return $this->hasOne(Producer::class, ['id' => 'id_producer']);
  105. }
  106. public function populateProducer(Producer $producer): void
  107. {
  108. $this->populateFieldObject('id_producer', 'producer', $producer);
  109. }
  110. public function getUser(): ActiveQuery
  111. {
  112. return $this->hasOne(User::class, ['id' => 'id_user']);
  113. }
  114. public function populateUser(User $user): void
  115. {
  116. $this->populateFieldObject('id_user', 'user', $user);
  117. }
  118. public function getUserObject(): ?User
  119. {
  120. return $this->user;
  121. }
  122. public function getUserAction(): ActiveQuery
  123. {
  124. return $this->hasOne(User::class, ['id' => 'id_user_action']);
  125. }
  126. public function populateUserAction(User $user): void
  127. {
  128. $this->populateFieldObject('id_user_action', 'userAction', $user);
  129. }
  130. public function getUserActionObject(): ?User
  131. {
  132. return $this->userAction;
  133. }
  134. public function getOrder(): ActiveQuery
  135. {
  136. return $this->hasOne(Order::class, ['id' => 'id_order']);
  137. }
  138. public function populateOrder(Order $order): void
  139. {
  140. $this->populateFieldObject('id_order', 'order', $order);
  141. }
  142. public function getOrderObject(): ?Order
  143. {
  144. return $this->order;
  145. }
  146. /*
  147. * Getters / setters
  148. */
  149. public function getId(): int
  150. {
  151. return $this->id;
  152. }
  153. public function getIdUser(): ?int
  154. {
  155. return $this->id_user;
  156. }
  157. public function setIdUser(?int $idUser): self
  158. {
  159. $this->id_user = $idUser;
  160. return $this;
  161. }
  162. public function getIdUserAction(): ?int
  163. {
  164. return $this->id_user_action;
  165. }
  166. public function setIdUserAction(?int $idUserAction): self
  167. {
  168. $this->id_user_action = $idUserAction;
  169. return $this;
  170. }
  171. public function getIdOrder(): ?int
  172. {
  173. return $this->id_order;
  174. }
  175. public function setIdOrder(?int $idOrder): self
  176. {
  177. $this->id_order = $idOrder;
  178. return $this;
  179. }
  180. public function getDate(): ?string
  181. {
  182. return $this->date;
  183. }
  184. public function setDate(?string $date): self
  185. {
  186. $this->date = $date;
  187. return $this;
  188. }
  189. public function getAmount(): ?float
  190. {
  191. return $this->amount;
  192. }
  193. public function setAmount(?float $amount): self
  194. {
  195. $this->amount = $amount;
  196. return $this;
  197. }
  198. public function getType(): ?string
  199. {
  200. return $this->type;
  201. }
  202. public function setType(?string $type): self
  203. {
  204. $this->type = $type;
  205. return $this;
  206. }
  207. public function getIdProducer(): ?int
  208. {
  209. return $this->id_producer;
  210. }
  211. public function setIdProducer(?int $idProducer): self
  212. {
  213. $this->id_producer = $idProducer;
  214. return $this;
  215. }
  216. public function getMeanPayment(): ?string
  217. {
  218. return $this->mean_payment;
  219. }
  220. public function setMeanPayment(?string $meanPayment): self
  221. {
  222. $this->mean_payment = $meanPayment;
  223. return $this;
  224. }
  225. public function getComment(): ?string
  226. {
  227. return $this->comment;
  228. }
  229. public function setComment(?string $comment): self
  230. {
  231. $this->comment = $comment;
  232. return $this;
  233. }
  234. }