Finished documenting Tab Form API.

This commit is contained in:
JT Smith 2003-02-26 04:27:35 +00:00
parent 1ea00268f6
commit 38e5ea2414
2 changed files with 103 additions and 10 deletions

View file

@ -249,9 +249,9 @@ sub www_editPage {
$page{endDate} = (addToDate(time(),10)) if ($page{endDate} < 0); $page{endDate} = (addToDate(time(),10)) if ($page{endDate} < 0);
#$output = helpIcon(1); #$output = helpIcon(1);
$output .= '<h1>'.WebGUI::International::get(102).'</h1>'; $output .= '<h1>'.WebGUI::International::get(102).'</h1>';
$f->hidden("pageId",$page{pageId}); $f->hidden({name=>"pageId",value=>$page{pageId}});
$f->hidden("parentId",$page{parentId}); $f->hidden({name=>"parentId",value=>$page{parentId}});
$f->hidden("op","editPageSave"); $f->hidden({name=>"op",value=>"editPageSave"});
$f->getTab("properties")->readOnly( $f->getTab("properties")->readOnly(
-value=>$page{pageId}, -value=>$page{pageId},
-label=>WebGUI::International::get(500), -label=>WebGUI::International::get(500),

View file

@ -46,7 +46,7 @@ Package that makes creating tab-based forms simple through an object-oriented AP
} }
); );
$tabform = WebGUI::TabForm->new; $tabform = WebGUI::TabForm->new(\%tabs);
$tabform->hidden($name, $value); $tabform->hidden($name, $value);
$tabform->submit(\%params); $tabform->submit(\%params);
@ -67,24 +67,103 @@ These methods are available from this class:
=cut =cut
#-------------------------------------------------------------------
=head2 formHeader ( hashRef )
Replaces the default form header with a new definition.
NOTE: This uses the same syntax of the WebGUI::Form::formHeader() method.
=cut
sub formHeader {
$_[0]->{_form} = WebGUI::Form::formHeader($_[1]);
}
#-------------------------------------------------------------------
=head2 getTab ( tabName )
Returns a WebGUI::HTMLForm object based upon a tab name created in the constructor.
=over
=item tabName
The name of the tab to return the form object for.
=back
=cut
sub getTab { sub getTab {
return $_[0]->{_tab}{$_[1]}{form}; return $_[0]->{_tab}{$_[1]}{form};
} }
#-------------------------------------------------------------------
=head2 hidden ( hashRef )
Adds a hidden field to the form.
NOTE: This uses the same syntax of the WebGUI::Form::hidden() method.
=cut
sub hidden { sub hidden {
$_[0]->{_form}->hidden($_[1],$_[2]); $_[0]->{_hidden} .= WebGUI::Form::hidden($_[1]);
} }
#-------------------------------------------------------------------
=head2 new ( tabHashRef )
Constructor.
=over
=item tabHashRef
A hash reference containing the definition of the tabs. It should be constructed like this:
use Tie::IxHash;
my %tabs;
tie %tabs, 'Tie::IxHash';
%tabs = (
cool=>{
label=>"Cool Tab",
uiLevel=>5
},
good=>{
label=>"Good Tab",
uiLevel=>8
}
);
=back
=cut
sub new { sub new {
my ($class, $tabs) = @_; my ($class, $tabs) = @_;
my $form = WebGUI::HTMLForm->new(1);
foreach my $key (keys %{$tabs}) { foreach my $key (keys %{$tabs}) {
$tabs->{$key}{form} = WebGUI::HTMLForm->new; $tabs->{$key}{form} = WebGUI::HTMLForm->new;
} }
bless {_submit=>WebGUI::Form::submit(),_form=>$form,_tab=>$tabs}, $class; bless { _submit=>WebGUI::Form::submit(), _form=>WebGUI::Form::formHeader(), _hidden=>"", _tab=>$tabs }, $class;
} }
#-------------------------------------------------------------------
=head2 print ( )
Returns an HTML string with all the necessary components to draw the tab form.
=cut
sub print { sub print {
my $output = ' my $output = '
@ -95,6 +174,8 @@ sub print {
<script src="'.$session{config}{extrasURL}.'/tabs/tabs.js" type="text/javascript"></script> <script src="'.$session{config}{extrasURL}.'/tabs/tabs.js" type="text/javascript"></script>
<link href="'.$session{config}{extrasURL}.'/tabs/tabs.css" rel="stylesheet" rev="stylesheet" type="text/css"> <link href="'.$session{config}{extrasURL}.'/tabs/tabs.css" rel="stylesheet" rev="stylesheet" type="text/css">
'; ';
$output .= $_[0]->{_form};
$output .= $_[0]->{_hidden};
my $i = 1; my $i = 1;
my $tabs; my $tabs;
my $form; my $form;
@ -109,16 +190,28 @@ sub print {
$form .= '</table></div>'; $form .= '</table></div>';
$i++; $i++;
} }
$_[0]->{_form}->raw('<div class="tabs">'.$tabs.$_[0]->{_submit}.'</div>'); $output .= '<div class="tabs">'.$tabs.$_[0]->{_submit}.'</div>';
$_[0]->{_form}->raw($form); $output .= $form;
$output .= $_[0]->{_form}->print; $output .= '</form>';
$output .= '<script>tabInit();</script>'; $output .= '<script>tabInit();</script>';
return $output; return $output;
} }
#-------------------------------------------------------------------
=head2 submit ( hashRef )
Replaces the default submit button with a new definition.
NOTE: This uses the same syntax of the WebGUI::Form::submit() method.
=cut
sub submit { sub submit {
$_[0]->{_submit} = WebGUI::Form::submit($_[1]); $_[0]->{_submit} = WebGUI::Form::submit($_[1]);
} }
1; 1;