Добрый день!
Интересует вопрос алгоритма сортировки выводимых групп товаров в меню магазина?
В частности, было бы неплохо как-то разделить визуально определенные группы, находящиеся в корне магазина и соответственно в общем меню групп магазина. Насчет подгрупп все понятно, хотелось бы оставить все группы в корне магазина.
Например, так: группы с такими-то id - в первом блоке меню (или в первом меню), с такими-то id- во втором меню.
Или согласно поля сортировки, или по доп. свойству для групп.
Шаблон вывода в меню такой - МагазинГруппыТоваровНаГлавной
<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE xsl:stylesheet>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output xmlns="http://www.w3.org/TR/xhtml1/strict" doctype-public="-//W3C//DTD XHTML 1.0 Strict//EN" encoding="utf-8" indent="yes" method="html" omit-xml-declaration="no" version="1.0" media-type="text/xml"/>
<!-- МагазинГруппыТоваровНаГлавной -->
<xsl:template match="/">
<xsl:apply-templates select="/shop"/>
</xsl:template>
<!-- Шаблон для магазина -->
<xsl:template match="/shop">
<SCRIPT>
<xsl:comment>
<xsl:text disable-output-escaping="yes">
<![CDATA[
function show_hide_menu(id)
{
if (obj = document.getElementById(id))
{
obj.style.display == 'none' ? obj.style.display = 'block' : obj.style.display = 'none';
return false;
}
return true;
}
]]>
</xsl:text>
</xsl:comment>
</SCRIPT>
<h2><a href="{path}" title="Интернет-магазин">Интернет-магазин</a></h2>
<ul class="left_menu" id="shop_menu">
<xsl:apply-templates select="group"/>
</ul>
</xsl:template>
<!-- Шаблон для групп товара -->
<xsl:template match="group">
<li>
<!-- Если это подпункт (родитель не равен 0) - выводим слева от него тире -->
<xsl:if test="@parent != 0">
—
</xsl:if>
<a href="{/shop/path}{fullpath}" onClick="return show_hide_menu('{@id}');">
<xsl:value-of disable-output-escaping="yes" select="name"/>
</a>
<!-- Если есть подгруппы -->
<xsl:if test="group">
<ul class="left_menu gray_link gray" id="{@id}" style="display: none;">
<xsl:apply-templates select="group"/>
</ul>
</xsl:if>
</li>
</xsl:template>
</xsl:stylesheet>