Files
domokits/local/modules/ChronopostHomeDelivery/Loop/ChronopostHomeDeliveryLoop.php

71 lines
2.2 KiB
PHP

<?php
namespace ChronopostHomeDelivery\Loop;
use ChronopostHomeDelivery\Model\ChronopostHomeDeliveryPrice;
use ChronopostHomeDelivery\Model\ChronopostHomeDeliveryPriceQuery;
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 ChronopostHomeDeliveryLoop
* @package ChronopostHomeDelivery\Loop
*
* @method integer getAreaId
* @method integer getDeliveryModeId
*/
class ChronopostHomeDeliveryLoop extends BaseLoop implements PropelSearchLoopInterface
{
/**
* @return ArgumentCollection
*/
protected function getArgDefinitions()
{
return new ArgumentCollection(
Argument::createIntTypeArgument('area_id', null, true),
Argument::createIntTypeArgument('delivery_mode_id', null, true)
);
}
/**
* @return ChronopostHomeDeliveryPriceQuery|\Propel\Runtime\ActiveQuery\ModelCriteria
*/
public function buildModelCriteria()
{
$areaId = $this->getAreaId();
$modeId = $this->getDeliveryModeId();
$areaPrices = ChronopostHomeDeliveryPriceQuery::create()
->filterByDeliveryModeId($modeId)
->filterByAreaId($areaId)
->orderByWeightMax();
return $areaPrices;
}
/**
* @param LoopResult $loopResult
* @return LoopResult
*/
public function parseResults(LoopResult $loopResult)
{
/** @var ChronopostHomeDeliveryPrice $price */
foreach ($loopResult->getResultDataCollection() as $price) {
$loopResultRow = new LoopResultRow($price);
$loopResultRow
->set("SLICE_ID", $price->getId())
->set("MAX_WEIGHT", $price->getWeightMax())
->set("MAX_PRICE", $price->getPriceMax())
->set("PRICE", $price->getPrice())
->set("FRANCO", $price->getFrancoMinPrice())
;
$loopResult->addRow($loopResultRow);
}
return $loopResult;
}
}