The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
package HTML::FormHandler::Manual::FromDFV;
# ABSTRACT: converting from Data::FormValidator

__END__

=pod

=encoding UTF-8

=head1 NAME

HTML::FormHandler::Manual::FromDFV - converting from Data::FormValidator

=head1 VERSION

version 0.40067

=head1 SYNOPSIS

L<Manual Index|HTML::FormHandler::Manual>

Cheatsheet for converting from L<Data::FormValidator>.

=head1 DESCRIPTION

Information that's useful when switching from Data::FormValidator to
HTML::FormHandler. There's not a lot here yet, so if you have something
to add, patches are welcome.

In a general way, FormHandler doesn't have nearly so many "special"
checks as Data::FormValidator. It would be possible to implement many
of them, but there hasn't been much demand for them. So far FormHandler
users seem to be satisfied with the "do your own checks in a Perl method"
solution. Because of the greater complexity of FormHandler's data model -
with Repeatable arrays and nested compounds, etc - it's somewhat harder
to do some of them automatically.

=head1 Differences/conversions

=over 4

=item dependencies

In FormHandler, 'dependency' is the equivalent of 'dependency_group',
without the key names.

The other variations of dependencies in DFV are not implemented in
FormHandler, and would normally be done in a form's 'validate' sub.

=item trim, filters

A 'trim' filter is installed by default in FormHandler; it's a
special version of an apply action, and can be set to a transform
or Moose type. See the documentation in L<HTML::FormHandler::Field#trim>.

Transforms and inflations/deflations do not change what is presented in
the form unless you set the 'fif_from_value' flag on the field.

=item FV_length_between, FV_max_length, FV_min_length

Use text fields with 'minlength' and 'maxlength' attributes.

=item FV_eq_with

Perform your own checks in the form 'validate' sub.

    sub validate {
        my $self = shift;
        if( $self->field('one')->value eq $self->field('two')->value ) {
        }
    }

=back

=head1 Constraints

The simple constraints from L<Data::FormValidator::Constraints> can be used
directly in a FormHandler form:

    use Data::FormValidator::Constraints ('match_state');
    has_field 'my_state' => (
        apply => [ { check => \&match_state, message => 'Invalid State' } ] );

=over 4

=item email

Use the 'Email' field type, or use the FH Moose Type, 'email'.

     has_field 'email' => ( type => 'Email' );
     -- or --
     use HTML::FormHandler::Types ('Email');
     has_field 'email' => ( apply => [ Email ] );

=back

=head1 AUTHOR

FormHandler Contributors - see HTML::FormHandler

=head1 COPYRIGHT AND LICENSE

This software is copyright (c) 2016 by Gerda Shank.

This is free software; you can redistribute it and/or modify it under
the same terms as the Perl 5 programming language system itself.

=cut