86 lines
2.3 KiB
PHP
86 lines
2.3 KiB
PHP
<?php
|
|
|
|
namespace LivraisonParSecteurs\Loop;
|
|
|
|
use LivraisonParSecteurs\Model\LpsAreaCityQuery;
|
|
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;
|
|
use Thelia\Type\EnumListType;
|
|
use Thelia\Type\TypeCollection;
|
|
|
|
/**
|
|
* Class AreaCitiesLoop
|
|
* @package LivraisonParSecteurs\Loop
|
|
*/
|
|
class AreaCitiesLoop 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 $lps_area_cities) {
|
|
|
|
$loopResultRow = new LoopResultRow($lps_area_cities);
|
|
$loopResultRow
|
|
->set("ID", $lps_area_cities->getId())
|
|
->set("ZIPCODE", $lps_area_cities->getZipcode())
|
|
->set("TITLE", $lps_area_cities->getTitle())
|
|
->set("LATITUDE", $lps_area_cities->getLatitude())
|
|
->set("LONGITUDE", $lps_area_cities->getLongitude())
|
|
;
|
|
$loopResult->addRow($loopResultRow);
|
|
}
|
|
return $loopResult;
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
protected function getArgDefinitions()
|
|
{
|
|
return new ArgumentCollection(
|
|
Argument::createIntListTypeArgument('area_id'),
|
|
Argument::createEnumListTypeArgument('order',
|
|
['title', 'zipcode'], 'title')
|
|
);
|
|
}
|
|
|
|
/**
|
|
* @inheritdoc
|
|
*/
|
|
public function buildModelCriteria()
|
|
{
|
|
$query = LpsAreaCityQuery::create();
|
|
|
|
if (null != $id = $this->getAreaId()) {
|
|
$query->filterByIdArea($id);
|
|
}
|
|
|
|
foreach ($this->getOrder() as $order) {
|
|
switch ($order) {
|
|
case 'title':
|
|
$query->orderByTitle();
|
|
break;
|
|
case 'zipcode':
|
|
$query->orderByZipcode()->orderByTitle();
|
|
break;
|
|
}
|
|
}
|
|
|
|
return $query;
|
|
}
|
|
|
|
}
|