/* aqPaging v1.1 - Paging function with next and previous ranges.
   Copyright (C) 2008 Paul Pham <http://aquaron.com/~jquery/aqPaging>

   This program is free software: you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation, either version 3 of the License, or
   (at your option) any later version.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program.  If not, see <http://www.gnu.org/licenses/>.
*/
(function($){
$.fn.aqPaging = function (options) {
   var opts = $.extend({ },$.fn.aqPaging.defaults,options);

   return this.each(function(){
      if (opts.pages <= 1) return false;

      if (!$('.aqPaging',this).length) {
         $.fn.aqPaging.defaults.uniqID++;
         $('<div class="aqPaging" id="aqPaging_'
            +$.fn.aqPaging.defaults.uniqID+'"><\/div>')
            .appendTo(this);

         $.fn.aqPaging.defaults.cbs[$.fn.aqPaging.defaults.uniqID]
            = opts.cb;

         $('.aqPaging',this).css(opts.css);
      }

      var $pager = $('.aqPaging',this);
      var pid = $pager.attr('id');

      var s = 1, e = opts.pages;
      var html = '';

      var offset = (opts.current > opts.max) ? 1 : 0;

      if (opts.pages > opts.max) {
         if (opts.current > opts.max)
            s = opts.max*parseInt((opts.current-offset)/opts.max);

         if (opts.current-offset+opts.max < opts.pages) 
            e = s + opts.max + offset;
      }

      for (var p=s; p<=e; p++)
         html += '<a href="'+ opts.servirurl +'&pg='+p+'" onclick="$.fn.aqPaging.flip(\''+pid+'\''
            +','+p+','+opts.pages+');">' + p + '<\/a> ';


			$pager.html(html);



		/*	if(opts.current != 1) {
			$pager.prepend('<a href=""><<</a>');
			} */


      if (opts.current >= s && opts.current-opts.max > 0) {
         $pager.prepend('<a href="'+ opts.servirurl +'&pg='+(s-opts.max+1)+'" onclick="$.fn.aqPaging.flip(\''
            +pid+'\''+','+(s-opts.max+1)+','+opts.pages +')">' 
            + (s-opts.max+1) + '<\/a> <i>&hellip;<\/i> ');
      }
      if ((opts.current-offset+opts.max) <= opts.pages && e != opts.pages) {
         $pager.append('<i>&hellip;<\/i>'
            +' <a href="'+ opts.servirurl +'&pg='+opts.pages+'" onclick="$.fn.aqPaging.flip(\''+pid+'\''+','
            +opts.pages+','+opts.pages +')">'+opts.pages+'<\/a> ');
      }

      var hi = ((opts.current-1)%opts.max) + ((offset+1)*offset);
      if (opts.css) {
         $pager.find('a').css(opts.aCss)
         .not(':eq('+hi+')').hover(
            function() { $(this).css(opts.hiCss) },
            function() { $(this).css(opts.loCss) }
         );
         $pager.find('i').css(opts.iCss);
         $pager.find('a').eq(hi).css(opts.hiCss);
      } else
         $pager.find('a').removeClass('aqPagingHi')
            .eq(hi).addClass('aqPagingHi');

      if (opts.flip)
         $.fn.aqPaging.flip(pid,opts.current,opts.pages);
   });
};

$.fn.aqPaging.flip = function(id,p,total) {
   var idx = id.replace(/aqPaging_/,'');
   var func = $.fn.aqPaging.defaults.cbs[idx];
   if (func) func(p);
   $('#'+id).parent().aqPaging({current: p, pages: total});
   return false;
};

$.fn.aqPaging.defaults = {
   cbs: [],  max: 10, uniqID: 1, flip: false,
   css: { font: 'bold 14px lucida grande,Arial,sans-serif', padding: '5px', margin: '0 auto 5px auto' },
   hiCss: { backgroundColor: '#c0c0c0', borderColor: '#c0c0c0',  color: '#eee' },
   loCss: { backgroundColor: 'transparent', borderColor: '#c0c0c0', color: '#00a530' },
   aCss: { margin: '2px', padding: '2px 5px', color: '#00a530', display: 'block', float: 'left', border: '1px solid #c0c0c0' },
   iCss: { display:'block', float:'left' }
};
})(jQuery);
