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
-
Available language keys:
-
url
: URL to invoke. Users can also pass parameters such as
userId
andrefurl
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
-
value
:
-
accessor: The object key whose value is to be set
-
value
:
name
,id
, etc.
-
value
:
-
accessorParser
-
value
:
int
,json
,date
-
value
:
-
accessorPath: Path for JSON if
accessorParser
is in JSON format - key: URL param name
-
accessorType: Access to an object
-
mode
: Open as a modal or in a new window. Defaults to window
-
value
:
iframe
,window
-
value
:
- 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
-
value
:
-
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. ForuserGroups
usename
orid
only. - accessorParser
-
accessorPath: Path for JSON if
accessorParser
is JSON -
value: Value to be compared, or an object for fetching value.
-
valueType
-
value
:
localStorage
orsessionStorage
-
value
:
-
valueAccessor: Key to be used to fetch value from
localStorage
orsessionStorage
-
valueParser
-
value
:
int
,json
,date
-
value
:
-
valuePath: Path for JSON if
valueParser
is JSON.
-
valueType
- 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
-
value
:
- conditions: Nested condition object
-
accessorType: Access to an object
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
-
Available language keys:
-
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
-
value
:
-
accessor: The object key whose value is to be set
-
value
:
name
,id
,defaultKbLanguage
,lastModified.date
, etc.
-
value
:
-
accessorParser
-
value
:
int
,json
,date
-
value
:
- accessorPath: Path for JSON if accessorParser is JSON
- key: URL param name
-
accessorType: Access to an object
-
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
-
Available language keys:
- icon : Image URL or Base64
-
conditions
-
accessorType: Access to an object
-
value
:
sessionStorage
,localStorage
,article
,user
,userGroups
,url
-
value
:
-
accessor: The object key whose value is to be compared. This key is used to look inside
accessorType
. It can be a JSON path. ForuserGroups
, usename
orid
only. -
accessorParser
-
value
:
int
,json
,date
-
value
:
- accessorPath: Path for JSON if accessorParser is JSON
-
value: Value to be compared, or an object for fetching value.
-
valueType
-
value
:
localStorage
orsessionStorage
-
value
:
-
valueAccessor: Key to be used to fetch value from
localStorage
orsessionStorage
-
valueParser
-
value
:
int
,json
,date
-
value
:
- valuePath: Path for JSON if valueParser is JSON
-
valueType
-
operator: Comparison operator.
contains
andnotcontains
only work if accessed value is a string. For values of array type and user group,has
andnothas
should be used.-
value
:
equal
,notequal
,gt
,gte
,lt
,lte
,contains
,notcontains
,has
,nothas
-
value
:
-
boolean: Boolean operator
-
value
:
and
,or
-
value
:
- conditions: Nested condition object
-
accessorType: Access to an object
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
-
value
:
-
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, usename
orid
only. -
accessorParser
-
value
:
int
,json
,date
-
value
:
-
value: Value to be compared, or an object for fetching value
-
valueType
-
value
:
localStorage
orsessionStorage
-
value
:
- valueAccessor: Key to be used to fetch value from localStorage or sessionStorage
-
valueParser
-
value
:
int
,json
,date
-
value
:
- valuePath: Path for JSON if valueParser is JSON
-
valueType
-
operator: Comparison operator.
contains
andnotcontains
only work if accessed value is a string. For values of array type and user group,has
andnothas
should be used.-
value
:
equal
,notequal
,gt
,gte
,lt
,lte
,contains
,notcontains
,has
,nothas
-
value
:
-
boolean: Boolean operator
-
value
:
and
,or
-
value
:
- conditions: Nested condition object
-
accessorType: Access to an object
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.
Example:
{
"ckeditorConfig": {
"toolbar": {
"items": [
"sourceEditing"
]
}
}
}