Files
aux-bieaux-legumes/local/modules/PointRetrait/Loop/GeneralLoop.php

117 lines
3.6 KiB
PHP

<?php
namespace PointRetrait\Loop;
use PlanificationLivraison\PlanificationLivraison;
use PointRetrait\Model\PdrPlacesQuery;
use PointRetrait\Model\PdrScheduleQuery;
use PointRetrait\PointRetrait;
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;
/**
* Class GeneralLoop
* @package LivraisonParSecteurs\Loop
*/
class GeneralLoop extends BaseLoop implements PropelSearchLoopInterface
{
public $countable = false;
public $timestampable = false;
public $versionable = false;
/**
* @param LoopResult $loopResult
*
* @return LoopResult
*/
public function parseResults(LoopResult $loopResult)
{
foreach ($loopResult->getResultDataCollection() as $places) {
$loopResultRow = new LoopResultRow($places);
$schedule = PdrScheduleQuery::create()
->filterByIdPlace($places->getId())
->orderByDay();
$deliveryDays = "";
foreach ($schedule as $day) {
$deliveryDays .= PlanificationLivraison::getDayLabel($day->getDay()) . ', ';
}
$deliveryDays = substr($deliveryDays, 0, strlen($deliveryDays)-2);
$loopResultRow
->set("ID", $places->getId())
->set("TITLE", $places->getTitle())
->set("ACTIVE", $places->getActive())
->set("PRICE", $places->getPrice())
->set("MINIMUM_AMOUNT", $places->getMinimumAmount())
->set("DELIVERY_DAYS", $deliveryDays)
->set("LATITUDE", $places->getLatitude())
->set("LONGITUDE", $places->getLongitude())
->set("ADDRESS1", $places->getAddress1())
->set("ADDRESS2", $places->getAddress2())
->set("ZIPCODE", $places->getZipcode())
->set("CITY", $places->getCity())
->set("ACCESS_COMMENT", $places->getAccessComment())
->set("MODULE_ID", PointRetrait::getModuleId())
;
$loopResult->addRow($loopResultRow);
}
return $loopResult;
}
/**
* @inheritdoc
*/
protected function getArgDefinitions()
{
return new ArgumentCollection(
Argument::createIntListTypeArgument('id'),
Argument::createIntListTypeArgument('active'),
Argument::createIntListTypeArgument('click_and_collect'),
Argument::createEnumListTypeArgument('order',
['city', 'title'], 'title')
);
}
/**
* @inheritdoc
*/
public function buildModelCriteria()
{
$places = PdrPlacesQuery::create();
/* Filtrage éventuel */
if (null != $id = $this->getId()) {
$places->filterById($id);
}
if (null != $active = $this->getActive()) {
$places->filterByActive($active);
}
if (null != $clickAndCollect = $this->getClickAndCollect()) {
$places->filterByClickAndCollect($clickAndCollect);
}
foreach ($this->getOrder() as $order) {
switch ($order) {
case 'title':
$places->orderByTitle();
break;
case 'city':
$places->orderByZipcode()->orderByCity()->orderByAddress1();
break;
}
}
return $places;
}
}