Курс 2016 года “Разработка на UMI.CMS от 0 до готового сайта”
Не выводится дополнительное меню в версии "Start"

Автор BabajkaРаздел Шаблоны XSLT

Ответов: 4
Просмотров: 3719
Последний ответ 10 Января 2013, 10:08:04
от admin
Магазин "Современный" - добавление заголовка к левому меню каталога

Автор manadsgnРаздел Шаблоны XSLT

Ответов: 4
Просмотров: 4319
Последний ответ 25 Июня 2012, 17:33:00
от manadsgn
Вывод страницы в меню с отключением вывода в карте сайта

Автор alpotemkinРаздел Макросы UMI.CMS

Ответов: 6
Просмотров: 5816
Последний ответ 03 Ноября 2011, 15:07:29
от alpotemkin
Текущая страница - добавление класса к ссылке главного меню

Автор manadsgnРаздел Шаблоны XSLT

Ответов: 2
Просмотров: 3110
Последний ответ 24 Июня 2012, 14:00:10
от manadsgn
Вывод в меню только разделов с определенными свойствами

Автор poloРаздел Шаблоны XSLT

Ответов: 4
Просмотров: 5630
Последний ответ 24 Июня 2011, 12:58:58
от polo

0 Пользователей и 1 Гость просматривают эту тему.

*

cybermax

  • *
  • 16
  • +1/-0
    • Просмотр профиля
Здравствуйте, помогите решить следующую задачу, необходимо, чтобы в выпадающем меню после определенного кол-ва элементов создавалась новая колонка.
Сейчас у меня это выглядит так
<ul>
   <li>Пункт1</li>
   <li>Пункт2</li>
   <li>Пункт3</li>
   <li>Пункт4</li>
   <li>Пункт5</li>
   <li>Пункт6</li>
   <li>Пункт7</li>
</ul>
А хочу чтобы получилось вот так
<ul>
   <li>
     <ul>
       <li>Пункт1</li>
       <li>Пункт2</li>
       <li>Пункт3</li>        
    </ul>
  </li>
  <li>
     <ul>
        <li>Пункт4</li>
        <li>Пункт5</li>
        <li>Пункт6</li>
        <li>Пункт7</li>
     </ul>
   </li>
</ul>

Вот код текущего шаблона

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE xsl:stylesheet SYSTEM "ulang://i18n/constants.dtd:file">

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:umi="http://www.umi-cms.ru/TR/umi">

    <xsl:variable name="max" select="4"/>

    <xsl:template match="udata" mode="left-list">
        <xsl:apply-templates select="items" mode="left-list"/>
    </xsl:template>

    <xsl:template match="items" mode="left-list">
        <nav class="menu-top-block">
            <ul class="menu-top"
                umi:element-id="{../@category-id}"
                umi:region="list"
                umi:sortable="sortable"
                umi:module="catalog">
                <xsl:apply-templates mode="left-list"/>
            </ul>
        </nav>
    </xsl:template>

    <xsl:template match="items/item" mode="left-list">
 
        <li>
            <a href="{@link}">
                <img src="{document(concat('upage://', @id, '.menu_pic'))/udata/property/value}" alt=""/>
                <div class="text">
                    <span>
                        <xsl:value-of select="."/>
                    </span>
                </div>
            </a>

            <xsl:apply-templates select="document(concat('udata://catalog/getCategoryList/default/', @id, '/0/1?expire=600'))/udata" mode="left-sublist"/>
        </li>
    </xsl:template>

    <xsl:template match="items/item" mode="left-sublist">

        <li>
            <a href="{@link}">
                <span class="submenu-icon-{@id}"></span>
                <span class="stext">
                    <xsl:value-of select="."/>
                </span>
            </a>
        </li>

    </xsl:template>


    <xsl:template match="udata" mode="left-sublist">
        <ul class="submenu-{@category-id}">
            <xsl:apply-templates select="items" mode="left-sublist"/>
        </ul>

    </xsl:template>

</xsl:stylesheet>

*

e.ioffe

  • ****
  • 369
  • +81/-2
  • Профессиональная разработка на UMI.CMS.
    • Просмотр профиля
    • Fullspace - Лучший хостинг для UMI.CMS
Re:Выпадающее меню в две колонки.
« Ответ #1 : 25 Мая 2014, 10:22:00 »
Набросал на скорую руку:

<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE xsl:stylesheet SYSTEM "ulang://i18n/constants.dtd:file">

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:umi="http://www.umi-cms.ru/TR/umi">

    <xsl:variable name="max" select="4"/>

    <xsl:template match="udata" mode="left-list">
        <xsl:apply-templates select="items" mode="left-list"/>
    </xsl:template>

    <xsl:template match="items" mode="left-list">
        <nav class="menu-top-block">
            <ul class="menu-top"
                umi:element-id="{../@category-id}"
                umi:region="list"
                umi:sortable="sortable"
                umi:module="catalog">
                <xsl:call-template name="left-list">
                    <xsl:with-param name="items" select="current()" />
                </xsl:call-template>
            </ul>
        </nav>
    </xsl:template>

    <xsl:template name="left-list">
        <xsl:param name="items" />
        <xsl:param name="start">1</xsl:param>
        <xsl:param name="limit">4</xsl:param>
       
        <xsl:variable name="next" select="$start + $limit" />

        <li>
            <ul>
                <xsl:apply-templates select="$items/item[position() &gt;= $start and position() &lt; $next]" mode="left-list" />
            </ul>
        </li>
       
        <xsl:if test="count(items/item) &lt; $next">
            <xsl:call-template name="left-list">
                <xsl:with-param name="items" select="$items" />
                <xsl:with-param name="start" select="$next" />
                <xsl:with-param name="limit" select="$limit" />
            </xsl:call-template>
        </xsl:if>
    </xsl:template>

    <xsl:template match="items/item" mode="left-list">

        <li>
            <a href="{@link}">
                <img src="{document(concat('upage://', @id, '.menu_pic'))/udata/property/value}" alt=""/>
                <div class="text">
                    <span>
                        <xsl:value-of select="."/>
                    </span>
                </div>
            </a>

            <xsl:apply-templates select="document(concat('udata://catalog/getCategoryList/default/', @id, '/0/1?expire=600'))/udata" mode="left-sublist"/>
        </li>
    </xsl:template>

    <xsl:template match="items/item" mode="left-sublist">

        <li>
            <a href="{@link}">
                <span class="submenu-icon-{@id}"></span>
                <span class="stext">
                    <xsl:value-of select="."/>
                </span>
            </a>
        </li>

    </xsl:template>


    <xsl:template match="udata" mode="left-sublist">
        <ul class="submenu-{@category-id}">
            <xsl:apply-templates select="items" mode="left-sublist"/>
        </ul>

    </xsl:template>

</xsl:stylesheet>
Ускорение сайта на UMI.CMS - http://speed.umispec.ru/