Vous ne pouvez pas sélectionner plus de 25 sujets Les noms de sujets doivent commencer par une lettre ou un nombre, peuvent contenir des tirets ('-') et peuvent comporter jusqu'à 35 caractères.

253 lines
8.6KB

  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\Product\Product;
  38. use common\components\ActiveRecordCommon;
  39. use common\helpers\GlobalParam;
  40. use domain\Config\TaxRate\TaxRate;
  41. use domain\Distribution\ProductDistribution\ProductDistribution;
  42. use domain\Producer\Producer\Producer;
  43. use domain\Product\ProductCategory\ProductCategory;
  44. use domain\Product\ProductPointSale\ProductPointSale;
  45. use domain\Product\ProductPrice\Model\ProductPrice;
  46. use domain\Subscription\ProductSubscription\ProductSubscription;
  47. use domain\_\StatusInterface;
  48. use yii\web\UploadedFile;
  49. /**
  50. * This is the model class for table "product".
  51. *
  52. */
  53. class Product extends ActiveRecordCommon implements StatusInterface
  54. {
  55. public $total = 0;
  56. public $apply_distributions = true;
  57. public $price_with_tax = 0;
  58. public $wording_unit = '';
  59. public $pointsSale;
  60. /**
  61. * @var UploadedFile
  62. */
  63. public $photoFile;
  64. public static $unitsArray = [
  65. 'piece' => [
  66. 'unit' => 'piece',
  67. 'wording_unit' => 'la pièce',
  68. 'wording' => 'pièce(s)',
  69. 'wording_short' => 'p.',
  70. 'coefficient' => 1
  71. ],
  72. 'g' => [
  73. 'ref_unit' => 'kg',
  74. 'unit' => 'g',
  75. 'wording_unit' => 'le g',
  76. 'wording' => 'g',
  77. 'wording_short' => 'g',
  78. 'coefficient' => 1000
  79. ],
  80. 'kg' => [
  81. 'unit' => 'kg',
  82. 'wording_unit' => 'le kg',
  83. 'wording' => 'kg',
  84. 'wording_short' => 'kg',
  85. 'coefficient' => 1
  86. ],
  87. 'mL' => [
  88. 'ref_unit' => 'L',
  89. 'unit' => 'mL',
  90. 'wording_unit' => 'le mL',
  91. 'wording' => 'mL',
  92. 'wording_short' => 'mL',
  93. 'coefficient' => 1000
  94. ],
  95. 'L' => [
  96. 'unit' => 'L',
  97. 'wording_unit' => 'le litre',
  98. 'wording' => 'L',
  99. 'wording_short' => 'L',
  100. 'coefficient' => 1
  101. ],
  102. ];
  103. /**
  104. * @inheritdoc
  105. */
  106. public static function tableName()
  107. {
  108. return 'product';
  109. }
  110. /**
  111. * @inheritdoc
  112. */
  113. public function rules()
  114. {
  115. return [
  116. [['name', 'id_producer'], 'required'],
  117. [['order', 'id_producer', 'id_tax_rate', 'id_product_category', 'status'], 'integer'],
  118. [['monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday', 'sunday', 'unavailable', 'apply_distributions', 'available_on_points_sale'], 'boolean'],
  119. [['price', 'weight', 'step', 'quantity_max', 'quantity_max_monday', 'quantity_max_tuesday', 'quantity_max_wednesday', 'quantity_max_thursday', 'quantity_max_friday', 'quantity_max_saturday', 'quantity_max_sunday'], 'number'],
  120. [['photoFile'], 'file', 'extensions' => 'png, jpg, jpeg', 'mimeTypes' => 'image/png, image/jpeg'],
  121. [['name', 'reference', 'description', 'photo', 'unit'], 'string', 'max' => 255],
  122. [['recipe'], 'string', 'max' => 1000],
  123. ['step', 'required', 'message' => 'Champs obligatoire', 'when' => function ($model) {
  124. if ($model->unit != 'piece') {
  125. return true;
  126. }
  127. return false;
  128. }],
  129. [['price_with_tax', 'wording_unit', 'pointsSale'], 'safe']
  130. ];
  131. }
  132. /**
  133. * @inheritdoc
  134. */
  135. public function attributeLabels()
  136. {
  137. return [
  138. 'id' => 'ID',
  139. 'name' => 'Nom',
  140. 'reference' => 'Référence',
  141. 'description' => 'Description',
  142. 'photoFile' => 'Photo',
  143. 'price' => 'Prix (€) TTC',
  144. 'weight' => 'Poids',
  145. 'recipe' => 'Recette',
  146. 'monday' => 'Lundi',
  147. 'tuesday' => 'Mardi',
  148. 'wednesday' => 'Mercredi',
  149. 'thursday' => 'Jeudi',
  150. 'friday' => 'Vendredi',
  151. 'saturday' => 'Samedi',
  152. 'sunday' => 'Dimanche',
  153. 'order' => 'Ordre',
  154. 'quantity_max' => 'Par défaut',
  155. 'quantity_max_monday' => 'Lundi',
  156. 'quantity_max_tuesday' => 'Mardi',
  157. 'quantity_max_wednesday' => 'Mercredi',
  158. 'quantity_max_thursday' => 'Jeudi',
  159. 'quantity_max_friday' => 'Vendredi',
  160. 'quantity_max_saturday' => 'Samedi',
  161. 'quantity_max_sunday' => 'Dimanche',
  162. 'unavailable' => 'Épuisé',
  163. 'apply_distributions' => 'Appliquer ces modifications dans les distributions à venir',
  164. 'unit' => 'Unité',
  165. 'step' => 'Pas',
  166. 'id_tax_rate' => 'TVA',
  167. 'id_product_category' => 'Catégorie',
  168. 'available_on_points_sale' => 'Par défaut',
  169. 'status' => 'Actif',
  170. ];
  171. }
  172. public function afterFind()
  173. {
  174. if ($this->taxRate == null) {
  175. if(GlobalParam::getCurrentProducerId() && $this->id_producer == GlobalParam::getCurrentProducerId()) {
  176. $producer = GlobalParam::getCurrentProducer();
  177. }
  178. else {
  179. $producer = Producer::searchOne(['id' => $this->id_producer]);
  180. }
  181. if ($producer) {
  182. $this->populateRelation('taxRate', $producer->taxRate);
  183. }
  184. }
  185. parent::afterFind();
  186. $productSolver = ProductSolver::getInstance();
  187. $this->wording_unit = $productSolver->strUnit($this);
  188. $this->price_with_tax = $productSolver->getPriceWithTax($this);
  189. }
  190. public function getProductDistribution()
  191. {
  192. return $this->hasMany(ProductDistribution::class, ['id_product' => 'id']);
  193. }
  194. public function getProductSubscription()
  195. {
  196. return $this->hasMany(ProductSubscription::class, ['id_product' => 'id']);
  197. }
  198. public function getTaxRate()
  199. {
  200. return $this->hasOne(TaxRate::class, ['id' => 'id_tax_rate']);
  201. }
  202. public function populateTaxRate(TaxRate $taxRate): void
  203. {
  204. $this->populateFieldObject('id_tax_rate', 'taxRate', $taxRate);
  205. }
  206. public function getProductPrice()
  207. {
  208. return $this->hasMany( ProductPrice::class, ['id_product' => 'id']);
  209. }
  210. public function getProductCategory()
  211. {
  212. return $this->hasOne( ProductCategory::class, ['id' => 'id_product_category']);
  213. }
  214. public function populateProductCategory(ProductCategory $productCategory): void
  215. {
  216. $this->populateFieldObject('id_product_category', 'productCategory', $productCategory);
  217. }
  218. public function getProductPointSale()
  219. {
  220. return $this->hasMany(ProductPointSale::class, ['id_product' => 'id']);
  221. }
  222. /**
  223. * Enregistre le produit.
  224. */
  225. public function save($runValidation = true, $attributeNames = NULL)
  226. {
  227. $this->id_producer = GlobalParam::getCurrentProducerId();
  228. return parent::save($runValidation, $attributeNames);
  229. }
  230. }