diff --git a/dist/CHANGELOG.md b/dist/CHANGELOG.md deleted file mode 100644 index e773453..0000000 --- a/dist/CHANGELOG.md +++ /dev/null @@ -1,11 +0,0 @@ -| Version | Changes | -| --------|------------------------------------------------------------| -| 0.1.0 | **First version for release** | -| 0.0.4 | Base theme option | -| | Bug fixes (#4) | -| 0.0.3 | Schema changes (BREAKING) | -| | Option to switch between default dark,light themes | -| | BG Image as theme option | -| | Bug fixes | -| 0.0.2 | Multiple Themes, Theme picker | -| 0.0.1 | Base version | \ No newline at end of file diff --git a/dist/README.md b/dist/README.md deleted file mode 100644 index e039b33..0000000 --- a/dist/README.md +++ /dev/null @@ -1,54 +0,0 @@ -# Boom Theme Panel - -Theme switcher with custom styles / themes for grafana dashboards. - -![image](https://user-images.githubusercontent.com/153843/57070256-ba874200-6cce-11e9-85f5-e0a036eb306b.png) - -![image](https://user-images.githubusercontent.com/153843/57070201-99265600-6cce-11e9-9a9c-734121df7cb8.png) - -# Features - -- Theme switcher -- Multiple themes per dashboard -- Theme builder -- External stylesheets support -- Add inline styles to themes to override styles -- Add many themes as possible without rebuilding / restarting grafana -- Users with view only option can also pick their favourite theme -- Themes applicable to current dashboard only - -# Creating Theme - -Themes can be created with multiple building blocks like background image, base theme etc. - -| Property | Description | -| --------------------------- | -------------------------------------------------------------------------------------------------------- | -| Base theme | Themes can be built on top of default/dark/light theme. Default is **Default Theme** | -| Background image | Optional property. Can be blank. If specified more than once, last wins. Value should be valid image URL | -| CSS url | External theme file. Should be valid CSS file URL | -| Custom Style / CSS Override | CSS Styles. Should be valid css | - -# Supported Grafana version - -This grafana plugin is tested with the grafna versions 6.x. But other versions are also expected to work. - -# Work in progress - -* Time based automatic theme switch - Automatically switch dark themes during night hours. -* Color palette based themes - Pick your own background/foregroud colors -* Font size adjuster - Viewers will be able to adjust their dashboard font sizes - -# Notes - -- When adding external stylesheets, make sure CORS enabled for those domains. -- To make panel invisible : Modify following theme panel settings: - - transparent = true - - title = "" - - Disable Theme Picker using panel settings - - Move this panel to the bottom of the dashboard - - Adjust the height and width if required. -- This plugin is in very much WIP / dev stage. Expect breaking changes & bugs. - -# Known issues - -- If any custom plugin is used, dark/light theme switch, base theme will not work for those custom plugins. Refer [this](https://github.com/yesoreyeram/yesoreyeram-boomtheme-panel/issues/3) github issue diff --git a/dist/module.js b/dist/module.js deleted file mode 100644 index bc3aafb..0000000 --- a/dist/module.js +++ /dev/null @@ -1,295 +0,0 @@ -System.register(["lodash", "app/plugins/sdk"], function (exports_1, context_1) { - "use strict"; - var __extends = (this && this.__extends) || (function () { - var extendStatics = function (d, b) { - extendStatics = Object.setPrototypeOf || - ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) || - function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; }; - return extendStatics(d, b); - }; - return function (d, b) { - extendStatics(d, b); - function __() { this.constructor = d; } - d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __()); - }; - })(); - var lodash_1, sdk_1, CONFIG, BoomThemeStyle, BoomTheme, BoomThemeCtl, getThemeCSSFile; - var __moduleName = context_1 && context_1.id; - return { - setters: [ - function (lodash_1_1) { - lodash_1 = lodash_1_1; - }, - function (sdk_1_1) { - sdk_1 = sdk_1_1; - } - ], - execute: function () { - CONFIG = { - BASE_THEMES: { - DARK: { - id: "dark", - index_id: -2000, - name: "Dark Theme" - }, - DEFAULT: { - id: "default", - index_id: -1000, - name: "Default Theme" - }, - LIGHT: { - id: "light", - index_id: -3000, - name: "Light Theme" - } - }, - DEFAULT_THEME_BG_IMAGE: "https://images.unsplash.com/photo-1524334228333-0f6db392f8a1", - DEFAULT_THEME_NAME: "New Theme", - DEFAULT_THEME_STYLE: ".panel-container {\n background-color: rgba(0,0,0,0.3);\n}", - FIRST_THEME_NAME: "Night Theme", - THEME_STYLES: { - BASE_THEME: "basetheme", - BG_IMAGE: "bgimage", - NONE: "none", - STYLE: "style", - URL: "url", - } - }; - BoomThemeStyle = (function () { - function BoomThemeStyle(type, props) { - switch (type.toLowerCase()) { - case CONFIG.THEME_STYLES.BASE_THEME: - this.type = CONFIG.THEME_STYLES.BASE_THEME; - this.props = { - theme: props && props.theme ? props.theme : "" - }; - break; - case CONFIG.THEME_STYLES.STYLE: - this.type = CONFIG.THEME_STYLES.STYLE; - this.props = { - text: props && props.text ? props.text : "" - }; - break; - case CONFIG.THEME_STYLES.URL: - this.type = CONFIG.THEME_STYLES.URL; - this.props = { - url: props && props.url ? props.url : "" - }; - break; - case CONFIG.THEME_STYLES.BG_IMAGE: - this.type = CONFIG.THEME_STYLES.BG_IMAGE; - this.props = { - url: props && props.url ? props.url : "" - }; - break; - default: - this.type = CONFIG.THEME_STYLES.NONE; - this.props = {}; - break; - } - } - return BoomThemeStyle; - }()); - BoomTheme = (function () { - function BoomTheme(options) { - this.name = options.name || CONFIG.DEFAULT_THEME_NAME; - this.styles = options.styles || [ - new BoomThemeStyle(CONFIG.THEME_STYLES.BASE_THEME, { theme: CONFIG.BASE_THEMES.DEFAULT.id }), - new BoomThemeStyle(CONFIG.THEME_STYLES.BG_IMAGE, { url: "" }), - new BoomThemeStyle(CONFIG.THEME_STYLES.URL, { url: "" }), - new BoomThemeStyle(CONFIG.THEME_STYLES.STYLE, { text: "" }), - ]; - } - BoomTheme.prototype.addStyle = function (type) { - this.styles.push(new BoomThemeStyle(type, {})); - }; - BoomTheme.prototype.deleteStyle = function (index) { - this.styles.splice(index, 1); - }; - BoomTheme.prototype.constructTheme = function (styles) { - var output = ""; - lodash_1.default.each(styles, function (style) { - if (style.type === CONFIG.THEME_STYLES.URL) { - if (style.props && style.props.url !== "") { - output += "@import url('" + style.props.url + "');\n "; - } - } - else if (style.type === CONFIG.THEME_STYLES.BASE_THEME) { - if (style.props && style.props.theme !== "") { - if (style.props.theme.toLowerCase() === CONFIG.BASE_THEMES.DARK.id) { - output += "@import url('" + getThemeCSSFile(CONFIG.BASE_THEMES.DARK.id) + "');\n "; - } - else if (style.props.theme.toLowerCase() === CONFIG.BASE_THEMES.LIGHT.id) { - output += "@import url('" + getThemeCSSFile(CONFIG.BASE_THEMES.LIGHT.id) + "');\n "; - } - } - } - else if (style.type === CONFIG.THEME_STYLES.STYLE) { - if (style.props && style.props.text !== "") { - output += (style.props.text || '') + "\n "; - } - } - else if (style.type === CONFIG.THEME_STYLES.BG_IMAGE) { - if (style.props && style.props.url !== "") { - output += "\n.main-view, .sidemenu, .sidemenu-open .sidemenu, .navbar, .dashboard-container {\n background: url(\"" + style.props.url + "\")\n no-repeat center center fixed;\n -webkit-background-size: cover;\n -moz-background-size: cover;\n -o-background-size: cover;\n background-size: cover;\n}\n "; - } - } - }); - return output; - }; - BoomTheme.prototype.getThemeContent = function () { - var output = ''; - if (this.styles && this.styles.length > 0) { - output += this.constructTheme(this.styles.filter(function (style) { return style.type === CONFIG.THEME_STYLES.URL; })); - output += this.constructTheme(this.styles.filter(function (style) { return style.type === CONFIG.THEME_STYLES.STYLE; })); - output += this.constructTheme(this.styles.filter(function (style) { return style.type !== CONFIG.THEME_STYLES.URL && style.type !== CONFIG.THEME_STYLES.STYLE; })); - } - return output; - }; - return BoomTheme; - }()); - BoomThemeCtl = (function (_super) { - __extends(BoomThemeCtl, _super); - function BoomThemeCtl($scope, $injector) { - var _this = _super.call(this, $scope, $injector) || this; - _this.base_theme_options = [CONFIG.BASE_THEMES.DEFAULT, CONFIG.BASE_THEMES.DARK, CONFIG.BASE_THEMES.LIGHT].map(function (theme) { - return { - text: theme.name, - value: theme.id - }; - }); - lodash_1.default.defaults(_this.panel, {}); - // Jaime modified at DATE20200326, for panel transparent always true issue, LINE - // _this.panel.transparent = true; - _this.panel.themes = _this.panel.themes || [ - new BoomTheme({ - name: CONFIG.FIRST_THEME_NAME, - styles: [ - new BoomThemeStyle(CONFIG.THEME_STYLES.BASE_THEME, { theme: CONFIG.BASE_THEMES.DEFAULT.id }), - new BoomThemeStyle(CONFIG.THEME_STYLES.BG_IMAGE, { url: CONFIG.DEFAULT_THEME_BG_IMAGE }), - new BoomThemeStyle(CONFIG.THEME_STYLES.STYLE, { text: CONFIG.DEFAULT_THEME_STYLE }) - ] - }) - ]; - _this.panel.activeThemeId = _this.panel.activeThemeId || 0; - _this.activeEditorTabIndex = _this.panel.activeThemeId >= 0 ? _this.panel.activeThemeId : -1; - _this.runtimeThemeSet = false; - _this.runtimeThemeIndex = _this.panel.activeThemeId >= 0 ? _this.panel.activeThemeId : 0; - _this.updatePrototypes(); - _this.events.on("init-edit-mode", _this.onInitEditMode.bind(_this)); - return _this; - } - BoomThemeCtl.prototype.updatePrototypes = function () { - if (this.panel.themes && this.panel.themes.length > 0) { - this.panel.themes.map(function (theme) { - Object.setPrototypeOf(theme, BoomTheme.prototype); - if (theme.styles && theme.styles.length > 0) { - theme.styles.map(function (style) { - Object.setPrototypeOf(style, BoomThemeStyle.prototype); - }); - } - return theme; - }); - } - }; - BoomThemeCtl.prototype.onInitEditMode = function () { - this.addEditorTab("Theme", "public/plugins/yesoreyeram-boomtheme-panel/partials/options.html", 2); - }; - BoomThemeCtl.prototype.addTheme = function () { - this.panel.themes = this.panel.themes || []; - this.panel.themes.push(new BoomTheme({ - name: "Theme " + (this.panel.themes.length + 1) - })); - this.activeEditorTabIndex = this.panel.themes.length - 1; - this.runtimeThemeIndex = this.panel.themes.length - 1; - this.render(); - }; - BoomThemeCtl.prototype.deleteTheme = function (index) { - this.panel.themes.splice(index, 1); - if (this.panel.activeThemeId === index) { - this.panel.activeThemeId = 0; - } - if (this.runtimeThemeIndex === index) { - this.runtimeThemeIndex = 0; - } - if (this.activeEditorTabIndex === index) { - this.activeEditorTabIndex = this.ctrl.panel.themes.length - 1; - } - }; - BoomThemeCtl.prototype.setThemeAsDefault = function (index) { - this.ctrl.panel.activeThemeId = index; - this.runtimeThemeIndex = index; - this.render(); - }; - BoomThemeCtl.prototype.setruntimeThemeIndex = function (index) { - this.runtimeThemeSet = true; - this.runtimeThemeIndex = index; - this.render(); - }; - BoomThemeCtl.prototype.limitText = function (text, maxlength) { - if (text.split("").length > maxlength) { - text = text.substring(0, Number(maxlength) - 3) + "..."; - } - return text; - }; - BoomThemeCtl.prototype.link = function (scope, elem, attrs, ctrl) { - this.scope = scope; - this.elem = elem; - this.attrs = attrs; - this.ctrl = ctrl; - this.render(); - }; - BoomThemeCtl.templateUrl = "partials/module.html"; - return BoomThemeCtl; - }(sdk_1.PanelCtrl)); - exports_1("PanelCtrl", BoomThemeCtl); - getThemeCSSFile = function (mode) { - var filename = ''; - if (["dark", "light"].indexOf(mode.toLowerCase()) > -1 && window.performance) { - var appfiles = window.performance.getEntries().map(function (e) { return e.name; }).filter(function (e) { return e.endsWith(".js"); }).filter(function (e) { return e.indexOf("/public/build/app.") > -1; }); - if (appfiles && appfiles.length > 0) { - filename = appfiles[0].replace("/public/build/app.", "/public/build/grafana." + mode.toLowerCase() + ".").slice(0, -3) + ".css"; - } - } - return filename; - }; - BoomThemeCtl.prototype.render = function () { - var _this = this; - if (this.ctrl.panel.title === "Panel Title") { - this.ctrl.panel.title = ""; - } - if (this.ctrl.panel.gridPos && this.ctrl.panel.gridPos.x === 0 && this.ctrl.panel.gridPos.y === 0) { - this.ctrl.panel.gridPos.w = 24; - this.ctrl.panel.gridPos.h = 3; - } - var output = ''; - lodash_1.default.each(this.panel.themes, function (theme, index) { - if (_this.runtimeThemeSet === false) { - if (_this.panel.activeThemeId === index && _this.panel.activeThemeId >= 0) { - output += theme.getThemeContent(); - } - } - else { - if (_this.runtimeThemeIndex === index && _this.runtimeThemeIndex >= 0) { - output += theme.getThemeContent(); - } - } - }); - if (this.runtimeThemeSet === true) { - if (this.runtimeThemeIndex === CONFIG.BASE_THEMES.DARK.index_id) { - output += "@import url('" + getThemeCSSFile(CONFIG.BASE_THEMES.DARK.id) + "');\n "; - } - else if (this.runtimeThemeIndex === CONFIG.BASE_THEMES.LIGHT.index_id) { - output += "@import url('" + getThemeCSSFile(CONFIG.BASE_THEMES.LIGHT.id) + "');\n "; - } - } - var style = document.createElement('style'); - style.type = 'text/css'; - style.appendChild(document.createTextNode(output)); - this.elem.find("#boom-theme").html(""); - this.elem.find("#boom-theme").append(style); - }; - } - }; -}); -//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"module.js","sourceRoot":"","sources":["../src/module.ts"],"names":[],"mappings":"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","sourcesContent":["///<reference path=\"../node_modules/grafana-sdk-mocks/app/headers/common.d.ts\" />\r\n\r\nimport _ from \"lodash\";\r\nimport { PanelCtrl } from \"app/plugins/sdk\";\r\n\r\nconst CONFIG = {\r\n    BASE_THEMES: {\r\n        DARK: {\r\n            id: \"dark\",\r\n            index_id: -2000,\r\n            name: \"Dark Theme\"\r\n        },\r\n        DEFAULT: {\r\n            id: \"default\",\r\n            index_id: -1000,\r\n            name: \"Default Theme\"\r\n        },\r\n        LIGHT: {\r\n            id: \"light\",\r\n            index_id: -3000,\r\n            name: \"Light Theme\"\r\n        }\r\n    },\r\n    DEFAULT_THEME_BG_IMAGE: `https://images.unsplash.com/photo-1524334228333-0f6db392f8a1`, // Image Credits : https://unsplash.com/photos/fX-qWsXl5x8\r\n    DEFAULT_THEME_NAME: \"New Theme\",\r\n    DEFAULT_THEME_STYLE: `.panel-container {\r\n    background-color: rgba(0,0,0,0.3);\r\n}`,\r\n    FIRST_THEME_NAME: \"Night Theme\",\r\n    THEME_STYLES: {\r\n        BASE_THEME: \"basetheme\",\r\n        BG_IMAGE: \"bgimage\",\r\n        NONE: \"none\",\r\n        STYLE: \"style\",\r\n        URL: \"url\",\r\n    }\r\n};\r\n\r\nclass BoomThemeStyle {\r\n    public type: string;\r\n    public props: any;\r\n    constructor(type, props) {\r\n        switch (type.toLowerCase()) {\r\n            case CONFIG.THEME_STYLES.BASE_THEME:\r\n                this.type = CONFIG.THEME_STYLES.BASE_THEME;\r\n                this.props = {\r\n                    theme: props && props.theme ? props.theme : \"\"\r\n                };\r\n                break;\r\n            case CONFIG.THEME_STYLES.STYLE:\r\n                this.type = CONFIG.THEME_STYLES.STYLE;\r\n                this.props = {\r\n                    text: props && props.text ? props.text : \"\"\r\n                };\r\n                break;\r\n            case CONFIG.THEME_STYLES.URL:\r\n                this.type = CONFIG.THEME_STYLES.URL;\r\n                this.props = {\r\n                    url: props && props.url ? props.url : \"\"\r\n                };\r\n                break;\r\n            case CONFIG.THEME_STYLES.BG_IMAGE:\r\n                this.type = CONFIG.THEME_STYLES.BG_IMAGE;\r\n                this.props = {\r\n                    url: props && props.url ? props.url : \"\"\r\n                };\r\n                break;\r\n            default:\r\n                this.type = CONFIG.THEME_STYLES.NONE;\r\n                this.props = {};\r\n                break;\r\n\r\n        }\r\n    }\r\n}\r\n\r\nclass BoomTheme {\r\n    public name: string;\r\n    public styles: BoomThemeStyle[];\r\n    constructor(options) {\r\n        this.name = options.name || CONFIG.DEFAULT_THEME_NAME;\r\n        this.styles = options.styles || [\r\n            new BoomThemeStyle(CONFIG.THEME_STYLES.BASE_THEME, { theme: CONFIG.BASE_THEMES.DEFAULT.id }),\r\n            new BoomThemeStyle(CONFIG.THEME_STYLES.BG_IMAGE, { url: \"\" }),\r\n            new BoomThemeStyle(CONFIG.THEME_STYLES.URL, { url: \"\" }),\r\n            new BoomThemeStyle(CONFIG.THEME_STYLES.STYLE, { text: `` }),\r\n        ];\r\n    }\r\n    public addStyle(type: string): void {\r\n        this.styles.push(new BoomThemeStyle(type, {}));\r\n    }\r\n    public deleteStyle(index: number): void {\r\n        this.styles.splice(index, 1);\r\n    }\r\n    private constructTheme(styles: any[]): string {\r\n        let output = ``;\r\n        _.each(styles, style => {\r\n            if (style.type === CONFIG.THEME_STYLES.URL) {\r\n                if (style.props && style.props.url !== \"\") {\r\n                    output += `@import url('${style.props.url}');\r\n                    `;\r\n                }\r\n            } else if (style.type === CONFIG.THEME_STYLES.BASE_THEME) {\r\n                if (style.props && style.props.theme !== \"\") {\r\n                    if (style.props.theme.toLowerCase() === CONFIG.BASE_THEMES.DARK.id) {\r\n                        output += `@import url('${getThemeCSSFile(CONFIG.BASE_THEMES.DARK.id)}');\r\n                        `;\r\n\r\n                    } else if (style.props.theme.toLowerCase() === CONFIG.BASE_THEMES.LIGHT.id) {\r\n                        output += `@import url('${getThemeCSSFile(CONFIG.BASE_THEMES.LIGHT.id)}');\r\n                        `;\r\n                    }\r\n                }\r\n            } else if (style.type === CONFIG.THEME_STYLES.STYLE) {\r\n                if (style.props && style.props.text !== \"\") {\r\n                    output += `${style.props.text || ''}\r\n                    `;\r\n                }\r\n            } else if (style.type === CONFIG.THEME_STYLES.BG_IMAGE) {\r\n                if (style.props && style.props.url !== \"\") {\r\n                    output += `\r\n.main-view, .sidemenu, .sidemenu-open .sidemenu, .navbar, .dashboard-container {\r\n    background: url(\"${style.props.url}\")\r\n    no-repeat center center fixed;\r\n    -webkit-background-size: cover;\r\n    -moz-background-size: cover;\r\n    -o-background-size: cover;\r\n    background-size: cover;\r\n}\r\n                    `;\r\n                }\r\n            }\r\n        });\r\n        return output;\r\n    }\r\n    public getThemeContent(): string {\r\n        let output = '';\r\n        if (this.styles && this.styles.length > 0) {\r\n            output += this.constructTheme(this.styles.filter(style => style.type === CONFIG.THEME_STYLES.URL));\r\n            output += this.constructTheme(this.styles.filter(style => style.type === CONFIG.THEME_STYLES.STYLE));\r\n            output += this.constructTheme(this.styles.filter(style => style.type !== CONFIG.THEME_STYLES.URL && style.type !== CONFIG.THEME_STYLES.STYLE));\r\n        }\r\n        return output;\r\n    }\r\n}\r\n\r\nclass BoomThemeCtl extends PanelCtrl {\r\n    public static templateUrl = \"partials/module.html\";\r\n    public scope: any;\r\n    public ctrl: any;\r\n    public elem: any;\r\n    public attrs: any;\r\n    public activeEditorTabIndex: number;\r\n    public runtimeThemeSet: Boolean;\r\n    public runtimeThemeIndex: number;\r\n    public base_theme_options: any = [CONFIG.BASE_THEMES.DEFAULT, CONFIG.BASE_THEMES.DARK, CONFIG.BASE_THEMES.LIGHT].map(theme => {\r\n        return {\r\n            text: theme.name,\r\n            value: theme.id\r\n        };\r\n    });\r\n    constructor($scope, $injector) {\r\n        super($scope, $injector);\r\n        _.defaults(this.panel, {});\r\n        this.panel.transparent = true;\r\n        this.panel.themes = this.panel.themes || [\r\n            new BoomTheme({\r\n                name: CONFIG.FIRST_THEME_NAME,\r\n                styles: [\r\n                    new BoomThemeStyle(CONFIG.THEME_STYLES.BASE_THEME, { theme: CONFIG.BASE_THEMES.DEFAULT.id }),\r\n                    new BoomThemeStyle(CONFIG.THEME_STYLES.BG_IMAGE, { url: CONFIG.DEFAULT_THEME_BG_IMAGE }),\r\n                    new BoomThemeStyle(CONFIG.THEME_STYLES.STYLE,{ text : CONFIG.DEFAULT_THEME_STYLE })\r\n                ]\r\n            })\r\n        ];\r\n        this.panel.activeThemeId = this.panel.activeThemeId || 0;\r\n        this.activeEditorTabIndex = this.panel.activeThemeId >= 0 ? this.panel.activeThemeId : -1;\r\n        this.runtimeThemeSet = false;\r\n        this.runtimeThemeIndex = this.panel.activeThemeId >= 0 ? this.panel.activeThemeId : 0;\r\n        this.updatePrototypes();\r\n        this.events.on(\"init-edit-mode\", this.onInitEditMode.bind(this));\r\n    }\r\n    private updatePrototypes(): void {\r\n        if (this.panel.themes && this.panel.themes.length > 0) {\r\n            this.panel.themes.map(theme => {\r\n                Object.setPrototypeOf(theme, BoomTheme.prototype);\r\n                if (theme.styles && theme.styles.length > 0) {\r\n                    theme.styles.map(style => {\r\n                        Object.setPrototypeOf(style, BoomThemeStyle.prototype);\r\n                    });\r\n                }\r\n                return theme;\r\n            });\r\n        }\r\n    }\r\n    private onInitEditMode(): void {\r\n        this.addEditorTab(\"Theme\", \"public/plugins/yesoreyeram-boomtheme-panel/partials/options.html\", 2);\r\n    }\r\n    public addTheme(): void {\r\n        this.panel.themes = this.panel.themes || [];\r\n        this.panel.themes.push(new BoomTheme({\r\n            name: `Theme ${this.panel.themes.length + 1}`\r\n        }));\r\n        this.activeEditorTabIndex = this.panel.themes.length - 1;\r\n        this.runtimeThemeIndex = this.panel.themes.length - 1;\r\n        this.render();\r\n    }\r\n    public deleteTheme(index: number): void {\r\n        this.panel.themes.splice(index, 1);\r\n        if (this.panel.activeThemeId === index) {\r\n            this.panel.activeThemeId = 0;\r\n        }\r\n        if (this.runtimeThemeIndex === index) {\r\n            this.runtimeThemeIndex = 0;\r\n        }\r\n        if (this.activeEditorTabIndex === index) {\r\n            this.activeEditorTabIndex = this.ctrl.panel.themes.length - 1;\r\n        }\r\n    }\r\n    public setThemeAsDefault(index: number) {\r\n        this.ctrl.panel.activeThemeId = index;\r\n        this.runtimeThemeIndex = index;\r\n        this.render();\r\n    }\r\n    public setruntimeThemeIndex(index: number) {\r\n        this.runtimeThemeSet = true;\r\n        this.runtimeThemeIndex = index;\r\n        this.render();\r\n    }\r\n    public limitText(text: string, maxlength: Number): string {\r\n        if (text.split(\"\").length > maxlength) {\r\n            text = text.substring(0, Number(maxlength) - 3) + \"...\";\r\n        }\r\n        return text;\r\n    }\r\n    public link(scope: any, elem: any, attrs: any, ctrl: any): void {\r\n        this.scope = scope;\r\n        this.elem = elem;\r\n        this.attrs = attrs;\r\n        this.ctrl = ctrl;\r\n        this.render();\r\n    }\r\n}\r\n\r\nlet getThemeCSSFile = function (mode: string): string {\r\n    let filename = '';\r\n    if ([\"dark\", \"light\"].indexOf(mode.toLowerCase()) > -1 && window.performance) {\r\n        let appfiles = window.performance.getEntries().map(e => e.name).filter(e => e.endsWith(\".js\")).filter(e => e.indexOf(\"/public/build/app.\") > -1);\r\n        if (appfiles && appfiles.length > 0) {\r\n            filename = appfiles[0].replace(`/public/build/app.`, `/public/build/grafana.${mode.toLowerCase()}.`).slice(0, -3) + \".css\";\r\n        }\r\n    }\r\n    return filename;\r\n};\r\n\r\nBoomThemeCtl.prototype.render = function () {\r\n\r\n    // #region Panel UI Options\r\n    if (this.ctrl.panel.title === \"Panel Title\") {\r\n        this.ctrl.panel.title = \"\";\r\n    }\r\n    if (this.ctrl.panel.gridPos && this.ctrl.panel.gridPos.x === 0 && this.ctrl.panel.gridPos.y === 0) {\r\n        this.ctrl.panel.gridPos.w = 24;\r\n        this.ctrl.panel.gridPos.h = 3;\r\n    }\r\n    // #endregion\r\n\r\n    // #region Themes Rendering\r\n    let output = '';\r\n    _.each(this.panel.themes, (theme, index) => {\r\n        if (this.runtimeThemeSet === false) {\r\n            if (this.panel.activeThemeId === index && this.panel.activeThemeId >= 0) {\r\n                output += theme.getThemeContent();\r\n            }\r\n        } else {\r\n            if (this.runtimeThemeIndex === index && this.runtimeThemeIndex >= 0) {\r\n                output += theme.getThemeContent();\r\n            }\r\n        }\r\n    });\r\n    if (this.runtimeThemeSet === true) {\r\n        if (this.runtimeThemeIndex === CONFIG.BASE_THEMES.DARK.index_id) {\r\n            output += `@import url('${getThemeCSSFile(CONFIG.BASE_THEMES.DARK.id)}');\r\n            `;\r\n        } else if (this.runtimeThemeIndex === CONFIG.BASE_THEMES.LIGHT.index_id) {\r\n            output += `@import url('${getThemeCSSFile(CONFIG.BASE_THEMES.LIGHT.id)}');\r\n            `;\r\n        }\r\n    }\r\n    const style = document.createElement('style');\r\n    style.type = 'text/css';\r\n    style.appendChild(document.createTextNode(output));\r\n    this.elem.find(\"#boom-theme\").html(\"\");\r\n    this.elem.find(\"#boom-theme\").append(style);\r\n    // #endregion\r\n\r\n};\r\n\r\nexport { BoomThemeCtl as PanelCtrl };\r\n"]} diff --git a/dist/partials/module.html b/dist/partials/module.html deleted file mode 100644 index e152416..0000000 --- a/dist/partials/module.html +++ /dev/null @@ -1,16 +0,0 @@ -