Defines and handles keywords and commands found in legacy screens for SNA.

The SNA commands extraction rule detects patterns of the form <KeyName><Separator><Action>, where KeyName must be found in a list provided in the Keywords table property of the rule.
The rule transforms these blocks into keyword type blocks and adds following XML attributes to matching blocks:

action: the javelin action to be executed on the mainframe,
data: optional additional data to be sent with the action.

Note: XML elements of the keyword type are handled by the keyword XSL template described in the keyword.xsl file. To change the way keywords are displayed in the HTML page, edit this file.

Property Type Category Description
Case dependency boolean configuration Defines whether letter case should be respected in keyword detection.
If set to false, keywords match even if the case is not similar. For example, pf13 and PF13 match the PF13 keyword.
Comment String configuration Describes the object comment to include in the documentation report.
This property generally contains an explanation about the object.
Is active boolean configuration Defines whether the extraction rule is active.
Is final boolean configuration Defines if the extraction is final, i.e. whether pending extraction rules should try to match on the current extraction rule matching blocks.

If set to true, once the rule applies on a matching block, Convertigo doesn’t apply the following rules on this block. This can be used to prevent a block from being modified by other rules.
Keyword separators String configuration Defines a concatenated list of keyword separator(s) that can be used.
This property lists separator characters used to separate each keyword name from its action.
For example, “=” is a keyword separator that matches the F3=EXIT command.
Keywords table XMLVector configuration Defines a list of keywords that can be detected, with replacement texts, optional data to send and associated action.
This property is a list of Keywords. For each Keyword you can define:

Keyword: Keyword string to handle when found in the screen,
Replace Text: Replacement text for the keyword (hotspot label, optional),
Sent data: Data to be sent before performing action (optionnal),
Action: Action key to be pressed when the user clicks on the button (action key corresponding to found keyword).

Notes:

• A new keyword can be added to the list using the blue keyboard icon. The keywords defined in the list can be ordered using the arrow up and arrow down buttons, or deleted using the red cross icon.
• The order of the keywords defined in this table is very important, it is used for detection priority. That means if two keywords can match on a block, only the first keyword from this table will be handled for this block.
Label location int configuration Defines where to search for the label.
The label location value can be one of the following:

From right block: the label is to the right of the keyword. For example: F12=Open
From left block: the label is to the left of the keyword. For example: Open=F12
From block above: the label is on top of the keyword. For example: DO This F12
From block below: the label is below the keyword. For example: F12 Do This
Mashup event String configuration Defines mashup events dispatched on click.
Mashup events can be of two types:

• Calling directly a transaction or a sequence in Convertigo,
• Launching an event in Mashup Composer.

Mashup event property allows to define a combination of one direct call to a Convertigo transaction or sequence and/or one launch of Mashup Composer event. Filling this property adds a mashup_event attribute to the block, containing the previous combination in a JSON syntax of one of the following formats:

{"requestable":{"__transaction":"<transaction name>","__connector":"<connector name>"}} for a transaction call only,
{"requestable":{"__sequence":"<sequence name>"}} for a sequence call only,
{"event":"<event name>"} for a mashup event only,
{"requestable":{"__transaction":"<transaction name>","__connector":"<connector name>"},"event":"<event name>"} for a transaction call and a mashup event,
{"requestable":{"__sequence":"<sequence name>"},"event":"<event name>"} for a sequence call and a mashup event.

This mashup_event attribute and its content have to be handled by the XSL file applying at the end of the transaction to generate a real Convertigo call and/or Mashup Composer event on click on the displayed object.
Separator mandatory boolean configuration Defines whether a separator character between keyword and label is mandatory.
If set to true, a block containing a keyword (defined in Keywords table property) but which doesn’t have one of the separator characters (defined in Keyword separators property) next to it will not match the rule.
Attributes int selection Defines the presentation attributes on which the rule applies, i.e. the rule applies on blocks matching these presentation attributes.
This property allows to configure the rule so that it applies only to parts of screens having specific attributes, for example green text on black background.
Presentation attributes to configure are :

Color: Foreground color, Background color, to choose in a list of predefined colors or “not to take into account”.
Decoration: bold, reverse, underlined, blink, for each decoration choose between “with the decoration”, “normal” (i.e. without the decoration), or “not to take into account”.
Screen zone XMLRectangle selection Defines the screen zone on which the rule applies, i.e. the rule applies on blocks completely contained in this screen area.
This property allows to configure the rule so that it applies only to areas of screens. All blocks found within the specified perimeter are matching this screen zone and can be processed by the rule.
The screen area is defined through four coordinates:

• x (area left corner),
• y (area upper corner),
• w (area width),
• h (area height).

All values are given in characters, with the upper left corner being (x=0, y=0).
-1 represents an undefined value: (x=-1, y=-1, w=-1, h=-1) is an undefined area representing the whole screen, i.e. all blocks, whatever their coordinates, are matching this screen zone and can be processed by the rule.
Type String selection Defines, using a regular expression, to which block types the rule applies.
For example, if set to:

static, the rule applies to blocks of static type only.
static | field, the rule applies to blocks of static or field type only.
[^field], the rule applies to all but field type blocks.

Notes:

• For more information about regular expression patterns, see the following page: http://www.regular-expressions.info/reference.html.
• To test regular expressions, you can use the regular expression tester at the following URL: http://www.regular-expressions.info/javascriptexample.html.