Files
domokits/local/modules/DHL/Loop/Price.php

71 lines
1.8 KiB
PHP

<?php
namespace DHL\Loop;
use DHL\Model\DHLDeliveryPrice;
use DHL\Model\DHLDeliveryPriceQuery;
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;
/**
*
* Price loop
*
*
* Class Price
* @package DHL\Loop
* @method int getAreaId()
* @author Laurent LE CORRE <laurent@thecoredev.>
*/
class Price extends BaseLoop implements PropelSearchLoopInterface
{
/* set countable to false since we need to preserve keys */
protected $countable = false;
/**
* @return \Thelia\Core\Template\Loop\Argument\ArgumentCollection
*/
protected function getArgDefinitions()
{
return new ArgumentCollection(
Argument::createIntListTypeArgument('area_id')
);
}
public function buildModelCriteria()
{
$query = DHLDeliveryPriceQuery::create();
if (null !== $areaId = $this->getAreaId()) {
$query->filterByAreaId($areaId, Criteria::IN);
}
$query->orderByMaxWeight();
return $query;
}
public function parseResults(LoopResult $loopResult)
{
/** @var DHLDeliveryPrice $item */
foreach ($loopResult->getResultDataCollection() as $item) {
$loopResultRow = new LoopResultRow($item);
$loopResultRow
->set('ID', $item->getId())
->set('MAX_WEIGHT', $item->getMaxWeight())
->set('PRICE', $item->getPriceWithTax())
->set('AREA_ID', $item->getAreaId())
;
$loopResult->addRow($loopResultRow);
}
return $loopResult;
}
}