Knowledge Console UI Hooks

The Knowledge Console supports declarative framework to define hooks in JSON format to add the following capabilities:

  • Add a custom button in the user options menu in the top toolbar.
  • Add a custom button in the article toolbar or the article options menu.
  • Hide default buttons from the user interface.
  • Modify CKEditor configuration (without adding extra plugins).

Add Top Toolbar Buttons

Use the topToolbarButtons() hook to include custom buttons in the user options menu. The object is an array of buttons. The structure for the button data is described in the following section:

Object
  • name : Name of the custom toolbar button.
    • Required : Yes
  • l10n_name : Localized name of the custom toolbar button. It is a key-value pair.
    • Available language keys:
      • en-us, de-de-, es-es, fr-ca, fr-fr, it-it, ja-jp, ko-kr, nl-nl, pt-br, pt-pt, zh-cn, ru-ru, pl-pl, cs-cz, da-da, sv-sv
    • value : One of the above
  • url : URL to invoke. Users can also pass parameters such as userId and refurl in the URL. See an example for more details.
    • Required : Yes
    • value : userId , refURL
  • urlParams : Additional parameters to be passed along with the URL.
    • accessorType: Access to an object
      • value : sessionStorage , localStorage , user , userGroups , url
    • accessor: The object key whose value is to be set
      • value : name , id , etc.
    • accessorParser
      • value : int , json , date
    • accessorPath: Path for JSON if accessorParser is in JSON format
    • key: URL param name
  • mode : Open as a modal or in a new window. Defaults to window
    • value : iframe , window
  • icon : Image URL or Base64
  • conditions : If not provided, the button is always shown.
    • accessorType: Access to an object
      • value : sessionStorage , localStorage , user , userGroups , url
    • accessor: The object key whose value it is to be compared. This key is used to look inside accessorType and can be a JSON path. For userGroups use name or id only.
    • accessorParser
    • accessorPath: Path for JSON if accessorParser is JSON
    • value: Value to be compared, or an object for fetching value.
      • valueType
        • value : localStorage or sessionStorage
      • valueAccessor: Key to be used to fetch value from localStorage or sessionStorage
      • valueParser
        • value : int , json , date
      • valuePath: Path for JSON if valueParser is JSON.
    • operator: Comparison operator. contains() and notcontains() only work if accessed value is type string. For values of array type and user group, has() and nothas() should be used.
    • boolean: Boolean operator
      • value : and , or
    • conditions: Nested condition object
Copy
Copied
Example:
{
    "topToolbarButtons": [
        {
            "name": "Top Button egain",
            "_comment_name": "// TODO need to think about l10n",
            "l10n_name": {
                "en-us": "Top English name",
                "de-de": "De  name",
                "es-es": "es name",
                "fr-ca": "fr name",
                "fr-fr": "fr fr name",
                "it-it": "it name",
                "ja-jp": "ja name",
                "ko-kr": "ko name",
                "nl-nl": "nl name",
                "pt-br": "pt name",
                "pt-pt": "pt pt name",
                "zh-cn": "zh name",
                "ru-ru": "ru name",
                "pl-pl": "pl name",
                "cs-cz": "cs name",
                "da-da": "da name",
                "sv-sv": "sv name"
            },
            "_comment_icon": "<some image url>",
            "url": "https://ussuhvvm0048.egdemo.info/duo.html?a={userId}",
            "mode": "window",
            "_comment_mode": "iframe, window",
            "icon": "",
            "hide": false
        }
    ]
}

Add Custom Article Buttons

Use the customArticleButtons() hook to include custom buttons in the article toolbar or in the article options menu.

