Fields & Field Types
Freeform uses its own set of fields and field types. Using a predefined set of fields also gives us the control to more easily account for how each form field should be displayed in Composer's live preview, and provides a smoother experience.
There is currently a limit (around 130+) on the number of Freeform fields for each install of Craft, due to the MySQL column limit, since all fields are stored in a single table. However, Freeform fields can be used across all forms, and even be relabelled for each form.
Fields Overview
Fields are global and available to all forms, but they can also be overwritten per form. This allows you to save time reusing existing fields when making other forms, but also gives you flexibility to make adjustments to them when needed. So to clarify, you can create fields with labels and options that are common to all forms, but also override those on each form. For example, if you have a field named Cell Phone, on the form level, you can rename the field name to Mobile Phone, or if you have a Checkbox Group field with options: Option 1, Option 2, and Option 3, you could override it to just have 2 options with values of Option A and Option B. When the fields are edited at global level (in main Fields area of Freeform control panel), your customizations per form will NOT be lost.
Fields can be created and managed in the main field creation area (Freeform > Fields > New Field) and can also be created directly within the Composer interface as well. Fields created here are available globally as well (they do not just exist for that form).
Some important notes:
- All field properties can be overwritten at form level inside Composer, including the field Handle.
- Once a field is created, you cannot change the field type after.
- Freeform will load fields of Hidden type at the beginning of the form, regardless of where they are placed in Composer layout.
Field Types
The following field types are available (see below for additional Pro Field Types):
-
Text #
- A simple input field.
- Can be marked as required.
- Can contain default text and/or placeholder.
- Can set
maxlength
property.
- View field specific properties for templating.
- A simple input field.
-
Textarea #
- A simple multi-line input field.
- Specify the number of rows the textarea should have.
- Can be marked as required.
- Can contain default text and/or placeholder.
- Can set
maxlength
property.
- View field specific properties for templating.
- A simple multi-line input field.
-
Email #
- An input field that is flagged in Freeform to expect an email address value as well as possibility for receiving email notifications.
- In the Property Editor (right column) in Composer, select a notification template if you want the email entered for this field to receive an email notification.
- Users/groups need to have permissions access for Email Notifications to create new formatting templates.
- To allow sending of email notifications to more than 1 email address (e.g. in the case of a "tell-a-friend" type form), you will need to add multiple input fields, each with the input name
email[]
. This approach would require that you code this part manually however. - Required field type if you wish for your users to receive an email notification.
- Required field type if you're using with a Mailing List API integration.
- Can be marked as required.
- Can contain default text and/or placeholder.
- In the Property Editor (right column) in Composer, select a notification template if you want the email entered for this field to receive an email notification.
- View field specific properties for templating.
- An input field that is flagged in Freeform to expect an email address value as well as possibility for receiving email notifications.
-
Hidden
- A hidden field.
- Can only include text strings at this time (no variables allowed).
- If you need you pass a value to your hidden field dynamically, you can do so with the
overrideValues
parameter. Ex:overrideValues: { myFieldname: myvalue }
- If you need you pass a value to your hidden field dynamically, you can do so with the
- Cannot be marked as required.
- Freeform will load fields of this type at the beginning of the form, regardless of where they are placed in Composer layout.
- Can only include text strings at this time (no variables allowed).
- A hidden field.
-
Select #
- A select dropdown menu field.
- Can specify labels (with values assumed) or labels and values (that differ).
- To make the first option empty, use labels and values approach with first option having -- or Please select..., etc for the label, and leave option blank.
- Can be marked as required.
- Can specify default option to be selected.
- Can specify labels (with values assumed) or labels and values (that differ).
- View field specific properties for templating.
- A select dropdown menu field.
-
Checkbox #
- A single checkbox field.
- Has a default value of Yes, which can be overwritten with any value you want. The front end however, will always display the value as
1
, but upon submission, the value will be switched to the one you have set. - Can be marked as required, which would essentially require that this checkbox be checked.
- Can be checked by default.
- Has a default value of Yes, which can be overwritten with any value you want. The front end however, will always display the value as
- View field specific properties for templating.
- A single checkbox field.
-
Checkbox Group #
- A group of checkboxes.
- Can specify labels (with values assumed) or labels and values (that differ).
- Can be marked as required.
- Can specify which (if any) options to be checked by default.
- View field specific properties for templating.
- A group of checkboxes.
-
Radio Group #
- A group of radio options.
- Can specify labels (with values assumed) or labels and values (that differ).
- Can be marked as required.
- Can specify which (if any) option to be selected by default.
- View field specific properties for templating.
- A group of radio options.
-
File Upload #
- A file upload field, using Craft Assets.
- Can allow a single file or multiple files (applies
multiple
attribute to the single file upload input) to be uploaded.- Specify a number larger than
1
in the File Count setting to allow multiple files to be uploaded at the same time.
- Specify a number larger than
- Must have an Asset Source location where the file will be uploaded to.
- Does NOT work with Image Transforms.
- Define maximum file size (in KB). Default is 2048 KB (2MB). Is subject to:
- Craft's maxUploadFileSize setting
- PHP memory_limit
- PHP post_max_size
- PHP upload_max_filesize
- Select which file types can be uploaded.
- Leaving all options unchecked will allow ALL file types.
- In multi-page forms, if an earlier page contains file upload field(s), files will actually be uploaded before the form is officially submitted.
- If the form is never completed, incomplete submissions are stored for 3hrs, and then are removed (along with the file(s)) after that.
- Can be marked as required.
- Can allow a single file or multiple files (applies
- View field specific properties for templating.
- A file upload field, using Craft Assets.
-
Dynamic Recipients #
-
A select dropdown menu field that contains protected email addresses and labels for each.
- Can be switched to Radio options at form level inside Composer.
- Specify labels and email address values.
- Emails are never parsed in source code (they're replaced with 0, 1, 2, etc).
- NOTE: When parsing this field semi-manually, be sure to use
loop.index0
to generate numeric values of options instead offieldName.value
.
- NOTE: When parsing this field semi-manually, be sure to use
- To make the first option empty, specify -- or Please select..., etc for the label, and leave option blank.
- Emails are never parsed in source code (they're replaced with 0, 1, 2, etc).
- In the Property Editor (right column) in Composer, select a notification template you want the selected recipient for this field to receive.
- Users/groups need to have permissions access for Email Notifications to create new formatting templates.
- Can be marked as required.
- Can specify default option to be selected.
- Currently only 1 recipient(s) option can be selected at this time.
- Multiple email addresses can be specified for each option, separated by commas.
- Can include more than 1 of this field type in your forms, allowing for multiple sets of recipients to be notified.
-
Pro Field Types
The following extra field types are available with Freeform Pro:
-
Confirmation #
- Allows you to force a user to enter a matching value for another field (e.g. "Confirm Email Address").
- Select a target field to compare with.
- Can be marked as required.
- Can contain default text and/or placeholder.
- View field specific properties for templating.
- Allows you to force a user to enter a matching value for another field (e.g. "Confirm Email Address").
- Date & Time #
- A complex date and/or time field. Can be used as Date only, Time only, or both. Many configuration and validation options available as well:
- Set a default value.
- Can use
now
,today
,5 days ago
,2017-01-01 20:00:00
, etc, which will format the default value according to the chosen format as a localized value.
- Can use
- Select if the field should use the default Freeform datepicker.
- Can include your own manually in the template if you wish.
- Generate a placeholder from your date format settings showing the accepted format.
- Can include your own placeholder if you wish.
- Date Order - the formatting order you'd like. Options are:
- Year month day
- Month day year
- Day month year
- Select if the year should be displayed/validated as 4 digits.
- Select if the day and month numbers should have a leading
0
for single digit values (e.g. August will display as08
instead of8
). - Date separator - the character used between each year, month, day value:
- None
- Space (
/
-
.
- Select if time and datepicker should use 24 hour clock.
- Clock separator - the character used to separate hours and minutes:
- None
- Space (
:
-
.
- Choose if placeholder should display lowercase AM/PM (for 12hr clock).
- Currently doesn't work with the default Freeform date picker, but could be applied to a custom date picker.
- Choose if placeholder should separate AM/PM with a space (for 12hr clock).
- Can be marked as required.
- Set a default value.
- Freeform will automatically insert javascript in the footer of the page for this fieldtype. If you prefer to have this load inside the
<form></form>
tags (for purposes of caching, etc), you can adjust the Freeform Javascript Insertion Location setting. - View field specific properties for templating.
- A complex date and/or time field. Can be used as Date only, Time only, or both. Many configuration and validation options available as well:
-
Number #
- An input field that is validated to contain numbers only, based on several configuration options.
- Choose if validation should allow negative numbers.
- Optionally set Min/Max values.
- Both are optional, you can have both, just one or neither.
- Optionally set Min/Max character length.
- Both are optional, you can have both, just one or neither.
- Set the number of decimals allowed.
- Decimal Separator - the character used to separate decimals:
.
,
- Thousands Separator - the character used to separate thousands:
- None
- Space (
,
.
- Can be marked as required.
- Can contain default text and/or placeholder.
- View field specific properties for templating.
- An input field that is validated to contain numbers only, based on several configuration options.
- Phone #
- An input field that is validated to contain phone numbers only, based on pattern configured.
- Set pattern to desired format, where
x
is a digit between0
and9
, e.g:(xxx) xxx xxxx
xxx-xxx-xxxx
- If no pattern specified, Freeform will default to a universal phone number validation pattern.
- Can be marked as required.
- Can contain default text and/or placeholder.
- Set pattern to desired format, where
- An input field that is validated to contain phone numbers only, based on pattern configured.
- Rating #
- A special field that allows for star ratings using Freeform's built in CSS and JS.
- Set a default star rating value (based on Maximum Number of Stars configuration option)
- Set the maximum number of stars allowed.
- Select an "Unselected" display color.
- Select a "Hover" display color.
- Select a "Selected" display color.
- Can be marked as required.
- Freeform will automatically insert javascript in the footer of the page for this fieldtype. If you prefer to have this load inside the
<form></form>
tags (for purposes of caching, etc), you can disable the Include Freeform Scripts in the Page Footer setting. - View field specific properties for templating.
- A special field that allows for star ratings using Freeform's built in CSS and JS.
- Regex #
- An input field that is validated based on the specified regex pattern (e.g.
/^[a-zA-Z0-9]*$/
).- Set error message a user will see if an incorrect value is supplied.
- Any occurrences of
{{pattern}}
will be replaced with specified regex pattern inside the error message, if any are found.
- Any occurrences of
- Can be marked as required.
- Can contain default text and/or placeholder.
- Set error message a user will see if an incorrect value is supplied.
- An input field that is validated based on the specified regex pattern (e.g.
- Website #
- A simple input field that checks to see if the URL specified has valid syntax (
http://
,https://
,ftp://
, etc).- Can be marked as required.
- Can contain default text and/or placeholder.
- View field specific properties for templating.
- A simple input field that checks to see if the URL specified has valid syntax (