Перемещение по страницам блоками (пагинация)

#
Перемещение по страницам блоками (пагинация)
Добрый день.

Исходные данные: вывод по 5 элементов на странице информационных элементов.

На данный момент дефолтная пагинация hostcms реализована следующим образом.

Цитата:
<< (самый первый элемент), стр6, стр7, <- ctrl ,стр8 (активная),ctrl ->, стр9, стр10, (самый последний элемент) >>


Переделал на такой вариант:
Цитата:
<< (самый первый элемент), <- ctrl, стр6, стр7,,стр8 (активная), стр9, стр10, ctrl ->, (самый последний элемент)>>


где <- ctrl и ctrl ->  осуществляют перемещение на предыдущую или следующую страницу, ссылками или комбинацией с клавиатуры.

Но вижу в такой реализации не удобство, так как на текущей странице и так видны все ссылки на страницы в пределах 5-ти штук и нет необходимости перемещаться по ним  нажимая соответствующие ссылки  <- ctrl и ctrl ->, комбинацию клавиатуры оставляем как есть. Мы их и так видим и можем нажать на нужную нам страницу. Но как только мы нажимаем скажем на какую то страницу, весь блок смещается относительно текущей страницы. Это вы можете наблюдать перемещаясь по страницам топика в форуме. А если таких блоков по 5 страниц около двадцати, то вернуться скажем со страницы номер 40 к странице 13, нужно нажать ссылку "<< самая первая страница" и прошагать до 13-ой. Особо умные конечно введут в поисковой странице нужный номер ))

Но есть смысл в нести в ссылки <- и ->  несколько иной смысл. Это смещение на следующий блок ссылок на страницы.
То есть, если я нахожусь на 15-й странице, а это третий блок ссылок по пять страниц. Нажимаю на 14-ю у меня не должно происходить смещения относительно нее. Я также должен видеть ссылки на страницы 11, 12, 13 , 14 (активная), 15. Но как только я нажимаю на ссылку (<-ctrl) я позиционируюсь на 6 страницу второго блока ссылок и вижу страницы  6(активная), 7, 8 ,9 ,10. Ну или 10-я активная. Как удобно.

Кто-нибудь делал такое???

Спасибо!

#
Re: Перемещение по страницам блоками (пагинация)
Вот есть xsl с переключением по 5 штук, уже не очень помню как именно и где вообще я это делал, но попробуйте. Возможно что-то полезное возьмете из него.


