The keyboard shortcut handler component uses the Javascript library Mousetrap (https://github.com/ccampbell/mousetrap).
To use the keyboard shortcuts handling, the following JavaScript resources must be included in the header of the used HTML template where all the other JavaScript libraries are defined (e.g. templates/Root.html):
mousetrap.min.js
Third-party library which provide the functionality for the shortcuts handling.
shortcuts.js
Library which binds the shortcuts functionality to the JAXFront Visualizer components.
<script language="JavaScript" src="js/jquery/plugins/mousetrap.min.js" type="text/javascript"></script> <script language="JavaScript" src="js/jquery/plugins/shortcuts.js" type="text/javascript"></script> |
If the configuration is loaded properly, the registered shortcuts will be visible on the tooltip informations of the concerned actions (if a link is provided within the visualizer component)
The following configurations are possible:
To enable the keyboard shortcuts handling, the shortcuts must be registered in the main HTML template with the function:
initShortcuts(shortcutHolderClass, bindingConf, searchGlobal); |
String which holds the class defining the starting point of an element for searching the shortcuts actions. (e.g. for lists the class is "jax-list-holder-div")
For the mapping of the shortcut keys, each shortcut can be paired with an html element id which holds the action called by the fired shortcut.
{"newLI":"alt+n", "cpLI":"alt+k", "delLI":"alt+r", "selPrevLI":"alt+up"} |
Boolean parameter which indicates if the focused field is not within the shortcutHolderClass, the shortcuts should be searched document wide instead.
If no searchGlobal param is passed, it's default value "true" is taken in place.
To enable the keyboard shortcuts handling for a list component the shortcuts could be registered with a list related constructor, which must be registered in the main HTML template:
registerListShortcuts(simplifiedConf, searchGlobalList); |
JSON-String for mapping each list function to a corresponding key. ("function" : "key kombination")
{"new":"alt+n", "copy":"alt+k", "delete":"alt+r", "moveUp":"alt+u", "moveDown":"alt+i", "selectPrevious":"alt+up", "selectNext":"alt+down"} |
Available id's are:
id | description | default shortcut |
---|---|---|
new | Add a new list entry | alt + ctrl + n |
copy | Copy the selected list entry | alt + ctrl + c |
delete | Delete the selected list entry | alt + ctrl + d |
moveUp | Move the selected list entry up | alt + ctrl + up |
moveDown | Move the selected list entry down | alt + ctrl + down |
selectPrevious | Selects the previous list entry | ctrl + up |
selectNext | Selects the next list entry | ctrl + down |
If no simplifiedConf param is passed, the defined default value is taken in place!
Boolean parameter which indicates if the focus is not within a list, the first list in the view should be applied if available instead.
If no searchGlobalList param is passed, it's default value "true" is taken in place.
To simplify the configuration of the shortcuts, the system variable shortcutConfig can be used within the javascript call.
registerListShortcuts('${shortcutConfig}', true); |
The variable shortcutConfig can be configured with the following options:
The shortcuts should be defined as combination like "alt+n", with the plus as seperator.
The following keys are available.
All other keys can be referenced by name like a, 3, /, $ ...