UNPKG

ngx-slice-kit

Version:

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

89 lines 12 kB
import { Directive, Inject, Input } from '@angular/core'; import { DOCUMENT } from '@angular/common'; import * as i0 from "@angular/core"; import * as i1 from "./theme.service"; import * as i2 from "../layout-control/layout-control.service"; export class ThemeDirective { constructor(document, elementRef, renderer, themeService, layoutControl) { this.document = document; this.elementRef = elementRef; this.renderer = renderer; this.themeService = themeService; this.layoutControl = layoutControl; /** * Whether the styles are scoped or not. */ this.scoped = false; } /** * Update the theme on the scoped element. */ updateTheme(theme) { const element = this.getElement(); element.className = `sdk-theme-${theme.name}`; // probably unsafe if (!this.layoutControl.platform.BLINK) { element.classList.add('sdk-custom-scroll'); } else { element.classList.add(this.layoutControl.getPlatformClass()); } const oldStyles = this.document.head.querySelectorAll('[sdkTheme]'); if (oldStyles?.length > 0) { this.document.head.removeChild(oldStyles[0]); } const styles = this.renderer.createElement('style'); // project properties onto the element styles.innerHTML += `body {`; for (const prop of theme.props()) { if (!!prop.rgb) { styles.innerHTML += (`${prop.prop}-raw: ${prop.value};`); styles.innerHTML += (`${prop.prop}-rgb: ${prop.rgb};`); styles.innerHTML += (`${prop.prop}-opposite: ${prop.background};`); styles.innerHTML += (`${prop.prop}: ${prop.hex};`); if (prop.text_value) { styles.innerHTML += (`${prop.prop}-text-raw: ${prop.text_value};`); styles.innerHTML += (`${prop.prop}-text: ${prop.text};`); } } } styles.innerHTML += `}`; this.renderer.setAttribute(styles, 'sdkTheme', theme.name); this.document.head.appendChild(styles); } /** * Element to attach the styles to. */ getElement() { return this.scoped ? this.elementRef.nativeElement : this.document.body; } ngOnInit() { this.sub = this.themeService.currentThemeObservable .subscribe((theme) => this.updateTheme(theme)); if (this.theme && this.theme?.length > 0) { this.themeService.setTheme(this.theme); } else { this.updateTheme(this.themeService.currentTheme); } } ngOnDestroy() { this.sub?.unsubscribe(); } } ThemeDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ThemeDirective, deps: [{ token: DOCUMENT }, { token: i0.ElementRef }, { token: i0.Renderer2 }, { token: i1.ThemeService }, { token: i2.LayoutControlService }], target: i0.ɵɵFactoryTarget.Directive }); ThemeDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.3", type: ThemeDirective, selector: "[sdkTheme]", inputs: { scoped: "scoped", theme: ["sdkTheme", "theme"] }, ngImport: i0 }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: ThemeDirective, decorators: [{ type: Directive, args: [{ selector: '[sdkTheme]' }] }], ctorParameters: function () { return [{ type: undefined, decorators: [{ type: Inject, args: [DOCUMENT] }] }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i1.ThemeService }, { type: i2.LayoutControlService }]; }, propDecorators: { scoped: [{ type: Input }], theme: [{ type: Input, args: ['sdkTheme'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"theme.directive.js","sourceRoot":"","sources":["../../../../../../libs/ngx-slice-kit/src/lib/core/theme/theme.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,MAAM,EAAE,KAAK,EAAgC,MAAM,eAAe,CAAC;AACnG,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;;;AAU3C,MAAM,OAAO,cAAc;IAavB,YAC8B,QAAa,EAC/B,UAAsB,EACtB,QAAmB,EACnB,YAA0B,EAC1B,aAAmC;QAJjB,aAAQ,GAAR,QAAQ,CAAK;QAC/B,eAAU,GAAV,UAAU,CAAY;QACtB,aAAQ,GAAR,QAAQ,CAAW;QACnB,iBAAY,GAAZ,YAAY,CAAc;QAC1B,kBAAa,GAAb,aAAa,CAAsB;QAhB/C;;WAEG;QACa,WAAM,GAAG,KAAK,CAAC;IAe/B,CAAC;IAED;;OAEG;IACI,WAAW,CAAC,KAAY;QAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;QAElC,OAAO,CAAC,SAAS,GAAG,aAAa,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,kBAAkB;QACjE,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC,KAAK,EAAE;YACpC,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;SAC9C;aAAM;YACH,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,gBAAgB,EAAE,CAAC,CAAC;SAChE;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;QACpE,IAAI,SAAS,EAAE,MAAM,GAAG,CAAC,EAAE;YACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;SAChD;QACD,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;QAEpD,sCAAsC;QACtC,MAAM,CAAC,SAAS,IAAI,QAAQ,CAAC;QAC7B,KAAK,MAAM,IAAI,IAAI,KAAK,CAAC,KAAK,EAAE,EAAE;YAC9B,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE;gBACZ,MAAM,CAAC,SAAS,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,SAAS,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;gBACzD,MAAM,CAAC,SAAS,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,SAAS,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC;gBACvD,MAAM,CAAC,SAAS,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,cAAc,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;gBACnE,MAAM,CAAC,SAAS,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,KAAK,IAAI,CAAC,GAAG,GAAG,CAAC,CAAC;gBACnD,IAAI,IAAI,CAAC,UAAU,EAAE;oBACjB,MAAM,CAAC,SAAS,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,cAAc,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;oBACnE,MAAM,CAAC,SAAS,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,UAAU,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;iBAC5D;aACJ;SACJ;QACD,MAAM,CAAC,SAAS,IAAI,GAAG,CAAC;QACxB,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,EAAE,UAAU,EAAE,KAAK,CAAC,IAAI,CAAC,CAAC;QAE3D,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC;IAC3C,CAAC;IAED;;OAEG;IACI,UAAU;QACb,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;IAC5E,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,sBAAsB;aAC9C,SAAS,CAAC,CAAC,KAAY,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;QAE1D,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,KAAK,EAAE,MAAM,GAAG,CAAC,EAAE;YACtC,IAAI,CAAC,YAAY,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAC1C;aAAM;YACH,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;SACpD;IACL,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,GAAG,EAAE,WAAW,EAAE,CAAC;IAC5B,CAAC;;2GAjFQ,cAAc,kBAcX,QAAQ;+FAdX,cAAc;2FAAd,cAAc;kBAH1B,SAAS;mBAAC;oBACP,QAAQ,EAAE,YAAY;iBACzB;;0BAeQ,MAAM;2BAAC,QAAQ;2JATJ,MAAM;sBAArB,KAAK;gBAIoB,KAAK;sBAA9B,KAAK;uBAAC,UAAU","sourcesContent":["import { Directive, ElementRef, Inject, Input, OnDestroy, OnInit, Renderer2 } from '@angular/core';\nimport { DOCUMENT } from '@angular/common';\nimport { Subscription } from 'rxjs';\n\nimport { Theme } from './theme.model';\nimport { ThemeService } from './theme.service';\nimport { LayoutControlService } from '../layout-control/layout-control.service';\n\n@Directive({\n    selector: '[sdkTheme]'\n})\nexport class ThemeDirective implements OnInit, OnDestroy {\n\n    /**\n     * Whether the styles are scoped or not.\n     */\n    @Input() public scoped = false;\n    /**\n     * specify selected theme or use default.\n     */\n    @Input('sdkTheme') public theme: string;\n\n    private sub: Subscription;\n\n    constructor(\n        @Inject(DOCUMENT) private document: any,\n        private elementRef: ElementRef,\n        private renderer: Renderer2,\n        private themeService: ThemeService,\n        private layoutControl: LayoutControlService\n    ) {\n    }\n\n    /**\n     * Update the theme on the scoped element.\n     */\n    public updateTheme(theme: Theme): void {\n        const element = this.getElement();\n\n        element.className = `sdk-theme-${theme.name}`; // probably unsafe\n        if (!this.layoutControl.platform.BLINK) {\n            element.classList.add('sdk-custom-scroll');\n        } else {\n            element.classList.add(this.layoutControl.getPlatformClass());\n        }\n\n        const oldStyles = this.document.head.querySelectorAll('[sdkTheme]');\n        if (oldStyles?.length > 0) {\n            this.document.head.removeChild(oldStyles[0]);\n        }\n        const styles = this.renderer.createElement('style');\n\n        // project properties onto the element\n        styles.innerHTML += `body {`;\n        for (const prop of theme.props()) {\n            if (!!prop.rgb) {\n                styles.innerHTML += (`${prop.prop}-raw: ${prop.value};`);\n                styles.innerHTML += (`${prop.prop}-rgb: ${prop.rgb};`);\n                styles.innerHTML += (`${prop.prop}-opposite: ${prop.background};`);\n                styles.innerHTML += (`${prop.prop}: ${prop.hex};`);\n                if (prop.text_value) {\n                    styles.innerHTML += (`${prop.prop}-text-raw: ${prop.text_value};`);\n                    styles.innerHTML += (`${prop.prop}-text: ${prop.text};`);\n                }\n            }\n        }\n        styles.innerHTML += `}`;\n        this.renderer.setAttribute(styles, 'sdkTheme', theme.name);\n\n        this.document.head.appendChild(styles);\n    }\n\n    /**\n     * Element to attach the styles to.\n     */\n    public getElement(): any {\n        return this.scoped ? this.elementRef.nativeElement : this.document.body;\n    }\n\n    public ngOnInit(): void {\n        this.sub = this.themeService.currentThemeObservable\n            .subscribe((theme: Theme) => this.updateTheme(theme));\n\n        if (this.theme && this.theme?.length > 0) {\n            this.themeService.setTheme(this.theme);\n        } else {\n            this.updateTheme(this.themeService.currentTheme);\n        }\n    }\n\n    public ngOnDestroy(): void {\n        this.sub?.unsubscribe();\n    }\n\n}\n"]}