package HTML::FormFu::Element::Checkbox;
use strict;
use base 'HTML::FormFu::Element::_Input';
use Class::C3;
__PACKAGE__->mk_output_accessors(qw/ default /);
use HTML::FormFu::Util qw(
append_xml_attribute
has_xml_attribute
remove_xml_attribute
xml_escape
);
sub new {
my $self = shift->next::method(@_);
$self->field_type('checkbox');
$self->reverse_multi(1);
return $self;
}
sub process_value {
my ( $self, $input ) = @_;
return $self->value;
}
sub prepare_attrs {
my ( $self, $render ) = @_;
my $form = $self->form;
my $submitted = $form->submitted;
my $default = $self->default;
my $original = $self->value;
my $value
= defined $self->name
? $self->get_nested_hash_value( $form->input, $self->nested_name )
: undef;
if ( $submitted
&& defined $value
&& defined $original
&& $value eq $original )
{
$render->{attributes}{checked} = 'checked';
}
elsif ($submitted
&& $self->retain_default
&& ( !defined $value || $value eq "" ) )
{
$render->{attributes}{checked} = 'checked';
}
elsif ($submitted) {
delete $render->{attributes}{checked};
}
elsif ( defined $default && defined $original && $default eq $original ) {
$render->{attributes}{checked} = 'checked';
}
$self->next::method($render);
return;
}
1;
__END__
=head1 NAME
HTML::FormFu::Element::Checkbox - Checkbox form field
=head1 SYNOPSIS
my $e = $form->element( Checkbox => 'foo' );
=head1 DESCRIPTION
Checkbox form field.
=head1 METHODS
=head2 default_empty_value
Inherited. See L for details.
=head2 reverse_multi
Overrides the default value, so it's C.
=head1 SEE ALSO
Is a sub-class of, and inherits methods from
L,
L,
L
L
=head1 AUTHOR
Carl Franks, C
=head1 LICENSE
This library is free software, you can redistribute it and/or modify it under
the same terms as Perl itself.