NAME
SyForm - Easy role driven form management
VERSION
version 0.010
SYNOPSIS
use SyForm;
my $form = SyForm->create([
'username' => {
required => 1,
label => 'Your name',
html => 'text',
},
'age' => {
decimal => 1,
label => 'Your age',
html => 'text',
},
'unchecked' => {
label => 'Unchecked',
html => 'textarea',
},
]);
$form->does('SyForm'); # its all roles
$form->field('username')->does('SyForm::Field');
$form->field('username')->does('SyForm::Field::Label');
$form->field('username')->does('SyForm::Field::Verify');
# Roles are only automatically loaded on requirement
!$form->field('unchecked')->does('SyForm::Field::Verify');
my $view = $form->process( username => 'YoCoolCopKiller', age => 13 );
# or ...
# $values = $form->process_values(%args);
# my $value = $values->value;
# !$values->can('success'); # values are only the input
# $results = $form->process_results(%args);
# my $result = $results->get_result('username');
# my $value = $results->values->get_value('username');
# my $success = $result->success # result is after check
for my $field_name (@{$view->field_names}) {
my $input_value = $view->field($field_name)->value;
if ($view->success) {
my $verified_result = $view->field($field_name)->result;
} else {
# result is filled for all valid fields, even on invalid form
my $verified_result_if_exist = $view->field($field_name)->result;
}
# for access to the main SyForm::Field of the view field
my $syform_field = $view->field($field_name)->field;
}
$view->render; # get HTML
DESCRIPTION
SyForm is developed for SyContent.
SyForm has many SyForm::Field. You get a form object with calling create([@fields], %form_args) on SyForm.
With SyForm::Process (automatically added) you can give it process_args via calling of process(%args) on your form object that you get from the create.
This call to process creates internally a SyForm::Values out of the process args together with the help of the fields. Those again use this to produce a SyForm::Results with the final results of the process.
Those end up in a SyForm::View together with a SyForm::ViewField for every SyForm::Field that is used in the process flow. The view field allows easy access to the SyForm::Values values, the SyForm::Results results and the actually SyForm::Field definition, to get a complete access of all variables in the rendering.
For validation SyForm implements Validation::Class and so most of the directives available there are available in SyForm. A complete list can be found at SyForm::Field::Verify.
SUPPORT
IRC
Join #sycontent on irc.perl.org. Highlight Getty for fast reaction :).
Repository
http://github.com/SyContent/SyForm
Pull request and additional contributors are welcome
Issue Tracker
http://github.com/SyContent/SyForm/issues
AUTHOR
Torsten Raudssus <torsten@raudss.us>
COPYRIGHT AND LICENSE
This software is copyright (c) 2014 by Torsten Raudssus.
This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.