X-Git-Url: https://git.decadent.org.uk/gitweb/?a=blobdiff_plain;f=lib%2FMaypole%2FModel%2FCDBI%2FAsForm.pm;h=c072dc8d7112e1433e1fd5ef3c062b598947842e;hb=753bfd73e7faf3e0cd8ec2468208d4f40dbfd997;hp=76003ff3cf811d4ea1e44c053a98ef12897ccee7;hpb=4f4bbd04570ff3c5f59f99c5cbf868d9b1a3da49;p=maypole.git diff --git a/lib/Maypole/Model/CDBI/AsForm.pm b/lib/Maypole/Model/CDBI/AsForm.pm index 76003ff..c072dc8 100644 --- a/lib/Maypole/Model/CDBI/AsForm.pm +++ b/lib/Maypole/Model/CDBI/AsForm.pm @@ -1173,11 +1173,13 @@ objects stringify method specified in $args->{stringify} as the content. Otherwi sub _options_from_objects { my ($self, $items, $args) = @_; my $selected = $args->{selected} || {}; - my $stringify = $args->{stringify}; my @res; for my $object (@$items) { - $stringify ||= $object->stringify_column; + my $stringify = $args->{stringify}; + if ($object->can('stringify_column') ) { + $stringify ||= $object->stringify_column if ($object->can($object->stringify_column)); + } my $id = $object->id; my $opt = HTML::Element->new("option", value => $id); $id =~ s/^0*//; # leading zeros no good in hash key @@ -1194,7 +1196,8 @@ sub _options_from_arrays { my $selected = $args->{selected} || {}; my @res; my $class = $args->{class} || ''; - my $stringify = $args->{stringify} || $self->stringify_column; + my $stringify = $args->{stringify}; + $stringify ||= $self->stringify_column if ($self->can('stringify_column')); for my $item (@$items) { my @pks; # for future multiple key support push @pks, shift @$item foreach $class->columns('Primary'); @@ -1251,7 +1254,8 @@ sub _options_from_hashes { my $selected = $args->{selected} || {}; my $pk = eval {$args->{class}->primary_column} || 'id'; my $fclass = $args->{class} || ''; - my $stringify = $args->{stringify} || $self->stringify_column; + my $stringify = $args->{stringify}; + $stringify ||= $self->stringify_column if ( $self->can('stringify_column') ); my @res; for my $item (@$items) { my $val = defined $item->{$pk} ? $item->{$pk} : ''; @@ -1264,7 +1268,8 @@ sub _options_from_hashes { $content = $item->{$stringify}; } else { $content = join(' ', map {$item->{$_} } keys %$item); - } + } + $opt->push_content( $content ); push @res, $opt; }