package WebGUI::Form::HiddenList; =head1 LEGAL ------------------------------------------------------------------- WebGUI is Copyright 2001-2005 Plain Black Corporation. ------------------------------------------------------------------- Please read the legal notices (docs/legal.txt) and the license (docs/license.txt) that came with this distribution before using this software. ------------------------------------------------------------------- http://www.plainblack.com info@plainblack.com ------------------------------------------------------------------- =cut use strict; use base 'WebGUI::Form::Control'; use WebGUI::International; use WebGUI::Session; =head1 NAME Package WebGUI::Form::HiddenList =head1 DESCRIPTION Creates a list of hidden fields. This is to be used by list type controls (selectList, checkList, etc) to store their vaiuses as hidden values. =head1 SEE ALSO This is a subclass of WebGUI::Form::Control. =head1 METHODS The following methods are specifically available from this class. Check the superclass for additional methods. =cut #------------------------------------------------------------------- =head2 definition ( [ additionalTerms ] ) See the super class for additional details. =head3 additionalTerms The following additional parameters have been added via this sub class. =head4 options A hash reference containing name value pairs. The name of each pair will be used to fill the value attribute of the hidden field. Defaults to an empty hash reference. =head4 defaultValue value and defaultValue are array referneces containing the names from the options list that should be stored. =cut sub definition { my $class = shift; my $definition = shift || []; push(@{$definition}, { options=>{ defaultValue=>{} }, defaultValue=>{ defaultValue=>[] } }); return $class->SUPER::definition($definition); } #------------------------------------------------------------------- =head2 getName () Returns the human readable name or type of this form control. =cut sub getName { return WebGUI::International::get("hidden list","WebGUI"); } #------------------------------------------------------------------- =head2 toHtml ( ) A synonym for toHtmlAsHidden. =cut sub toHtml { my $self = shift; $self->toHtmlAsHidden; } #------------------------------------------------------------------- =head2 toHtmlAsHidden ( ) Renders an input tag of type hidden. =cut sub toHtmlAsHidden { my $self = shift; my $output; foreach my $key (keys %{$self->{options}}) { foreach my $item (@{$self->{values}}) { if ($item eq $key) { $output .= WebGUI::Form::Hidden->( name=>$self->{name}, value=>$key ); } } } return $output; } #------------------------------------------------------------------- =head2 toHtmlWithWrapper ( ) A synonym for toHtmlAsHidden. =cut sub toHtmlWithWrapper { my $self = shift; return $self->toHtmlAsHidden; } 1;