=item search
+The search action
+
+=back
+
=head1 Helper Methods
+=over
+
=item order
=item stringify_column
=item do_pager
+=item related_class
+
+Given an accessor name as a method, this function returns the class this accessor returns.
+
+=back
+
=cut
sub related {
return keys %{ $self->meta_info('has_many') || {} };
}
-#sub related_class {
-# my ( $self, $r, $accessor ) = @_;
-# my $related=$self->related->{$accessor};
-# if ( my $mapping=$related->{args}->{mapping} ) {
-# return $related->{foreign_class}->meta_info('has_a')->{$$mapping[0]}->{foreign_class};
-# } else {
-# return $related->{foreign_class};
-# }
-#}
+sub related_class {
+ my ( $self, $r, $accessor ) = @_;
+ my $related = $self->related->{$accessor};
+ if ( my $mapping = $related->{args}->{mapping} ) {
+ return $related->{foreign_class}->meta_info('has_a')->{ $$mapping[0] }
+ ->{foreign_class};
+ }
+ else {
+ return $related->{foreign_class};
+ }
+}
sub do_edit : Exported {
my ( $self, $r ) = @_;
my $oper = "like"; # For now
my %params = %{ $r->{params} };
my %values = map { $_ => { $oper, $params{$_} } }
- grep { $params{$_} and $fields{$_} } keys %params;
+ grep { defined $params{$_} and $fields{$_} } keys %params;
$r->template("list");
if ( !%values ) { return $self->list($r) }