migrate DataForm www_editField to FormBuilder

This commit is contained in:
Doug Bell 2011-01-26 16:05:39 -06:00
parent 325dbad2a3
commit 8c01fdbc73
2 changed files with 66 additions and 32 deletions

View file

@ -17,7 +17,7 @@ http://www.plainblack.com info@plainblack.com
use strict;
use Tie::IxHash;
use WebGUI::Form;
use WebGUI::HTMLForm;
use WebGUI::FormBuilder;
use WebGUI::International;
use WebGUI::Mail::Send;
use WebGUI::Macro;
@ -1489,23 +1489,23 @@ sub www_editField {
else {
$field = {};
}
my $f = WebGUI::HTMLForm->new($self->session, action => $self->getUrl);
$f->hidden(
my $f = WebGUI::FormBuilder->new($self->session, action => $self->getUrl);
$f->addField( "hidden",
name => "fieldName",
value => $field->{name},
);
$f->hidden(
$f->addField( "hidden",
name => "func",
value => "editFieldSave"
);
$f->text(
$f->addField( "text",
name=>"label",
label=>$i18n->get(77),
hoverHelp=>$i18n->get('77 description'),
value=>$field->{label}
);
if ($field->{isMailField}) {
$f->readOnly(
$f->addField( "readOnly",
name => "newName",
label => $i18n->get(21),
hoverHelp => $i18n->get('21 description'),
@ -1513,7 +1513,7 @@ sub www_editField {
);
}
else {
$f->text(
$f->addField( "text",
name => "newName",
label => $i18n->get(21),
hoverHelp => $i18n->get('21 description'),
@ -1525,14 +1525,14 @@ sub www_editField {
0 => $i18n->get("no tab"),
map { $_ => $self->getTabConfig($_)->{label} } @{ $self->getTabOrder },
);
$f->selectBox(
$f->addField( "selectBox",
name => "tabId",
options => \%tabs,
label => $i18n->get(104),
hoverHelp => $i18n->get('104 description'),
value => [ $field->{tabId} ]
);
$f->text(
$f->addField( "text",
name => "subtext",
value => $field->{subtext},
label => $i18n->get(79),
@ -1545,62 +1545,62 @@ sub www_editField {
"editable" => $i18n->get(6),
"required" => $i18n->get(75),
);
$f->selectBox(
$f->addField( "selectBox",
name => "status",
options => \%fieldStatus,
label => $i18n->get(22),
hoverHelp => $i18n->get('22 description'),
value => [ $field->{status} || "editable" ],
);
$f->fieldType(
$f->addField( "fieldType",
name => "type",
label => $i18n->get(23),
hoverHelp => $i18n->get('23 description'),
value => "\u$field->{type}" || "Text",
types => [qw(DateTime TimeField Float Zipcode Text Textarea HTMLArea Url Date Email Phone Integer YesNo SelectList RadioList CheckList SelectBox File)],
);
$f->integer(
$f->addField( "integer",
name => "width",
label => $i18n->get(8),
hoverHelp => $i18n->get('8 description'),
value => ($field->{width} || 0),
);
$f->integer(
$f->addField( "integer",
name => "rows",
value => $field->{rows} || 0,
label => $i18n->get(27),
hoverHelp => $i18n->get('27 description'),
subtext => $i18n->get(28),
);
$f->yesNo(
$f->addField( "yesNo",
name=>"vertical",
value=>$field->{vertical},
label=>$i18n->get('editField vertical label'),
hoverHelp=>$i18n->get('editField vertical label description'),
subtext=>$i18n->get('editField vertical subtext')
);
$f->text(
$f->addField( "text",
name=>"extras",
value=>$field->{extras},
label=>$i18n->get('editField extras label'),
hoverHelp=>$i18n->get('editField extras label description'),
);
$f->textarea(
-name=>"options",
-label=>$i18n->get(24),
-hoverHelp=>$i18n->get('24 description'),
-value=>$field->{options},
-subtext=>'<br />'.$i18n->get(85)
$f->addField( "textarea",
name=>"options",
label=>$i18n->get(24),
hoverHelp=>$i18n->get('24 description'),
value=>$field->{options},
subtext=>'<br />'.$i18n->get(85)
);
$f->textarea(
-name=>"defaultValue",
-label=>$i18n->get(25),
-hoverHelp=>$i18n->get('25 description'),
-value=>$field->{defaultValue},
-subtext=>'<br />'.$i18n->get(85)
$f->addField( "textarea",
name=>"defaultValue",
label=>$i18n->get(25),
hoverHelp=>$i18n->get('25 description'),
value=>$field->{defaultValue},
subtext=>'<br />'.$i18n->get(85)
);
if (!$fieldName) {
$f->whatNext(
$f->addField( "whatNext",
options => {
"editField" => $i18n->get(76),
"viewDataForm" => $i18n->get(745),
@ -1608,9 +1608,8 @@ sub www_editField {
value => "editField"
);
}
$f->submit;
my $ac = $self->getAdminConsole;
return $ac->render($f->print,$i18n->get('20'));
$f->addField( "submit", name => "submit" );
return '<h1>' . $i18n->get('20') . '</h1>' . $f->toHtml;
}
#-------------------------------------------------------------------

View file

@ -17,6 +17,7 @@ use strict;
use Test::More;
use Test::Deep;
use WebGUI::Test; # Must use this before any other WebGUI modules
use WebGUI::Test::Mechanize;
use WebGUI::Asset;
use WebGUI::Asset::Wobject::DataForm;
use WebGUI::VersionTag;
@ -43,7 +44,7 @@ $dform->createField('gotCaptcha', { type => 'Captcha', name => 'humanCheck', });
#----------------------------------------------------------------------------
# Tests
plan tests => 4; # Increment this number for each test you create
plan tests => 8; # Increment this number for each test you create
#----------------------------------------------------------------------------
# _createForm
@ -84,4 +85,38 @@ cmp_ok(
'... form with a captcha does not return lastModified, even in form mode'
);
#----------------------------------------------------------------------------
# www_editField
my $mech = WebGUI::Test::Mechanize->new( config => WebGUI::Test->file );
$mech->get_ok('/');
$mech->session->user({ userId => 3 });
# Create a new field
$mech->get_ok( $df->getUrl( 'func=editField;fieldName=new' ) );
$mech->submit_form_ok( {
fields => {
label => 'Request',
newName => 'request',
tabId => 0,
subtext => 'Submit your request to the circular file',
type => "Textarea",
},
}, "add a new field" );
$df = WebGUI::Asset->newById( $mech->session, $df->getId );
cmp_deeply(
$df->getFieldConfig( "request" ),
superhashof( {
label => 'Request',
name => 'request',
tabId => undef,
subtext => 'Submit your request to the circular file',
type => 'Textarea',
} ),
"field exists with correct config",
);
# Edit that field
#vim:ft=perl