Files
aux-bieaux-legumes/local/modules/PlanificationLivraison/Loop/ScheduledDeliveriesLoop.php

163 lines
5.7 KiB
PHP

<?php
namespace PlanificationLivraison\Loop;
use DateTime;
use LivraisonParSecteurs\Model\LpsArea;
use LivraisonParSecteurs\Model\LpsAreaCityQuery;
use LivraisonParSecteurs\Model\LpsAreaQuery;
use PlanificationLivraison\Model\OrderDeliveryScheduleQuery;
use PointRetrait\Model\PdrPlacesQuery;
use Propel\Runtime\ActiveQuery\Criteria;
use Thelia\Core\Template\Element\BaseLoop;
use Thelia\Core\Template\Element\LoopResult;
use Thelia\Core\Template\Element\LoopResultRow;
use Thelia\Core\Template\Element\PropelSearchLoopInterface;
use Thelia\Core\Template\Loop\Argument\Argument;
use Thelia\Core\Template\Loop\Argument\ArgumentCollection;
use Thelia\Model\Base\OrderStatus;
use Thelia\Model\CustomerQuery;
use Thelia\Model\OrderAddressQuery;
use Thelia\Model\OrderQuery;
use Thelia\Model\OrderStatusQuery;
/**
* Class ScheduledDeliveriesLoop
* @package PlanificationLivraison\Loop
*/
class ScheduledDeliveriesLoop extends BaseLoop implements PropelSearchLoopInterface
{
const DOMICILE = "domicile";
const RETRAIT = "retrait";
const CLICK_AND_COLLECT = "clickandcollect";
public $countable = true;
/**
* @param LoopResult $loopResult
*
* @return LoopResult
*/
public function parseResults(LoopResult $loopResult)
{
foreach ($loopResult->getResultDataCollection() as $deliveries) {
$loopResultRow = new LoopResultRow($deliveries);
$delta = date_diff($deliveries->getDueDeliveryTimeStart(), new DateTime("now"));
$order = OrderQuery::create()->findOneById($deliveries->getOrderId());
$customer = $order->getCustomer()->getFirstname() . ' ' . $order->getCustomer()->getLastname();
if (null != $deliveries->getDeliveryAddressId()) {
$city = OrderAddressQuery::create()->findOneById($order->getDeliveryOrderAddressId())->getCity();
$area = LpsAreaQuery::create()->findOneById(LpsAreaCityQuery::create()->findOneById($deliveries->getDeliveryAddressId())->getIdArea())->getTitle();
}
if (null != $deliveries->getDeliveryPlaceId())
$place = PdrPlacesQuery::create()->findOneById($deliveries->getDeliveryPlaceId())->getTitle();
$loopResultRow
->set("ORDER_ID", $deliveries->getOrderId())
->set("ADDRESS_ID", $deliveries->getDeliveryAddressId())
->set("PLACE_ID", $deliveries->getDeliveryPlaceId())
->set("SCHEDULE_ID", $deliveries->getScheduleId())
->set("START_DATE", $deliveries->getDueDeliveryTimeStart())
->set("END_DATE", $deliveries->getDueDeliveryTimeEnd())
->set("DELTA", $delta->days)
->set("CUSTOMER", $customer)
->set("AREA", $area)
->set("CITY", $city)
->set("PLACE", $place)
;
$loopResult->addRow($loopResultRow);
}
return $loopResult;
}
/**
* @inheritdoc
*/
protected function getArgDefinitions()
{
return new ArgumentCollection(
Argument::createIntTypeArgument('order_id'),
Argument::createEnumListTypeArgument('list_type', [
self::DOMICILE,
self::RETRAIT,
self::CLICK_AND_COLLECT
], self::DOMICILE),
Argument::createBooleanTypeArgument('only_future', true),
Argument::createEnumListTypeArgument('order', [
'date',
'date-reverse',
], 'date')
);
}
/**
* @inheritdoc
*/
public function buildModelCriteria()
{
$deliveries = OrderDeliveryScheduleQuery::create();
if (null !== $this->getOrderId()) {
return $deliveries->filterByOrderId($this->getOrderId());
}
// Déjà, on n'affiche que les commandes non annulées
$deliveries->filterByOrderId(self::onlyNotCanceledOrders());
$clickAndCollectPlaces = PdrPlacesQuery::create()->filterByClickAndCollect(1)->find()->getData();
foreach ($this->getListType() as $parametre) {
switch ($parametre) {
case self::DOMICILE:
$deliveries->filterByDeliveryAddressId(null, Criteria::NOT_EQUAL);
break;
case self::RETRAIT:
$deliveries->filterByDeliveryPlaceId($clickAndCollectPlaces, Criteria::IN);
break;
case self::CLICK_AND_COLLECT:
$deliveries->filterByDeliveryPlaceId($clickAndCollectPlaces, Criteria::NOT_IN);
break;
default:
break;
}
}
if ($this->getOnlyFuture())
$deliveries->filterByDueDeliveryTimeStart(array('min' => time()))->find();
else
$deliveries->filterByDueDeliveryTimeStart(array('max' => time()))->find();
foreach ($this->getOrder() as $parametre) {
switch ($parametre) {
case 'date':
$deliveries->orderByDueDeliveryTimeStart(Criteria::ASC);
break;
case 'date-reverse':
$deliveries->orderByDueDeliveryTimeStart(Criteria::DESC);
break;
default:
break;
}
}
return $deliveries;
}
private function onlyNotCanceledOrders() {
$notCanceledOrders = [];
$notCanceledData = OrderQuery::create()->filterByStatusId(OrderStatusQuery::create()->findOneByCode('canceled')->getId(), Criteria::NOT_EQUAL)->find()->getData();
foreach ($notCanceledData as $data) {
array_push($notCanceledOrders, $data->getId());
}
return $notCanceledOrders;
}
}