NAME

SyForm - SyForm - a role driven form management

VERSION

version 0.005

SYNOPSIS

use SyForm;

my $form = SyForm->create([
  'username' => {
    isa => 'Str',
    required => 1,
    label => 'Your name',
  },
  'age' => {
    isa => 'Int',
    label => 'Your age',
  },
  'unchecked' => {
    label => 'Unchecked',
  },
]);

$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->username;
# my $value = $results->values->username; # same as above $value
# my $success = $result->success # result is after check

for (@{$view->field_names}) {
  my $input_value = $view->field($_)->value;
  if ($view->success) {
    my $verified_result = $view->field($_)->result;  
  } else {
    my $verified_result_if_exist = $view->field($_)->result;
  }
  # for access to the main B<SyForm::Field> of the view field
  my $syform_field = $view->field($_)->field;
}

DESCRIPTION

SyForm is developed for SyContent.

SyForm has many SyForm::Field.

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.

WARNING: SyForm::Values and SyForm::Results produce Moose attributes for storing their data, those are named directly after the key given for the field on the definition. This is highly risky for collides so its best to avoid using any term used in SyForm as key for those fields. This will change and getting real attributes will become an optional feature.

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.