1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102
|
package HTML::FormFu::Element::Textarea;
$HTML::FormFu::Element::Textarea::VERSION = '2.01';
use Moose;
extends "HTML::FormFu::Element";
with 'HTML::FormFu::Role::Element::Field',
'HTML::FormFu::Role::Element::SingleValueField';
use HTML::FormFu::Util qw( process_attrs );
__PACKAGE__->mk_attr_accessors(qw(
autocomplete
cols
maxlength
rows
placeholder
));
after BUILD => sub {
my $self = shift;
$self->layout_field_filename('field_layout_textarea_field');
$self->cols(40);
$self->rows(20);
return;
};
sub _string_field {
my ( $self, $render ) = @_;
# textarea_tag template
my $html = sprintf qq{<textarea name="%s"%s>},
$render->{nested_name},
process_attrs( $render->{attributes} ),
;
if ( defined $render->{value} ) {
$html .= $render->{value};
}
$html .= "</textarea>";
return $html;
}
__PACKAGE__->meta->make_immutable;
1;
__END__
=head1 NAME
HTML::FormFu::Element::Textarea - Textarea form field
=head1 SYNOPSIS
my $element = $form->element( Textarea => 'foo' );
=head1 DESCRIPTION
Textarea form field.
=head1 ATTRIBUTE ACCESSORS
Get / set input attributes directly with these methods.
Arguments: [$string]
Return Value: $string
=head2 autocomplete
=head2 cols
=head2 maxlength
=head2 rows
=head2 placeholder
=head1 SEE ALSO
Is a sub-class of, and inherits methods from
L<HTML::FormFu::Role::Element::Field>,
L<HTML::FormFu::Element>
L<HTML::FormFu>
=head1 AUTHOR
Carl Franks, C<cfranks@cpan.org>
=head1 LICENSE
This library is free software, you can redistribute it and/or modify it under
the same terms as Perl itself.
=cut
|