TWiki
>
TWiki Web
>
TWikiFormDotPm
(revision 2) (raw view)
Edit
Attach
---+ Package =TWiki::Form= Object representing a single form definition. %TOC% ---++ ClassMethod *new* <tt>($session,$web,$form)</tt> * $web - default web to recover form from, if $form doesn't specify a web * =$form= - topic name to read form definition from May throw TWiki::OopsException ---++ ObjectMethod *renderForEdit* <tt>($web,$topic,$meta,$useDefaults) -> $html</tt> * =$web= the web of the topic being rendered * =$topic= the topic being rendered * =$meta= the meta data for the form * =$useDefaults= if true, will use default values from the form definition if no other value is given Render the form fields for entry during an edit session, using data values from $meta ---++ ObjectMethod *renderFieldForEdit* <tt>($fieldDef,$web,$topic,$value) -> $html</tt> * =$fieldDef= the field being rendered * =$web= the web of the topic being rendered * =$topic= the topic being rendered * =$value= the current value of the field Render a single form field for entry during an edit session, using data values from $meta. Plugins can provide a handler that extends the set of supported types SMELL: this should be a method on a field class SMELL: JSCalendarContrib ought to provide a 'date' handler. ---++ ObjectMethod *renderHidden* <tt>($meta,$useDefaults) -> $html</tt> * =$useDefaults= if true, will use default values from the form definition if no other value is given Render form fields found in the meta as hidden inputs, so they pass through edits untouched. ---++ ObjectMethod *cgiName* <tt>($field) -> $string</tt> Generate the 'name' of the CGI parameter used to represent a field. ---++ ObjectMethod *getFieldValuesFromQuery* <tt>($query,$metaObject,$initialiseMissing) -> ($seen,\@missing)</tt> Extract new values for form fields from a query. * =$query= - the query * =$metaObject= - the meta object that is storing the form values * =$initialiseMissing= - if true, will cause fields that are in the form but have no value in the query or in the meta to be initialised to ''. For each field, if there is a value in the query, use it. Otherwise if there is already entry for the field in the meta, keep it. Returns the number of fields which had values provided by the query, and a references to an array of the names of mandatory fields that were missing from the query. ---++ ObjectMethod *isTextMergeable* <tt>($name) -> $boolean</tt> * =$name= - name of a form field (value of the =name= attribute) Returns true if the type of the named field allows it to be text-merged. If the form does not define the field, it is assumed to be mergeable. ---++ ObjectMethod *getField* <tt>($name) -> \%row</tt> * =$name= - name of a form field (value of the =name= attribute) Returns the field, or undef if the form does not define the field. ---++ StaticMethod *renderForDisplay* <tt>($templates,$meta)</tt> * =$templates= ref to templates singleton * =$meta= - meta object containing the form to be rendered Static because we want to be able to do this without a form definition. SMELL: Why? Is reading the form topic such a big burden?
Edit
|
Attach
|
Watch
|
P
rint version
|
H
istory
:
r7
|
r4
<
r3
<
r2
<
r1
|
B
acklinks
|
V
iew topic
|
Raw edit
|
More topic actions...
Topic revision: r2 - 2006-04-01
-
TWikiContributor
TWiki
Log In
or
Register
TWiki Web
Users
Groups
Index
Search
Changes
Notifications
RSS Feed
Statistics
Preferences
User Reference
ATasteOfTWiki
TextFormattingRules
TWikiVariables
FormattedSearch
QuerySearch
TWikiDocGraphics
TWikiSkinBrowser
InstalledPlugins
Admin Maintenance
Reference Manual
AdminToolsCategory
InterWikis
ManagingWebs
TWikiSiteTools
TWikiPreferences
WebPreferences
Categories
Admin Documentation
Admin Tools
Developer Doc
User Documentation
User Tools
Webs
LAPPD
Sandbox
TWiki
Copyright © 1999-2025 by the contributing authors. All material on this collaboration platform is the property of the contributing authors.
Ideas, requests, problems regarding TWiki?
Send feedback
Note:
Please contribute updates to this topic on TWiki.org at
TWiki:TWiki.TWikiFormDotPm
.