app, $request, true, ['cancmd']); $hasOneAdmin = []; if (!$records->isEmpty()) { $order = new OrderEntity(); $order->setUser($this->getAuthenticatedUser()); $order->setDeadline((null !== $deadLine = $request->request->get('deadline')) ? new \DateTime($deadLine) : $deadLine); $order->setOrderUsage($request->request->get('use', '')); foreach ($records as $key => $record) { if ($collectionHasOrderAdmins->containsKey($record->get_base_id())) { if (!$collectionHasOrderAdmins->get($record->get_base_id())) { $records->remove($key); } } if (!isset($hasOneAdmin[$record->get_base_id()])) { $query = $this->createUserQuery(); $hasOneAdmin[$record->get_base_id()] = (Boolean) count($query->on_base_ids([$record->get_base_id()]) ->who_have_right(['order_master']) ->execute()->get_results()); } $collectionHasOrderAdmins->set($record->get_base_id(), $hasOneAdmin[$record->get_base_id()]); if (!$hasOneAdmin[$record->get_base_id()]) { $toRemove[] = $key; } else { $orderElement = new OrderElement(); $order->addElement($orderElement); $orderElement->setOrder($order); $orderElement->setBaseId($record->get_base_id()); $orderElement->setRecordId($record->get_record_id()); $this->getEntityManager()->persist($orderElement); } } foreach ($toRemove as $key) { if ($records->containsKey($key)) { $records->remove($key); } } $noAdmins = $collectionHasOrderAdmins->forAll(function ($key, $hasAdmin) { return false === $hasAdmin; }); if ($noAdmins) { $msg = $this->app->trans('There is no one to validate orders, please contact an administrator'); } else { $order->setTodo($order->getElements()->count()); try { $this->dispatch(PhraseaEvents::ORDER_CREATE, new OrderEvent($order)); $this->getEntityManager()->persist($order); $this->getEntityManager()->flush(); $msg = $this->app->trans('The records have been properly ordered'); $success = true; } catch (\Exception $e) { $msg = $this->app->trans('An error occured'); } } } else { $msg = $this->app->trans('There is no record eligible for an order'); } if ('json' === $request->getRequestFormat()) { return $this->app->json([ 'success' => $success, 'msg' => $msg, ]); } return $this->app->redirectPath('prod_orders', [ 'success' => (int) $success, 'action' => 'send', ]); } /** * Display list of orders * * @param Request $request * * @return Response */ public function displayOrders(Request $request) { $page = (int) $request->query->get('page', 1); $offsetStart = $page - 1; $perPage = (int) $request->query->get('per-page', 10); $sort = $request->query->get('sort'); $baseIds = array_keys($this->getAclForUser()->get_granted_base(['order_master'])); $ordersList = $this->getOrderRepository()->listOrders($baseIds, $offsetStart, $perPage, $sort); $total = $this->getOrderRepository()->countTotalOrders($baseIds); return $this->render('prod/orders/order_box.html.twig', [ 'page' => $page, 'perPage' => $perPage, 'total' => $total, 'previousPage' => $page < 2 ? false : ($page - 1), 'nextPage' => $page >= ceil($total / $perPage) ? false : $page + 1, 'orders' => new ArrayCollection($ordersList), ]); } /** * Display a single order identified by its id * * @param integer $order_id * @return Response */ public function displayOneOrder($order_id) { $order = $this->getOrderRepository()->find($order_id); if (null === $order) { throw new NotFoundHttpException('Order not found'); } return $this->render('prod/orders/order_item.html.twig', [ 'order' => $order, ]); } /** * Send an order * * @param Request $request * @param integer $order_id * @return RedirectResponse|JsonResponse */ public function sendOrder(Request $request, $order_id) { $success = false; /** @var Order $order */ if (null === $order = $this->getOrderRepository()->find($order_id)) { throw new NotFoundHttpException('Order not found'); } $manager = $this->getEntityManager(); $basket = $order->getBasket(); if (null === $basket) { $basket = new Basket(); $basket->setName($this->app->trans('Commande du %date%', [ '%date%' => $order->getCreatedOn()->format('Y-m-d'), ])); $basket->setUser($order->getUser()); $basket->setPusher($this->getAuthenticatedUser()); $manager->persist($basket); $manager->flush(); } $n = 0; $elements = $request->request->get('elements', []); foreach ($order->getElements() as $orderElement) { if (in_array($orderElement->getId(), $elements)) { $sbas_id = \phrasea::sbasFromBas($this->app, $orderElement->getBaseId()); $record = new \record_adapter($this->app, $sbas_id, $orderElement->getRecordId()); $basketElement = new BasketElement(); $basketElement->setRecord($record); $basketElement->setBasket($basket); $orderElement->setOrderMaster($this->getAuthenticatedUser()); $orderElement->setDeny(false); $orderElement->getOrder()->setBasket($basket); $basket->addElement($basketElement); $n++; $this->getAclForUser($basket->getUser())->grant_hd_on($record, $this->getAuthenticatedUser(), 'order'); } } try { if ($n > 0) { $order->setTodo($order->getTodo() - $n); $this->dispatch(PhraseaEvents::ORDER_DELIVER, new OrderDeliveryEvent($order, $this->getAuthenticatedUser(), $n)); } $success = true; // There was a basketElement persist here. Seems useless as all entities are managed. $manager->persist($basket); $manager->persist($order); $manager->flush(); } catch (\Exception $e) { } if ('json' === $request->getRequestFormat()) { return $this->app->json([ 'success' => $success, 'msg' => $success ? $this->app->trans('Order has been sent') : $this->app->trans('An error occured while sending, please retry or contact an admin if problem persists'), 'order_id' => $order_id, ]); } return $this->app->redirectPath('prod_orders', [ 'success' => (int) $success, 'action' => 'send', ]); } /** * Deny an order * * @param Request $request * @param integer $order_id * @return RedirectResponse|JsonResponse */ public function denyOrder(Request $request, $order_id) { $success = false; /** @var Order $order */ $order = $this->getOrderRepository()->find($order_id); if (null === $order) { throw new NotFoundHttpException('Order not found'); } $n = 0; $elements = $request->request->get('elements', []); $manager = $this->getEntityManager(); foreach ($order->getElements() as $orderElement) { if (in_array($orderElement->getId(),$elements)) { $orderElement->setOrderMaster($this->getAuthenticatedUser()); $orderElement->setDeny(true); $manager->persist($orderElement); $n++; } } try { if ($n > 0) { $order->setTodo($order->getTodo() - $n); $this->dispatch(PhraseaEvents::ORDER_DENY, new OrderDeliveryEvent($order, $this->getAuthenticatedUser(), $n)); } $success = true; $manager->persist($order); $manager->flush(); } catch (\Exception $e) { } if ('json' === $request->getRequestFormat()) { return $this->app->json([ 'success' => $success, 'msg' => $success ? $this->app->trans('Order has been denied') : $this->app->trans('An error occured while denying, please retry or contact an admin if problem persists'), 'order_id' => $order_id, ]); } return $this->app->redirectPath('prod_orders', [ 'success' => (int) $success, 'action' => 'send', ]); } /** * @return OrderRepository */ private function getOrderRepository() { return $this->app['repo.orders']; } }