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

CreditHistory.php 6.7KB

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