diff options
author | Jo-Philipp Wich <jo@mein.io> | 2020-03-31 21:29:28 +0200 |
---|---|---|
committer | Jo-Philipp Wich <jo@mein.io> | 2020-03-31 21:31:04 +0200 |
commit | 4250f99d7f061e47d24e18db26bf6dffc98cc72e (patch) | |
tree | 1939d0243e822acc7f6527e1c8af6ea915392e49 /modules/luci-base/htdocs | |
parent | 1bb27177296cbfc4ad4a07dc59edf31fb8f92c7a (diff) |
luci-base: ui.js: add generic indicator handling functions
Signed-off-by: Jo-Philipp Wich <jo@mein.io>
Diffstat (limited to 'modules/luci-base/htdocs')
-rw-r--r-- | modules/luci-base/htdocs/luci-static/resources/ui.js | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/modules/luci-base/htdocs/luci-static/resources/ui.js b/modules/luci-base/htdocs/luci-static/resources/ui.js index 91c62ca314..acc37008d1 100644 --- a/modules/luci-base/htdocs/luci-static/resources/ui.js +++ b/modules/luci-base/htdocs/luci-static/resources/ui.js @@ -3140,6 +3140,88 @@ return L.Class.extend(/** @lends LuCI.ui.prototype */ { }, /** + * Display or update an header area indicator. + * + * An indicator is a small label displayed in the header area of the screen + * providing few amounts of status information such as item counts or state + * toggle indicators. + * + * Multiple indicators may be shown at the same time and indicator labels + * may be made clickable to display extended information or to initiate + * further actions. + * + * Indicators can either use a default `active` or a less accented `inactive` + * style which is useful for indicators representing state toggles. + * + * @param {string} id + * The ID of the indicator. If an indicator with the given ID already exists, + * it is updated with the given label and style. + * + * @param {string} label + * The text to display in the indicator label. + * + * @param {function} [handler] + * A handler function to invoke when the indicator label is clicked/touched + * by the user. If omitted, the indicator is not clickable/touchable. + * + * Note that this parameter only applies to new indicators, when updating + * existing labels it is ignored. + * + * @param {string} [style=active] + * The indicator style to use. May be either `active` or `inactive`. + * + * @returns {boolean} + * Returns `true` when the indicator has been updated or `false` when no + * changes were made. + */ + showIndicator: function(id, label, handler, style) { + if (indicatorDiv == null) { + indicatorDiv = document.body.querySelector('#indicators'); + + if (indicatorDiv == null) + return false; + } + + var handlerFn = (typeof(handler) == 'function') ? handler : null, + indicatorElem = indicatorDiv.querySelector('span[data-indicator="%s"]'.format(id)) || + indicatorDiv.appendChild(E('span', { + 'data-indicator': id, + 'data-clickable': handlerFn ? true : null, + 'click': handlerFn + }, [''])); + + if (label == indicatorElem.firstChild.data && style == indicatorElem.getAttribute('data-style')) + return false; + + indicatorElem.firstChild.data = label; + indicatorElem.setAttribute('data-style', (style == 'inactive') ? 'inactive' : 'active'); + return true; + }, + + /** + * Remove an header area indicator. + * + * This function removes the given indicator label from the header indicator + * area. When the given indicator is not found, this function does nothing. + * + * @param {string} id + * The ID of the indicator to remove. + * + * @returns {boolean} + * Returns `true` when the indicator has been removed or `false` when the + * requested indicator was not found. + */ + hideIndicator: function(id) { + var indicatorElem = indicatorDiv ? indicatorDiv.querySelector('span[data-indicator="%s"]'.format(id)) : null; + + if (indicatorElem == null) + return false; + + indicatorDiv.removeChild(indicatorElem); + return true; + }, + + /** * Formats a series of label/value pairs into list-like markup. * * This function transforms a flat array of alternating label and value |