blob: 562c5e7616cae1e91f3d5ed4bb8f119d850e467d [file] [log] [blame] [view]
# Example - Field Assist
##### Introduction
The Field Assist example shows how to use the support provided in <code>org.eclipse.jface.fieldassist</code>
to provide task assistance in text fields. An example dialog shows how to set up field decorations
to indicate required fields, fields with errors and warnings, and fields that supply content assist or quick
fix. The
example also includes a preference page that
allows you to configure the decorations and the content assist support.
#### Running the example
When the plug-in is installed, you should see a FieldAssist action
on the action bar. Choose the menu item "Open Field Assist Dialog..."
This will launch the field assist dialog. The dialog can be configured
using the example preferences.
#### Setting Field Assist Preferences
Two preference pages are provided for setting up the way the dialog
behaves. The **Field Assist Example Preferences** page allows you
to configure how the dialog annotates fields with errors and warnings,
required fields, and content assist. A combination of decorations
can be used to annotate the fields. This preference
page is intended to show what is possible when configuring decorations.
It is geared more toward the programmer trying out field assist, and
is not intended to be an example of a good preference page for letting
end users control the annotations.
The **Content Assist Preferences** page allows you to configure how the content assist is
installed on the dialog text field. Most of the options provided in the
field assist API (ContentProposalAdapter) are configurable on this page.
Note that it is possible to configure the content assist for an undesirable
user experience. For example, setting content assist to auto-activate on all
characters using a long delay is not desirable. It can be confusing
to use cumulative proposal filtering when the filter keys are not propagated
back to the control. The purpose of exposing the API in the preference page is
to allow the field assist programmer to try all possible combinations.
It is not expected that any of these preferences would ever be exposed to
an end user, but rather that the developer chooses the best combination of
these values to provide a certain style of content assist.
#### Using the dialog
The example dialog shows several different ways to configure
decorations and content proposal behavior in the first
dialog group (Security group):
- The **User name** field is configured as a required field with content
assist. This field is considered in error when a non-alphabetic character
is typed in the field. A quick fix menu is installed on the error decoration
that allows the user to strip non-alphabetic characters. The field is
considered in a warning mode when the name "bob"
is typed in the field. This field also installs a default select (double-click) listener on
the decoration to demonstrate the decoration listener interface.
- The **Combo user name** field is configured similarly, but uses a combo box
instead of a text field, and installs a selection (single click) listener on
the decoration rather than a default select listener.
- The **Age** field demonstrates the use of a Spinner widget with decorations.
It is configured as a required field, but does not provide an error state. It
is considered in a warning mode when an age greater than 65 is set.
- The **Password** field does not use any decorations or content assist.
It is merely provided to demonstrate that non-decorated fields can be easily aligned
with decorated fields.
The second dialog group shows how to use the AutoCompleteField to
get automatic field completion without using a content assist key or
decorator.
#### Example source code
The example dialog is not very complex, but is intended to demonstrate how to
program field assist. Some notes about the source code follow:
- When using ControlDecoration, the layout code must ensure that there is
enough margin space around the decoration to render the decoration.
- The example plug-in registers standard field decorators for indicating
the availability of content assist, marking a field as required, or marking
a field that has an error with quick fix or warning. In cases where a standard decorator
description is used in all fields, the actual decorations from the registry are
used. In cases where the field provides a unique description of an error or warning,
a unique decoration containing the text is managed by the field.
- SmartField and its subclasses are used to provide field-specific
validation, error and warning messages, content retrieval, and optional quick fix for
the different fields in the dialog. We expect that applications provide
similar frameworks (such as data binding) to achieve this goal. SmartField
is intended to show a simple technique for validating different fields inside
a dialog. It is not considered a robust example of a semantic field definition
framework.