Module DigressivePrice
This commit is contained in:
115
.well-known/local/modules/PointRetrait/Loop/GeneralLoop.php
Normal file
115
.well-known/local/modules/PointRetrait/Loop/GeneralLoop.php
Normal file
@@ -0,0 +1,115 @@
|
||||
<?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())
|
||||
;
|
||||
$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;
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user