Creating fields that auto-complete in Progressive Web Applications
Standard view

Progressive view
By default, the suggestion list is case-insensitive, and it displays the value of the option, not the label. (You can change the configuration so that the menu's labels are displayed instead of its values.)
The results in the suggestion list can differ among databases. For example, for an Oracle database, the results are case sensitive by default. For other databases, the results are case insensitive.
The Menu/Row/Level Choice workflow condition runs when auto complete is used to fill in the value. Remember these tips when configuring workflow with character fields that have the automatic complete feature turned on:
- If workflow manipulates values of menu selections, you might want to configure auto-complete to show labels rather than values so that the workflow runs properly.
- The Return/Table or Level Dbl-Clk workflow condition does not run when the user presses Enter as part of the Auto Complete feature (that is, when the selection list is displayed). At other times, the workflow condition runs normally.
For more information, see Defining-workflow-to-automate-processes.
The following video (0:40) provides an overview of using the auto-complete or typeahead feature.
The following video (5:41) shows how to create typeahead fields and explore various options available to customize them.
To enable or disable auto-complete
- In Developer Studio, create a New Regular Form. 
- Create a Progressive View. 
- Create a character field in the view.
- Attach a menu to it.
- Select the character field.
- In the Properties tab, set the following properties: - Property - Description - Auto Complete - Determines what types of matches are displayed. The options are: - None (the default)—Disables auto-complete.
- Leading Match—Lists menu options that begin with the text that the user entered in the field.
- Anywhere Match—Lists menu options that include any text that the user entered in the field.
 - Auto Complete After Keystrokes - This property is used only for character fields with a search menu attached. The property is ignored for all other fields.
- The number of characters the user must type to trigger auto complete. For example, if you enter 3, auto complete displays the list of matching values after the users enters 3 or more characters. The default is 0.
- Use the Auto Complete After Keystrokes property to set the typeahead value for search menus in Progressive Views.
- Choose the value carefully to get efficient results as this can have performance implications. If menu is expected to return huge amount of data, set this value to a higher number such as 3 or more.
- If you have enabled the Auto Complete property and set the Auto Complete After Keystrokes to zero (0), the dropdown will appear as soon as you click or tab to focus on the character field.
 - Auto Complete Hide Menu Button - Determines whether the menu box is displayed (False) or hidden (True). The default is False. For large data sets, set this option to True so that users cannot open a menu. Instead, the menu data is used for auto-completion purposes only. - Auto Complete Match By - Determines whether menu values or labels are displayed. The options are: - Value (the default)—Menu values are displayed and used for matching while typing, as well as for completion.
- Label—Menu labels are displayed and used for matching while typing, but the menu value is used for completion. (This option is not normally used unless workflow on menu choice operates on the value, but you want to show the label to the user.)
 - At runtime, users can disable auto-complete by pressing Escape while typing in a character field. Auto-complete remains canceled until the field loses focus; it is re-enabled the next time the field gets focus. 
To configure auto-complete to match by label
- Follow the steps in To enable or disable auto-complete to enable Auto Complete for a character field.
- Select the character field.
- In the Properties tab, click Auto Complete Match By, and select one of the following values:- Value (default)—Menu values are displayed and used for matching while typing, as well as for completion.
- Label—Menu labels are displayed and used for matching while typing, but the menu value is used for completion. (This option is not normally used unless workflow on menu choice operates on the value but you want to show the label to the user.)
 
Considerations for search menus with large data sets
Fields with search menus that represent a large data set (for example, over 10,000 entries) can cause performance issues and might not show the complete set of matches if the query limit is exceeded. Additionally, if a menu on the character field has thousands of entries, you might not want to display the menu with the field. To avoid these issues, remember these tips:
- Make sure that the menu is a search menu whose values are character fields in the target data source. Set the Refresh option for the menu to On Open.
- Because the data set is large, hide the menu button for the character field. (Set the character field's Auto Complete Hide Menu Button property to True.) This ensures that the menu data is used only for auto-completion purposes.
- Optionally, enable a limit on the number of characters required to be typed before matching begins. (Enter an integer in the character field's Auto Complete After Keystrokes property.)
Workflow considerations
Remember these tips when configuring workflow with character fields that have the automatic complete feature turned on:
- The Menu/Row/Level Choice workflow condition executes when auto complete is used to fill in the value.
- If workflow manipulates values of menu selections, you might want to configure auto-complete to show labels rather than values so that the workflow runs properly.
- The Return/Table or Level Dbl-Clk workflow condition does not run when the user presses Enter as part of the Auto Complete feature (that is, when the selection list is displayed). At other times, the workflow condition executes normally.
For more information about workflow conditions, see Defining-workflow-to-automate-processes.
 
 
 
