1 package Reaction::UI::ViewPort::Collection::Grid;
5 use aliased 'Reaction::InterfaceModel::Collection' => 'IM_Collection';
6 use aliased 'Reaction::UI::ViewPort::Collection::Grid::Member';
8 use namespace::clean -except => [ qw(meta) ];
9 extends 'Reaction::UI::ViewPort::Collection';
13 has field_order => ( is => 'ro', isa => 'ArrayRef', lazy_build => 1);
14 has excluded_fields => ( is => 'ro', isa => 'ArrayRef', lazy_build => 1);
15 has field_labels => ( is => 'ro', isa => 'HashRef', lazy_build => 1);
17 has computed_field_order => (is => 'ro', isa => 'ArrayRef', lazy_build => 1);
19 ####################################
20 sub _build_member_class { Member };
21 sub _build_field_labels {
24 for my $field ( @{$self->computed_field_order}){
25 $labels{$field} = join(' ', map{ ucfirst } split('_', $field));
29 sub _build_field_order { []; };
30 sub _build_excluded_fields { []; };
31 sub _build_computed_field_order {
33 my %excluded = map { $_ => undef } @{ $self->excluded_fields };
34 #treat _$field_name as private and exclude fields with no reader
35 my @names = grep { $_ !~ /^_/ && !exists($excluded{$_})} map { $_->name }
37 !($_->has_type_constraint &&
38 ($_->type_constraint->is_a_type_of('ArrayRef') ||
39 eval {$_->type_constraint->name->isa('Reaction::InterfaceModel::Collection')} ||
40 eval { $_->_isa_metadata->isa('Reaction::InterfaceModel::Collection') }
43 grep { defined $_->get_read_method }
44 $self->current_collection->member_type->parameter_attributes;
46 return $self->sort_by_spec($self->field_order, \@names);
49 before _build_members => sub {
51 $self->member_args->{computed_field_order} ||= $self->computed_field_order;
54 __PACKAGE__->meta->make_immutable;
63 Reaction::UI::ViewPort::Collection
67 This subclass of L<Reaction::UI::ViewPort::Collection> allows you to display a
68 homogenous collection of Reaction::InterfaceModel::Objects as a grid.
74 =head2 excluded_fields
78 =head2 computed_field_order
82 =head1 INTERNAL METHODS
84 These methods, although stable, are subject to change without notice. These are meant
85 to be used only by developers. End users should refrain from using these methods to
86 avoid potential breakages.
90 L<Reaction::UI::ViewPort::Collection>
94 See L<Reaction::Class> for authors.
98 See L<Reaction::Class> for the license.