UNPKG

ngx-slice-kit

Version:

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

106 lines 14 kB
import { Component, Input, ViewEncapsulation } from '@angular/core'; import { GLYPHS } from './icon.glyphs'; import { BehaviorSubject } from 'rxjs'; import * as i0 from "@angular/core"; import * as i1 from "@angular/platform-browser"; const DEFAULT_SIZE = 24; const DEFAULT_COLOR = 'var(--base)'; const DEFAULT_ICON = 'ngx-slice'; const INKBE_ICON = 'inkbe'; const INKBE_COEFF = 70 / 32; export class IconComponent { constructor(elementRef, sanitizer, renderer) { this.elementRef = elementRef; this.sanitizer = sanitizer; this.renderer = renderer; this.$color = new BehaviorSubject(DEFAULT_COLOR); this.$size = new BehaviorSubject(DEFAULT_SIZE); this.icon = DEFAULT_ICON; this.inline = true; } set size(size) { this.$size.next(size); this.renderComponentSvg(); // is it even good? } get size() { return this.$size.getValue(); } set color(c) { this.$color.next(c); this.renderComponentSvg(); } get color() { return this.$color.getValue(); } prepareSymbol(name, color) { if (this.preparing) { return; } this.preparing = true; let symbol = GLYPHS[name] || DEFAULT_ICON; if (color?.length > 0) { symbol = symbol.replace(`fill="var(--base)"`, `fill="${color}"`); } if (this.size > DEFAULT_SIZE || this.size < DEFAULT_SIZE) { symbol = symbol.replace(`height="24px"`, `height="${this.size}px"`); if (name === INKBE_ICON) { symbol = symbol.replace(`width="52.5px"`, `width="${this.size * INKBE_COEFF}px"`); } else { symbol = symbol.replace(`width="24px"`, `width="${this.size}px"`); } } this.preparing = false; return symbol; } createIcon(symbol) { this.renderer.createElement('svg', symbol); } createSafeHtml(symbol) { return this.sanitizer.bypassSecurityTrustHtml(symbol); } renderComponentSvg() { this.svg = this.createSafeHtml(this.prepareSymbol(this.icon, this.color)); } setIconColor(color) { if (color && color.length > 0) { const symbol = this.elementRef.nativeElement.querySelector(`[class="icon"]`); this.renderer.setAttribute(symbol, 'fill', color); } } ngAfterContentInit() { const svg = this.elementRef.nativeElement.querySelector(`[fill="var(--base)"]`); if (svg) { this.renderer.setAttribute(svg, 'height', `${this.size}px`); this.renderer.setAttribute(svg, 'width', `${this.size}px`); this.renderer.setAttribute(svg, `fill`, this.color); } } ngOnInit() { if (!this.icon) { this.icon = 'ngx-slice'; } this.svg = this.createSafeHtml(this.prepareSymbol(this.icon, this.color)); } } IconComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: IconComponent, deps: [{ token: i0.ElementRef }, { token: i1.DomSanitizer }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); IconComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.3", type: IconComponent, selector: "sdk-icon", inputs: { icon: "icon", image: "image", inline: "inline", size: "size", color: "color" }, ngImport: i0, template: ` <span [innerHTML]="svg"></span> `, isInline: true, styles: [":host{display:inline-flex;margin:0;padding:0;font-size:0;line-height:0}:host *{line-height:0;font-size:0}\n"], encapsulation: i0.ViewEncapsulation.None }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.3", ngImport: i0, type: IconComponent, decorators: [{ type: Component, args: [{ selector: 'sdk-icon', template: ` <span [innerHTML]="svg"></span> `, encapsulation: ViewEncapsulation.None, styles: [":host{display:inline-flex;margin:0;padding:0;font-size:0;line-height:0}:host *{line-height:0;font-size:0}\n"] }] }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i1.DomSanitizer }, { type: i0.Renderer2 }]; }, propDecorators: { icon: [{ type: Input }], image: [{ type: Input }], inline: [{ type: Input }], size: [{ type: Input }], color: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"icon.component.js","sourceRoot":"","sources":["../../../../../../libs/ngx-slice-kit/src/lib/buttons/icon/icon.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAc,KAAK,EAAqB,iBAAiB,EAAE,MAAM,eAAe,CAAC;AAErH,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;;;AAEvC,MAAM,YAAY,GAAG,EAAE,CAAC;AACxB,MAAM,aAAa,GAAG,aAAa,CAAC;AACpC,MAAM,YAAY,GAAG,WAAW,CAAC;AACjC,MAAM,UAAU,GAAG,OAAO,CAAC;AAC3B,MAAM,WAAW,GAAG,EAAE,GAAG,EAAE,CAAC;AAU5B,MAAM,OAAO,aAAa;IA6BtB,YACY,UAAsB,EACtB,SAAuB,EACvB,QAAmB;QAFnB,eAAU,GAAV,UAAU,CAAY;QACtB,cAAS,GAAT,SAAS,CAAc;QACvB,aAAQ,GAAR,QAAQ,CAAW;QA9BvB,WAAM,GAA4B,IAAI,eAAe,CAAS,aAAa,CAAC,CAAC;QAC7E,UAAK,GAA4B,IAAI,eAAe,CAAS,YAAY,CAAC,CAAC;QAInE,SAAI,GAAW,YAAY,CAAC;QAE5B,WAAM,GAAY,IAAI,CAAC;IAyBvC,CAAC;IAvBD,IAAoB,IAAI,CAAC,IAAY;QACjC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACtB,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC,mBAAmB;IAClD,CAAC;IAED,IAAW,IAAI;QACX,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;IACjC,CAAC;IAED,IAAoB,KAAK,CAAC,CAAS;QAC/B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QACpB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC9B,CAAC;IAED,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;IASM,aAAa,CAAC,IAAY,EAAE,KAAc;QAC7C,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,OAAO;SACV;QAED,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QAEtB,IAAI,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,YAAY,CAAC;QAC1C,IAAI,KAAK,EAAE,MAAM,GAAG,CAAC,EAAE;YACnB,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,oBAAoB,EAAE,SAAS,KAAK,GAAG,CAAC,CAAC;SACpE;QAED,IAAI,IAAI,CAAC,IAAI,GAAG,YAAY,IAAI,IAAI,CAAC,IAAI,GAAG,YAAY,EAAE;YACtD,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,eAAe,EAAE,WAAW,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC;YACpE,IAAI,IAAI,KAAK,UAAU,EAAE;gBACrB,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,gBAAgB,EAAE,UAAU,IAAI,CAAC,IAAI,GAAG,WAAW,KAAK,CAAC,CAAC;aACrF;iBAAM;gBACH,MAAM,GAAG,MAAM,CAAC,OAAO,CAAC,cAAc,EAAE,UAAU,IAAI,CAAC,IAAI,KAAK,CAAC,CAAC;aACrE;SACJ;QAED,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,OAAO,MAAM,CAAC;IAClB,CAAC;IAEM,UAAU,CAAC,MAAc;QAC5B,IAAI,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IAC/C,CAAC;IAEM,cAAc,CAAC,MAAc;QAChC,OAAO,IAAI,CAAC,SAAS,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC;IAC1D,CAAC;IAEM,kBAAkB;QACrB,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAC9E,CAAC;IAEM,YAAY,CAAC,KAAa;QAC7B,IAAI,KAAK,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3B,MAAM,MAAM,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC;YAC7E,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;SACrD;IACL,CAAC;IAEM,kBAAkB;QACrB,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;QAChF,IAAI,GAAG,EAAE;YACL,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE,QAAQ,EAAE,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC;YAC5D,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC;YAC3D,IAAI,CAAC,QAAQ,CAAC,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;SACvD;IACL,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;YACZ,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC;SAC3B;QACD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAC9E,CAAC;;0GA9FQ,aAAa;8FAAb,aAAa,0IANZ;;KAET;2FAIQ,aAAa;kBARzB,SAAS;+BACI,UAAU,YACV;;KAET,iBAEc,iBAAiB,CAAC,IAAI;oJASrB,IAAI;sBAAnB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,MAAM;sBAArB,KAAK;gBAEc,IAAI;sBAAvB,KAAK;gBASc,KAAK;sBAAxB,KAAK","sourcesContent":["import { AfterContentInit, Component, ElementRef, Input, OnInit, Renderer2, ViewEncapsulation } from '@angular/core';\nimport { DomSanitizer, SafeHtml } from '@angular/platform-browser';\nimport { GLYPHS } from './icon.glyphs';\nimport { BehaviorSubject } from 'rxjs';\n\nconst DEFAULT_SIZE = 24;\nconst DEFAULT_COLOR = 'var(--base)';\nconst DEFAULT_ICON = 'ngx-slice';\nconst INKBE_ICON = 'inkbe';\nconst INKBE_COEFF = 70 / 32;\n\n@Component({\n    selector: 'sdk-icon',\n    template: `\n        <span [innerHTML]=\"svg\"></span>\n    `,\n    styleUrls: ['./icon.component.scss'],\n    encapsulation: ViewEncapsulation.None,\n})\nexport class IconComponent implements OnInit, AfterContentInit {\n\n    private $color: BehaviorSubject<string> = new BehaviorSubject<string>(DEFAULT_COLOR);\n    private $size: BehaviorSubject<number> = new BehaviorSubject<number>(DEFAULT_SIZE);\n    private preparing: boolean;\n    public svg: SafeHtml;\n\n    @Input() public icon: string = DEFAULT_ICON;\n    @Input() public image: string;\n    @Input() public inline: boolean = true;\n\n    @Input() public set size(size: number) {\n        this.$size.next(size);\n        this.renderComponentSvg(); // is it even good?\n    }\n\n    public get size(): number {\n        return this.$size.getValue();\n    }\n\n    @Input() public set color(c: string) {\n        this.$color.next(c);\n        this.renderComponentSvg();\n    }\n\n    public get color(): string {\n        return this.$color.getValue();\n    }\n\n    constructor(\n        private elementRef: ElementRef,\n        private sanitizer: DomSanitizer,\n        private renderer: Renderer2\n    ) {\n    }\n\n    public prepareSymbol(name: string, color?: string): string {\n        if (this.preparing) {\n            return;\n        }\n\n        this.preparing = true;\n\n        let symbol = GLYPHS[name] || DEFAULT_ICON;\n        if (color?.length > 0) {\n            symbol = symbol.replace(`fill=\"var(--base)\"`, `fill=\"${color}\"`);\n        }\n\n        if (this.size > DEFAULT_SIZE || this.size < DEFAULT_SIZE) {\n            symbol = symbol.replace(`height=\"24px\"`, `height=\"${this.size}px\"`);\n            if (name === INKBE_ICON) {\n                symbol = symbol.replace(`width=\"52.5px\"`, `width=\"${this.size * INKBE_COEFF}px\"`);\n            } else {\n                symbol = symbol.replace(`width=\"24px\"`, `width=\"${this.size}px\"`);\n            }\n        }\n\n        this.preparing = false;\n        return symbol;\n    }\n\n    public createIcon(symbol: string): void {\n        this.renderer.createElement('svg', symbol);\n    }\n\n    public createSafeHtml(symbol: string): SafeHtml {\n        return this.sanitizer.bypassSecurityTrustHtml(symbol);\n    }\n\n    public renderComponentSvg(): void {\n        this.svg = this.createSafeHtml(this.prepareSymbol(this.icon, this.color));\n    }\n\n    public setIconColor(color: string): void {\n        if (color && color.length > 0) {\n            const symbol = this.elementRef.nativeElement.querySelector(`[class=\"icon\"]`);\n            this.renderer.setAttribute(symbol, 'fill', color);\n        }\n    }\n\n    public ngAfterContentInit(): void {\n        const svg = this.elementRef.nativeElement.querySelector(`[fill=\"var(--base)\"]`);\n        if (svg) {\n            this.renderer.setAttribute(svg, 'height', `${this.size}px`);\n            this.renderer.setAttribute(svg, 'width', `${this.size}px`);\n            this.renderer.setAttribute(svg, `fill`, this.color);\n        }\n    }\n\n    public ngOnInit(): void {\n        if (!this.icon) {\n            this.icon = 'ngx-slice';\n        }\n        this.svg = this.createSafeHtml(this.prepareSymbol(this.icon, this.color));\n    }\n}\n"]}