Ne pas oublier de vérifier si les tables nécessaires sont bien créées en BDD.
57 lines
1.7 KiB
PHP
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;
|
|
}
|
|
} |