UNPKG

ngx-slice-kit

Version:

[![npm version](https://badge.fury.io/js/ngx-slice-kit.svg)](https://badge.fury.io/js/ngx-slice-kit)

134 lines 21.3 kB
const defaultBaseRgb = `25,25,25`; const defaultBackgroundRgb = `255,255,255`; const defaultRegularRgb = `186,186,186`; // `66,66,66`; const defaultPrimaryRgb = `0,85,255`; // `0,85,255`; const defaultSuccessRgb = `39,174,96`; // `39,174,96`; const defaultAccentRgb = `241,201,79`; // `255,168,38`; const defaultWarnRgb = `211,50,39`; // `238,112,112`; export const defaultColors = { base: defaultBaseRgb, base_text: defaultBackgroundRgb, background: defaultBackgroundRgb, regular: defaultRegularRgb, regular_text: defaultBaseRgb, primary: defaultPrimaryRgb, primary_text: defaultBackgroundRgb, success: defaultSuccessRgb, success_text: defaultBackgroundRgb, accent: defaultAccentRgb, accent_text: defaultBackgroundRgb, warn: defaultWarnRgb, warn_text: defaultBackgroundRgb, }; export const baseColors = [ `base`, `background`, ]; export const colors = [ `regular`, `primary`, `success`, `accent`, `warn`, ]; const alphaLimit = 100; const alphaStep = 10; export class ColorProperty { constructor(cp) { Object.assign(this, cp); this.prop = `--${this.name}`; // find color values const rgbVal = this.value.split(sep(this.value)).map(i => parseInt(i, 10)); const bgVal = this.background.split(sep(this.background)).map(i => parseInt(i, 10)); const rgbMixin = MixinRgba(rgbVal, bgVal, this.alpha / 100); const bgMixin = MixinRgba(bgVal, rgbVal, this.alpha / 100); // declare rgb values this.rgb = NumArrayToRgbString(rgbMixin); this.hex = RgbaToHex(this.rgb); this.background = NumArrayToRgbString(bgMixin); // check if text value is available if (this.text_value?.length > 0) { const textVal = this.text_value.split(sep(this.text_value)).map(i => parseInt(i, 10)); const textMixin = MixinRgba(textVal, bgVal, 0.9); this.text = NumArrayToRgbString(textMixin); } } } export class Theme { constructor(t) { Object.assign(this, defaultColors, t); this.colors = new Set(); for (const color of [...baseColors, ...colors]) { const rgb = this[color]; const textColor = `${color}_text`; const colorProp = new ColorProperty({ name: color, text_value: this[textColor], alpha: alphaLimit, value: rgb, background: rgb === this.background ? this.base : this.background, }); this.colors.add(colorProp); } } props() { const results = []; for (const c of this.colors) { results.push(c); } for (const color of [...baseColors, ...colors]) { const rgb = this[color]; for (let alpha = alphaStep; alpha <= alphaLimit; alpha += alphaStep) { results.push(new ColorProperty({ name: `${color}-a${alpha}`, alpha, value: rgb, background: rgb === this.background ? this.base : this.background, })); } } return results; } } const sep = (str) => { return str?.indexOf(',') < 0 ? (str?.indexOf(', ') < 0 ? ' ' : ', ') : ','; }; const trim = (str) => { return str?.replace(/^\s+|\s+$/gm, ''); }; export const MixinRgba = (base, added, alpha) => { const r3 = Math.round(((1 - alpha) * added[0]) + (alpha * base[0])); const g3 = Math.round(((1 - alpha) * added[1]) + (alpha * base[1])); const b3 = Math.round(((1 - alpha) * added[2]) + (alpha * base[2])); return [r3, g3, b3]; }; export const NumArrayToRgbString = (rgb) => { return `rgb(${rgb[0]},${rgb[1]},${rgb[2]})`; }; export const RgbaToHex = (rgba) => { if (!rgba) { return ''; } const inParts = rgba.substring(rgba.indexOf('(')).split(sep(rgba)); const r = parseInt(trim(inParts[0].substring(1)), 10); const g = parseInt(trim(inParts[1]), 10); const b = parseInt(trim(inParts[2]), 10); const outParts = [ r.toString(16), g.toString(16), b.toString(16) ]; if (inParts.length > 3) { const a = parseFloat(trim(inParts[3].substring(0, inParts[3].length - 1))).toFixed(2); outParts.push(Math.round(a * 255).toString(16).substring(0, 2)); } // Pad single-digit output values outParts.forEach((part, i) => { if (part.length === 1) { outParts[i] = '0' + part; } }); return ('#' + outParts.join('')); }; export const HexToRgb = (hex) => { const r = parseInt(hex.substr(1, 2), 16); const g = parseInt(hex.substr(3, 2), 16); const b = parseInt(hex.substr(5, 2), 16); return [r, g, b]; }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.model.js","sourceRoot":"","sources":["../../../../../../libs/ngx-slice-kit/src/lib/core/theme/theme.model.ts"],"names":[],"mappings":"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","sourcesContent":["const defaultBaseRgb = `25,25,25`;\nconst defaultBackgroundRgb = `255,255,255`;\nconst defaultRegularRgb = `186,186,186`; // `66,66,66`;\nconst defaultPrimaryRgb = `0,85,255`; // `0,85,255`;\nconst defaultSuccessRgb = `39,174,96`; // `39,174,96`;\nconst defaultAccentRgb = `241,201,79`; // `255,168,38`;\nconst defaultWarnRgb = `211,50,39`; // `238,112,112`;\n\nexport type ThemeBaseColors = 'base' | 'background';\nexport type ThemeColors = 'regular' | 'primary' | 'success' | 'accent' | 'warn';\n\nexport const defaultColors = {\n    base: defaultBaseRgb,\n    base_text: defaultBackgroundRgb,\n    background: defaultBackgroundRgb,\n    regular: defaultRegularRgb,\n    regular_text: defaultBaseRgb,\n    primary: defaultPrimaryRgb,\n    primary_text: defaultBackgroundRgb,\n    success: defaultSuccessRgb,\n    success_text: defaultBackgroundRgb,\n    accent: defaultAccentRgb,\n    accent_text: defaultBackgroundRgb,\n    warn: defaultWarnRgb,\n    warn_text: defaultBackgroundRgb,\n};\n\nexport const baseColors = [\n    `base`, `background`,\n];\n\nexport const colors = [\n    `regular`, `primary`, `success`, `accent`, `warn`,\n];\n\nconst alphaLimit = 100;\nconst alphaStep = 10;\n\nexport class ColorProperty {\n    public value: string;\n    public text_value?: string;\n    public background: string;\n    public name: string;\n    public text?: string;\n    public prop?: string;\n    public alpha?: number;\n    public rgb?: string;\n    public hex?: string;\n\n    constructor(cp?: ColorProperty) {\n        Object.assign(this, cp);\n        this.prop = `--${this.name}`;\n\n        // find color values\n        const rgbVal = this.value.split(sep(this.value)).map(i => parseInt(i, 10));\n        const bgVal = this.background.split(sep(this.background)).map(i => parseInt(i, 10));\n        const rgbMixin = MixinRgba(rgbVal, bgVal, this.alpha / 100);\n        const bgMixin = MixinRgba(bgVal, rgbVal, this.alpha / 100);\n\n        // declare rgb values\n        this.rgb = NumArrayToRgbString(rgbMixin);\n        this.hex = RgbaToHex(this.rgb);\n        this.background = NumArrayToRgbString(bgMixin);\n\n        // check if text value is available\n        if (this.text_value?.length > 0) {\n            const textVal = this.text_value.split(sep(this.text_value)).map(i => parseInt(i, 10));\n            const textMixin = MixinRgba(textVal, bgVal, 0.9);\n            this.text = NumArrayToRgbString(textMixin);\n        }\n    }\n}\n\nexport class Theme {\n    public name: string;\n\n    // there goes RGB colors palette string values\n    public base?: string;\n    public background?: string;\n    public regular?: string;\n    public primary?: string;\n    public success?: string;\n    public accent?: string;\n    public warn?: string;\n    // text keys\n    public base_text?: string;\n    public regular_text?: string;\n    public primary_text?: string;\n    public success_text?: string;\n    public accent_text?: string;\n    public warn_text?: string;\n\n    public colors?: Set<ColorProperty>;\n\n    constructor(t?: Theme) {\n        Object.assign(this, defaultColors, t);\n\n        this.colors = new Set<ColorProperty>();\n        for (const color of [...baseColors, ...colors]) {\n            const rgb = this[color];\n\n            const textColor = `${color}_text`;\n            const colorProp = new ColorProperty({\n                name: color,\n                text_value: this[textColor],\n                alpha: alphaLimit,\n                value: rgb,\n                background: rgb === this.background ? this.base : this.background,\n            });\n            this.colors.add(colorProp);\n        }\n    }\n\n    public props?(): ColorProperty[] {\n        const results = [];\n\n        for (const c of this.colors) {\n            results.push(c);\n        }\n\n        for (const color of [...baseColors, ...colors]) {\n            const rgb = this[color];\n\n            for (let alpha = alphaStep; alpha <= alphaLimit; alpha += alphaStep) {\n                results.push(new ColorProperty({\n                    name: `${color}-a${alpha}`,\n                    alpha,\n                    value: rgb,\n                    background: rgb === this.background ? this.base : this.background,\n                }));\n            }\n        }\n\n        return results;\n    }\n}\n\nconst sep = (str: string): string => {\n    return str?.indexOf(',') < 0 ? (str?.indexOf(', ') < 0 ? ' ' : ', ') : ',';\n};\n\nconst trim = (str: string): string => {\n    return str?.replace(/^\\s+|\\s+$/gm, '');\n};\n\nexport const MixinRgba = (base: number[], added: number[], alpha: number): number[] => {\n    const r3 = Math.round(((1 - alpha) * added[0]) + (alpha * base[0]));\n    const g3 = Math.round(((1 - alpha) * added[1]) + (alpha * base[1]));\n    const b3 = Math.round(((1 - alpha) * added[2]) + (alpha * base[2]));\n    return [r3, g3, b3];\n};\n\nexport const NumArrayToRgbString = (rgb: number[]): string => {\n    return `rgb(${rgb[0]},${rgb[1]},${rgb[2]})`;\n};\n\nexport const RgbaToHex = (rgba: string): string => {\n    if (!rgba) {\n        return '';\n    }\n\n    const inParts = rgba.substring(rgba.indexOf('(')).split(sep(rgba));\n    const r = parseInt(trim(inParts[0].substring(1)), 10);\n    const g = parseInt(trim(inParts[1]), 10);\n    const b = parseInt(trim(inParts[2]), 10);\n    const outParts = [\n        r.toString(16),\n        g.toString(16),\n        b.toString(16)\n    ];\n\n    if (inParts.length > 3) {\n        const a: any = parseFloat(trim(inParts[3].substring(0, inParts[3].length - 1))).toFixed(2);\n        outParts.push(Math.round(a * 255).toString(16).substring(0, 2));\n    }\n\n    // Pad single-digit output values\n    outParts.forEach((part, i) => {\n        if (part.length === 1) {\n            outParts[i] = '0' + part;\n        }\n    });\n\n    return ('#' + outParts.join(''));\n};\n\nexport const HexToRgb = (hex: string): number[] => {\n    const r = parseInt(hex.substr(1, 2), 16);\n    const g = parseInt(hex.substr(3, 2), 16);\n    const b = parseInt(hex.substr(5, 2), 16);\n    return [r, g, b];\n};\n"]}