Apache::Wyrd::Input - Form Input Wyrds (scalar)
<BASENAME::Input type="text" name="foo" flags="required" /> <BASENAME::Input type="textarea" name="desc" height="100" width="100"> This is the default text </BASENAME::Input> <BASENAME::Input type="hidden" name="name" value="lenore" /> <BASENAME::Input type="password" name="name" size="10" /> sub _startup_integer { my ($self, $value, $params) = @_; $self->{'_datum'} ||= Apache::Wyrd::Datum::Integer->new($self->{'value'}, $params); $self->{'_template'} ||= '<input type="text" name="$:name" ' . 'value="$:value"?:size{ size="$:size"}?:id{ id="$:id"}' . '?:readonly{ readonly}>'; $self->{'_smart_type'} = 'text'; } <BASENAME::Input type="integer" default="1" name="counted" />
This is the base class for Input objects, which are tracked and affected by the Apache::Wyrd::Form (Form) objects that enclose them. The base Input object is meant to replace, in most cases, the input HTML objects:
text inputs
password inputs
textarea inputs
hidden inputs
For these, set the type attribute to text, password, textarea, and hidden respectively. Another hybrid input is plaintext, which both shows the text and includes it in the form as a hidden input. For other input types, such as radiobuttons, checkboxes, selection sets, etc., see Apache::Wyrd::Input::Set.
Apache::Wyrd::Input::Set
The Input does its work in the _format_output phase. If given a type of "foo", it will first attempt to match it to one of the standard types, then look for a startup_foo method and if it finds it, will call the method. This is to allow derived Input objects to initialize builtins, if needed, without re-implementing the whole _format_output method.
_format_output
startup_foo
Any derived startup_foo method should, for completeness, set the _datum attribute to a Datum object appropriate to the type, put together a template for the input appropriate to the expected output, and if the Apache::Wyrd::Interfaces::SmartInput interface is to be used, set the _smart_type attribute to the appropriate one for the template. See the SYNOPSIS for an example startup routine for integer types.
Apache::Wyrd::Interfaces::SmartInput
For entry pages to Forms or any other state where the enclosing Form cannot determine the initial value of an input, the Input will try the current value it would be getting from a submission now (typically by using a CGI parameter of the same name), any previous submissions (in this form sequence) of variables of the same name, and lastly the "default" value before giving up and initializing to null.
Most Input objects also accept the attributes of their HTML counterparts. For example, text-type Inputs accept name, value, size, class, id, maxlength, tabindex, accesskey, onchange, onselect, onblur, etc. Dev Note: Derived classes should maintain this support by including conditionals in the template (see the code).
A description for this input, to be used in error messages.
Maximum length of the inputted text, applies both to text and textarea type Inputs.
Required. The name of the Input.
The CGI parameter to use for this Input, if not the name.
The triggers fired (comma separated list) by this input if invalid, if not param or name (in that order of precedence).
Width of the item, in pixels. This is an estimated value based on the browser in use and assuming default style-sheets for those browsers. Meant for really quick-and-dirty formatting. Applies only to text and textarea Inputs, or Inputs that somehow make use of the Apache::Wyrd::Interfaces::SmartInput interface.
With the same caveats as width, this attribute is the height of the item, in pixels. As with width, applies only to textarea attributes or SmartInputs that implement a height in chars.
Required. The type of the Input.
By default, a value of zero is not considered a valid value, and a value of zero will trigger an error if the required flag is set. This flag will allow values that are mathematically equivalent to zero. It may become the default behavior in future versions of this Wyrd.
Escape the HTML of the value, so as to avoid HTML parsing errors. Default behavior for Inputs who's end-result input tags have this problem, such as <input type="text">
Always accept value, even when invalid.
an alias for required.
Do not report error messages, only errors.
trigger an error if empty
Do not track the value of this input, but allow it to be reset on every submit (used in some no_submit flagged forms).
Enforce the strict pragma on the underlying datum object. Of limited use outside of debugging Input objects.
(format: (returns) name (arguments after self))
name/type/value/description/param
Input has read-only methods for name, type, value, description, triggers, and param. The param attribute is optional for Inputs which might need to use another name than the CGI variable of their associated HTML input, such as to use 'username' and 'password' when the browser may attempt to auto-fill these values.
name
type
value
description
triggers
param
Note that the value call gets the current value of the input from the underlying _datum object, and not from it's temporary storage under the _value attribute. This allows the Datum to be independent of the temporary value of the Input.
_datum
_value
null_ok
In rare cases (a number of checkboxes, for example), the Form Wyrd being unable to find the params associated with this input. Normally, the Form Wyrd will consider this an error, and refuse to alter the value of the associated variable. Setting a positive value for null_ok will allow the unfound parameter to indicate a null value (such as when all checkboxes are unchecked) You should not normally have to use this feature.
set
set accepts a value, which is converted to the appropriate type (arrayref, scalar, etc.) to safely pass the next test, which is the _check_param internal method. If _check_param returns a null result, it is assumed to have failed and the appropriate error calls are made, setting error flags in the parent via the parent's register_errors and register_error_messages.
In the parent, register_errors is assumed to process the triggers and register that at least one error has occurred in submitting it's inputs. register_error_messages is called separately, as there may not be a one-to-one correspondence between what the Input should warn the user about and what it considers an error.
The no_fail flag prevents the errors from registering at all, while the quiet flag will suppress only the error messages.
However, pass or fail, a call to the _datum object will occur with the set call, and presumably, the Datum class will know how to deal with that. For it's own purposes, however, the value will be temporarily stored by the Input, and HTML esacaped if the escape flag is set.
_parse_options
_parse_options looks to the options attribute, which may be explicit as a comma/whitespace delineated list or built up by sub-objects (see Apache::Wyrd::Input::Opt) in order to determine what options to give to the datum object. If this value is already a hashref or arrayref, it does no further processing. Otherwise it attempts to separate the words of the options attribute, using an optional regexp under the "delimiter" attribute.
Apache::Wyrd::Input::Opt
_check_param
the _check_param method itself, by default, calls the check method of the underlying Datum instance. Datum returns two values, the first indicating pass/fail for defined/undefined and the second indicating what the default error message is. Authors producing Datum objects created to support the Input should pay special attention to this, as this is where useful error messages can be generated, rather than the default "Invalid data in <param-name>". _check_param also adds the parameter/name as a token to the error register so it can be tracked by the parent.
A shorthand for adding this method to an item is the description attribute, which will be prepended to the error string if an error occurs.
the values stored in the _errors and _error_messages registers can be accessed read_only through the errors and error_messages methods, as demonstrated by the Form object.
errors
Return all the errors for this Input. Should be considered as "triggers" of an Apache::Wyrd::Form object for the Apache::Wyrd::ErrTag objects to detect (see documentation for those modules).
Apache::Wyrd::Form
Apache::Wyrd::ErrTag
error_messages
Return all the error messages for this Input.
_escape
the _escape method is a utility for escaping the data in an HTML text-type input in order to avoid formatting errors. The default is to only escape quotes and ampersands by encoding them as the appropriate entity.
the _unescape method reverse-mirrors the _escape method exactly.
_unescape
_template_foo
the _template methods should provide an Apache::Wyrd::Interfaces::Setter-style template for a given input. Built-in templates are text, textarea, password
_template
Apache::Wyrd::Interfaces::Setter
Reserves the _format_output and _generate_output methods. Also reserves the final_output method.
_generate_output
final_output
Barry King <wyrd@nospam.wyrdwright.com>
General-purpose HTML-embeddable perl object
Build complex HTML forms from Wyrds
Copyright 2002-2007 Wyrdwright, Inc. and licensed under the GNU GPL.
See LICENSE under the documentation for Apache::Wyrd.
Apache::Wyrd
To install Apache::Wyrd, copy and paste the appropriate command in to your terminal.
cpanm
cpanm Apache::Wyrd
CPAN shell
perl -MCPAN -e shell install Apache::Wyrd
For more information on module installation, please visit the detailed CPAN module installation guide.