Why Gemfury? Push, build, and install  RubyGems npm packages Python packages Maven artifacts PHP packages Go Modules Bower components Debian packages RPM packages NuGet packages

vipera-npm-registry / motif-web-admin-core   js

Repository URL to install this package:

Version: 0.3.1 

/ esm5 / lib / services / ThemeDesigner / ThemeModel.js

/**
 * @fileoverview added by tsickle
 * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
 */
import * as tslib_1 from "tslib";
/**
 * @record
 */
export function ThemeItem() { }
if (false) {
    /** @type {?} */
    ThemeItem.prototype.description;
}
var ThemeGroup = /** @class */ (function () {
    function ThemeGroup() {
    }
    return ThemeGroup;
}());
export { ThemeGroup };
if (false) {
    /** @type {?} */
    ThemeGroup.prototype.items;
    /** @type {?} */
    ThemeGroup.prototype.description;
}
/**
 * @abstract
 */
var /**
 * @abstract
 */
ThemeModel = /** @class */ (function (_super) {
    tslib_1.__extends(ThemeModel, _super);
    function ThemeModel() {
        return _super !== null && _super.apply(this, arguments) || this;
    }
    return ThemeModel;
}(ThemeGroup));
/**
 * @abstract
 */
export { ThemeModel };
if (false) {
    /** @type {?} */
    ThemeModel.prototype.description;
    /**
     * @abstract
     * @return {?}
     */
    ThemeModel.prototype.exportTheme = function () { };
}
/** @type {?} */
var LOG_TAG = '[DefaultThemeModel]';
var ThemeColorItem = /** @class */ (function () {
    function ThemeColorItem(name, description, cssPropertyName, scssVariableName, themeWrapper, logger) {
        this.name = name;
        this.description = description;
        this.cssPropertyName = cssPropertyName;
        this.scssVariableName = scssVariableName;
        this.themeWrapper = themeWrapper;
        this.logger = logger;
        this.presets = ['#00000000'];
        this._value = this.getColorProperty(cssPropertyName);
    }
    Object.defineProperty(ThemeColorItem.prototype, "value", {
        get: /**
         * @return {?}
         */
        function () {
            return this._value;
        },
        set: /**
         * @param {?} colorValue
         * @return {?}
         */
        function (colorValue) {
            this._value = colorValue;
            this.themeWrapper.style.setProperty(this.cssPropertyName, colorValue);
            //console.log(">>>>> Set color value: ", colorValue);
        },
        enumerable: true,
        configurable: true
    });
    /**
     * @private
     * @param {?} variableName
     * @return {?}
     */
    ThemeColorItem.prototype.getColorProperty = /**
     * @private
     * @param {?} variableName
     * @return {?}
     */
    function (variableName) {
        /** @type {?} */
        var style = getComputedStyle(this.themeWrapper);
        /** @type {?} */
        var ret = style.getPropertyValue(variableName).trim();
        return ret;
    };
    return ThemeColorItem;
}());
export { ThemeColorItem };
if (false) {
    /**
     * @type {?}
     * @private
     */
    ThemeColorItem.prototype._value;
    /** @type {?} */
    ThemeColorItem.prototype.presets;
    /** @type {?} */
    ThemeColorItem.prototype.name;
    /** @type {?} */
    ThemeColorItem.prototype.description;
    /** @type {?} */
    ThemeColorItem.prototype.cssPropertyName;
    /** @type {?} */
    ThemeColorItem.prototype.scssVariableName;
    /**
     * @type {?}
     * @private
     */
    ThemeColorItem.prototype.themeWrapper;
    /**
     * @type {?}
     * @private
     */
    ThemeColorItem.prototype.logger;
}
var DefaultThemeModel = /** @class */ (function () {
    function DefaultThemeModel(logger, document) {
        this.logger = logger;
        this.document = document;
        this.items = [];
        this.logger.debug(LOG_TAG, 'Initializing');
        this.themeWrapper = this.document.querySelector('app-root');
        this.createModel();
    }
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createModel = /**
     * @private
     * @return {?}
     */
    function () {
        this.items.push(this.createMainGroup());
        this.items.push(this.createToolbarGroup());
        this.items.push(this.createHeaderGroup());
        this.items.push(this.createFooterGroup());
        this.items.push(this.createGridGroup());
        this.items.push(this.createTabsGroup());
        this.items.push(this.createButtonsGroup());
        this.items.push(this.createComboboxGroup());
        this.items.push(this.createInputGroup());
    };
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createMainGroup = /**
     * @private
     * @return {?}
     */
    function () {
        /** @type {?} */
        var ret = new ThemeGroup();
        ret.description = "Main";
        ret.items = [
            // Main Colors
            this.createColorItem('background', 'Main Background', '--main-background-color', '$main_background_color'),
            //Titles
            this.createColorItem('background', 'Title 1 Color', '--title-1-color', '$title1_color'),
        ];
        return ret;
    };
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createHeaderGroup = /**
     * @private
     * @return {?}
     */
    function () {
        /** @type {?} */
        var ret = new ThemeGroup();
        ret.description = "Header";
        ret.items = [
            // Header Colors
            this.createColorItem('header', 'Header Background', '--header-background-color', '$header_background_color'),
            this.createColorItem('header', 'Header Color', '--header-color', '$header_description_color'),
            this.createColorItem('header', 'Header Hover', '--header-color-hover', '$header_description_hover_color')
        ];
        return ret;
    };
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createFooterGroup = /**
     * @private
     * @return {?}
     */
    function () {
        /** @type {?} */
        var ret = new ThemeGroup();
        ret.description = "Footer";
        ret.items = [
            // Footer Colors
            this.createColorItem('footer', 'Footer Background', '--footer-background-color', '$footer_background_color'),
            this.createColorItem('footer', 'Footer Color', '--footer-color', '$footer_color')
        ];
        return ret;
    };
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createGridGroup = /**
     * @private
     * @return {?}
     */
    function () {
        /** @type {?} */
        var ret = new ThemeGroup();
        ret.description = "Grid";
        ret.items = [
            // Grid Colors 
            this.createColorItem('grid', 'Grid Background', '--grid-background-color', '$grid_background_color'),
            this.createColorItem('grid', 'Grid Color', '--grid-color', '$grid_color'),
            this.createColorItem('grid', 'Grid Border Color', '--grid-border-color', '$grid_border_color'),
            this.createColorItem('grid', 'Grid Header Color', '--grid-header-color', '$grid_header_color'),
            this.createColorItem('grid', 'Grid Header Border', '--grid-header-border-color', '$grid_header_border_color'),
            this.createColorItem('grid', 'Grid Hover Backgorund', '--grid-row-hover-background-color', '$grid_tr_hover_background_color'),
            this.createColorItem('grid', 'Grid Hover Color', '--grid-row-hover-color', '$grid_tr_hover_color'),
            this.createColorItem('grid', 'Grid Selected Background Color', '--grid-row-selected-background-color', '$grid_selected_row_color'),
            this.createColorItem('grid', 'Grid Selected Color', '--grid-row-selected-color', '$grid_selected_row'),
            this.createColorItem('grid', 'Grid Command Color', '--grid-command-color', '$grid_command_color'),
            this.createColorItem('grid', 'Grid Selected Row Command Color', '--grid-selected-row-command-color', '$grid_selected_row_command_color')
        ];
        return ret;
    };
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createToolbarGroup = /**
     * @private
     * @return {?}
     */
    function () {
        /** @type {?} */
        var ret = new ThemeGroup();
        ret.description = "Main Toolbar";
        ret.items = [
            // Toolbar Colors
            this.createColorItem('mainToolbar', 'Background', '--nav-background-color', '$nav_background_color'),
            this.createColorItem('mainToolbar', 'Border', '--nav-border-color', '$nav_a_a_border_color'),
            this.createColorItem('mainToolbar', 'Color', '--nav-color', '$nav_color'),
            this.createColorItem('mainToolbar', 'Background Hover', '--nav-hover-background-color', '$nav_hover_background_color'),
            this.createColorItem('mainToolbar', 'Color Hover', '--nav-hover-color', '$nav_hover_color')
        ];
        return ret;
    };
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createTabsGroup = /**
     * @private
     * @return {?}
     */
    function () {
        /** @type {?} */
        var ret = new ThemeGroup();
        ret.description = "Tabs";
        ret.items = [
            // Toolbar Colors
            this.createColorItem('tabs', 'Background', '--tab-background-color', '$tab_background_color'),
            this.createColorItem('tabs', 'Color', '--tab-color', '$tab_color'),
            this.createColorItem('tabs', 'Selected Background', '--tab-selected-background-color', '$tab_selected_background_color'),
            this.createColorItem('tabs', 'Selected Color', '--tab-selected-color', '$tab_selected_color'),
        ];
        return ret;
    };
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createButtonsGroup = /**
     * @private
     * @return {?}
     */
    function () {
        /** @type {?} */
        var ret = new ThemeGroup();
        ret.description = "Buttons";
        ret.items = [
            // Toolbar Colors
            this.createColorItem('buttons', 'Background', '--button-background-color', '$button_background_color'),
            this.createColorItem('buttons', 'Color', '--button-color', '$button_color'),
            this.createColorItem('buttons', 'Border', '--button-border-color', '$button_border_color'),
            this.createColorItem('buttons', 'Hover Background', '--button-hover-background-color', '$button_hover_background_color'),
            this.createColorItem('buttons', 'Hover Color', '--button-hover-color', '$button_hover_color'),
            this.createColorItem('buttons', 'Hover Border', '--button-hover-border-color', '$button_hover_border_color'),
            this.createColorItem('buttons', 'Disabled Background', '--button-disabled-background-color', '$button_disabled_background_color'),
            this.createColorItem('buttons', 'Disabled Color', '--button-disabled-color', '$button_disabled_color'),
            this.createColorItem('buttons', 'Disabled Border', '--button-disabled-border-color', '$button_disabled_border_color')
        ];
        return ret;
    };
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createComboboxGroup = /**
     * @private
     * @return {?}
     */
    function () {
        /** @type {?} */
        var ret = new ThemeGroup();
        ret.description = "Comboboxes";
        ret.items = [
            // Toolbar Colors
            this.createColorItem('combobox', 'Background', '--combobox-background-color', '$combobox_background_color'),
            this.createColorItem('combobox', 'Color', '--combobox-color', '$combobox_color'),
            this.createColorItem('combobox', 'Selection Background', '--combobox-selected-item-background-color', '$combobox_selected_item_background_color'),
            this.createColorItem('combobox', 'Selection Color', '--combobox-selected-item-color', '$combobox_selected_item_color'),
            this.createColorItem('combobox', 'Button Background', '--combobox-button-background-color', '$combobox_button_background_color'),
            this.createColorItem('combobox', 'Button Color', '--combobox-button-color', '$combobox_button_color')
        ];
        return ret;
    };
    /**
     * @private
     * @return {?}
     */
    DefaultThemeModel.prototype.createInputGroup = /**
     * @private
     * @return {?}
     */
    function () {
        /** @type {?} */
        var ret = new ThemeGroup();
        ret.description = "Input";
        ret.items = [
            // Toolbar Colors
            this.createColorItem('input', 'Background', '--input-background-color', '$input_background_color'),
            this.createColorItem('input', 'Color', '--input-color', '$input_color'),
            this.createColorItem('input', 'Placeholder Color', '--input-placeholder-color', '$input_placeholder_color'),
            this.createColorItem('input', 'Border Color', '--input-border-color', '$input_border_color'),
            this.createColorItem('input', 'Focus Background', '--input-focus-background-color', '$input_focus_background_color'),
            this.createColorItem('input', 'Focus Color', '--input-focus-color', '$input_focus_color')
        ];
        return ret;
    };
    /**
     * @return {?}
     */
    DefaultThemeModel.prototype.exportTheme = /**
     * @return {?}
     */
    function () {
        /** @type {?} */
        var retStr = "";
        for (var i = 0; i < this.items.length; i++) {
            /** @type {?} */
            var groupItem = (/** @type {?} */ (this.items[i]));
            for (var k = 0; k < groupItem.items.length; k++) {
                /** @type {?} */
                var item = (/** @type {?} */ (groupItem.items[k]));
                retStr += "\n" + item.scssVariableName + ":" + item.value + ";";
            }
        }
        return retStr;
    };
    /**
     * @private
     * @param {?} name
     * @param {?} description
     * @param {?} cssPropertyName
     * @param {?} scssVariableName
     * @return {?}
     */
    DefaultThemeModel.prototype.createColorItem = /**
     * @private
     * @param {?} name
     * @param {?} description
     * @param {?} cssPropertyName
     * @param {?} scssVariableName
     * @return {?}
     */
    function (name, description, cssPropertyName, scssVariableName) {
        return new ThemeColorItem(name, description, cssPropertyName, scssVariableName, this.themeWrapper, this.logger);
    };
    return DefaultThemeModel;
}());
export { DefaultThemeModel };
if (false) {
    /**
     * @type {?}
     * @private
     */
    DefaultThemeModel.prototype.themeWrapper;
    /** @type {?} */
    DefaultThemeModel.prototype.items;
    /** @type {?} */
    DefaultThemeModel.prototype.description;
    /**
     * @type {?}
     * @private
     */
    DefaultThemeModel.prototype.logger;
    /**
     * @type {?}
     * @private
     */
    DefaultThemeModel.prototype.document;
}
import { Inject } from '@angular/core';
import { NGXLogger } from 'web-console-core';
import { DOCUMENT } from '@angular/common';
var ThemeModelBuilder = /** @class */ (function () {
    function ThemeModelBuilder(logger, document) {
        this.logger = logger;
        this.document = document;
        this.logger.debug(LOG_TAG, 'Initializing Theme Builder');
    }
    /**
     * @return {?}
     */
    ThemeModelBuilder.prototype.createModel = /**
     * @return {?}
     */
    function () {
        /** @type {?} */
        var model = new DefaultThemeModel(this.logger, this.document);
        //console.log("createModel :", model);
        return model;
    };
    /** @nocollapse */
    ThemeModelBuilder.ctorParameters = function () { return [
        { type: NGXLogger },
        { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
    ]; };
    return ThemeModelBuilder;
}());
export { ThemeModelBuilder };
if (false) {
    /**
     * @type {?}
     * @private
     */
    ThemeModelBuilder.prototype.logger;
    /**
     * @type {?}
     * @private
     */
    ThemeModelBuilder.prototype.document;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ThemeModel.js","sourceRoot":"ng://motif-web-admin-core/","sources":["lib/services/ThemeDesigner/ThemeModel.ts"],"names":[],"mappings":";;;;;;;;AAEA,+BAEC;;;IADC,gCAAmB;;AAGrB;IAAA;IAGA,CAAC;IAAD,iBAAC;AAAD,CAAC,AAHD,IAGC;;;;IAFC,2BAAmB;;IACnB,iCAAoB;;;;;AAGtB;;;;IAAyC,sCAAU;IAAnD;;IAGA,CAAC;IAAD,iBAAC;AAAD,CAAC,AAHD,CAAyC,UAAU,GAGlD;;;;;;;IAFC,iCAAoB;;;;;IACpB,mDAA+B;;;IAK3B,OAAO,GAAG,qBAAqB;AAErC;IAME,wBAAmB,IAAY,EACtB,WAAmB,EACnB,eAAuB,EACvB,gBAAgB,EACf,YAAiB,EACjB,MAAiB;QALR,SAAI,GAAJ,IAAI,CAAQ;QACtB,gBAAW,GAAX,WAAW,CAAQ;QACnB,oBAAe,GAAf,eAAe,CAAQ;QACvB,qBAAgB,GAAhB,gBAAgB,CAAA;QACf,iBAAY,GAAZ,YAAY,CAAK;QACjB,WAAM,GAAN,MAAM,CAAW;QAPpB,YAAO,GAAG,CAAE,WAAW,CAAC,CAAC;QAQ5B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,CAAC,CAAC;IACzD,CAAC;IAED,sBAAW,iCAAK;;;;QAAhB;YACE,OAAO,IAAI,CAAC,MAAM,CAAC;QACrB,CAAC;;;;;QAED,UAAiB,UAAiB;YAChC,IAAI,CAAC,MAAM,GAAG,UAAU,CAAC;YACzB,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;YACtE,qDAAqD;QACvD,CAAC;;;OANA;;;;;;IAQO,yCAAgB;;;;;IAAxB,UAAyB,YAAoB;;YACvC,KAAK,GAAG,gBAAgB,CAAC,IAAI,CAAC,YAAY,CAAC;;YAC3C,GAAG,GAAG,KAAK,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC,IAAI,EAAE;QACrD,OAAO,GAAG,CAAC;IACb,CAAC;IAGH,qBAAC;AAAD,CAAC,AAhCD,IAgCC;;;;;;;IA9BC,gCAAuB;;IAEvB,iCAAgC;;IAEpB,8BAAmB;;IAC7B,qCAA0B;;IAC1B,yCAA8B;;IAC9B,0CAAuB;;;;;IACvB,sCAAyB;;;;;IACzB,gCAAyB;;AAwB7B;IAOE,2BAAoB,MAAiB,EAAU,QAAa;QAAxC,WAAM,GAAN,MAAM,CAAW;QAAU,aAAQ,GAAR,QAAQ,CAAK;QAH5D,UAAK,GAAgB,EAAE,CAAC;QAItB,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,cAAc,CAAE,CAAC;QAC5C,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;QAC5D,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;;;;;IAEO,uCAAW;;;;IAAnB;QACE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QACxC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;QAC3C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC;QAC1C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QACxC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QACxC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;QAC3C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,CAAC,CAAC;QAC5C,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC3C,CAAC;;;;;IAEO,2CAAe;;;;IAAvB;;YACM,GAAG,GAAG,IAAI,UAAU,EAAE;QAC1B,GAAG,CAAC,WAAW,GAAG,MAAM,CAAC;QACzB,GAAG,CAAC,KAAK,GAAG;YAEV,cAAc;YACd,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,iBAAiB,EAAE,yBAAyB,EAAE,wBAAwB,CAAC;YACxG,QAAQ;YACR,IAAI,CAAC,eAAe,CAAC,YAAY,EAAE,eAAe,EAAE,iBAAiB,EAAE,eAAe,CAAC;SAC1F,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;;;;;IAGO,6CAAiB;;;;IAAzB;;YACM,GAAG,GAAG,IAAI,UAAU,EAAE;QAC1B,GAAG,CAAC,WAAW,GAAG,QAAQ,CAAC;QAC3B,GAAG,CAAC,KAAK,GAAG;YACV,gBAAgB;YAChB,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,mBAAmB,EAAE,2BAA2B,EAAE,0BAA0B,CAAC;YAC5G,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,cAAc,EAAE,gBAAgB,EAAE,2BAA2B,CAAC;YAC7F,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,cAAc,EAAE,sBAAsB,EAAE,iCAAiC,CAAC;SAC1G,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;;;;;IAEO,6CAAiB;;;;IAAzB;;YACM,GAAG,GAAG,IAAI,UAAU,EAAE;QAC1B,GAAG,CAAC,WAAW,GAAG,QAAQ,CAAC;QAC3B,GAAG,CAAC,KAAK,GAAG;YACV,gBAAgB;YAChB,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,mBAAmB,EAAE,2BAA2B,EAAC,0BAA0B,CAAC;YAC3G,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,cAAc,EAAE,gBAAgB,EAAC,eAAe,CAAC;SACjF,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;;;;;IAGO,2CAAe;;;;IAAvB;;YACM,GAAG,GAAG,IAAI,UAAU,EAAE;QAC1B,GAAG,CAAC,WAAW,GAAG,MAAM,CAAC;QACzB,GAAG,CAAC,KAAK,GAAG;YACV,eAAe;YACf,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,iBAAiB,EAAE,yBAAyB,EAAC,wBAAwB,CAAC;YACnG,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,YAAY,EAAE,cAAc,EAAE,aAAa,CAAC;YACzE,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,oBAAoB,CAAC;YAC9F,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,mBAAmB,EAAE,qBAAqB,EAAE,oBAAoB,CAAC;YAC9F,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,oBAAoB,EAAE,4BAA4B,EAAE,2BAA2B,CAAC;YAC7G,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,uBAAuB,EAAE,mCAAmC,EAAE,iCAAiC,CAAC;YAC7H,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,kBAAkB,EAAE,wBAAwB,EAAE,sBAAsB,CAAC;YAClG,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,gCAAgC,EAAE,sCAAsC,EAAE,0BAA0B,CAAC;YAClI,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,qBAAqB,EAAE,2BAA2B,EAAE,oBAAoB,CAAC;YACtG,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,oBAAoB,EAAE,sBAAsB,EAAE,qBAAqB,CAAC;YACjG,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,iCAAiC,EAAE,mCAAmC,EAAE,kCAAkC,CAAC;SACzI,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;;;;;IAGO,8CAAkB;;;;IAA1B;;YACM,GAAG,GAAG,IAAI,UAAU,EAAE;QAC1B,GAAG,CAAC,WAAW,GAAG,cAAc,CAAC;QACjC,GAAG,CAAC,KAAK,GAAG;YACV,iBAAiB;YACjB,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,YAAY,EAAE,wBAAwB,EAAE,uBAAuB,CAAC;YACpG,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,QAAQ,EAAE,oBAAoB,EAAE,uBAAuB,CAAC;YAC5F,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,OAAO,EAAE,aAAa,EAAE,YAAY,CAAC;YACzE,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,kBAAkB,EAAE,8BAA8B,EAAC,6BAA6B,CAAC;YACrH,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,aAAa,EAAE,mBAAmB,EAAC,kBAAkB,CAAC;SAC3F,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;;;;;IAEO,2CAAe;;;;IAAvB;;YACM,GAAG,GAAG,IAAI,UAAU,EAAE;QAC1B,GAAG,CAAC,WAAW,GAAG,MAAM,CAAC;QACzB,GAAG,CAAC,KAAK,GAAG;YACV,iBAAiB;YACjB,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,YAAY,EAAE,wBAAwB,EAAE,uBAAuB,CAAC;YAC7F,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,OAAO,EAAE,aAAa,EAAE,YAAY,CAAC;YAClE,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,qBAAqB,EAAE,iCAAiC,EAAE,gCAAgC,CAAC;YACxH,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,qBAAqB,CAAC;SAC9F,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;;;;;IAGO,8CAAkB;;;;IAA1B;;YACM,GAAG,GAAG,IAAI,UAAU,EAAE;QAC1B,GAAG,CAAC,WAAW,GAAG,SAAS,CAAC;QAC5B,GAAG,CAAC,KAAK,GAAG;YACV,iBAAiB;YACjB,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,YAAY,EAAE,2BAA2B,EAAE,0BAA0B,CAAC;YACtG,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,OAAO,EAAE,gBAAgB,EAAE,eAAe,CAAC;YAC3E,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,QAAQ,EAAE,uBAAuB,EAAE,sBAAsB,CAAC;YAC1F,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,kBAAkB,EAAE,iCAAiC,EAAE,gCAAgC,CAAC;YACxH,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,aAAa,EAAE,sBAAsB,EAAE,qBAAqB,CAAC;YAC7F,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,cAAc,EAAE,6BAA6B,EAAE,4BAA4B,CAAC;YAC5G,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,qBAAqB,EAAE,oCAAoC,EAAE,mCAAmC,CAAC;YACjI,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,gBAAgB,EAAE,yBAAyB,EAAE,wBAAwB,CAAC;YACtG,IAAI,CAAC,eAAe,CAAC,SAAS,EAAE,iBAAiB,EAAE,gCAAgC,EAAE,+BAA+B,CAAC;SACtH,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;;;;;IAEO,+CAAmB;;;;IAA3B;;YACM,GAAG,GAAG,IAAI,UAAU,EAAE;QAC1B,GAAG,CAAC,WAAW,GAAG,YAAY,CAAC;QAC/B,GAAG,CAAC,KAAK,GAAG;YACV,iBAAiB;YACjB,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,YAAY,EAAE,6BAA6B,EAAE,4BAA4B,CAAC;YAC3G,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,OAAO,EAAE,kBAAkB,EAAE,iBAAiB,CAAC;YAChF,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,sBAAsB,EAAE,2CAA2C,EAAE,0CAA0C,CAAC;YACjJ,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,iBAAiB,EAAE,gCAAgC,EAAE,+BAA+B,CAAC;YACtH,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,mBAAmB,EAAE,oCAAoC,EAAE,mCAAmC,CAAC;YAChI,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,cAAc,EAAE,yBAAyB,EAAE,wBAAwB,CAAC;SACtG,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;;;;;IAEO,4CAAgB;;;;IAAxB;;YACM,GAAG,GAAG,IAAI,UAAU,EAAE;QAC1B,GAAG,CAAC,WAAW,GAAG,OAAO,CAAC;QAC1B,GAAG,CAAC,KAAK,GAAG;YACV,iBAAiB;YACjB,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,YAAY,EAAE,0BAA0B,EAAE,yBAAyB,CAAC;YAClG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,eAAe,EAAE,cAAc,CAAC;YACvE,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,mBAAmB,EAAE,2BAA2B,EAAE,0BAA0B,CAAC;YAC3G,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,cAAc,EAAE,sBAAsB,EAAE,qBAAqB,CAAC;YAC5F,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,kBAAkB,EAAE,gCAAgC,EAAE,+BAA+B,CAAC;YACpH,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,aAAa,EAAE,qBAAqB,EAAE,oBAAoB,CAAC;SAC1F,CAAC;QACF,OAAO,GAAG,CAAC;IACb,CAAC;;;;IAGM,uCAAW;;;IAAlB;;YACM,MAAM,GAAG,EAAE;QACf,KAAK,IAAI,CAAC,GAAC,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,EAAC,CAAC,EAAE,EAAC;;gBAChC,SAAS,GAAgB,mBAAA,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAc;YAC1D,KAAI,IAAI,CAAC,GAAC,CAAC,EAAC,CAAC,GAAC,SAAS,CAAC,KAAK,CAAC,MAAM,EAAC,CAAC,EAAE,EAAC;;oBACjC,IAAI,GAAkB,mBAAA,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAkB;gBAChE,MAAM,IAAI,IAAI,GAAG,IAAI,CAAC,gBAAgB,GAAE,GAAG,GAAG,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;aAChE;SACF;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;;;;;;;;;IAGO,2CAAe;;;;;;;;IAAvB,UAAwB,IAAY,EAAE,WAAkB,EAAE,eAAuB,EAAE,gBAAuB;QACxG,OAAO,IAAI,cAAc,CAAC,IAAI,EAAE,WAAW,EAAE,eAAe,EAAE,gBAAgB,EAAE,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAClH,CAAC;IAEH,wBAAC;AAAD,CAAC,AAlLD,IAkLC;;;;;;;IAhLC,yCAA0B;;IAE1B,kCAAwB;;IACxB,wCAA2B;;;;;IAEf,mCAAyB;;;;;IAAE,qCAAqB;;AA8K9D,OAAO,EAAE,MAAM,EAAmB,MAAM,eAAe,CAAC;AACxD,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAE3C;IAEI,2BAAoB,MAAiB,EAA4B,QAAa;QAA1D,WAAM,GAAN,MAAM,CAAW;QAA4B,aAAQ,GAAR,QAAQ,CAAK;QAC5E,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,OAAO,EAAE,4BAA4B,CAAE,CAAC;IAC5D,CAAC;;;;IAEM,uCAAW;;;IAAlB;;YACM,KAAK,GAAe,IAAI,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC;QACzE,sCAAsC;QACtC,OAAO,KAAK,CAAC;IACf,CAAC;;;gBAbI,SAAS;gDAK0B,MAAM,SAAC,QAAQ;;IAW3D,wBAAC;CAAA,AAbD,IAaC;SAbY,iBAAiB;;;;;;IAEd,mCAAyB;;;;;IAAE,qCAAuC","sourcesContent":["\n\nexport interface ThemeItem {\n  description: string\n}\n\nexport class ThemeGroup implements ThemeItem {\n  items: ThemeItem[];\n  description: string;\n}\n\nexport abstract class ThemeModel extends ThemeGroup {\n  description: string;\n  abstract exportTheme(): string;\n}\n\n\n\nconst LOG_TAG = '[DefaultThemeModel]';\n\nexport class ThemeColorItem implements ThemeItem {\n\n  private _value: string;\n\n  public presets = [ '#00000000'];\n\n  constructor(public name: string,\n    public description: string,\n    public cssPropertyName: string,\n    public scssVariableName,\n    private themeWrapper: any,\n    private logger: NGXLogger) {\n      this._value = this.getColorProperty(cssPropertyName);\n  }\n\n  public get value(){\n    return this._value;\n  }\n\n  public set value(colorValue:string) {\n    this._value = colorValue;\n    this.themeWrapper.style.setProperty(this.cssPropertyName, colorValue);\n    //console.log(\">>>>> Set color value: \", colorValue);\n  }\n\n  private getColorProperty(variableName: string): string {\n    var style = getComputedStyle(this.themeWrapper);\n    var ret = style.getPropertyValue(variableName).trim();\n    return ret;\n  }\n\n\n}\n\n\nexport class DefaultThemeModel implements ThemeModel {\n\n  private themeWrapper: any;\n\n  items: ThemeItem[] = [];\n  description: \"Theme Model\";\n\n  constructor(private logger: NGXLogger, private document: any){\n    this.logger.debug(LOG_TAG, 'Initializing' );\n    this.themeWrapper = this.document.querySelector('app-root');\n    this.createModel();\n  }\n\n  private createModel(){\n    this.items.push(this.createMainGroup());\n    this.items.push(this.createToolbarGroup());\n    this.items.push(this.createHeaderGroup());\n    this.items.push(this.createFooterGroup());\n    this.items.push(this.createGridGroup());\n    this.items.push(this.createTabsGroup());\n    this.items.push(this.createButtonsGroup());\n    this.items.push(this.createComboboxGroup());\n    this.items.push(this.createInputGroup());\n  }\n\n  private createMainGroup(): ThemeGroup {\n    let ret = new ThemeGroup();\n    ret.description = \"Main\";\n    ret.items = [\n\n      // Main Colors\n      this.createColorItem('background', 'Main Background', '--main-background-color', '$main_background_color'),\n        //Titles\n        this.createColorItem('background', 'Title 1 Color', '--title-1-color', '$title1_color'),\n    ];\n    return ret;\n  }\n\n\n  private createHeaderGroup(): ThemeGroup {\n    let ret = new ThemeGroup();\n    ret.description = \"Header\";\n    ret.items = [\n      // Header Colors\n      this.createColorItem('header', 'Header Background', '--header-background-color', '$header_background_color'),\n      this.createColorItem('header', 'Header Color', '--header-color', '$header_description_color'),\n      this.createColorItem('header', 'Header Hover', '--header-color-hover', '$header_description_hover_color')\n    ];\n    return ret;\n  }\n\n  private createFooterGroup(): ThemeGroup {\n    let ret = new ThemeGroup();\n    ret.description = \"Footer\";\n    ret.items = [\n      // Footer Colors\n      this.createColorItem('footer', 'Footer Background', '--footer-background-color','$footer_background_color'),\n      this.createColorItem('footer', 'Footer Color', '--footer-color','$footer_color')\n    ];\n    return ret;\n  }\n\n\n  private createGridGroup(): ThemeGroup {\n    let ret = new ThemeGroup();\n    ret.description = \"Grid\";\n    ret.items = [\n      // Grid Colors \n      this.createColorItem('grid', 'Grid Background', '--grid-background-color','$grid_background_color'),\n      this.createColorItem('grid', 'Grid Color', '--grid-color', '$grid_color'),\n      this.createColorItem('grid', 'Grid Border Color', '--grid-border-color', '$grid_border_color'),\n      this.createColorItem('grid', 'Grid Header Color', '--grid-header-color', '$grid_header_color'),\n      this.createColorItem('grid', 'Grid Header Border', '--grid-header-border-color', '$grid_header_border_color'),\n      this.createColorItem('grid', 'Grid Hover Backgorund', '--grid-row-hover-background-color', '$grid_tr_hover_background_color'),\n      this.createColorItem('grid', 'Grid Hover Color', '--grid-row-hover-color', '$grid_tr_hover_color'),\n      this.createColorItem('grid', 'Grid Selected Background Color', '--grid-row-selected-background-color', '$grid_selected_row_color'),\n      this.createColorItem('grid', 'Grid Selected Color', '--grid-row-selected-color', '$grid_selected_row'),\n      this.createColorItem('grid', 'Grid Command Color', '--grid-command-color', '$grid_command_color'),\n      this.createColorItem('grid', 'Grid Selected Row Command Color', '--grid-selected-row-command-color', '$grid_selected_row_command_color')\n    ];\n    return ret;\n  }\n  \n\n  private createToolbarGroup(): ThemeGroup {\n    let ret = new ThemeGroup();\n    ret.description = \"Main Toolbar\";\n    ret.items = [\n      // Toolbar Colors\n      this.createColorItem('mainToolbar', 'Background', '--nav-background-color', '$nav_background_color'),\n      this.createColorItem('mainToolbar', 'Border', '--nav-border-color', '$nav_a_a_border_color'),\n      this.createColorItem('mainToolbar', 'Color', '--nav-color', '$nav_color'),\n      this.createColorItem('mainToolbar', 'Background Hover', '--nav-hover-background-color','$nav_hover_background_color'),\n      this.createColorItem('mainToolbar', 'Color Hover', '--nav-hover-color','$nav_hover_color')\n    ];\n    return ret;\n  }\n\n  private createTabsGroup(): ThemeGroup {\n    let ret = new ThemeGroup();\n    ret.description = \"Tabs\";\n    ret.items = [\n      // Toolbar Colors\n      this.createColorItem('tabs', 'Background', '--tab-background-color', '$tab_background_color'),\n      this.createColorItem('tabs', 'Color', '--tab-color', '$tab_color'),\n      this.createColorItem('tabs', 'Selected Background', '--tab-selected-background-color', '$tab_selected_background_color'),\n      this.createColorItem('tabs', 'Selected Color', '--tab-selected-color', '$tab_selected_color'),\n    ];\n    return ret;\n  }\n\n\n  private createButtonsGroup(): ThemeGroup {\n    let ret = new ThemeGroup();\n    ret.description = \"Buttons\";\n    ret.items = [\n      // Toolbar Colors\n      this.createColorItem('buttons', 'Background', '--button-background-color', '$button_background_color'),\n      this.createColorItem('buttons', 'Color', '--button-color', '$button_color'),\n      this.createColorItem('buttons', 'Border', '--button-border-color', '$button_border_color'),\n      this.createColorItem('buttons', 'Hover Background', '--button-hover-background-color', '$button_hover_background_color'),\n      this.createColorItem('buttons', 'Hover Color', '--button-hover-color', '$button_hover_color'),\n      this.createColorItem('buttons', 'Hover Border', '--button-hover-border-color', '$button_hover_border_color'),\n      this.createColorItem('buttons', 'Disabled Background', '--button-disabled-background-color', '$button_disabled_background_color'),\n      this.createColorItem('buttons', 'Disabled Color', '--button-disabled-color', '$button_disabled_color'),\n      this.createColorItem('buttons', 'Disabled Border', '--button-disabled-border-color', '$button_disabled_border_color')\n    ];\n    return ret;\n  }\n\n  private createComboboxGroup(): ThemeGroup {\n    let ret = new ThemeGroup();\n    ret.description = \"Comboboxes\";\n    ret.items = [\n      // Toolbar Colors\n      this.createColorItem('combobox', 'Background', '--combobox-background-color', '$combobox_background_color'),\n      this.createColorItem('combobox', 'Color', '--combobox-color', '$combobox_color'),\n      this.createColorItem('combobox', 'Selection Background', '--combobox-selected-item-background-color', '$combobox_selected_item_background_color'),\n      this.createColorItem('combobox', 'Selection Color', '--combobox-selected-item-color', '$combobox_selected_item_color'),\n      this.createColorItem('combobox', 'Button Background', '--combobox-button-background-color', '$combobox_button_background_color'),\n      this.createColorItem('combobox', 'Button Color', '--combobox-button-color', '$combobox_button_color')\n    ];\n    return ret;\n  }\n\n  private createInputGroup(): ThemeGroup {\n    let ret = new ThemeGroup();\n    ret.description = \"Input\";\n    ret.items = [\n      // Toolbar Colors\n      this.createColorItem('input', 'Background', '--input-background-color', '$input_background_color'),\n      this.createColorItem('input', 'Color', '--input-color', '$input_color'),\n      this.createColorItem('input', 'Placeholder Color', '--input-placeholder-color', '$input_placeholder_color'),\n      this.createColorItem('input', 'Border Color', '--input-border-color', '$input_border_color'),\n      this.createColorItem('input', 'Focus Background', '--input-focus-background-color', '$input_focus_background_color'),\n      this.createColorItem('input', 'Focus Color', '--input-focus-color', '$input_focus_color')\n    ];\n    return ret;\n  }\n\n\n  public exportTheme(): string {\n    let retStr = \"\";\n    for (var i=0; i < this.items.length;i++){\n      const groupItem : ThemeGroup = this.items[i] as ThemeGroup;\n      for(var k=0;k<groupItem.items.length;k++){\n        const item:ThemeColorItem = groupItem.items[k] as ThemeColorItem;\n        retStr += \"\\n\" + item.scssVariableName +\":\" + item.value + \";\";\n      }\n    }\n    return retStr;\n  }\n\n\n  private createColorItem(name: string, description:string, cssPropertyName: string, scssVariableName:string): ThemeColorItem {\n    return new ThemeColorItem(name, description, cssPropertyName, scssVariableName, this.themeWrapper, this.logger);\n  }\n\n}\n\n\nimport { Inject, destroyPlatform } from '@angular/core';\nimport { NGXLogger } from 'web-console-core';\nimport { DOCUMENT } from '@angular/common';\n\nexport class ThemeModelBuilder {\n\n    constructor(private logger: NGXLogger, @Inject(DOCUMENT) private document: any){\n      this.logger.debug(LOG_TAG, 'Initializing Theme Builder' );\n    }\n\n    public createModel(): ThemeModel {\n      let model: ThemeModel = new DefaultThemeModel(this.logger, this.document);\n      //console.log(\"createModel :\", model);\n      return model;\n    }\n\n\n}\n"]}