AJAX Меню для магазина

#
AJAX Меню для магазина
Предлагаю вариант вывода меню магазина в виде раскрывающегося списка средствами JS+XSL

Приведенный метод будет полезен в рервую очередь тем, у кого длинный список категорий товаров и доступ к категориям необходим сквозной на всех страницах, но длииные списки портят общую картину.
Пример реализации можно посмотреть на сайте www.gplus.ru

Итак, приступим...

Вывод в макете сайта:

<?php

// находим локацию относительно каталога товаров
$current_shop_id = to_int($GLOBALS['LA']['shop_id']);
$shop = new shop();
$shop_item_path = $shop->GetItemPath($current_shop_id);
$external_propertys = array();
$external_propertys['shop_path']=array();
if($shop_item_path) {
  $group_id=$shop_item_path['group'];
  $parent_id=$group_id;
  if($parent_id!=0) {
    do {

      $group_id=$parent_id;
      $group=$shop->GetGroup($group_id);
      $parent_id=$group['shop_groups_parent_id'];
    } while($parent_id!=0);
    $external_propertys['shop_path']['level']=1; // в подгруппе каталога
    $external_propertys['shop_path']['group']=$group_id;
  } else {
    $external_propertys['shop_path']['level']=0; // в корне каталога
  }
} else {
  $external_propertys['shop_path']['level']=-1; // не в каталоге
}

$Structure = & singleton('Structure');
$param = array();
$param['show_shop_groups']=true;
$Structure->ShowStructure(1,'ЦентральноеМенюКаталог',$param,$external_propertys);
?>


XSL-шаблон