Object Attributes
  • name : Name of the custom article button
    • Required : Yes
  • l10n_name : Localized name of the custom toolbar button. It is a key-value pair.
    • Available language keys:
      • en-us, de-de, es-es, fr-ca, fr-fr, it-it, ja-jp, ko-kr, nl-nl, pt-br, pt-pt, zh-cn, ru-ru, pl-pl, cs-cz, da-da, sv-sv
  • position : Display in the article toolbar or in the articles options menu
    • Required : Yes
    • value : toolbar , more
  • url : URL to invoke, passes the user or article parameters.
    • Required : Yes
    • value : usrId , articleId , versionId , lastModified , refURL
  • urlParams : Additional parameters to be passed with the URL
    • accessorType: Access to an object
      • value : sessionStorage , localStorage , article , user , userGroups , url
    • accessor: The object key whose value is to be set
      • value : name , id , defaultKbLanguage , lastModified.date , etc.
    • accessorParser
      • value : int , json , date
    • accessorPath: Path for JSON if accessorParser is JSON
    • key: URL param name
  • mode : Open as a modal or in a new window
    • Required : Yes
    • value : iframe , window
  • title : Title of the modal window
  • l10_title : Localized title of the modal window. It is a key-value pair.
    • Available language keys:
      • en-us, de-de, es-es, fr-ca, fr-fr, it-it, ja-jp, ko-kr, nl-nl, pt-br, pt-pt, zh-cn, ru-ru, pl-pl, cs-cz, da-da, sv-sv
  • icon : Image URL or Base64
  • conditions
    • accessorType: Access to an object
      • value : sessionStorage , localStorage , article , user , userGroups , url
    • accessor: The object key whose value is to be compared. This key is used to look inside accessorType . It can be a JSON path. For userGroups , use name or id only.
    • accessorParser
      • value : int , json , date
    • accessorPath: Path for JSON if accessorParser is JSON
    • value: Value to be compared, or an object for fetching value.
      • valueType
        • value : localStorage or sessionStorage
      • valueAccessor: Key to be used to fetch value from localStorage or sessionStorage
      • valueParser
        • value : int , json , date
      • valuePath: Path for JSON if valueParser is JSON
    • operator: Comparison operator. contains and notcontains only work if accessed value is a string. For values of array type and user group, has and nothas should be used.
      • value : equal , notequal , gt , gte , lt , lte , contains , notcontains , has , nothas
    • boolean: Boolean operator
      • value : and , or
    • conditions: Nested condition object
Copy
Copied
Example:
{
    "customArticleButtons": [
        {
            "name": "Custom egain",
            "l10n_name": {
                "en-us": "English name",
                "de-de": "De  name",
                "es-es": "es name",
                "fr-ca": "fr name",
                "fr-fr": "fr fr name",
                "it-it": "it name",
                "ja-jp": "ja name",
                "ko-kr": "ko name",
                "nl-nl": "nl name",
                "pt-br": "pt name",
                "pt-pt": "pt pt name",
                "zh-cn": "zh name",
                "ru-ru": "ru name",
                "pl-pl": "pl name",
                "cs-cz": "cs name",
                "da-da": "da name",
                "sv-sv": "sv name"
            },
            "title": "Modal title",
            "l10n_title": {
                "en-us": "English modal title"
            },
            "icon": "",
            "url": "https://ussuhvvm0048.egdemo.info/duo.html?a={articleId}&b={userId}&c={versionId}&d={lastModified}",
            "mode": "iframe",
            "_comment_mode": "iframe, window",
            "position": "toolbar",
            "_comment_position": "more, toolbar",
            "hide": false,
            "conditions": [
                {
                    "accessor": "versions.version[0].articleState",
                    "operator": "equal",
                    "_comment_operator": "equal, notequal, gt, gte, lt, lte",
                    "value": "published",
                    "boolean": "or"
                },
                {
                    "conditions": [
                        {
                            "accessor": "versions.version[0].articleState",
                            "operator": "equal",
                            "value": "transient",
                            "boolean": "and"
                        },
                        {
                            "accessor": "versions.version[0].lockedBy",
                            "operator": "notequal",
                            "value": null,
                            "boolean": "and"
                        }
                    ],
                    "boolean": "or"
                }
            ]
        },
        {
            "name": "Custom egain2",
            "_comment_name": "// TODO need to think about l10n",
            "l10n_name": {
                "en-us": "English name more",
                "de-de": "De  name",
                "es-es": "es name",
                "fr-ca": "fr name",
                "fr-fr": "fr fr name",
                "it-it": "it name",
                "ja-jp": "ja name",
                "ko-kr": "ko name",
                "nl-nl": "nl name",
                "pt-br": "pt name",
                "pt-pt": "pt pt name",
                "zh-cn": "zh name",
                "ru-ru": "ru name",
                "pl-pl": "pl name",
                "cs-cz": "cs name",
                "da-da": "da name",
                "sv-sv": "sv name"
            },
            "_comment_icon": "<some image url>",
            "url": "https://ussuhvvm0048.egdemo.info/duo.html?a={articleId}&b={userId}&c={versionId}&d={lastModified}",
            "mode": "window",
            "_comment_mode": "iframe, window",
            "position": "more",
            "_comment_position": "more, toolbar",
            "hide": false,
            "conditions": [
                {
                    "accessor": "versions.version[0].articleState",
                    "operator": "equal",
                    "_comment_operator": "equal, notequal, gt, gte, lt, lte",
                    "value": "published",
                    "boolean": "or"
                },
                {
                    "conditions": [
                        {
                            "accessor": "versions.version[0].articleState",
                            "operator": "equal",
                            "value": "transient",
                            "boolean": "and"
                        },
                        {
                            "accessor": "versions.version[0].lockedBy",
                            "operator": "notequal",
                            "value": null,
                            "boolean": "and"
                        }
                    ],
                    "boolean": "or"
                }
            ]
        }
    ]
}

