Repository URL to install this package:
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
/**
* @record
*/
export function ThemeItem() { }
if (false) {
/** @type {?} */
ThemeItem.prototype.description;
}
export class ThemeGroup {
}
if (false) {
/** @type {?} */
ThemeGroup.prototype.items;
/** @type {?} */
ThemeGroup.prototype.description;
}
/**
* @abstract
*/
export class ThemeModel extends ThemeGroup {
}
if (false) {
/** @type {?} */
ThemeModel.prototype.description;
/**
* @abstract
* @return {?}
*/
ThemeModel.prototype.exportTheme = function () { };
}
/** @type {?} */
const LOG_TAG = '[DefaultThemeModel]';
export class ThemeColorItem {
/**
* @param {?} name
* @param {?} description
* @param {?} cssPropertyName
* @param {?} scssVariableName
* @param {?} themeWrapper
* @param {?} logger
*/
constructor(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);
}
/**
* @return {?}
*/
get value() {
return this._value;
}
/**
* @param {?} colorValue
* @return {?}
*/
set value(colorValue) {
this._value = colorValue;
this.themeWrapper.style.setProperty(this.cssPropertyName, colorValue);
//console.log(">>>>> Set color value: ", colorValue);
}
/**
* @private
* @param {?} variableName
* @return {?}
*/
getColorProperty(variableName) {
/** @type {?} */
var style = getComputedStyle(this.themeWrapper);
/** @type {?} */
var ret = style.getPropertyValue(variableName).trim();
return ret;
}
}
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;
}
export class DefaultThemeModel {
/**
* @param {?} logger
* @param {?} document
*/
constructor(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 {?}
*/
createModel() {
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 {?}
*/
createMainGroup() {
/** @type {?} */
let 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 {?}
*/
createHeaderGroup() {
/** @type {?} */
let 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 {?}
*/
createFooterGroup() {
/** @type {?} */
let 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 {?}
*/
createGridGroup() {
/** @type {?} */
let 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 {?}
*/
createToolbarGroup() {
/** @type {?} */
let 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 {?}
*/
createTabsGroup() {
/** @type {?} */
let 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 {?}
*/
createButtonsGroup() {
/** @type {?} */
let 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 {?}
*/
createComboboxGroup() {
/** @type {?} */
let 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 {?}
*/
createInputGroup() {
/** @type {?} */
let 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 {?}
*/
exportTheme() {
/** @type {?} */
let retStr = "";
for (var i = 0; i < this.items.length; i++) {
/** @type {?} */
const groupItem = (/** @type {?} */ (this.items[i]));
for (var k = 0; k < groupItem.items.length; k++) {
/** @type {?} */
const item = (/** @type {?} */ (groupItem.items[k]));
retStr += "\n" + item.scssVariableName + ":" + item.value + ";";
}
}
return retStr;
}
/**
* @private
* @param {?} name
* @param {?} description
* @param {?} cssPropertyName
* @param {?} scssVariableName
* @return {?}
*/
createColorItem(name, description, cssPropertyName, scssVariableName) {
return new ThemeColorItem(name, description, cssPropertyName, scssVariableName, this.themeWrapper, this.logger);
}
}
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';
export class ThemeModelBuilder {
/**
* @param {?} logger
* @param {?} document
*/
constructor(logger, document) {
this.logger = logger;
this.document = document;
this.logger.debug(LOG_TAG, 'Initializing Theme Builder');
}
/**
* @return {?}
*/
createModel() {
/** @type {?} */
let model = new DefaultThemeModel(this.logger, this.document);
//console.log("createModel :", model);
return model;
}
}
/** @nocollapse */
ThemeModelBuilder.ctorParameters = () => [
{ type: NGXLogger },
{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] }
];
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":"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","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"]}