|  |  TWiki Forms  | 
|  | The Name,TypeandSizecolumns are required. Other columns are optional. The form must have a header row (e.g.| *Name* | *Type* | *Size* |). | 
|
| < <
 | Nameis the name of the form field. | 
| > >
 | Name column: Nameis the name of the form field.
Type, Size, Value columns:Type,SizeandValuedescribe the type, size and initial value for this field:
		
			| Type | Description | Size | Value |  
			| text | One-line text field | Text box width in number of characters | Initial (default) content |  
			| textarea | Multi-line text box | Columns x rows, such as 80x6; default is40x5 | Initial (default) content |  
			| label | Read-only text label |  | Text of the label |  
			| checkbox | One or more checkboxes that can be toggled individually | Number of checkboxes shown per line | Comma-space-separated list of item labels - can be a dynamic SEARCH |  
			| checkbox+buttons | Like checkbox, adding [Set] and [Clear] buttons |  
			| radio | Radio buttons, mutually exclusive; only one can be selected | Number of radio buttons shown per line | Comma-space-separated list of item labels - can be a dynamic SEARCH |  
			| select | Select box, rendered as a picklist or a multi-row selector box depending on the size value | • 1: Show a picklist• Number > 1: Multi-row selector box of specified size
 • Range e.g.
 3..10: Multi-row selector box with variable size - the box will never be smaller than 3 items, never larger than 10, and will be 5 high if there are only 5 options | Comma-space-separated list of options of the select box - can be a dynamic SEARCH |  
			| select+multi | Like select, turning multi-select on, to allow Shift+Click and Ctrl+Click to select (or deselect) multiple items |  
			| select+values | Like select, allowing definition of values that are different to the displayed text. For example:
 | Field 9 | select+values | 3 | One, Two=2, Three=III | Various values formats |shows  but the values of options
 TwoandThreeare2andIII, respectively. |  
			| select+multi+values | Combination of select+multiandselect+values |  
			| date |  Single-line text box and a button next to it to pick a date from a popup calendar. The date can also be typed into the text box. The date format can be customized. See details. | Text box width in number of characters | Initial (default) date |  | 
|  |  | 
|
| < <
 | The Type,SizeandValuefields describe the legal values for this field, and how to display them.
 Typecheckboxspecifies one or more checkboxes. TheSizefield specifies how many checkboxes will be displayed on each line. TheValuefield should be a comma-separated list of item labels.
 Typecheckbox+buttonswill add Set and Clear buttons to the basiccheckboxtype. Typeradiois likecheckboxexcept that radio buttons are mutually exclusive; only one can be selected. Typelabelspecifies read-only label text. TheValuefield should contain the text of the label. Typeselectspecifies a select box. TheValuefield should contain a comma-separated list of options for the box. TheSizefield can specify a fixed size for the box (e.g.1, or a range e.g.3..10. If you specify a range, then the box will never be smaller than 3 items, never larger than 10, and will be 5 high if there are only 5 options.
 There are two modifiers that can be applied to the selecttype: Typetextspecifies a one-line text field.Sizespecifies the text box width in number of characters.Valueis the initial (default) content when a new topic is created with this form template. Typetextareaspecifies a multi-line text box. TheSizefield should specify columns x rows, e.g.80x6; default size is 40x5. As fortext, theValuefield specifies the initial text Typedatespecifies a single-line text box and a button next to it; clicking on the button will bring up a calendar from which the user can select a date. The date can also be typed into the text box.Sizespecifies the text box width in characters. As fortext, theValuefield specifies the initial text | 
| > >
 | Tooltip message column: The Tooltip messagewill be displayed when the cursor is hovered over the field ineditview. | 
|  |  | 
|
| < <
 | Tooltip messageis a message that will be displayed when the cursor is hovered over the field ineditview. | 
| > >
 | Attributes column: Attributesspecifies special attributes for the field. Multiple attributes can be entered, separated by spaces. | 
|  |  | 
|
| < <
 | Attributesspecifies special attributes for the field. Multiple attributes can be entered, separated by spaces. | 
|  | 
 An attribute Hindicates that this field should not be shown in view mode. However, the field is available for editing and storing information. An attribute Mindicates that this field is mandatory. The topic cannot be saved unless a value is provided for this field. If the field is found empty during topic save, an error is raised and the user is redirected to anoopspage. Mandatory fields are indicated by an asterisks next to the field name. | 
|  | 
 The Valuescolumn must be empty in the referring form definition.  Extending the range of form data types  | 
|
| > >
 |  | 
|  | You can extend the range of data types accepted by forms by using TWikiPlugins. All such extended data types are single-valued (can only have one value) with the following exceptions: 
Types with names like this can both take multiple values. any type name starting with checkbox any type name with +multianywhere in the name  Hints and Tips  | 
|
| < <
 |  Build an HTML form to create new Form-based topics 
 New topics with a form are created by simple HTML forms asking for a topic name. For example, you can have a SubmitExpenseReporttopic where you can create new expense reports, aSubmitVacationRequesttopic, and so on. These can specify the required template topic with its associated form. Template topics has more. | 
| > >
 |  Editing Just Form Data, Without Topic Text In some cases you want to change only the form data. You have the option of hiding the topic text with two methods:
 To display only the form whenever you edit a topic, set the preference variable EDITACTION to value form(see details). To change the edit action in a URL, add a action=formparameter to the edit URL string, such as
 %SCRIPTURL{edit}%/%BASEWEB%/%BASETOPIC%?t=%SERVERTIME{$epoch}%;action=form(see details).  Build an HTML Form to Create New Form-based Topics New topics with a form are created by simple HTML forms asking for a topic name. For example, you can have aSubmitExpenseReporttopic where you can create new expense reports, aSubmitVacationRequesttopic, and so on. These can specify the required template topic with its associated form. Template topics has more. | 
|  | A Form Template specifies the fields in a form. A Form Template is simply a page containing a TWiki table, where each row of the table specifies one form field. | 
|
| > >
 |  | 
|  |  Searching for Form Data  | 
|
| > >
 |  | 
|  | TWiki Forms accept user-input data, stored as TWikiMetaData. Meta data also contains program-generated info about changes, attachments, etc. To find, format and display form and other meta data, see TWikiMetaData, FORMFIELD,SEARCHandMETASEARCHvariables in TWikiVariables, and TWiki Formatted Search. | 
|  | Searching forms this way is obviously pretty inefficient, but it's easy to do. If you want better performance, take a look at some of the structured wiki extensions that support higher performance searching e.g. TWiki:Plugins.DBCachePlugin. | 
|
| > >
 |  | 
|  |  Gotcha!  | 
|
| > >
 |  | 
|  | 
 Some browsers may strip linefeeds from textfields when a topic is saved. If you need linefeeds in a field, make sure it is atextarea. | 
|
| < <
 | Related Topics: TWikiTemplates, TWikiScripts, UserDocumentationCategory | 
| > >
 | Related Topics: TWikiTemplates, TWikiScripts, VarSEARCH, FormattedSearch, UserDocumentationCategory |