About Me

My photo
"Enoughtheory.com" had its humble beginning in the year 2011 by ( Founder of Enoughtheory.com ) Mr Ravi Kant Soni , an Enterprise Java and Spring Framework Specialist, with a bachelor degree (B.E) in Information Science and Engineering from Reva Institute of Technology at Bangalore. He has been into the software development discipline for many years now. Ravi has worn many hats throughout his tenure, ranging from software development, designing multi-tenant applications, integration of new technology into an existing system, to his current love of writing a Spring Framework book. Currently, he is a lead engineer at HCL Technology. Ravi has focused on Web and Enterprise development using Spring Framework for most of his career and has been extensively involved in application design and implementation. He has developed applications for Core-Bank, HR and Payroll System, and e-Commerce systems using Spring Framework. Ravi Kant Soni is author of book "Learning Spring Application development" http://learningspringapplicationdevelopment.com

Friday, 27 November 2015

Pagination using JQuery



[don't copy paste]

var pageNo = 1;
var numPages;
var currentPage = 0;
numPages = response.pagination.pageCount;
var paginationToShow = '';
paginationToShow += "<ul class='pagination pagination-sm'>";
if(response.pagination.pageNo > 1){
 paginationToShow += "<li id='NA'></li>";
 paginationToShow += "<li id='first'><a href='#'>First</a></li>";
 paginationToShow += "<li id='previous'><a href='#'>Prev</a></li>";
}else{
 paginationToShow += "<li id='NA'></li>";
 paginationToShow += "<li id='first'></li>";
 paginationToShow += "<li id='previous'></li>";
}
// paginationToShow +=  "<li><a href='#' rel='1'>1<span class='sr-only'>(current)</span></a></li>";
var pageCount = numPages;
var pageNumber = response.pagination.pageNo;
var paginationValues = [];
var activePosition = 0;
var i = 0;
if (pageNumber > 4) {   
 var leftCount = 8 - ((pageCount - pageNumber) >= 4 ? 4
   : (pageCount - pageNumber));
 leftCount = leftCount < pageNumber ? leftCount
   : (pageNumber - 1);
 while (i <= leftCount) {
  paginationValues[i] = pageNumber + i - leftCount;
  i++;
 }
} else {
 while (i < pageNumber) {
  paginationValues[i] = i + 1;
  i++;
 }
}
activePosition = i+3;
if (pageNumber < pageCount) {
 var value = pageNumber + 1;
 var rightCount = 9 - paginationValues.length;
 var j = 0;
 while ((value <= pageCount) && (j < rightCount)) {
  paginationValues[i++] = value++;
  j++;
 }
}
console.log(paginationValues);
console.log(activePosition);  
for (var i = 0; i < paginationValues.length; i++) {
 paginationToShow += "<li><a href='#' rel='" + paginationValues[i] + "'>" + paginationValues[i]
   + "</a></li>";
}
if(response.pagination.pageNo < numPages){
 paginationToShow += "<li id='next'><a href='#'>Next</a></li>";
 paginationToShow += "<li id='last'><a href='#'>Last</a></li>";
 paginationToShow += "<li id='NA'></li>";
}else{
 paginationToShow += "<li id='next'></li>";
 paginationToShow += "<li id='last'></li>";
 paginationToShow += "<li id='NA'></li>";
}
paginationToShow += "</ul>";
$('#page_navigation').html(paginationToShow);
$(
  "#page_navigation li:nth-child("
    + (activePosition) + ")").addClass(
  'active');
flag = true;
currentPage = response.pagination.pageNo;

No comments:

Post a Comment