abapGit/docs/collections/_development/developing-ui-js.md
Alexander Tsybulsky 739b14ab6a Command palette: Git actions (#2908)
* enumerateToolbarActions

* command prefix

* docs
2019-09-09 21:34:30 -07:00

2.1 KiB

title order
UI - Java script 93

This doc covers java script specifics in abapGit UI. See also the UI - HTML pages.

General

abapGit UI contains JS code. Some of dynamic features relate on it e.g. keyboard navigation. The JS code is located in ui/zabapgit_js_common.w3mi.data.js - the recommended way to modify it described in "Recommended asset development flow" section of UI - CSS and assets.

As SAP GUI uses Internet Explorer component to render HTML the JS code must be optimized for IE11 (and use the features available in it). Although some polyfills are available (and more can be added) at the beginning of the code (like String.includes).

The pull request CI check includes a run of eslint, so new code should confirm to the rules defined for the abapGit repository.

Components

The JS library contains several components which can be reused in different places.

Command Palette

To add a command palette add the following code in the script method of the page.

ro_html->add( 'var gCommandPalette = new CommandPalette(enumerateFn, {' ).
ro_html->add( '  toggleKey: "F1",' ).
ro_html->add( '  hotkeyDescription: "Command ..."' ).
ro_html->add( '});' ).

where:

  • enumerateFn is a function that returns list of commands in the form of array of
{
    action:    "go_home",        // sapevent action or js function
    iconClass: "icon icon-star", // class for item icon, OPTIONAL !!!
    title:     "Go home"         // title of the command
}
  • toggleKey is a key to toggle the palette. "^" at the beginning requires Ctrl ("^g" = Ctrl+g )
  • hotkeyDescription is the description which is a) added to the shortkey help popup b) used as placeholder in the command palette

See example of enumerators - enumerateToolbarActions and enumerateTocAllRepos.

to do

  • debugOutput
  • submitSapeventForm
  • setInitialFocus
  • setInitialFocusWithQuerySelector
  • submitFormById
  • findStyleSheetByName
  • getIndocStyleSheet
  • toggleDisplay
  • Hotkeys.addHotkeyToHelpSheet
  • ...