package HTML::Widget::Element::Textarea;
use warnings;
use strict;
use base 'HTML::Widget::Element';
use HTML::Element;
use NEXT;
__PACKAGE__->mk_accessors(qw/comment label value retain_default/);
__PACKAGE__->mk_attr_accessors(qw/cols rows wrap/);
=head1 NAME
HTML::Widget::Element::Textarea - Textarea Element
=head1 SYNOPSIS
my $e = $widget->element( 'Textarea', 'foo' );
$e->comment('(Required)');
$e->label('Foo');
$e->cols(30);
$e->rows(40);
$e->value('bar');
$e->wrap('wrap');
=head1 DESCRIPTION
Textarea Element.
=head1 METHODS
=head2 new
Create new textarea with default size of 20 rows and 40 columns
=cut
sub new {
shift->NEXT::new(@_)->rows(20)->cols(40);
}
=head2 containerize
=cut
sub containerize {
my ( $self, $w, $value, $errors, $args ) = @_;
$value = $self->value
if ( not defined $value )
and $self->retain_default || not $args->{submitted};
$value = ref $value eq 'ARRAY' ? shift @$value : $value;
my $l = $self->mk_label( $w, $self->label, $self->comment, $errors );
$self->attributes->{class} ||= 'textarea';
my $i = HTML::Element->new('textarea');
$i->push_content($value) if defined $value;
my $id = $self->id($w);
$i->attr( id => $id );
$i->attr( name => $self->name );
$i->attr( $_ => ${ $self->attributes }{$_} )
for ( keys %{ $self->attributes } );
my $e = $self->mk_error( $w, $errors );
return $self->container( { element => $i, error => $e, label => $l } );
}
=head2 label
=head2 value
=head2 cols
=head2 rows
=head2 wrap
=head2 retain_default
If true, overrides the default behaviour, so that after a field is missing
from the form submission, the xml output will contain the default value,
rather than be empty.
=head1 SEE ALSO
L
=head1 AUTHOR
Sebastian Riedel, C
=head1 LICENSE
This library is free software, you can redistribute it and/or modify it under
the same terms as Perl itself.
=cut
1;