refactpored most of the action stuff into roles. should fields be a role too?
[catagits/Reaction.git] / lib / Reaction / UI / ViewPort / Collection / Role / Pager.pm
CommitLineData
ddccc6a2 1package Reaction::UI::ViewPort::Collection::Role::Pager;
e22de101 2
3use Reaction::Role;
4
5use aliased 'Reaction::InterfaceModel::Collection';
6
b8faba69 7# XX This needs to be consumed after Ordered
81393881 8use namespace::clean -except => [ qw(meta) ];
e22de101 9
e22de101 10
81393881 11#has paged_collection => (isa => Collection, is => 'rw', lazy_build => 1);
e22de101 12
81393881 13has pager => (isa => 'Data::Page', is => 'rw', lazy_build => 1);
14has page => (isa => 'Int', is => 'rw', lazy_build => 1, trigger_adopt('page'));
15has per_page => (isa => 'Int', is => 'rw', lazy_build => 1, trigger_adopt('page'));
16has per_page_max => (isa => 'Int', is => 'rw', lazy_build => 1);
17sub _build_page { 1 };
18sub _build_per_page { 10 };
19sub _build_per_page_max { 100 };
20sub _build_pager { shift->current_collection->pager };
21sub adopt_page {
22 my ($self) = @_;
23 #$self->clear_paged_collection;
e22de101 24
81393881 25 $self->clear_pager;
26 $self->clear_current_collection;
27};
89939ff9 28
81393881 29around accept_events => sub { ('page','per_page', shift->(@_)); };
e22de101 30
81393881 31#implements build_paged_collection => as {
32# my ($self) = @_;
33# my $collection = $self->current_collection;
34# return $collection->where(undef, {rows => $self->per_page})->page($self->page);
35#};
e22de101 36
81393881 37around _build_current_collection => sub {
38 my $orig = shift;
39 my ($self) = @_;
40 my $collection = $orig->(@_);
41 return $collection->where(undef, {rows => $self->per_page})->page($self->page);
42};
b8faba69 43
e22de101 44
e22de101 45
461;