This module enables non technical users to create and edit forms. The forms can be inserted into any HTML field using the insert object button in the toolbar of the HTML editor.
Form definition
The forms are defined in the forms module:
data:image/s3,"s3://crabby-images/9e88e/9e88eb4a3c1245618ff939f6ebb4ee59b543fd12" alt="forms_module forms_module"
The first time you go to the module, there is only one button. "New webform":
data:image/s3,"s3://crabby-images/96ccc/96ccc070b6d405f3682d4fa421f967529d7d7307" alt="forms_module2 forms_module2"
When you add a new form, you're shown the following screen:
data:image/s3,"s3://crabby-images/eeba2/eeba2c923556173cc7fd9729cbe7bd4ab9678b10" alt="forms_module_new_form forms_module_new_form"
Form settings
There are a lot of settings for the forms you define. From behaviour to how it looks; almost everything can be customized. The settings are split into different categories (tabs):
- The "Web form" tab contains the basic settings and confirmation and notification settings.
- The Settings tab contains a lot of detailed information on how to render the html.
- The Templates tab contains the template code used to render the form. These templates can be overridden to get your desired look and functionality.
- The Definitions tab contains the field definitions of the form.
Fields
There are a number of different field types you can create when you have defined a form.
If you switch to the "Fields" tab:
data:image/s3,"s3://crabby-images/fa9a9/fa9a9f23a2a78b9ef1e02dfd0beb517268170b6c" alt="forms_module_new_form2 forms_module_new_form2"
Click on the "Add new form field" button to add a new field. You get a dialog where you have to choose the field type. The types available are:
data:image/s3,"s3://crabby-images/21a52/21a5239e6cbfc17d45b19afdd3a35d0819a1eeaf" alt="form_field form_field"
If you select the "Text box" field type, you get the following:
data:image/s3,"s3://crabby-images/5fd0e/5fd0e255691fc59020ff42aed53b8c943a533473" alt="form_field2 form_field2"
When you create new fields, they are listed on the left:
data:image/s3,"s3://crabby-images/72a0c/72a0ce9e4956d92bdd75a88d5cd8a63c3b54a50e" alt="form_field4 form_field4"
Preview
When you open a form, you can click the preview icon on the blade to preview and test your form without publishing it on any pages. Note that the styling and look might be different than what you'll see in a real web page, due to the fact that different css rules may apply to the fields. The preview is very plain.
data:image/s3,"s3://crabby-images/764e4/764e41a6a4546c922ad3b7fdc9b89971adbf5b5f" alt="form_preview form_preview"
Inbox
The inbox displays the submissions of the current form. This is a copy of the content sent in an email to the notification email addresses.
data:image/s3,"s3://crabby-images/cab2d/cab2df28562f6f322f9a338b54700cc289cdc38f" alt="forms_inbox forms_inbox"
You can click on any of the submissions to read them:
data:image/s3,"s3://crabby-images/d8ede/d8edefb0f6746d56c7df2b50c475798950143202" alt="forms_inbox2 forms_inbox2"
Using forms
Forms can be used inside the html editor in Relatude, and the forms can be rendered inside content without any programming required:
- First, click on the "Insert or edit object" button in the editor:
data:image/s3,"s3://crabby-images/8c535/8c53564384963aaaffe5b1152c484806c6d55741" alt="forms_editor_insert forms_editor_insert"
- In the dialog that opens, select the "Form" button:
data:image/s3,"s3://crabby-images/ca9bf/ca9bf0d85d4ff7ae64aa0249cb57673d8c028a1a" alt="forms_editor_insert2 forms_editor_insert2"
- That opens a dialog that lists all the forms in the current site. Select the one you want to show:
data:image/s3,"s3://crabby-images/94743/94743a4ddee12347ac29b8c547afa34cecb85092" alt="forms_editor_insert3 forms_editor_insert3"
- The inserted forms is rendered as a placeholder. The placeholder makes it easy to move the form around in the text content:
data:image/s3,"s3://crabby-images/9fe67/9fe67f2abf0aa1c175feab523bb9a6aa48cd0998" alt="forms_editor_insert4 forms_editor_insert4"
For the visitor, the inserted form can look something like this:
data:image/s3,"s3://crabby-images/670ca/670ca58983025b7cc804a20a29882b745f6bca22" alt="insert5 insert5insert5insert5"
Rendering forms programmatically
The most common way of using forms have traditionally been to insert the forms in the editor. But with the popularity of modular page architecture, many new sites are composing pages using modules. On those situations, it is common to create a "Forms module", with a node parent relation on the module where you can select a form. In the code that renders the module, you can do the following to render a form:
WebForm form = module.Form.Get();
string formHtml = form.GetFormHtml(httpContext.Request.Params);