<?xml version="1.0" encoding="windows-1251"?>
<!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="Windows-1251" indent="yes" method="html" omit-xml-declaration="no" version="1.0" media-type="text/xml"/>
   
   <xsl:template match="/document">
      <xsl:variable name="domen" select="/document/site/alias[@alias_current='1']/alias_name"/>
      <script type="text/javascript">
         function toggle(id)
         {
         var o = document.getElementById('n' + id);
         var p = document.getElementById('p' + id);
         if ( 'none' == o.style.display )
         {
         o.style.display = 'block';
         p.src = 'http://<xsl:value-of select="$domen"/>/minus.gif';
         }
         else
         {
         o.style.display = 'none';
         p.src = 'http://<xsl:value-of select="$domen"/>/plus.gif';
         }
         }
      </script>
      <table border="0" width="100%" height="200" cellspacing="0" cellpadding="0" style="margin-left:4px; margin-right:4px;">
         <tr>
            <td width="100%" class="menu_line"></td>
         </tr>
         <!-- Выбираем узлы структуры -->
         <xsl:apply-templates select="structure[show=1]"/>
      </table>
   </xsl:template>
   
   <xsl:template match="structure">
      
      <!-- Запишем в константу ID структуры, данные для которой будут выводиться пользователю -->
      <xsl:variable name="current_structure_id" select="/document/structure/current_structure_id"/>
      <xsl:variable name="domen" select="/document/site/alias[@alias_current='1']/alias_name"/>
      <tr>
         <td width="100%">
            
            <!-- Расчитываем размер отступа -->
            <xsl:variable name="padding" select="level * 10"/>
            
            <xsl:variable name="idx" select="string(@id)"/>
            <xsl:variable name="pidx" select="concat('p',string($idx))"/>
            <xsl:variable name="nidx" select="concat('n',string($idx))"/>
            
            <xsl:variable name="level" select="/document/shop_path/level"/>
            
            <div style="padding-left: {$padding}px;">
               
               
               <xsl:if test="@id=42">
                  <a href="JavaScript:void(0)" onclick="toggle('{$idx}');">
                     <xsl:choose>
                        <xsl:when test="$level=-1">
                           <img id="{$pidx}" class="p_m" border="0" src="http://{$domen}/plus.gif"/>
                        </xsl:when>
                        <xsl:otherwise>
                           <img id="{$pidx}" class="p_m" border="0" src="http://{$domen}/minus.gif"/>
                        </xsl:otherwise>
                     </xsl:choose>
                  </a>
                  
               </xsl:if>
               
               <!-- Показывать ссылку, или нет -->
               <xsl:if test="show_link=1">
                  
                  <!-- Определяем адрес ссылки -->
                  <xsl:variable name="link">
                     <xsl:choose>
                        <!-- Если внешняя ссылка -->
                        <xsl:when test="is_external_link=1">
                           <xsl:value-of disable-output-escaping="yes" select="external_link"/>
                        </xsl:when>
                        <!-- Иначе если внутренняя ссылка -->
                        <xsl:otherwise>
                           <xsl:value-of disable-output-escaping="yes" select="link"/>
                        </xsl:otherwise>
                     </xsl:choose>
                  </xsl:variable>
                  
                  <!-- Определяем стиль вывода ссылки -->
                  <xsl:variable name="link_style">
                     <xsl:choose>
                        <!-- Выделяем текущую страницу жирным (если это текущая страница, либо у нее есть ребенок с ID, равным текущей) -->
                        <xsl:when test="current_structure_id=@id or count(.//structure[@id=$current_structure_id])=1">font-weight: bold</xsl:when>
                        <!-- Иначе обычный вывод с пустым стилем -->
                        <xsl:otherwise></xsl:otherwise>
                     </xsl:choose>
                  </xsl:variable>
                  
                  <a href="{$link}">
                     <span style="{$link_style}">
                        <xsl:value-of disable-output-escaping="yes" select="name"/>
                     </span>
                  </a>
               </xsl:if>
               
               <!-- Если не показывать ссылку - выводим просто имя ссылки -->
               <xsl:if test="show_link=0">
                  <xsl:value-of disable-output-escaping="yes" select="name"/>
               </xsl:if>
            </div>
            
            <xsl:if test="@id=42">
               <xsl:variable name="block">
                  <xsl:choose>
                     <xsl:when test="$level=-1">none</xsl:when>
                     <xsl:otherwise>block</xsl:otherwise>
                  </xsl:choose>
               </xsl:variable>
               <div id="{$nidx}" style="display: {$block}">
                  <xsl:apply-templates mode="catalog1" select="structure"/>
               </div>
            </xsl:if>
            
         </td>
      </tr>
      <tr>
         <td width="100%" class="menu_line"></td>
      </tr>
   </xsl:template>
   
   <xsl:template match="structure" mode="catalog1">
      <xsl:variable name="domen" select="/document/site/alias[@alias_current='1']/alias_name"/>
      <xsl:if test="level=0">
         <xsl:variable name="padding" select="(level+1) * 10"/>
         
         <xsl:variable name="idx" select="string(@id)"/>
         <xsl:variable name="pidx" select="concat('p',string($idx))"/>
         <xsl:variable name="nidx" select="concat('n',string($idx))"/>
         
         <xsl:variable name="group" select="/document/shop_path/group"/>
         <xsl:variable name="group_name" select="concat('group_',$group)"/>
         
         <div style="padding-left: {$padding}px;">
            <img border="0" src="/images/menu_point.gif" class="menu_point" width="4" height="7"/>
            
            <a href="JavaScript:void(0)" onclick="toggle('{$idx}');">
               <xsl:choose>
                  <xsl:when test="$group_name=$idx">
                     <img id="{$pidx}" class="p_m" border="0" src="http://{$domen}/minus.gif"/>
                  </xsl:when>
                  <xsl:otherwise>
                     <img id="{$pidx}" class="p_m" border="0" src="http://{$domen}/plus.gif"/>
                  </xsl:otherwise>
               </xsl:choose>
            </a>
            
            <!-- Показывать ссылку, или нет -->
            <xsl:if test="show_link=1">
               
               <!-- Определяем адрес ссылки -->
               <xsl:variable name="link">
                  <xsl:choose>
                     <!-- Если внешняя ссылка -->
                     <xsl:when test="is_external_link=1">
                        <xsl:value-of disable-output-escaping="yes" select="external_link"/>
                     </xsl:when>
                     <!-- Иначе если внутренняя ссылка -->
                     <xsl:otherwise>
                        <xsl:value-of disable-output-escaping="yes" select="link"/>
                     </xsl:otherwise>
                  </xsl:choose>
               </xsl:variable>
               
               <a href="{$link}">
                  <span style="font-weight: bold">
                     <xsl:value-of disable-output-escaping="yes" select="name"/>
                  </span>
               </a>
            </xsl:if>
         </div>
         
         <xsl:variable name="block">
            <xsl:choose>
               <xsl:when test="$group_name=$idx">block</xsl:when>
               <xsl:otherwise>none</xsl:otherwise>
            </xsl:choose>
         </xsl:variable>
         <div id="{$nidx}" style="display: {$block}">
            <xsl:variable name="pid" select="substring(@id,7,5)"/>
            <xsl:apply-templates mode="catalog2" select="structure[id_parent=$pid]"/>
         </div>
         
      </xsl:if>
   </xsl:template>
   
   <xsl:template match="structure" mode="catalog2">
      <xsl:if test="level=1">
         <xsl:variable name="padding" select="(level+2) * 10"/>
         <div style="padding-left: {$padding}px;">
            <img border="0" src="/images/menu_point.gif" class="menu_point" width="4" height="7"/>
            
            <!-- Показывать ссылку, или нет -->
            <xsl:if test="show_link=1">
               
               <!-- Определяем адрес ссылки -->
               <xsl:variable name="link">
                  <xsl:choose>
                     <!-- Если внешняя ссылка -->
                     <xsl:when test="is_external_link=1">
                        <xsl:value-of disable-output-escaping="yes" select="external_link"/>
                     </xsl:when>
                     <!-- Иначе если внутренняя ссылка -->
                     <xsl:otherwise>
                        <xsl:value-of disable-output-escaping="yes" select="link"/>
                     </xsl:otherwise>
                  </xsl:choose>
               </xsl:variable>
               
               <a href="{$link}">
                  <span style="">
                     <xsl:value-of disable-output-escaping="yes" select="name"/>
                  </span>
               </a>
            </xsl:if>
         </div>
      </xsl:if>
   </xsl:template>
   