Hide Default Article Buttons

Use the hideOOBArticleButtons() hook to hide default article buttons from the article toolbar or from the article options menu.

Object Attributes
  • buttonName : Name of the default article button
    • Required : yes
    • value : publishDropDown , sendTo , checkOut , checkIn , close , publish
  • conditions : If empty, the button is hidden. If evaluated as true, the button is hidden.
    • accessorType: Access to an object
      • value : sessionStorage , localStorage , article , user , userGroups , url
    • accessor: The object key whose value is to be compared. This key is used to look inside accessorType . It can be a JSON path. For userGroups, use name or id only.
    • accessorParser
      • value : int , json , date
    • value: Value to be compared, or an object for fetching value
      • valueType
        • value : localStorage or sessionStorage
      • valueAccessor: Key to be used to fetch value from localStorage or sessionStorage
      • valueParser
        • value : int , json , date
      • valuePath: Path for JSON if valueParser is JSON
    • operator: Comparison operator. contains and notcontains only work if accessed value is a string. For values of array type and user group, has and nothas should be used.
      • value : equal , notequal , gt , gte , lt , lte , contains , notcontains , has , nothas
    • boolean: Boolean operator
      • value : and , or
    • conditions: Nested condition object
Copy
Copied
Example:
{
    "hideOOBArticleButtons": [
        {
            "buttonName": "testButton",
            "_comment_buttonName": "publishDropDown, sendTo, checkOut, checkIn, close, publish",
            "conditions": [
                {
                    "accessor": "versions.version[0].articleState",
                    "operator": "equal",
                    "_comment_operator": "equal, notequal, gt, gte, lt, lte",
                    "value": "published",
                    "boolean": "or"
                },
                {
                    "conditions": [
                        {
                            "accessor": "versions.version[0].articleState",
                            "operator": "equal",
                            "value": "transient",
                            "boolean": "and"
                        },
                        {
                            "accessor": "versions.version[0].lockedBy",
                            "operator": "notequal",
                            "value": null,
                            "boolean": "and"
                        }
                    ],
                    "boolean": "or"
                }
            ]
        }
    ]
}

Modify CKEditor Configuration

Use the ckeditor4Config() hook to define CKEditor configuration. It follows the CKEditor config structure. Additionally, use ckeditor4ExtraPlugin() to define the path of extra plugins that need to be loaded. This is an array of objects defined by the following structure:

Object Attributes
  • name: Name of plugin
  • path: URL of plugin, usually the path to the plugin file.
Copy
Copied
Example:
{
    "ckeditorConfig": {
        "toolbar": {
            "items": [
            "sourceEditing"
            ]
        }
    }
}