Premiers écrans sur module PointRetrait

This commit is contained in:
2021-02-26 21:10:10 +01:00
parent 86d849a059
commit 1276d9bf3d
34 changed files with 1200 additions and 100 deletions

View File

@@ -4,6 +4,7 @@ namespace PlanificationLivraison\Loop;
use DateTime;
use PlanificationLivraison\Model\OrderDeliveryScheduleQuery;
use Propel\Runtime\ActiveQuery\Criteria;
use Thelia\Core\Template\Element\BaseLoop;
use Thelia\Core\Template\Element\LoopResult;
use Thelia\Core\Template\Element\LoopResultRow;
@@ -17,9 +18,12 @@ use Thelia\Core\Template\Loop\Argument\ArgumentCollection;
*/
class ScheduledDeliveriesLoop extends BaseLoop implements PropelSearchLoopInterface
{
public $countable = true;
const DOMICILE = "domicile";
const RETRAIT = "retrait";
public $countable = true;
/**
* @param LoopResult $loopResult
*
@@ -35,22 +39,30 @@ class ScheduledDeliveriesLoop extends BaseLoop implements PropelSearchLoopInterf
$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("SCHEDULE_ID", $deliveries->getScheduleId())
;
$loopResult->addRow($loopResultRow);
}
return $loopResult;
}
/**
* @inheritdoc
*/
protected function getArgDefinitions()
{
return new ArgumentCollection(
Argument::createEnumListTypeArgument('domicile_ou_retrait', [
self::DOMICILE,
self::RETRAIT
], self::DOMICILE),
Argument::createBooleanTypeArgument('only_future', true),
Argument::createEnumListTypeArgument('order', [
'date',
'date-reverse'
@@ -64,9 +76,35 @@ class ScheduledDeliveriesLoop extends BaseLoop implements PropelSearchLoopInterf
public function buildModelCriteria()
{
$deliveries = OrderDeliveryScheduleQuery::create();
$deliveries->filterByDueDeliveryTimeStart(array('min' => time()))->find();
return $deliveries->orderByDueDeliveryTimeStart();
foreach ($this->getDomicileOuRetrait() as $parametre) {
switch ($parametre) {
case self::DOMICILE:
$deliveries->filterByDeliveryAddressId(null, Criteria::NOT_EQUAL);
break;
case self::RETRAIT:
$deliveries->filterByDeliveryPlaceId(null, Criteria::NOT_EQUAL);
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;
}
}
return $deliveries;
}
}