create breadcrumb and FolderPath loop
This commit is contained in:
@@ -21,6 +21,7 @@
|
|||||||
<loop class="Thelia\Core\Template\Loop\FeatureAvailability" name="feature-availability"/>
|
<loop class="Thelia\Core\Template\Loop\FeatureAvailability" name="feature-availability"/>
|
||||||
<loop class="Thelia\Core\Template\Loop\FeatureValue" name="feature_value"/>
|
<loop class="Thelia\Core\Template\Loop\FeatureValue" name="feature_value"/>
|
||||||
<loop class="Thelia\Core\Template\Loop\Folder" name="folder"/>
|
<loop class="Thelia\Core\Template\Loop\Folder" name="folder"/>
|
||||||
|
<loop class="Thelia\Core\Template\Loop\FolderPath" name="folder-path"/>
|
||||||
<loop class="Thelia\Core\Template\Loop\Module" name="module"/>
|
<loop class="Thelia\Core\Template\Loop\Module" name="module"/>
|
||||||
<loop class="Thelia\Core\Template\Loop\Order" name="order"/>
|
<loop class="Thelia\Core\Template\Loop\Order" name="order"/>
|
||||||
<loop class="Thelia\Core\Template\Loop\OrderAddress" name="order_address"/>
|
<loop class="Thelia\Core\Template\Loop\OrderAddress" name="order_address"/>
|
||||||
|
|||||||
160
core/lib/Thelia/Core/Template/Loop/FolderPath.php
Normal file
160
core/lib/Thelia/Core/Template/Loop/FolderPath.php
Normal file
@@ -0,0 +1,160 @@
|
|||||||
|
<?php
|
||||||
|
/*************************************************************************************/
|
||||||
|
/* */
|
||||||
|
/* Thelia */
|
||||||
|
/* */
|
||||||
|
/* Copyright (c) OpenStudio */
|
||||||
|
/* email : info@thelia.net */
|
||||||
|
/* web : http://www.thelia.net */
|
||||||
|
/* */
|
||||||
|
/* This program is free software; you can redistribute it and/or modify */
|
||||||
|
/* it under the terms of the GNU General Public License as published by */
|
||||||
|
/* the Free Software Foundation; either version 3 of the License */
|
||||||
|
/* */
|
||||||
|
/* This program is distributed in the hope that it will be useful, */
|
||||||
|
/* but WITHOUT ANY WARRANTY; without even the implied warranty of */
|
||||||
|
/* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the */
|
||||||
|
/* GNU General Public License for more details. */
|
||||||
|
/* */
|
||||||
|
/* You should have received a copy of the GNU General Public License */
|
||||||
|
/* along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
/* */
|
||||||
|
/*************************************************************************************/
|
||||||
|
|
||||||
|
namespace Thelia\Core\Template\Loop;
|
||||||
|
use Thelia\Core\Template\Element\BaseI18nLoop;
|
||||||
|
use Thelia\Core\Template\Element\LoopResult;
|
||||||
|
use Thelia\Core\Template\Element\LoopResultRow;
|
||||||
|
use Thelia\Core\Template\Loop\Argument\Argument;
|
||||||
|
use Thelia\Core\Template\Loop\Argument\ArgumentCollection;
|
||||||
|
use Thelia\Model\FolderQuery;
|
||||||
|
use Thelia\Type\BooleanOrBothType;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Class FolderPath
|
||||||
|
* @package Thelia\Core\Template\Loop
|
||||||
|
* @author Manuel Raynaud <mraynaud@openstudio.fr>
|
||||||
|
*/
|
||||||
|
class FolderPath extends BaseI18nLoop
|
||||||
|
{
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* define all args used in your loop
|
||||||
|
*
|
||||||
|
*
|
||||||
|
* example :
|
||||||
|
*
|
||||||
|
* public function getArgDefinitions()
|
||||||
|
* {
|
||||||
|
* return new ArgumentCollection(
|
||||||
|
* Argument::createIntListTypeArgument('id'),
|
||||||
|
* new Argument(
|
||||||
|
* 'ref',
|
||||||
|
* new TypeCollection(
|
||||||
|
* new Type\AlphaNumStringListType()
|
||||||
|
* )
|
||||||
|
* ),
|
||||||
|
* Argument::createIntListTypeArgument('category'),
|
||||||
|
* Argument::createBooleanTypeArgument('new'),
|
||||||
|
* Argument::createBooleanTypeArgument('promo'),
|
||||||
|
* Argument::createFloatTypeArgument('min_price'),
|
||||||
|
* Argument::createFloatTypeArgument('max_price'),
|
||||||
|
* Argument::createIntTypeArgument('min_stock'),
|
||||||
|
* Argument::createFloatTypeArgument('min_weight'),
|
||||||
|
* Argument::createFloatTypeArgument('max_weight'),
|
||||||
|
* Argument::createBooleanTypeArgument('current'),
|
||||||
|
*
|
||||||
|
* );
|
||||||
|
* }
|
||||||
|
*
|
||||||
|
* @return \Thelia\Core\Template\Loop\Argument\ArgumentCollection
|
||||||
|
*/
|
||||||
|
protected function getArgDefinitions()
|
||||||
|
{
|
||||||
|
return new ArgumentCollection(
|
||||||
|
Argument::createIntTypeArgument('folder', null, true),
|
||||||
|
Argument::createIntTypeArgument('depth'),
|
||||||
|
Argument::createIntTypeArgument('level'),
|
||||||
|
Argument::createBooleanOrBothTypeArgument('visible', true, false)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* this function have to be implement in your own loop class.
|
||||||
|
*
|
||||||
|
* All loops parameters can be accessible via getter.
|
||||||
|
*
|
||||||
|
* for example, ref parameter is accessible through getRef method
|
||||||
|
*
|
||||||
|
* @param $pagination
|
||||||
|
*
|
||||||
|
* @return mixed
|
||||||
|
*/
|
||||||
|
public function exec(&$pagination)
|
||||||
|
{
|
||||||
|
$id = $this->getFolder();
|
||||||
|
$visible = $this->getVisible();
|
||||||
|
|
||||||
|
$search = FolderQuery::create();
|
||||||
|
|
||||||
|
$locale = $this->configureI18nProcessing($search, array('TITLE'));
|
||||||
|
|
||||||
|
$search->filterById($id);
|
||||||
|
if ($visible != BooleanOrBothType::ANY) $search->filterByVisible($visible);
|
||||||
|
|
||||||
|
$results = array();
|
||||||
|
|
||||||
|
$ids = array();
|
||||||
|
|
||||||
|
do {
|
||||||
|
$folder = $search->findOne();
|
||||||
|
|
||||||
|
if ($folder != null) {
|
||||||
|
|
||||||
|
$loopResultRow = new LoopResultRow();
|
||||||
|
|
||||||
|
$loopResultRow
|
||||||
|
->set("TITLE",$folder->getVirtualColumn('i18n_TITLE'))
|
||||||
|
->set("URL", $folder->getUrl($locale))
|
||||||
|
->set("ID", $folder->getId())
|
||||||
|
->set("LOCALE",$locale)
|
||||||
|
;
|
||||||
|
|
||||||
|
$results[] = $loopResultRow;
|
||||||
|
|
||||||
|
$parent = $folder->getParent();
|
||||||
|
|
||||||
|
if ($parent > 0) {
|
||||||
|
|
||||||
|
// Prevent circular refererences
|
||||||
|
if (in_array($parent, $ids)) {
|
||||||
|
throw new \LogicException(sprintf("Circular reference detected in category ID=%d hierarchy (category ID=%d appears more than one times in path)", $id, $parent));
|
||||||
|
}
|
||||||
|
|
||||||
|
$ids[] = $parent;
|
||||||
|
|
||||||
|
$search = FolderQuery::create();
|
||||||
|
|
||||||
|
$this->configureI18nProcessing($search, array('TITLE'));
|
||||||
|
|
||||||
|
$search->filterById($parent);
|
||||||
|
if ($visible != BooleanOrBothType::ANY) $search->filterByVisible($visible);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} while ($folder != null && $parent > 0);
|
||||||
|
|
||||||
|
// Reverse list and build the final result
|
||||||
|
$results = array_reverse($results);
|
||||||
|
|
||||||
|
$loopResult = new LoopResult();
|
||||||
|
|
||||||
|
foreach($results as $result) $loopResult->addRow($result);
|
||||||
|
|
||||||
|
return $loopResult;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
@@ -9,7 +9,7 @@
|
|||||||
|
|
||||||
<div id="wrapper" class="container">
|
<div id="wrapper" class="container">
|
||||||
|
|
||||||
{* include file="includes/folder-breadcrumb.html" *}
|
{include file="includes/folder-breadcrumb.html" }
|
||||||
|
|
||||||
{module_include location='folders_top'}
|
{module_include location='folders_top'}
|
||||||
|
|
||||||
|
|||||||
@@ -5,17 +5,17 @@
|
|||||||
<li><a href="{url path='admin/folders'}">Folders</a>
|
<li><a href="{url path='admin/folders'}">Folders</a>
|
||||||
|
|
||||||
{ifloop rel="folder_path"}</li>
|
{ifloop rel="folder_path"}</li>
|
||||||
{loop name="folder_path" type="folder-path" visible="*" folder=$folder_id}
|
{loop name="folder_path" type="folder-path" visible="*" folder=$parent}
|
||||||
{if $ID == $folder_id}
|
{if $ID == $parent}
|
||||||
<li class="active">
|
<li class="active">
|
||||||
{if $editing_folder == true}
|
{if $editing_folder == true}
|
||||||
{intl l='Editing %fold' fold="{$TITLE}"}
|
{intl l='Editing %fold' fold="{$TITLE}"}
|
||||||
{else}
|
{else}
|
||||||
{$TITLE} <a href="{url path='/admin/folders/update' folder_id=$ID}" title="{intl l='Edit this folder'}">{intl l="(edit)"}</a>
|
{$TITLE} <a href="{url path="/admin/folders/update/$ID"}" title="{intl l='Edit this folder'}">{intl l="(edit)"}</a>
|
||||||
{/if}
|
{/if}
|
||||||
</li>
|
</li>
|
||||||
{else}
|
{else}
|
||||||
<li><a href="{url path='/admin/folders' folder_id=" $ID" action='browse'}">{$TITLE}</a></li>
|
<li><a href="{url path='/admin/folders' parent="$ID" }">{$TITLE}</a></li>
|
||||||
{/if}
|
{/if}
|
||||||
{/loop}
|
{/loop}
|
||||||
{/ifloop}
|
{/ifloop}
|
||||||
|
|||||||
Reference in New Issue
Block a user