NAME
Data::MuForm::Field - Base field package
VERSION
version 0.02
SYNOPSIS
Instances of Field subclasses are generally built by Data::MuForm from 'has_field' declarations or the field_list.
has_field 'my_field' => ( type => 'Integer' );
field_list => [
my_field => { type => 'Integer' }
]
Fields can also be added with add_field:
$form->add_field( name => 'my_field', type => 'Integer' );
You can create custom field classes:
package MyApp::Field::MyText;
use Moo;
use Data::MuForm::Meta;
extends 'Data::MuForm::Field::Text';
has 'my_attribute' => ( is => 'rw' );
sub validate { <perform validation> }
1;
DESCRIPTION
This is the base class for form fields. The 'type' of a field class is used in the MuForm field_list or has_field to identify which field class to load from the 'field_namespace' (or directly, when prefixed with '+'). If the type is not specified, it defaults to Text.
See Data::MuForm::Manual::Fields for a list of the fields and brief descriptions of their structure.
NAME
Data::MuForm::Field
ATTRIBUTES
Names, types, accessor
- name
-
The name of the field. Used in the HTML form. Often a db accessor. The only required attribute.
- type
-
The class or type of the field. The 'type' of Data::MuForm::Field::Currency is 'Currency'. Classes that you define yourself are prefixed with '+'.
- id
-
The id to use when rendering.
- accessor
-
If the name of your field is different than your database accessor, use this attribute to provide the accessor.
- full_name
-
The name of the field with all parents:
'event.start_date.month'
- full_accessor
-
The field accessor with all parents.
- prefixed_name
-
The full_name plus the prefix provided in 'field_prefix'. Useful for multiple forms on the same page.
- input_param
-
By default we expect an input parameter based on the field name. This allows you to look for a different input parameter.
Field data
- active, inactive, is_active, is_inactive
-
Determines which fields will be processed and rendered.
Can be changed on a process call, and cleared afterward:
$form->process( active => [ 'foo', 'bar' ], params => $params );
You can use the is_inactive and is_active methods to check whether this particular field is active. May be necessary to use in templates if you're changing the active/inactive of some fields.
if( $form->field('foo')->is_active ) { ... }
- input
-
The input string from the parameters passed in. This is not usually set by the user.
- value
-
The value as it would come from or go into the database, after being acted on by transforms and validation code. Used to construct the
$form->values
hash. Before validation is performed, the input is copied to the 'value', and validation and constraints should act on 'value'. After validation,$form->value
will get a hashref of the values.See also Data::MuForm::Manual::Transforms.
- fif
-
Values used to fill in the form. Read only.
[% form.field('title').fif %]
- init_value
-
Initial value populated by fill_from_object. You can tell if a field has changed by comparing 'init_value' and 'value'. You wouldn't normally change this.
- input_without_param
-
Input for this field if there is no param. Set by default for Checkbox, and Select, since an unchecked checkbox or unselected pulldown does not return a parameter.
Form, parent, etc
- form
-
A reference to the containing form.
- parent
-
A reference to the parent of this field. Compound fields are the parents for the fields they contain.
- localizer
-
Set from the form when fields are created.
- renderer
-
Set from the form when fields are created.
Errors
- errors
-
Returns the error list (arrayref) for the field. Also provides 'all_errors', 'num_errors', 'has_errors', 'push_error' and 'clear_errors'. Use 'add_error' to add an error to the array if you want to localize the error message, or 'push_error' to skip the localization.
- add_error
-
Add an error to the list of errors. Error message will be localized using 'localize' method, and the Localizer (default is Data::MuForm::Localizer, which use a gettext style .po file).
return $field->add_error( 'bad data' ) if $bad;
- push_error
-
Adds an error to the list of errors without localization.
- error_fields
-
The form and Compound fields will have an array of errors from the subfields.
methods
A 'methods' hashref allows setting various coderefs, 'build_id', 'build_label', 'build_options', 'validate', 'default'.
methods => { build_id => \&my_build_id } - coderef for constructing the id
methods => { build_label => \&my_build_label } - coderef for constructing the label
- build_id
-
A coderef to build the field's id. If one doesn't exist, will use a form 'build_field_id' method. Fallback is to use the field's full name.
- build_label
- build_options
- validate
- default
render_args
The 'render_args' hashref contains keys which are used in rendering, with shortcuts for easier specification in a field definition.
element_attr - ea
label_attr - la
wrapper_attr - wa
error_attr - era
element_wrapper_attr - ewa
has_field 'foo' => ( render_args => { element_attr => { readonly => 1, my_attr => 'abc' }} );
has_field 'foo' => ( 'ra.ea' => { readonly => 1, my_attr => 'abc' } );
has_field 'foo' => ( 'ra'.wa.class' => ['mb10', 'wr66'] );
Note the the 'name', 'id', and 'value' of fields is set by field attributes. Though it is possible to override the id in render_args, it then won't be available for other code such as 'errors_by_id'. There is some behavior associated with the 'disabled' flag too.
label - Text label for this field. Defaults to ucfirst field name.
id - Used in 'id="<id>"' in HTML
disabled - Boolean to set field disabled
The order attribute may be used to set the order in which fields are rendered.
order - Used for sorting errors and fields. Built automatically,
but may also be explicitly set. Auto sequence is by 5: 5, 10, 15, etc
Flags
- password
-
Prevents the entered value from being displayed in the form
- writeonly
-
The initial value is not taken from the database
- no_update
-
Do not include this field in
$form->values
, and so it won't be updated in the database. - not_nullable
-
Fields that contain 'empty' values such as '' are changed to undef in the validation process. If this flag is set, the value is not changed to undef. If your database column requires an empty string instead of a null value (such as a NOT NULL column), set this attribute.
has_field 'description' => ( type => 'TextArea', not_nullable => 1, );
This attribute is also used when you want an empty array to stay an empty array and not be set to undef.
It's also used when you have a compound field and you want the 'value' returned to contain subfields with undef, instead of the whole field to be undef.
Defaults
See also the documentation on Data::MuForm::Manual::Defaults.
- default method
-
Note: do *not* set defaults by setting the 'checked' or 'selected' attributes in options. The code will be unaware that defaults have been set.
has_field 'foo' => ( methods => { default => \&my_default } ); sub my_default { } OR has_field 'foo'; sub default_foo { }
Supply a coderef (which will be a method on the field). If not specified and a form method with a name of
default_<field_name>
exists, it will be used. - default
-
Provide an initial value in the field declaration:
has_field 'bax' => ( default => 'Default bax' );
Constraints and Validations
See also Data::MuForm::Manual::Validation.
Constraints set in attributes
- required
-
Flag indicating whether this field must have a value
- unique
-
For DB field - check for uniqueness. Action is performed by the DB model.
- apply
-
Use the 'apply' keyword to specify an ArrayRef of constraints and coercions to be executed on the field at field_validate time.
has_field 'test' => ( apply => [ TinyType, { check => sub {...}, message => { } }, { transform => sub { ... lc(shift) ... } } ], );
messages
has_field 'foo' => ( messages => { required => '...', unique => '...' } );
or
has_field 'foo' => ( 'msg.required' => '...' );
Set messages created by MuForm by setting in the 'messages' hashref or with the 'msg.<msg_name>' shortcut. Some field subclasses have additional settable messages.
required: Error message text added to errors if required field is not present. The default is "Field <field label> is required".
Transforms
There are a number of methods to provide finely tuned transformation of the input or value.
See also Data::MuForm::Manual::Transforms.
- transform_input_to_value
-
In FH was 'inflate_method'.
Transforms the string that was submitted in params (and copied to 'input') when it's stored in the 'value' attribute during validation.
- transform_value_to_fif
-
In FH was 'deflate_method'.
When you get 'fif' for the field and the 'value' is used (as opposed to input) transforms the value to a string suitable for filling in a form field.
- transform_default_to_value
-
In FH was inflate_default_method.
Transform the 'default' provided by an 'model' or 'init_values' or 'default' when it's stored in the 'value'.
- transform_value_after_validate
-
In FH was 'deflate_value_method';
Transform the value after validation has been performs, in order to return a different form in
$form->value
. - transform_param_to_input
-
Transform the param when it's stored in 'input'. Will change what the user sees in a re-presented form.
- trim
-
A transform to trim the field. The default 'trim' sub strips beginning and trailing spaces. Set this attribute to null to skip trimming, or supply a different sub.
trim => sub { my $string = shift; <do something> return $string; }
Trimming is performed before any other defined actions.
Processing and validating the field
See also Data::MuForm::Manual::Validation.
Validate method
has_field 'foo' => ( methods => { validate => \&foo_validation } );
sub foo_validation { }
OR
has_field 'foo';
sub validate_foo { }
Supply a coderef (which will be a method on the field). If not specified and a form method with a name of validate_<field_name>
exists, it will be used instead.
Periods in field names will be replaced by underscores, so that the field 'addresses.city' will use the 'validate_addresses_city' method for validation.
apply actions
Use Type::Tiny types;
use Types::Standard ('PosInteger');
has_field 'foo' => ( apply => [ PosInteger ] );
validate
This field method can be used in addition to or instead of 'apply' actions in custom field classes. It should validate the field data and set error messages on errors with $field->add_error
.
sub validate {
my $field = shift;
my $value = $field->value;
return $field->add_error( ... ) if ( ... );
}
AUTHOR
Gerda Shank
COPYRIGHT AND LICENSE
This software is copyright (c) 2017 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.