From de9a5228098f6139ffc28d84c7e0d123c215e4c9 Mon Sep 17 00:00:00 2001
From: mcramer <m.cramer@pixcept.de>
Date: Wed, 14 Nov 2012 07:32:27 -0500
Subject: [PATCH] Implemented: - new pagination for lists

---
 interface/web/themes/default/css/styles.css |   29 ++++++++++++++
 interface/lib/classes/listform.inc.php      |   58 +++++++++++++++++++++++++---
 2 files changed, 79 insertions(+), 8 deletions(-)

diff --git a/interface/lib/classes/listform.inc.php b/interface/lib/classes/listform.inc.php
index 6128022..314b257 100644
--- a/interface/lib/classes/listform.inc.php
+++ b/interface/lib/classes/listform.inc.php
@@ -243,21 +243,65 @@
     public function getPagingHTML($vars)
     {
         global $app;
-        $content = '<a href="'."javascript:loadContent('".$vars['list_file'].'?page=0'.$vars['page_params']."');".'">'
-                    .'<img src="themes/'.$_SESSION['s']['theme'].'/icons/x16/arrow_stop_180.png"></a> &nbsp; ';
+        
+        // we want to show at max 15 page numbers (7 left, current, 7 right)
+        $show_pages_count = 15;
+        
+        $show_pages = array(0); // first page
+        if($vars['pages'] > 0) $show_pages[] = $vars['pages']; // last page
+        for($p = $vars['page'] - 3; $p <= $vars['page'] + 3; $p++) { // surrounding pages
+            if($p > 0 && $p < $vars['pages']) $show_pages[] = $p;
+        }
+        
+        $l_start = $vars['page'] - 503;
+        $l_start -= ($l_start % 100) + 1;
+        $h_end = $vars['page'] + 603;
+        $h_end -= ($h_end % 100) + 1;
+        for($p = $l_start; $p <= $h_end; $p += 100) { // surrounding pages
+            if($p > 0 && $p < $vars['pages'] && !in_array($p, $show_pages, true) && count($show_pages) < $show_pages_count) $show_pages[] = $p;
+        }
+        
+        $l_start = $vars['page'] - 203;
+        $l_start -= ($l_start % 25) + 1;
+        $h_end = $vars['page'] + 228;
+        $h_end -= ($h_end % 25) + 1;
+        for($p = $l_start; $p <= $h_end; $p += 25) { // surrounding pages
+            if($p > 0 && $p < $vars['pages'] && !in_array($p, $show_pages, true) && count($show_pages) < $show_pages_count) $show_pages[] = $p;
+        }
+        
+        $l_start = $vars['page'] - 53;
+        $l_start -= ($l_start % 10) + 1;
+        $h_end = $vars['page'] + 63;
+        $h_end -= ($h_end % 10) + 1;
+        for($p = $l_start; $p <= $h_end; $p += 10) { // surrounding pages
+            if($p > 0 && $p < $vars['pages'] && !in_array($p, $show_pages, true) && count($show_pages) < $show_pages_count) $show_pages[] = $p;
+        }
+        
+        sort($show_pages);
+        $show_pages = array_unique($show_pages);
+        
         //* Show Back 
         if(isset($vars['show_page_back']) && $vars['show_page_back'] == 1){
-            $content .= '<a href="'."javascript:loadContent('".$vars['list_file'].'?page='.$vars['last_page'].$vars['page_params']."');".'">'
+        $content = '<a class="btn-page first-page" href="'."javascript:loadContent('".$vars['list_file'].'?page=0'.$vars['page_params']."');".'">'
+                    .'<img src="themes/'.$_SESSION['s']['theme'].'/icons/x16/arrow_stop_180.png"></a> &nbsp; ';
+            $content .= '<a class="btn-page previous-page" href="'."javascript:loadContent('".$vars['list_file'].'?page='.$vars['last_page'].$vars['page_params']."');".'">'
                         .'<img src="themes/'.$_SESSION['s']['theme'].'/icons/x16/arrow_180.png"></a> &nbsp; ';
         }
-        $content .= ' '.$this->lng('page_txt').' '.$vars['next_page'].' '.$this->lng('page_of_txt').' '.$vars['max_pages'].' &nbsp; ';
+        $content .= ' '.$this->lng('page_txt').' ';
+        $prev = -1;
+        foreach($show_pages as $p) {
+            if($prev != -1 && $p > $prev + 1) $content .= '<span class="page-spacer">...</span>';
+            $content .= '<a class="link-page' . ($p == $vars['page'] ? ' current-page' : '') . '" href="'."javascript:loadContent('".$vars['list_file'].'?page='.$p.$vars['page_params']."');".'">'. ($p+1) .'</a>';
+            $prev = $p;
+        }
+        //.$vars['next_page'].' '.$this->lng('page_of_txt').' '.$vars['max_pages'].' &nbsp; ';
         //* Show Next
         if(isset($vars['show_page_next']) && $vars['show_page_next'] == 1){
-            $content .= '<a href="'."javascript:loadContent('".$vars['list_file'].'?page='.$vars['next_page'].$vars['page_params']."');".'">'
+            $content .= '<a class="btn-page next-page" href="'."javascript:loadContent('".$vars['list_file'].'?page='.$vars['next_page'].$vars['page_params']."');".'">'
                         .'<img src="themes/'.$_SESSION['s']['theme'].'/icons/x16/arrow.png"></a> &nbsp; ';
-        }
-        $content .= '<a href="'."javascript:loadContent('".$vars['list_file'].'?page='.$vars['pages'].$vars['page_params']."');".'">'
+        $content .= '<a class="btn-page last-page" href="'."javascript:loadContent('".$vars['list_file'].'?page='.$vars['pages'].$vars['page_params']."');".'">'
                     .'<img src="themes/'.$_SESSION['s']['theme'].'/icons/x16/arrow_stop.png"></a>';
+        }
         return $content;
     }
 		
diff --git a/interface/web/themes/default/css/styles.css b/interface/web/themes/default/css/styles.css
index 96815d0..913c33c 100644
--- a/interface/web/themes/default/css/styles.css
+++ b/interface/web/themes/default/css/styles.css
@@ -1787,4 +1787,31 @@
 .ui-combobox-toggle { position: absolute !important; top: 0; bottom: 0; margin-left: -1px; padding: 1px !important; background: none repeat scroll 0 0 #FFFFFF !important; border: 1px solid #DFDFDF !important;}
 .ui-combobox-input { background: none repeat scroll 0 0 #FFFFFF !important; border: 1px solid #DFDFDF !important; padding: 1px; font-weight: normal !important; }
 .panel_install_package .ui-combobox { float: left; }
-.clear-float { clear: both; }
\ No newline at end of file
+.clear-float { clear: both; }
+
+a.link-page, span.page-spacer {
+    display: inline-block;
+    text-align: center;
+    padding: 2px;
+    line-height: 16px;
+    text-decoration: none !important;
+    color: inherit !important;
+    min-width: 16px;
+}
+a.link-page {
+    border: 1px solid #FFFFFF;
+    margin: 0 5px;
+}
+
+a.link-page:hover {
+    background-color: #DFDFDF;
+}
+
+span.page-spacer {
+    margin: 0 -5px;
+}
+
+a.link-page.current-page {
+    background-color: #DFDFDF;
+    font-weight: bold;
+}
\ No newline at end of file

--
Gitblit v1.9.1