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 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143
|
package HTML::FormFu::Role::Element::Input;
use Moose::Role;
use MooseX::SetOnce;
with 'HTML::FormFu::Role::Element::Field',
'HTML::FormFu::Role::Element::FieldMethods' => { -excludes => 'nested_name' },
'HTML::FormFu::Role::Element::Coercible';
use HTML::FormFu::Attribute qw(
mk_attr_accessors
mk_output_accessors
mk_inherited_accessors
mk_inherited_merging_accessors
);
use HTML::FormFu::Util qw( process_attrs );
has field_type => (
is => 'rw',
#traits => ['SetOnce'],
);
__PACKAGE__->mk_attr_accessors(qw( checked size maxlength alt ));
after BUILD => sub {
my $self = shift;
$self->filename('input');
$self->field_filename('input_tag');
return;
};
around render_data_non_recursive => sub {
my ( $orig, $self, $args ) = @_;
my $render = $self->$orig( $args );
$render->{field_type} = $self->field_type;
$render->{placeholder} = $self->placeholder;
#$self->_field_render_data_non_recursive;
return $render;
};
sub string {
my ( $self, $args ) = @_;
$args ||= {};
my $render
= exists $args->{render_data}
? $args->{render_data}
: $self->render_data;
# field wrapper template - start
my $html = $self->_string_field_start($render);
# input_tag template
$html .= $self->_string_field($render);
# field wrapper template - end
$html .= $self->_string_field_end($render);
return $html;
}
sub _string_field {
my ( $self, $render ) = @_;
my $html .= "<input";
if ( defined $render->{nested_name} ) {
$html .= sprintf qq{ name="%s"}, $render->{nested_name};
}
$html .= sprintf qq{ type="%s"}, $render->{field_type};
if ( defined $render->{value} ) {
$html .= sprintf qq{ value="%s"}, $render->{value};
}
if ( defined $render->{placeholder} ) {
$html .= sprintf qq{ placeholder="%s"}, $render->{placeholder};
}
$html .= sprintf "%s />", process_attrs( $render->{attributes} );
return $html;
}
sub as {
my ( $self, $type, %attrs ) = @_;
return $self->_coerce(
type => $type,
attributes => \%attrs,
errors => $self->_errors,
package => __PACKAGE__,
);
}
1;
__END__
=head1 NAME
HTML::FormFu::Element::_Input - input field base-class
=head1 DESCRIPTION
Base-class for L<HTML::FormFu::Element::Button>,
L<HTML::FormFu::Element::Checkbox>,
L<HTML::FormFu::Element::File>,
L<HTML::FormFu::Element::Hidden>,
L<HTML::FormFu::Element::Password>,
L<HTML::FormFu::Element::Radio>,
L<HTML::FormFu::Element::Text>.
=head1 METHODS
=head1 SEE ALSO
Is a sub-class of, and inherits methods from
L<HTML::FormFu::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
|