ngx-slice-kit
Version:
[](https://badge.fury.io/js/ngx-slice-kit)
134 lines • 21.3 kB
JavaScript
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":"AAAA,MAAM,cAAc,GAAG,UAAU,CAAC;AAClC,MAAM,oBAAoB,GAAG,aAAa,CAAC;AAC3C,MAAM,iBAAiB,GAAG,aAAa,CAAC,CAAC,cAAc;AACvD,MAAM,iBAAiB,GAAG,UAAU,CAAC,CAAC,cAAc;AACpD,MAAM,iBAAiB,GAAG,WAAW,CAAC,CAAC,eAAe;AACtD,MAAM,gBAAgB,GAAG,YAAY,CAAC,CAAC,gBAAgB;AACvD,MAAM,cAAc,GAAG,WAAW,CAAC,CAAC,iBAAiB;AAKrD,MAAM,CAAC,MAAM,aAAa,GAAG;IACzB,IAAI,EAAE,cAAc;IACpB,SAAS,EAAE,oBAAoB;IAC/B,UAAU,EAAE,oBAAoB;IAChC,OAAO,EAAE,iBAAiB;IAC1B,YAAY,EAAE,cAAc;IAC5B,OAAO,EAAE,iBAAiB;IAC1B,YAAY,EAAE,oBAAoB;IAClC,OAAO,EAAE,iBAAiB;IAC1B,YAAY,EAAE,oBAAoB;IAClC,MAAM,EAAE,gBAAgB;IACxB,WAAW,EAAE,oBAAoB;IACjC,IAAI,EAAE,cAAc;IACpB,SAAS,EAAE,oBAAoB;CAClC,CAAC;AAEF,MAAM,CAAC,MAAM,UAAU,GAAG;IACtB,MAAM,EAAE,YAAY;CACvB,CAAC;AAEF,MAAM,CAAC,MAAM,MAAM,GAAG;IAClB,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM;CACpD,CAAC;AAEF,MAAM,UAAU,GAAG,GAAG,CAAC;AACvB,MAAM,SAAS,GAAG,EAAE,CAAC;AAErB,MAAM,OAAO,aAAa;IAWtB,YAAY,EAAkB;QAC1B,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;QACxB,IAAI,CAAC,IAAI,GAAG,KAAK,IAAI,CAAC,IAAI,EAAE,CAAC;QAE7B,oBAAoB;QACpB,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QAC3E,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;QACpF,MAAM,QAAQ,GAAG,SAAS,CAAC,MAAM,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;QAC5D,MAAM,OAAO,GAAG,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC;QAE3D,qBAAqB;QACrB,IAAI,CAAC,GAAG,GAAG,mBAAmB,CAAC,QAAQ,CAAC,CAAC;QACzC,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC/B,IAAI,CAAC,UAAU,GAAG,mBAAmB,CAAC,OAAO,CAAC,CAAC;QAE/C,mCAAmC;QACnC,IAAI,IAAI,CAAC,UAAU,EAAE,MAAM,GAAG,CAAC,EAAE;YAC7B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC;YACtF,MAAM,SAAS,GAAG,SAAS,CAAC,OAAO,EAAE,KAAK,EAAE,GAAG,CAAC,CAAC;YACjD,IAAI,CAAC,IAAI,GAAG,mBAAmB,CAAC,SAAS,CAAC,CAAC;SAC9C;IACL,CAAC;CACJ;AAED,MAAM,OAAO,KAAK;IAqBd,YAAY,CAAS;QACjB,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,aAAa,EAAE,CAAC,CAAC,CAAC;QAEtC,IAAI,CAAC,MAAM,GAAG,IAAI,GAAG,EAAiB,CAAC;QACvC,KAAK,MAAM,KAAK,IAAI,CAAC,GAAG,UAAU,EAAE,GAAG,MAAM,CAAC,EAAE;YAC5C,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;YAExB,MAAM,SAAS,GAAG,GAAG,KAAK,OAAO,CAAC;YAClC,MAAM,SAAS,GAAG,IAAI,aAAa,CAAC;gBAChC,IAAI,EAAE,KAAK;gBACX,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC;gBAC3B,KAAK,EAAE,UAAU;gBACjB,KAAK,EAAE,GAAG;gBACV,UAAU,EAAE,GAAG,KAAK,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU;aACpE,CAAC,CAAC;YACH,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;SAC9B;IACL,CAAC;IAEM,KAAK;QACR,MAAM,OAAO,GAAG,EAAE,CAAC;QAEnB,KAAK,MAAM,CAAC,IAAI,IAAI,CAAC,MAAM,EAAE;YACzB,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;SACnB;QAED,KAAK,MAAM,KAAK,IAAI,CAAC,GAAG,UAAU,EAAE,GAAG,MAAM,CAAC,EAAE;YAC5C,MAAM,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC;YAExB,KAAK,IAAI,KAAK,GAAG,SAAS,EAAE,KAAK,IAAI,UAAU,EAAE,KAAK,IAAI,SAAS,EAAE;gBACjE,OAAO,CAAC,IAAI,CAAC,IAAI,aAAa,CAAC;oBAC3B,IAAI,EAAE,GAAG,KAAK,KAAK,KAAK,EAAE;oBAC1B,KAAK;oBACL,KAAK,EAAE,GAAG;oBACV,UAAU,EAAE,GAAG,KAAK,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU;iBACpE,CAAC,CAAC,CAAC;aACP;SACJ;QAED,OAAO,OAAO,CAAC;IACnB,CAAC;CACJ;AAED,MAAM,GAAG,GAAG,CAAC,GAAW,EAAU,EAAE;IAChC,OAAO,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;AAC/E,CAAC,CAAC;AAEF,MAAM,IAAI,GAAG,CAAC,GAAW,EAAU,EAAE;IACjC,OAAO,GAAG,EAAE,OAAO,CAAC,aAAa,EAAE,EAAE,CAAC,CAAC;AAC3C,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAG,CAAC,IAAc,EAAE,KAAe,EAAE,KAAa,EAAY,EAAE;IAClF,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACpE,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACpE,MAAM,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IACpE,OAAO,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;AACxB,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,GAAa,EAAU,EAAE;IACzD,OAAO,OAAO,GAAG,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;AAChD,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAG,CAAC,IAAY,EAAU,EAAE;IAC9C,IAAI,CAAC,IAAI,EAAE;QACP,OAAO,EAAE,CAAC;KACb;IAED,MAAM,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC;IACnE,MAAM,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACtD,MAAM,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACzC,MAAM,CAAC,GAAG,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACzC,MAAM,QAAQ,GAAG;QACb,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;QACd,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;QACd,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC;KACjB,CAAC;IAEF,IAAI,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;QACpB,MAAM,CAAC,GAAQ,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC;QAC3F,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;KACnE;IAED,iCAAiC;IACjC,QAAQ,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE;QACzB,IAAI,IAAI,CAAC,MAAM,KAAK,CAAC,EAAE;YACnB,QAAQ,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,IAAI,CAAC;SAC5B;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,CAAC,GAAG,GAAG,QAAQ,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;AACrC,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,GAAW,EAAY,EAAE;IAC9C,MAAM,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACzC,MAAM,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACzC,MAAM,CAAC,GAAG,QAAQ,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC;IACzC,OAAO,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;AACrB,CAAC,CAAC","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"]}