<?xml version="1.0" encoding="utf-8"?>
<!DOCTYPE xsl:stylesheet>
<xsl:stylesheet version="1.0"
   xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
   xmlns:hostcms="http://www.hostcms.ru/"
   exclude-result-prefixes="hostcms">
   
   <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="/informationsystem"/>
   </xsl:template>
   
   <xsl:variable name="n" select="number(3)"/>
   
   <xsl:template match="/informationsystem">
      
      <!-- Получаем ID родительской группы и записываем в переменную $group -->
      <xsl:variable name="group" select="group"/>
      
      
      <xsl:value-of disable-output-escaping="yes" select="add"/>
      
      <div class="b-news-page-top">
         
         
         <div class="l-right">
            <div class="b-news-page-pagination">
               
               <xsl:if test="total &gt; 0 and limit &gt; 0">
                  
                  <xsl:variable name="count_pages" select="ceiling(total div limit)"/>
                  
                  <xsl:variable name="visible_pages" select="5"/>
                  
                  <xsl:variable name="real_visible_pages"><xsl:choose>
                        <xsl:when test="$count_pages &lt; $visible_pages"><xsl:value-of select="$count_pages"/></xsl:when>
                        <xsl:otherwise><xsl:value-of select="$visible_pages"/></xsl:otherwise>
                  </xsl:choose></xsl:variable>
                  
                  <!-- Считаем количество выводимых ссылок перед текущим элементом -->
                  <xsl:variable name="pre_count_page"><xsl:choose>
                        <!--по левой границе-->
                        <xsl:when test="page - (floor($real_visible_pages div 2)) &lt; 0">
                           <xsl:value-of select="page"/>
                        </xsl:when>
                        <!--по правой границе
                        <xsl:when test="($count_pages - page - 1) &lt; floor($real_visible_pages div 2)">
                           <xsl:value-of select="$real_visible_pages - ($count_pages - page - 1) - 1"/>
                        </xsl:when>-->
                        <xsl:otherwise>
                           
                           <xsl:value-of select="(page) mod $real_visible_pages"/>
                           
                        </xsl:otherwise>
                  </xsl:choose></xsl:variable>
                  
                  <!-- Считаем количество выводимых ссылок после текущего элемента -->
                  <xsl:variable name="post_count_page"><xsl:choose>
                        
                        <xsl:when test="0 &gt; page - (floor($real_visible_pages div 2) - 1)">
                           <xsl:value-of select="$real_visible_pages - page - 1"/>
                        </xsl:when>
                        
                        <!--   <xsl:when test="($count_pages - page - 1) &lt; floor($real_visible_pages div 2)">
                           <xsl:value-of select="$real_visible_pages - $pre_count_page - 1"/>
                        </xsl:when> -->
                        <xsl:otherwise>
                           <xsl:value-of select="$real_visible_pages - (page mod $real_visible_pages) - 1"/>
                        </xsl:otherwise>
                  </xsl:choose></xsl:variable>
                  
                  <xsl:variable name="i"><xsl:choose>
                        <xsl:when test="page + 1 = $count_pages"><xsl:value-of select="page - $real_visible_pages + 1"/></xsl:when>
                        <xsl:when test="page - $pre_count_page &gt; 0"><xsl:value-of select="page - $pre_count_page"/></xsl:when>
                        <xsl:otherwise>0</xsl:otherwise>
                  </xsl:choose></xsl:variable>
                  <xsl:if test="0">
                     limit <xsl:value-of select="limit"/><br />
                     page <xsl:value-of select="page"/><br />
                     total <xsl:value-of select="total"/><br />
                     $i <xsl:value-of select="$i"/><br />
                     $pre_count_page <xsl:value-of select="$pre_count_page"/><br />
                     $post_count_page <xsl:value-of select="$post_count_page"/><br />
                     $real_visible_pages <xsl:value-of select="$real_visible_pages"/><br />
                  </xsl:if>
                  
                  <div class="b-news-page-pagination">
                     <div class="b-news-page-pagination">
                        <xsl:call-template name="for">
                           <xsl:with-param name="limit" select="limit"/>
                           <xsl:with-param name="page" select="page"/>
                           <xsl:with-param name="items_count" select="total"/>
                           <xsl:with-param name="i" select="$i"/>
                           <xsl:with-param name="post_count_page" select="$post_count_page"/>
                           <xsl:with-param name="pre_count_page" select="$pre_count_page"/>
                           <xsl:with-param name="visible_pages" select="$real_visible_pages"/>
                        </xsl:call-template>
                        
                     </div>
                  </div>
                  
               </xsl:if>
               
            </div>
         </div>
      </div>
      
      <!-- Отображение записи информационной системы -->
      <div class="b-news-page-middle">
         <ul class="b-news-list">
            <xsl:apply-templates select="informationsystem_item"/>
         </ul>
      </div>
      
      <div class="b-news-page-bottom">
         <div class="l-left">&#160;</div>
         <div class="l-right">
            
            <xsl:if test="total &gt; 0 and limit &gt; 0">
               
               <xsl:variable name="count_pages" select="ceiling(total div limit)"/>
               
               <xsl:variable name="visible_pages" select="5"/>
               
               <xsl:variable name="real_visible_pages"><xsl:choose>
                     <xsl:when test="$count_pages &lt; $visible_pages"><xsl:value-of select="$count_pages"/></xsl:when>
                     <xsl:otherwise><xsl:value-of select="$visible_pages"/></xsl:otherwise>
               </xsl:choose></xsl:variable>
               
               <!-- Считаем количество выводимых ссылок перед текущим элементом -->
               <xsl:variable name="pre_count_page"><xsl:choose>
                     <!--по левой границе-->
                     <xsl:when test="page - (floor($real_visible_pages div 2)) &lt; 0">
                        <xsl:value-of select="page"/>
                     </xsl:when>
                     <!--по правой границе
                     <xsl:when test="($count_pages - page - 1) &lt; floor($real_visible_pages div 2)">
                        <xsl:value-of select="$real_visible_pages - ($count_pages - page - 1) - 1"/>
                     </xsl:when>-->
                     <xsl:otherwise>
                        
                        <xsl:value-of select="(page) mod $real_visible_pages"/>
                        
                     </xsl:otherwise>
               </xsl:choose></xsl:variable>
               
               <!-- Считаем количество выводимых ссылок после текущего элемента -->
               <xsl:variable name="post_count_page"><xsl:choose>
                     
                     <xsl:when test="0 &gt; page - (floor($real_visible_pages div 2) - 1)">
                        <xsl:value-of select="$real_visible_pages - page - 1"/>
                     </xsl:when>
                     
                     <!--   <xsl:when test="($count_pages - page - 1) &lt; floor($real_visible_pages div 2)">
                        <xsl:value-of select="$real_visible_pages - $pre_count_page - 1"/>
                     </xsl:when> -->
                     <xsl:otherwise>
                        <xsl:value-of select="$real_visible_pages - (page mod $real_visible_pages) - 1"/>
                     </xsl:otherwise>
               </xsl:choose></xsl:variable>
               
               <xsl:variable name="i"><xsl:choose>
                     <xsl:when test="page + 1 = $count_pages"><xsl:value-of select="page - $real_visible_pages + 1"/></xsl:when>
                     <xsl:when test="page - $pre_count_page &gt; 0"><xsl:value-of select="page - $pre_count_page"/></xsl:when>
                     <xsl:otherwise>0</xsl:otherwise>
               </xsl:choose></xsl:variable>
               <xsl:if test="0">
                  limit <xsl:value-of select="limit"/><br />
                  page <xsl:value-of select="page"/><br />
                  total <xsl:value-of select="total"/><br />
                  $i <xsl:value-of select="$i"/><br />
                  $pre_count_page <xsl:value-of select="$pre_count_page"/><br />
                  $post_count_page <xsl:value-of select="$post_count_page"/><br />
                  $real_visible_pages <xsl:value-of select="$real_visible_pages"/><br />
               </xsl:if>
               
               <div class="b-news-page-pagination">
                  <div class="b-news-page-pagination">
                     <xsl:call-template name="for">
                        <xsl:with-param name="limit" select="limit"/>
                        <xsl:with-param name="page" select="page"/>
                        <xsl:with-param name="items_count" select="total"/>
                        <xsl:with-param name="i" select="$i"/>
                        <xsl:with-param name="post_count_page" select="$post_count_page"/>
                        <xsl:with-param name="pre_count_page" select="$pre_count_page"/>
                        <xsl:with-param name="visible_pages" select="$real_visible_pages"/>
                     </xsl:call-template>
                     
                  </div>
               </div>
               
            </xsl:if>
         </div>
      </div>
      
      <xsl:if test="count(informationsystem_group_properties) and group != 0">
         <div style="margin: 10px 0px;">
            <h2>Атрибуты группы инфоэлементов</h2>
            
            <xsl:if test="count(informationsystem_group[@id = //group]/property[parent_id = 0])">
               <table border="0">
                  <xsl:apply-templates select="informationsystem_group[@id = //group]/property[parent_id = 0]"/>
               </table>
            </xsl:if>
            
            <xsl:apply-templates select="informationsystem_group_properties"/>
         </div>
      </xsl:if>
      
   </xsl:template>
   
   <!-- Вывод строки со значением свойства -->
   <xsl:template match="property">
      <tr>
         <td style="padding: 5px" bgcolor="#eeeeee">
            <b><xsl:value-of select="name"/></b>
         </td>
         <td style="padding: 5px" bgcolor="#eeeeee">
            <xsl:choose>
               <xsl:when test="type = 1">
                  <a href="{file_path}">Скачать файл</a>
               </xsl:when>
               <xsl:when test="type = 7">
                  <xsl:choose>
                     <xsl:when test="value = 1">
                        <input type="checkbox" checked="" disabled="" />
                     </xsl:when>
                     <xsl:otherwise>
                        <input type="checkbox" disabled="" />
                     </xsl:otherwise>
                  </xsl:choose>
               </xsl:when>
               <xsl:otherwise>
                  <xsl:value-of disable-output-escaping="yes" select="value"/>
               </xsl:otherwise>
            </xsl:choose>
         </td>
      </tr>
   </xsl:template>
   
   <!-- Шаблон вывода информационного элемента -->
   <xsl:template match="informationsystem_item">
      
      
      <li class="b-news-list-item">
         <div class="l-left">
            
            <xsl:if test="image_small!=''">
               <a class="b-news-list-item-image-link" rel="fancybox" href="{dir}{image_large}">
                  <img width="100%" src="{dir}{image_small}"  class="b-news-list-item-image"  alt="{name}" />
               </a>
            </xsl:if>
            
         </div>
         
         <div class="l-right">
            <h3 class="b-news-list-item-title">
               <a title="{name}" class="b-news-list-item-title-link" href="javascript:void(0);" hostcms:id="{@id}" hostcms:field="name" hostcms:entity="informationsystem_item">
                  <xsl:value-of disable-output-escaping="yes" select="name"/>
               </a>
            </h3>
            <div class="b-news-list-item-introtext">
               <div hostcms:id="{@id}" hostcms:field="description" hostcms:entity="informationsystem_item" hostcms:type="wysiwyg"><xsl:value-of disable-output-escaping="yes" select="description"/></div>
            </div>
            <div class="b-news-list-item-fulltext">
               <div hostcms:id="{@id}" hostcms:field="text" hostcms:entity="informationsystem_item" hostcms:type="wysiwyg"><xsl:value-of disable-output-escaping="yes" select="text"/></div>
            </div>
            <div class="b-news-list-item-date">
               <xsl:value-of select="substring-before(date, '.')"/>
               <xsl:variable name="month_year" select="substring-after(date, '.')"/>
               <xsl:variable name="month" select="substring-before($month_year, '.')"/>
               <xsl:choose>
                  <xsl:when test="$month = 1"> января </xsl:when>
                  <xsl:when test="$month = 2"> февраля </xsl:when>
                  <xsl:when test="$month = 3"> марта </xsl:when>
                  <xsl:when test="$month = 4"> апреля </xsl:when>
                  <xsl:when test="$month = 5"> мая </xsl:when>
                  <xsl:when test="$month = 6"> июня </xsl:when>
                  <xsl:when test="$month = 7"> июля </xsl:when>
                  <xsl:when test="$month = 8"> августа </xsl:when>
                  <xsl:when test="$month = 9"> сентября </xsl:when>
                  <xsl:when test="$month = 10"> октября </xsl:when>
                  <xsl:when test="$month = 11"> ноября </xsl:when>
                  <xsl:otherwise> декабря </xsl:otherwise>
               </xsl:choose>
               <xsl:value-of select="substring-after($month_year, '.')"/>
               
            </div>
            <a class="b-news-list-item-hide" href="javascript:void(0);">свернуть</a>
            <a class="b-news-list-item-show" href="javascript:void(0);" style="display: inline; ">подробнее</a>
         </div>
      </li>
      
   </xsl:template>
   
   <!-- Цикл для вывода строк ссылок -->
   <xsl:template name="for">
      
      <xsl:param name="limit"/>
      <xsl:param name="page"/>
      <xsl:param name="pre_count_page"/>
      <xsl:param name="post_count_page"/>
      <xsl:param name="i" select="0"/>
      <xsl:param name="items_count"/>
      <xsl:param name="visible_pages"/>
      
      <xsl:variable name="n" select="ceiling($items_count div $limit)"/>
      
      <xsl:variable name="start_page"><xsl:choose>
            <xsl:when test="$page + 1 = $n"><xsl:value-of select="$page - $visible_pages + 1"/></xsl:when>
            <xsl:when test="$page - $pre_count_page &gt; 0"><xsl:value-of select="$page - $pre_count_page"/></xsl:when>
            <xsl:otherwise>0</xsl:otherwise>
      </xsl:choose></xsl:variable>
      
      <xsl:if test="$items_count &gt; $limit and ($page + $post_count_page + 1) &gt; $i">
         <!-- Заносим в переменную $group идентификатор текущей группы -->
         <xsl:variable name="group" select="/informationsystem/group"/>
         
         <!-- Путь для тэга -->
         <xsl:variable name="tag_path">
            <xsl:choose>
               <!-- Если не нулевой уровень -->
               <xsl:when test="count(/informationsystem/tag) != 0">tag/<xsl:value-of select="/informationsystem/tag/urlencode"/>/</xsl:when>
               <!-- Иначе если нулевой уровень - просто ссылка на страницу со списком элементов -->
               <xsl:otherwise></xsl:otherwise>
            </xsl:choose>
         </xsl:variable>
         
         <!-- Определяем группу для формирования адреса ссылки -->
         <xsl:variable name="group_link">
            <xsl:choose>
               <!-- Если группа не корневая (!=0) -->
               <xsl:when test="$group != 0">
                  <xsl:value-of select="/informationsystem//informationsystem_group[@id=$group]/url"/>
               </xsl:when>
               <!-- Иначе если нулевой уровень - просто ссылка на страницу со списком элементов -->
               <xsl:otherwise><xsl:value-of select="/informationsystem/url"/></xsl:otherwise>
            </xsl:choose>
         </xsl:variable>
         
         <!-- Определяем адрес ссылки -->
         <xsl:variable name="number_link">
            <xsl:choose>
               <!-- Если не нулевой уровень -->
               <xsl:when test="$i != 0">page-<xsl:value-of select="$i + 1"/>/</xsl:when>
               <!-- Иначе если нулевой уровень - просто ссылка на страницу со списком элементов -->
               <xsl:otherwise></xsl:otherwise>
            </xsl:choose>
         </xsl:variable>
         
         
         <!-- Ссылка на предыдущую страницу для Ctrl + влево -->
         <xsl:if test="$page &gt; ($visible_pages - 1) and $i  = $start_page">
            <xsl:variable name="prev_number_link">
               <xsl:choose>
                  <!-- Если не нулевой уровень -->
                  <xsl:when test="($page) != 0">page-<xsl:value-of select="(floor($page div $visible_pages) - 1)*$visible_pages + $visible_pages"/>/</xsl:when>
                  <!-- Иначе если нулевой уровень - просто ссылка на страницу со списком элементов -->
                  <xsl:otherwise></xsl:otherwise>
               </xsl:choose>
            </xsl:variable>
            <a class="b-news-page-pagination-prev-link" href="{$group_link}{$prev_number_link}{$tag_path}">Предыдущие</a>
            
         </xsl:if>
         
         
         
         
         <!-- Выводим ссылку на первую страницу -->
         <xsl:if test="$page - $pre_count_page &gt; 0 and $i = $start_page">
            <a href="{$group_link}{$tag_path}" class="page_link" style="text-decoration: none;"></a>
         </xsl:if>
         
         
         <!-- Ставим ссылку на страницу-->
         <xsl:if test="$i != $page">
            <xsl:if test="($page - $pre_count_page) &lt;= $i and $i &lt; $n">
               <!-- Выводим ссылки на видимые страницы -->
               <a class="b-news-page-pagination-link" href="{$group_link}{$number_link}{$tag_path}">
                  <xsl:value-of select="$i + 1"/>
               </a>
            </xsl:if>
            
            <!-- Выводим ссылку на последнюю страницу -->
            <xsl:if test="$i+1 &gt;= ($page + $post_count_page + 1) and $n &gt; ($page + 1 + $post_count_page)">
               <!-- Выводим ссылку на последнюю страницу
               <a href="{$group_link}page-{$n}/{$tag_path}" class="page_link" style="text-decoration: none;"></a>-->
            </xsl:if>
         </xsl:if>
         
         
         
         
         <!-- Не ставим ссылку на страницу-->
         <xsl:if test="$i = $page">
            <span class="b-news-page-pagination-current-link"><xsl:value-of select="$i+1"/></span>
         </xsl:if>
         
         <!-- Рекурсивный вызов шаблона. НЕОБХОДИМО ПЕРЕДАВАТЬ ВСЕ НЕОБХОДИМЫЕ ПАРАМЕТРЫ! -->
         <xsl:call-template name="for">
            <xsl:with-param name="i" select="$i + 1"/>
            <xsl:with-param name="limit" select="$limit"/>
            <xsl:with-param name="page" select="$page"/>
            <xsl:with-param name="items_count" select="$items_count"/>
            <xsl:with-param name="pre_count_page" select="$pre_count_page"/>
            <xsl:with-param name="post_count_page" select="$post_count_page"/>
            <xsl:with-param name="visible_pages" select="$visible_pages"/>
         </xsl:call-template>
         
         <!-- Ссылка на следующую страницу для Ctrl + вправо -->
         <xsl:if test="$i = ($page + $post_count_page) and $page &lt; floor($n div $visible_pages)*$visible_pages  and $n &gt; $visible_pages">
            <a class="b-news-page-pagination-next-link" href="{$group_link}page-{(floor($page div $visible_pages)+1)*$visible_pages + 1}/{$tag_path}">Следующие</a>
         </xsl:if>
      </xsl:if>
   </xsl:template>
   
   <!-- Склонение после числительных -->
   <xsl:template name="declension">
      
      <xsl:param name="number" select="number"/>
      
      <!-- Именительный падеж -->
      <xsl:variable name="nominative">
         <xsl:text>комментарий</xsl:text>
      </xsl:variable>
      
      <!-- Родительный падеж, единственное число -->
      <xsl:variable name="genitive_singular">
         <xsl:text>комментария</xsl:text>
      </xsl:variable>
      
      
      <xsl:variable name="genitive_plural">
         <xsl:text>комментариев</xsl:text>
      </xsl:variable>
      
      <xsl:variable name="last_digit">
         <xsl:value-of select="$number mod 10"/>
      </xsl:variable>
      
      <xsl:variable name="last_two_digits">
         <xsl:value-of select="$number mod 100"/>
      </xsl:variable>
      
      <xsl:choose>
         <xsl:when test="$last_digit = 1 and $last_two_digits != 11">
            <xsl:value-of select="$nominative"/>
         </xsl:when>
         <xsl:when test="$last_digit = 2 and $last_two_digits != 12
            or $last_digit = 3 and $last_two_digits != 13
            or $last_digit = 4 and $last_two_digits != 14">
            <xsl:value-of select="$genitive_singular"/>
         </xsl:when>
         <xsl:otherwise>
            <xsl:value-of select="$genitive_plural"/>
         </xsl:otherwise>
      </xsl:choose>
   </xsl:template>
</xsl:stylesheet>
Команда разработчиков KAD Systems | Интеграция и нестандартные решения на совесть | Email: info@kad.systems Skype: kad.systems | http://kad.systems/ https://vk.com/kad_sys
#
Re: Перемещение по страницам блоками (пагинация)
Спасибо! Вы помогли и даже очень )
#
Re: Перемещение по страницам блоками (пагинация)
Подскажите, я реализую пагинацию для подгрупп и товаров этих подрупп. Товары у меня выводятся, скажем, по 5 шт на страницу и у каждой страницы добавляется page-1/ page-2/ page-3/ с товарами это работает проблем нет. а как реализовать , чтобы подгруппы, так же, выводились постранично page-1/ page-2/ page-3/ . сейчас у меня все подгруппы выводятся в /page-1/ и никакие ограничения limit в Shop_Controller_Show на них не срабатывают, похоже они только для самих товаров работают. На форуме и api решение не удалось найти, помогите разобраться .
Авторизация