You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

OrderShopRepositoryQuery.php 9.6KB

3 anni fa
3 anni fa
3 anni fa
3 anni fa
3 anni fa
3 anni fa
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345
  1. <?php
  2. namespace Lc\CaracoleBundle\Repository\Order;
  3. use Knp\Component\Pager\PaginatorInterface;
  4. use Lc\CaracoleBundle\Model\Address\AddressInterface;
  5. use Lc\CaracoleBundle\Model\Distribution\DistributionInterface;
  6. use Lc\CaracoleBundle\Model\Product\ProductInterface;
  7. use Lc\CaracoleBundle\Model\Reduction\ReductionCartInterface;
  8. use Lc\CaracoleBundle\Model\Reduction\ReductionCreditInterface;
  9. use Lc\CaracoleBundle\Model\User\VisitorInterface;
  10. use Lc\CaracoleBundle\Repository\SectionRepositoryQueryTrait;
  11. use Lc\SovBundle\Model\User\UserInterface;
  12. use Lc\SovBundle\Repository\AbstractRepositoryQuery;
  13. use DateTime;
  14. class OrderShopRepositoryQuery extends AbstractRepositoryQuery
  15. {
  16. use SectionRepositoryQueryTrait;
  17. protected bool $isJoinProduct = false;
  18. protected bool $isJoinDistribution = false;
  19. protected bool $isJoinProductFamily = false;
  20. protected bool $isJoinOrderProduct = false;
  21. protected bool $isJoinOrderReductionCredits = false;
  22. protected bool $isJoinOrderReductionCarts = false;
  23. protected bool $isJoinOrderStatus = false;
  24. protected bool $isJoinMerchant = false;
  25. protected bool $isJoinComplementaryOrderShops = false;
  26. protected bool $isJoinDeliveryPointSale = false;
  27. public function __construct(OrderShopRepository $repository, PaginatorInterface $paginator)
  28. {
  29. parent::__construct($repository, 'r', $paginator);
  30. }
  31. public function selectSumStatTotalWithTax(): self
  32. {
  33. return $this
  34. ->select(
  35. 'SUM(DISTINCT(r.statTotalWithTax)) as total'
  36. );
  37. }
  38. public function selectSumQuantityOrder(): self
  39. {
  40. $this->joinOrderProduct();
  41. return $this
  42. ->select(
  43. 'SUM(orderProduct.quantityOrder) as quantity'
  44. );
  45. }
  46. public function selectSum(): self
  47. {
  48. $this->joinProduct();
  49. $this->joinDistribution();
  50. return $this
  51. ->select(
  52. 'SUM(orderProduct.quantityOrder) as quantity, distribution.cycleNumber as cycleNumber, distribution.year as year , product.id as productId'
  53. );
  54. }
  55. public function selectCountUser(): self
  56. {
  57. return $this
  58. ->select('count(DISTINCT(r.user)) as total');
  59. }
  60. // @TODO : nécessaire ?
  61. public function selectParam($select): self
  62. {
  63. return $this
  64. ->addSelect($select);
  65. }
  66. public function selectCount(): self
  67. {
  68. return $this
  69. ->select('count(DISTINCT(r.id)) as total');
  70. }
  71. public function filterByUser(UserInterface $user): self
  72. {
  73. return $this
  74. ->andWhere('.user = :user')
  75. ->setParameter('user', $user);
  76. }
  77. public function filterByAlias(array $status): self
  78. {
  79. $this->joinOrderStatus();
  80. return $this
  81. ->andWhere('os.alias IN (:alias)')
  82. ->setParameter('alias', $status);
  83. }
  84. public function filterByDistributions(array $distributions): self
  85. {
  86. return $this
  87. ->andWhere('.distribution IN(:distributions)')
  88. ->setParameter('distributions', $distributions);
  89. }
  90. public function filterByProducts(array $products): self
  91. {
  92. $this->joinOrderProduct();
  93. return $this
  94. ->andWhere('product.id IN(:products)')
  95. ->setParameter('products', $products);
  96. }
  97. public function filterByProduct(ProductInterface $product): self
  98. {
  99. $this->joinProduct();
  100. return $this
  101. ->andWhere('orderProduct.product = :product')
  102. ->setParameter('product', $product);
  103. }
  104. public function filterIsMerchantOnline(): self
  105. {
  106. $this->joinMerchant();
  107. return $this
  108. ->andWhere('merchant.status = :status')
  109. ->setParameter(':status', 1);
  110. }
  111. public function filterByDateStart(string $dateField, DateTime $dateStart): self
  112. {
  113. return $this
  114. ->andWhere('.' . $dateField . ' >= :dateStart')
  115. ->setParameter('dateStart', $dateStart);
  116. }
  117. public function filterByDateEnd(string $dateField, DateTime $dateEnd): self
  118. {
  119. return $this
  120. ->andWhere('.' . $dateField . ' <= :dateEnd')
  121. ->setParameter('dateEnd', $dateEnd);
  122. }
  123. public function filterByVisitor(VisitorInterface $visitor): self
  124. {
  125. return $this->andWhereEqual('visitor', $visitor);
  126. }
  127. public function filterByAddress(AddressInterface $address): self
  128. {
  129. return $this
  130. ->andWhere('.deliveryAddress = :address OR .invoiceAddress = :address')
  131. ->setParameter('address', $address);
  132. }
  133. public function filterByStatus(array $statusArray): self
  134. {
  135. $this->joinOrderStatus();
  136. return $this
  137. ->andWhere('os.alias IN (:alias)')
  138. ->setParameter('alias', $statusArray);
  139. }
  140. public function filterByReductionCredit(ReductionCreditInterface $reductionCredit): self
  141. {
  142. $this->joinOrderReductionCredits();
  143. return $this
  144. ->andWhere('orc.reductionCredit = :reductionCredit')
  145. ->setParameter('reductionCredit', $reductionCredit);
  146. }
  147. public function filterByReductionCart(ReductionCartInterface $reductionCart): self
  148. {
  149. $this->joinOrderReductionCarts();
  150. return $this
  151. ->andWhere('orcart.reductionCart = :reductionCart')
  152. ->setParameter('reductionCart', $reductionCart);
  153. }
  154. public function filterByDistribution(DistributionInterface $distribution): self
  155. {
  156. return $this
  157. ->andWhere('.distribution = :distribution')
  158. ->setParameter('distribution', $distribution);
  159. }
  160. public function filterIsNotComplementaryOrderShop(): self
  161. {
  162. return $this
  163. ->andWhere('.mainOrderShop = false OR .mainOrderShop IS NULL');
  164. }
  165. public function filterIsNullMainOrderShop(): self
  166. {
  167. return $this
  168. ->andWhere('.mainOrderShop IS NULL');
  169. }
  170. public function filterMinimumTomorrowDelivery(): self
  171. {
  172. return $this->andWhere('.deliveryDate > :today')->setParameter('today', (new DateTime())->setTime(23, 59));
  173. }
  174. public function selectOrderReductionCarts(): self
  175. {
  176. $this->joinOrderReductionCarts();
  177. return $this->addSelect('orcart');
  178. }
  179. public function joinOrderProduct(bool $addSelect = false): self
  180. {
  181. if (!$this->isJoinOrderProduct) {
  182. $this->isJoinOrderProduct = true;
  183. $this->leftJoin('.orderProducts', 'orderProduct');
  184. if ($addSelect) {
  185. $this->addSelect('orderProduct');
  186. }
  187. }
  188. return $this;
  189. }
  190. public function joinProduct(bool $addSelect = false): self
  191. {
  192. $this->joinOrderProduct($addSelect);
  193. if (!$this->isJoinProduct) {
  194. $this->isJoinProduct = true;
  195. $this->leftJoin('orderProduct.product', 'product');
  196. if ($addSelect) {
  197. $this->addSelect('product');
  198. }
  199. }
  200. return $this;
  201. }
  202. public function joinDistribution(bool $addSelect = false): self
  203. {
  204. if (!$this->isJoinDistribution) {
  205. $this->isJoinDistribution = true;
  206. $this->leftJoin('.distribution', 'distribution');
  207. if ($addSelect) {
  208. $this->addSelect('distribution');
  209. }
  210. }
  211. return $this;
  212. }
  213. public function joinProductFamily(bool $addSelect = false): self
  214. {
  215. $this->joinProduct($addSelect);
  216. if (!$this->isJoinProductFamily) {
  217. $this->isJoinProductFamily = true;
  218. $this->leftJoin('product.productFamily', 'productFamily');
  219. if ($addSelect) {
  220. $this->addSelect('productFamily');
  221. }
  222. }
  223. return $this;
  224. }
  225. public function joinOrderReductionCredits(): self
  226. {
  227. if (!$this->isJoinOrderReductionCredits) {
  228. $this->isJoinOrderReductionCredits = true;
  229. return $this
  230. ->innerJoin('.orderReductionCredits', 'orc');
  231. }
  232. return $this;
  233. }
  234. public function joinOrderStatus(): self
  235. {
  236. if (!$this->isJoinOrderStatus) {
  237. $this->isJoinOrderStatus = true;
  238. return $this
  239. ->leftJoin('.orderStatus', 'os');
  240. }
  241. return $this;
  242. }
  243. public function joinOrderReductionCarts(): self
  244. {
  245. if (!$this->isJoinOrderReductionCarts) {
  246. $this->isJoinOrderReductionCarts = true;
  247. return $this
  248. ->leftJoin('.orderReductionCarts', 'orcart');
  249. }
  250. return $this;
  251. }
  252. public function joinMerchant(): self
  253. {
  254. $this->joinSection();
  255. if (!$this->isJoinMerchant) {
  256. $this->isJoinMerchant = true;
  257. return $this
  258. ->leftJoin('s.merchant', 'merchant');
  259. }
  260. return $this;
  261. }
  262. public function joinComplementaryOrderShops(): self
  263. {
  264. if (!$this->isJoinComplementaryOrderShops) {
  265. $this->isJoinComplementaryOrderShops = true;
  266. return $this
  267. ->leftJoin('.complementaryOrderShops', 'complementaryOrderShops');
  268. }
  269. return $this;
  270. }
  271. public function joinDeliveryPointSale(): self
  272. {
  273. if (!$this->isJoinDeliveryPointSale) {
  274. $this->isJoinDeliveryPointSale = true;
  275. return $this
  276. ->leftJoin('.deliveryPointSale', 'pointSale');
  277. }
  278. return $this;
  279. }
  280. }