query = $query; $this->entityManager = $entityManager; $this->priceSolver = $priceSolver; $this->documentBuilder = $documentBuilder; $this->reductionCreditStore = $reductionCreditStore; $this->sectionStore = $sectionStore; $this->orderProductStore = $orderProductStore; $this->merchantStore = $merchantStore; $this->flashBag = $flashBag; $this->openingResolver = $openingResolver; $this->parameterBag = $parameterBag; $this->router = $router; } // getOrderShopsOfWeek public function getByCycle(SectionInterface $section, $params = []) { $orderShops = $this->getBy( array_merge( [ 'section' => $section, 'cycleNumber' => $this->getCycleNumberCurrentOrder($section), 'isValid' => true, ], $params ) ); return $orderShops; } // getOrderShopsOfWeekByUser public function getByCycleAndUser(SectionInterface $section, UserInterface $user, array $params = []) { return $this->getByCycle( $section, array_merge( [ 'user' => $user, 'weekNumber' => $this->getCycleNumberCurrentOrder($section), 'excludeComplementaryOrderShops' => true ], $params ) ); } //public $countOrderShopsOfWeek = null; public function countByCycle(SectionInterface $section, bool $excludeComplementaryOrderShops = true) { return $this->getByCycle( $section, [ 'count' => true, 'excludeComplementaryOrderShops' => $excludeComplementaryOrderShops ] ); // @TODO : optimisation à remettre en place /*if (is_null($this->countOrderShopsOfWeek)) { $this->countOrderShopsOfWeek = $this->getByCycle( $section, [ 'count' => true, 'excludeComplementaryOrderShops' => $excludeComplementaryOrderShops ] ); } return $this->countOrderShopsOfWeek;*/ } // getNextWeekId public function getNextCycleId(SectionInterface $section, int $cycleNumber): int { $lastOrder = $this->getOneLastOrderValidOfCycle($section, $cycleNumber); if ($lastOrder) { return intval($lastOrder->getCycleId() + 1); } else { return 1; } } public function getNextIdValidOrder(Section $section) { $lastOrder = $this->getOneLastValid($section); if ($lastOrder) { return intval($lastOrder->getIdValidOrder() + 1); } else { return 1; } } // countValidOrderShopByUserAllMerchant public function countValidByUserAllMerchant($user) { $totalOrder = 0; foreach ($this->merchantStore->getRepositoryQuery()->findAll() as $merchant) { $totalOrder += $this->countValidByUser($user, $merchant); } return $totalOrder; } public function countValidByUser(UserInterface $user, MerchantInterface $merchant = null) { return $this->getBy( [ 'user' => $user, 'isValid' => true, 'merchant' => $merchant, 'excludeComplementaryOrderShops' => true, 'count' => true ] ); } // countValidOrderWithReductionCredit public function countValidWithReductionCredit( OrderReductionCreditInterface $reductionCredit, UserInterface $user = null ): string { $query = $this->query->create(); if ($user) { $query->filterByUser($user); } $query ->selectCount() ->filterByReductionCredit($reductionCredit) ->filterByStatus(OrderStatus::$statusAliasAsValid) ->filterBySection($this->section); return $query->count(); } // countValidOrderWithReductionCart public function countValidWithReductionCart( OrderReductionCartInterface $reductionCart ): int { $query = $this->query->create(); $query ->selectCount() ->filterByReductionCart($reductionCart) ->filterByStatus(OrderStatus::$statusAliasAsValid) ->filterBySection($this->section); return $query->count(); } // countValidOrderWithReductionCartPerUser public function countValidWithReductionCartPerUser( OrderReductionCartInterface $reductionCart, UserInterface $user ): string { $query = $this->query->create(); $query ->selectCount() ->filterByUser($user) ->filterByReductionCart($reductionCart) ->filterByStatus(OrderStatus::$statusAliasAsValid) ->filterBySection($this->section); return $query->count(); } // findCartCurrent public function getCartCurrent(array $params): ?OrderShopInterface { $query = $this->query->create(); if (isset($params['user'])) { $query ->filterByUser($params['user']); } if (isset($params['visitor'])) { $query ->filterByVisitor($params['visitor']); } $query ->selectOrderReductionCarts() ->filterByStatus(OrderStatus::$statusAliasAsValid) ->filterBySection($this->section); $results = $query->find(); if ($results) { return $results[0]; } return null; } // findLastOrderValidOfWeek public function getOneLastValidOfCycle(int $cycleNumber): ?OrderShopInterface { $query = $this->query->create(); $query ->filterByCycleNumber($cycleNumber) ->filterByStatus(OrderStatus::$statusAliasAsValid) ->filterIsNotMainOrderShop() ->orderBy('.weekId', 'DESC') ->filterBySection($this->section); return $query->findOne(); } //findLastOrderValid public function getOneLastValid(): ?OrderShopInterface { $query = $this->query->create(); $query ->filterByStatus(OrderStatus::$statusAliasAsValid) ->filterIsNotMainOrderShop() ->orderBy('.idValidOrder', 'DESC') ->filterBySection($this->section); return $query->findOne(); } // @TODO : Fonction à tester // findAllBy public function getBy(array $params = []) { $query = $this->query->create(); if (isset($params['section'])) { $query->filterBySection($params['section']); } else { $query->filterBySection($this->section); } if (isset($params['count']) && $params['count']) { $query->selectCount(); } else { if (isset($params['select'])) { $query->selectParam($params['select']); } } if (isset($params['dateStart']) || isset($params['dateEnd'])) { $params['dateField'] = isset($params['dateField']) ? $params['dateField'] : 'validationDate'; } if (isset($params['dateStart'])) { $query->filterByDateStart($params['dateField'], $params['dateStart']); } if (isset($params['dateEnd'])) { $query->filterByDateEnd($params['dateField'], $params['dateEnd']); } if (isset($params['cycleNumber'])) { $query->filterByCycleNumber($params['cycleNumber']); } if (isset($params['isCart'])) { $query->filterByStatus(OrderStatus::$statusAliasAsCart); } if (isset($params['isValid'])) { $query->filterByStatus(OrderStatus::$statusAliasAsValid); } if (isset($params['isWaitingDelivery'])) { $query->filterByStatus(OrderStatus::$statusAliasWaitingDelivery); } if (isset($params['orderStatus'])) { $query->filterByStatus($params['orderStatus']); } if (isset($params['user'])) { $query->filterByUser($params['user']); } if (isset($params['address'])) { $query->filterByAddress($params['address']); } if (isset($params['weekDeliveryTrucks'])) { $query->filterByWeekDeliveryTruck($params['weekDeliveryTrucks']); } if (isset($params['estimatedDeliveryDateTime'])) { $date = clone $params['estimatedDeliveryDateTime']; $query ->filterByEstimatedDeliveryDateStart($date->format('Y-m-d 00:00:00')) ->filterByEstimatedDeliveryDateEnd($date->modify('+1 day')->format('Y-m-d 00:00:00')); } if (isset($params['deliveryDate'])) { $date = clone $params['deliveryDate']; $query ->filterByDeliveryDateStart($date->format('Y-m-d 00:00:00')) ->filterByDeliveryDateEnd($date->modify('+1 day')->format('Y-m-d 00:00:00')); } if (isset($params['mergeComplementaryOrderShops'])) { $query ->joinComplementaryOrderShops(); } if (isset($params['excludeComplementaryOrderShops']) || isset($params['mergeComplementaryOrderShops'])) { $query->filterIsNullMainOrderShop(); } if (isset($params['isCircuit'])) { $query->filterIsNullDeliveryPointSale(); } if (isset($params['isDepository'])) { $query->filterIsNotNullDeliveryPointSale(); } if (isset($params['isOffCircuit'])) { $query->filterIsPointSale('devAliasHorsTournee'); } if (isset($params['isGiftVoucher'])) { $query->filterIsPointSale('devAliasGiftVoucher'); } if (isset($params['deliveryAvailability'])) { $deliveryAvailability = $params['deliveryAvailability']; $deliveryAvailabilityZone = ($deliveryAvailability instanceof DeliveryAvailabilityZone) ? $deliveryAvailability : false; $deliveryAvailabilityPointSale = ($deliveryAvailability instanceof DeliveryAvailabilityPointSale) ? $deliveryAvailability : false; if ($deliveryAvailabilityZone) { $query->filterByAvailabilityPointZone($deliveryAvailabilityZone); } if ($deliveryAvailabilityPointSale) { $query->filterByAvailabilityPointZone($deliveryAvailabilityPointSale); } } else { $query->joinDeliverySlotZone(); $query->joinDeliverySlotPointSale(); } if (isset($params['orderBy'])) { $sort = isset($params['orderByDirection']) ? $params['orderByDirection'] : 'DESC'; $query->orderBy($params['orderBy'], $sort); } else { $query->orderBy('.id', 'DESC'); } if (isset($params['groupBy'])) { $query->groupBy($params['groupBy']); } if (isset($params['count']) && $params['count']) { return $query->count(); } return $query->find(); } /* public function getCartCurrent(SectionInterface $section, UserInterface $user = null, VisitorInterface $visitor = null) { $paramsSearchOrderShop = []; $user = $this->security->getUser(); $visitor = $this->userUtils->getVisitorCurrent(); $orderShop = null; $orderShopUser = null; $orderShopVisitor = null; if ($user) { $orderShopUser = $this->orderShopRepo->findCartCurrent( [ 'user' => $user ] ); } if ($visitor) { $orderShopVisitor = $this->orderShopRepo->findCartCurrent( [ 'visitor' => $visitor ] ); } if ($orderShopUser || $orderShopVisitor) { // merge if ($orderShopUser && $orderShopVisitor && $orderShopUser != $orderShopVisitor && $orderShopVisitor->getOrderProducts() && count($orderShopVisitor->getOrderProducts()) && $orderShopUser->getOrderStatus()->getAlias() == OrderStatus::ALIAS_CART) { $orderShop = $this->mergeOrderShops($orderShopUser, $orderShopVisitor); $this->utils->addFlash( 'success', "Votre panier visiteur vient d'être fusionné avec votre panier client." ); } else { $orderShop = ($orderShopUser) ? $orderShopUser : $orderShopVisitor; } // set user if ($orderShop && $user && !$orderShop->getUser()) { $orderShop->setUser($user); $orderShop->setVisitor(null); $this->em->persist($orderShop); $this->em->flush(); } } return $orderShop; }*/ }