</xsl:stylesheet>


Вот и все.
Делаю мэйк-ап сайтов
#
Re: AJAX Меню для магазина
$Structure->ShowStructure(1,'ЦентральноеМенюКаталог',$param,$external_propertys);
?>


1 - это что ? ничего не выводится у меня
http://www.aiventa.ru
#
Re: AJAX Меню для магазина
Это вывод данного меню через xsl-шаблон по имени "ЦентральноеМенюКаталог", код которого приведен выше, на основе структуры сайта. Возможно у вас немного другие входные данные. 1 - это ID сайта в системе (собственно структуру какого сайта выводить) а дальше все стандартно, как по мануалу.
Делаю мэйк-ап сайтов
#
Re: AJAX Меню для магазина
Заменил на 3. Получаю меню сайта, нужно меню магазина.
Домен тоже неверно получаешь, ибо тогда без www. Можно ведь просто /images
http://www.aiventa.ru
#
Re: AJAX Меню для магазина
Скрипт на яве взят как есть с гуглокода. править его особо резона небыло.
По поводу магазина - должен отображать. Там по сути JS - обертка для ветки магазина, взятой по принципу карты сайта, с добавлеными проверками. Смотрите XML, который отдается в меню. Если он там есть, значит надо смотркть XSL
Делаю мэйк-ап сайтов
#
Re: AJAX Меню для магазина
Меню магазина через showshop ведь ?
а ваш код выводит вот что http://www.cheapbay.ru/ (слева верхнее меню)
http://www.aiventa.ru
#
Re: AJAX Меню для магазина
Вы пример смотрели? это вывод стандартного меню, но с рекруссий групп товаров из магазина и вывода их в меню
Делаю мэйк-ап сайтов
#
Re: AJAX Меню для магазина
В примере меню магазина. Как оно попало в стандартное тогда?
http://www.aiventa.ru
#
Re: AJAX Меню для магазина
подскажите, пожалуйста, как сделать такое меню для инфосистем а не только интернет-магазина! очень надо
#
Re: AJAX Меню для магазина
Это итак для инфосистемы. То есть для структуры.
http://www.aiventa.ru
Авторизация