Files
domokits/local/modules/ColissimoWs/Loop/PriceSlicesLoop.php
Laurent LE CORRE 649c92e52f Ajout des modules ColissimoWs et ColissimoLabel.php
Ne pas oublier de vérifier si les tables nécessaires sont bien créées en BDD.
2020-05-07 11:45:31 +02:00

57 lines
1.7 KiB
PHP

<?php
namespace ColissimoWs\Loop;
use ColissimoWs\Model\ColissimowsPriceSlicesQuery;
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;
use function mysql_xdevapi\getSession;
class PriceSlicesLoop extends BaseLoop implements PropelSearchLoopInterface
{
/**
* @return ArgumentCollection
*/
protected function getArgDefinitions()
{
return new ArgumentCollection(
Argument::createIntTypeArgument('area_id', null, true)
);
}
public function buildModelCriteria()
{
$areaId = $this->getAreaId();
$areaPrices = ColissimowsPriceSlicesQuery::create()
->filterByAreaId($areaId)
->orderByMaxWeight()
->orderByMaxPrice()
;
return $areaPrices;
}
public function parseResults(LoopResult $loopResult)
{
/** @var \ColissimoWs\Model\ColissimoWsPriceSlices $priceSlice */
foreach ($loopResult->getResultDataCollection() as $priceSlice) {
$loopResultRow = new LoopResultRow($priceSlice);
$loopResultRow
->set("SLICE_ID", $priceSlice->getId())
->set("MAX_WEIGHT", $priceSlice->getMaxWeight())
->set("MAX_PRICE", $priceSlice->getMaxPrice())
->set("SHIPPING", $priceSlice->getShipping())
->set("FRANCO", $priceSlice->getFrancoMinPrice())
;
$loopResult->addRow($loopResultRow);
}
return $loopResult;
}
}