[![Build Status](https://travis-ci.org/ainame/p5-Data-Paging.png?branch=master)](https://travis-ci.org/ainame/p5-Data-Paging) # NAME Data::Paging - pagination helper for view # SYNOPSIS use Data::Paging; my $paging = Data::Paging->create({ entries => $entries, total_count => 100, per_page => 30, current_page => 1, }); $paging->has_next; #=> TRUE $paging->has_prev; #=> FALSE $paging->prev_page; #=> 0 $paging->next_page; #=> 2 $paging->begin_count; #=> 30 $paging->end_count; #=> 30 ... # If you use simple template engine like HTML::Template, # you should use Data::Paging with renderer. my $paging = Data::Paging->create({ entries => $entries, total_count => 100, per_page => 30, current_page => 1, }, '-NeighborLink'); # NeighborLink is the bundled renderer. You can load renderer like Plack::Middleware. $paging->render #=> output HASHREF value # DESCRIPTION Data::Paging = Data::Page + Data::Page::Navigation + Data::Page::NoTotalEntries Data::Paging is the helper library for implementation of paging. Especialy, Data::Paging class is the factory class of Data::Paging::Collection. Data::Paging::Collection is the accessor of many pagination parameters like Data::Page, and then, that contain other Data::Page's brother features. In addition, Data::Paging has renderer mechanism. That is convenience feature, when the application use rigid template engine like HTML::Template. Data::Paging bundle two default renderer to create common paging UI, also Data::Paging make application be able to define original renderer and load it as you like. A point to notice is Data::Paging always has next or prev page number. This feature difference from Data::Page' one. You should use has\_next/has\_prev method, when check whether next\_page/prev\_page exist or not. # LICENSE Copyright (C) ainame. This library is free software; you can redistribute it and/or modify it under the same terms as Perl itself. # AUTHOR ainame <s.namai.2012@gmail.com>