ON CHANGE block

Syntax

ON CHANGE field-spec
   instruction [...]

Usage

The ON CHANGE block can be used to detect when a field has been changed by user input. The ON CHANGE block is executed, if the value has changed since the field got the focus and the modification flag is set.

The ON CHANGE block can be used in INPUT, INPUT ARRAY and CONSTRUCT dialogs.

For editable fields defined as EDIT, TEXTEDIT or BUTTONEDIT, the ON CHANGE block is executed when leaving a field, if the value of the specified field has changed since the field got the focus and the modification flag is set for the field. The field is left when user validates the dialog, when moving to another field, or when moving to another row in an INPUT ARRAY. However, if the text edit field is defined with the COMPLETER attribute to enable autocompletion, the ON CHANGE trigger will be fired after a short period of time, when the user has typed characters in.

For editable fields defined as CHECKBOX, COMBOBOX, DATEEDIT, DATETIMEEDIT, TIMEEDIT, RADIOGROUP, SPINEDIT, SLIDER or URL-based WEBCOMPONENT (when the COMPONENTTYPE attribute is not used), the ON CHANGE block is invoked immediately when the user changes the value with the widget edition feature. For example, when toggling the state of a CHECKBOX, when selecting an item in a COMBOBOX list, or when choosing a date in the calendar of a DATEEDIT. Note that for such item types, when ON CHANGE is fired, the modification flag is always set.

   ON CHANGE order_checked -- Defined as CHECKBOX
      CALL setup_dialog(DIALOG)

If both an ON CHANGE block and AFTER FIELD block are defined for a field, the ON CHANGE block is executed before the AFTER FIELD block.

When changing by program the value of the current field in an ON ACTION block, the ON CHANGE block will be executed when leaving the field, if the value is different from the previous value and the modification flag is set (after previous user input or when the touched flag has been changed by program).

In an INPUT or INPUT ARRAY, the field value change is related to the value of the variable bound to the field. In a CONSTRUCT dialog, the field value change is related to the input buffer / displayed value.

With a NEXT FIELD instruction, the state of the field value change is reset, as if the user had left and reentered the field. When using NEXT FIELD in ON CHANGE block or in an ON ACTION block, the ON CHANGE block will only be re-executed, if the value is changed since NEXT FIELD, and the modification flag is set. Therefore, ON CHANGE should not be used for field validation with a NEXT FIELD, because ON CHANGE will not get triggered again, if the (invalid) value has not changed; Field validation rules must be implemented in AFTER FIELD blocks and/or AFTER INPUT blocks.