package HTML::Widget::Element::Upload;
use warnings;
use strict;
use base 'HTML::Widget::Element';
__PACKAGE__->mk_accessors(qw/comment label/);
__PACKAGE__->mk_attr_accessors(qw/accept maxlength size/);
=head1 NAME
HTML::Widget::Element::Upload - Upload Element
=head1 SYNOPSIS
my $e = $widget->element( 'Upload', 'foo' );
$e->comment('(Required)');
$e->label('Foo');
$e->accept('text/html');
$e->maxlength(1000);
$e->size(23);
=head1 DESCRIPTION
Upload Element.
Adding an Upload element automatically calls
C<$widget->enctype('multipart/form-data')> for you.
=head1 METHODS
=head2 accept
Arguments: $type
A comma-separated list of media types, as per C.
=head2 prepare
=cut
sub prepare {
my ( $self, $w ) = @_;
# force multipart
$w->enctype('multipart/form-data');
return;
}
=head2 containerize
=cut
sub containerize {
my ( $self, $w, $value, $errors ) = @_;
$value = ref $value eq 'ARRAY' ? shift @$value : $value;
my $l = $self->mk_label( $w, $self->label, $self->comment, $errors );
my $i = $self->mk_input( $w, { type => 'file', value => $value }, $errors );
my $e = $self->mk_error( $w, $errors );
return $self->container( { element => $i, error => $e, label => $l } );
}
=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;