NAME
Form::Factory::Feature::Role::ControlValueConverter - form features that convert values
VERSION
version 0.016
SYNOPSIS
package MyApp::Feature::Control::Integer;
use Moose;
with qw(
Form::Factory::Feature
Form::Factory::Feature::Role::ControlValueConverter
);
sub check_control {
my ($self, $cotnrol) = @_;
die "not a scalar valued control"
unless $control->does('Form::Factory::Control::Role::ScalarValue');
}
sub control_to_value {
my ($self, $value) = @_;
return int($value);
}
sub value_to_control {
my ($self, $value) = @_;
return ''.$value;
}
DESCRIPTION
This role is used to provide standard value convertions between control values and action attributes. This allows you to reuse a common conversion by creating a feature to handle it.
Use of this role implies Form::Factory::Feature::Role::Control.
ROLE METHODS
The feature implementing this role must provide these methods.
control_to_value
This method is used to convert a value on a control for use in assignment to the action attribute to which it is attached.
This method should be defined like so:
sub control_to_value {
my ($self, $value) = @_;
return # ... converted value ...
}
The $value
here will be teh value to convert. This is usually going to be the current_value
of the control, but might be something else, so make sure you use the given value for conversion.
value_to_control
This method does the reverse of control_to_value
and is used to convert the action attribute to the control value.
It is defined like this:
sub value_to_control {
my ($self, $value) = @_;
return # ... converted value ...
}
The $value
here will be a value from the action attribute (or something of the same type) and the value returned should be appropriate for assigning to the control value.
AUTHOR
Andrew Sterling Hanenkamp <hanenkamp@cpan.org>
COPYRIGHT AND LICENSE
Copyright 2010 Qubling Software LLC.
This library is free software. You can redistribute it and/or modify it under the same terms as Perl itself.