312 lines
7.5KB

  1. <?php
  2. /**
  3. * Copyright Souke (2018)
  4. *
  5. * contact@souke.fr
  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\Payment;
  38. use common\components\ActiveRecordCommon;
  39. use domain\Document\Invoice\Invoice;
  40. use domain\Order\Order\Order;
  41. use domain\Producer\Producer\Producer;
  42. use domain\User\User\User;
  43. use yii\db\ActiveQuery;
  44. class Payment 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 'payment';
  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_invoice', 'id_producer'], 'integer'],
  66. [['date'], 'safe'],
  67. [['amount'], 'double'],
  68. [['date_transaction'], 'date', 'format' => 'php:Y-m-d'],
  69. [['type', 'mean_payment'], 'string', 'max' => 255],
  70. [['comment', 'summary'], 'string', 'max' => 2048],
  71. ];
  72. }
  73. /**
  74. * @inheritdoc
  75. */
  76. public function attributeLabels(): array
  77. {
  78. return [
  79. 'id' => 'ID',
  80. 'id_user' => 'Utilisateur',
  81. 'id_user_action' => 'Utilisateur',
  82. 'id_order' => 'Commande',
  83. 'id_invoice' => 'Facture',
  84. 'date' => 'Date',
  85. 'amount' => 'Montant',
  86. 'type' => 'Type',
  87. 'id_producer' => 'Producteur',
  88. 'mean_payment' => 'Moyen de paiement',
  89. 'comment' => 'Commentaire',
  90. 'summary' => 'Résumé',
  91. 'date_transaction' => 'Date transaction'
  92. ];
  93. }
  94. /*
  95. * Relations
  96. */
  97. public function getProducer(): ActiveQuery
  98. {
  99. return $this->hasOne(Producer::class, ['id' => 'id_producer']);
  100. }
  101. public function populateProducer(Producer $producer): void
  102. {
  103. $this->populateFieldObject('id_producer', 'producer', $producer);
  104. }
  105. public function getUser(): ActiveQuery
  106. {
  107. return $this->hasOne(User::class, ['id' => 'id_user']);
  108. }
  109. public function populateUser(User $user): void
  110. {
  111. $this->populateFieldObject('id_user', 'user', $user);
  112. }
  113. public function getUserObject(): ?User
  114. {
  115. return $this->user;
  116. }
  117. public function getUserAction(): ActiveQuery
  118. {
  119. return $this->hasOne(User::class, ['id' => 'id_user_action']);
  120. }
  121. public function populateUserAction(User $user): void
  122. {
  123. $this->populateFieldObject('id_user_action', 'userAction', $user);
  124. }
  125. public function getUserActionObject(): ?User
  126. {
  127. return $this->userAction;
  128. }
  129. public function getOrder(): ActiveQuery
  130. {
  131. return $this->hasOne(Order::class, ['id' => 'id_order']);
  132. }
  133. public function populateOrder(Order $order): void
  134. {
  135. $this->populateFieldObject('id_order', 'order', $order);
  136. }
  137. public function getOrderObject(): ?Order
  138. {
  139. return $this->order;
  140. }
  141. public function getInvoice(): ActiveQuery
  142. {
  143. return $this->hasOne(Invoice::class, ['id' => 'id_invoice']);
  144. }
  145. public function populateInvoice(Invoice $invoice): void
  146. {
  147. $this->populateFieldObject('id_invoice', 'invoice', $invoice);
  148. }
  149. public function getInvoiceObject(): ?Invoice
  150. {
  151. return $this->invoice;
  152. }
  153. /*
  154. * Getters / setters
  155. */
  156. public function getId(): int
  157. {
  158. return $this->id;
  159. }
  160. public function getIdUser(): ?int
  161. {
  162. return $this->id_user;
  163. }
  164. public function setIdUser(?int $idUser): self
  165. {
  166. $this->id_user = $idUser;
  167. return $this;
  168. }
  169. public function getIdUserAction(): ?int
  170. {
  171. return $this->id_user_action;
  172. }
  173. public function setIdUserAction(?int $idUserAction): self
  174. {
  175. $this->id_user_action = $idUserAction;
  176. return $this;
  177. }
  178. public function getIdOrder(): ?int
  179. {
  180. return $this->id_order;
  181. }
  182. public function setIdOrder(?int $idOrder): self
  183. {
  184. $this->id_order = $idOrder;
  185. return $this;
  186. }
  187. public function getDate(): ?string
  188. {
  189. return $this->date;
  190. }
  191. public function setDate(?string $date): self
  192. {
  193. $this->date = $date;
  194. return $this;
  195. }
  196. public function getAmount(): ?float
  197. {
  198. return $this->amount;
  199. }
  200. public function setAmount(?float $amount): self
  201. {
  202. $this->amount = $amount;
  203. return $this;
  204. }
  205. public function getType(): ?string
  206. {
  207. return $this->type;
  208. }
  209. public function setType(?string $type): self
  210. {
  211. $this->type = $type;
  212. return $this;
  213. }
  214. public function getIdProducer(): ?int
  215. {
  216. return $this->id_producer;
  217. }
  218. public function setIdProducer(?int $idProducer): self
  219. {
  220. $this->id_producer = $idProducer;
  221. return $this;
  222. }
  223. public function getMeanPayment(): ?string
  224. {
  225. return $this->mean_payment;
  226. }
  227. public function setMeanPayment(?string $meanPayment): self
  228. {
  229. $this->mean_payment = $meanPayment;
  230. return $this;
  231. }
  232. public function getComment(): ?string
  233. {
  234. return $this->comment;
  235. }
  236. public function setComment(?string $comment): self
  237. {
  238. $this->comment = $comment;
  239. return $this;
  240. }
  241. public function setDateTransaction(?string $dateTransaction): self
  242. {
  243. $this->date_transaction = $dateTransaction;
  244. return $this;
  245. }
  246. public function getSummary(): ?string
  247. {
  248. return $this->summary;
  249. }
  250. public function setSummary(?string $summary): self
  251. {
  252. $this->summary = $summary;
  253. return $this;
  254. }
  255. }