UNPKG

@taiga-ui/kit

Version:
96 lines 12.7 kB
import { __decorate, __param } from "tslib"; import { DOCUMENT } from '@angular/common'; import { Directive, ElementRef, Inject, Input, OnChanges, Renderer2 } from '@angular/core'; import { px, svgNodeFilter, tuiDefaultProp, TuiDestroyService, TuiResizeService, } from '@taiga-ui/cdk'; import { Observable } from 'rxjs'; // @dynamic var TuiHighlightDirective = /** @class */ (function () { function TuiHighlightDirective(documentRef, elementRef, renderer, resize$) { var _this = this; this.documentRef = documentRef; this.elementRef = elementRef; this.renderer = renderer; this.tuiHighlight = ''; this.highlight = this.setUpHighlight(); this.treeWalker = this.documentRef.createTreeWalker(this.elementRef.nativeElement, NodeFilter.SHOW_TEXT, svgNodeFilter, false); resize$.subscribe(function () { _this.updateStyles(); }); } Object.defineProperty(TuiHighlightDirective.prototype, "match", { get: function () { return this.indexOf(this.elementRef.nativeElement.textContent) !== -1; }, enumerable: true, configurable: true }); TuiHighlightDirective.prototype.ngOnChanges = function () { this.updateStyles(); }; TuiHighlightDirective.prototype.updateStyles = function () { this.highlight.style.display = 'none'; if (!this.match) { return; } this.treeWalker.currentNode = this.elementRef.nativeElement; do { var index = this.indexOf(this.treeWalker.currentNode.nodeValue); if (index === -1) { continue; } var range = this.documentRef.createRange(); range.setStart(this.treeWalker.currentNode, index); range.setEnd(this.treeWalker.currentNode, index + this.tuiHighlight.length); var hostRect = this.elementRef.nativeElement.getBoundingClientRect(); var _a = range.getBoundingClientRect(), left = _a.left, top_1 = _a.top, width = _a.width, height = _a.height; var style = this.highlight.style; style.left = px(left - hostRect.left); style.top = px(top_1 - hostRect.top); style.width = px(width); style.height = px(height); style.display = 'block'; return; } while (this.treeWalker.nextNode()); }; TuiHighlightDirective.prototype.indexOf = function (source) { return !source || !this.tuiHighlight ? -1 : source.toLowerCase().indexOf(this.tuiHighlight.toLowerCase()); }; TuiHighlightDirective.prototype.setUpHighlight = function () { var highlight = this.renderer.createElement('div'); var style = highlight.style; style.background = 'var(--tui-selection)'; style.zIndex = '-1'; style.position = 'absolute'; this.renderer.appendChild(this.elementRef.nativeElement, highlight); return highlight; }; TuiHighlightDirective.ctorParameters = function () { return [ { type: Document, decorators: [{ type: Inject, args: [DOCUMENT,] }] }, { type: ElementRef, decorators: [{ type: Inject, args: [ElementRef,] }] }, { type: Renderer2, decorators: [{ type: Inject, args: [Renderer2,] }] }, { type: Observable, decorators: [{ type: Inject, args: [TuiResizeService,] }] } ]; }; __decorate([ Input(), tuiDefaultProp() ], TuiHighlightDirective.prototype, "tuiHighlight", void 0); TuiHighlightDirective = __decorate([ Directive({ selector: '[tuiHighlight]', host: { '[style.position]': '"relative"', '[style.zIndex]': '0', }, providers: [TuiDestroyService, TuiResizeService], }), __param(0, Inject(DOCUMENT)), __param(1, Inject(ElementRef)), __param(2, Inject(Renderer2)), __param(3, Inject(TuiResizeService)) ], TuiHighlightDirective); return TuiHighlightDirective; }()); export { TuiHighlightDirective }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"highlight.directive.js","sourceRoot":"ng://@taiga-ui/kit/directives/highlight/","sources":["highlight.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport {Directive, ElementRef, Inject, Input, OnChanges, Renderer2} from '@angular/core';\nimport {\n    px,\n    svgNodeFilter,\n    tuiDefaultProp,\n    TuiDestroyService,\n    TuiResizeService,\n} from '@taiga-ui/cdk';\nimport {Observable} from 'rxjs';\n\n// @dynamic\n@Directive({\n    selector: '[tuiHighlight]',\n    host: {\n        '[style.position]': '\"relative\"',\n        '[style.zIndex]': '0',\n    },\n    providers: [TuiDestroyService, TuiResizeService],\n})\nexport class TuiHighlightDirective implements OnChanges {\n    @Input()\n    @tuiDefaultProp()\n    tuiHighlight = '';\n\n    private readonly highlight: HTMLElement = this.setUpHighlight();\n\n    private readonly treeWalker = this.documentRef.createTreeWalker(\n        this.elementRef.nativeElement,\n        NodeFilter.SHOW_TEXT,\n        svgNodeFilter,\n        false,\n    );\n\n    constructor(\n        @Inject(DOCUMENT) private readonly documentRef: Document,\n        @Inject(ElementRef) private readonly elementRef: ElementRef<HTMLElement>,\n        @Inject(Renderer2) private readonly renderer: Renderer2,\n        @Inject(TuiResizeService) resize$: Observable<unknown>,\n    ) {\n        resize$.subscribe(() => {\n            this.updateStyles();\n        });\n    }\n\n    get match(): boolean {\n        return this.indexOf(this.elementRef.nativeElement.textContent) !== -1;\n    }\n\n    ngOnChanges() {\n        this.updateStyles();\n    }\n\n    private updateStyles() {\n        this.highlight.style.display = 'none';\n\n        if (!this.match) {\n            return;\n        }\n\n        this.treeWalker.currentNode = this.elementRef.nativeElement;\n\n        do {\n            const index = this.indexOf(this.treeWalker.currentNode.nodeValue);\n\n            if (index === -1) {\n                continue;\n            }\n\n            const range = this.documentRef.createRange();\n\n            range.setStart(this.treeWalker.currentNode, index);\n            range.setEnd(this.treeWalker.currentNode, index + this.tuiHighlight.length);\n\n            const hostRect = this.elementRef.nativeElement.getBoundingClientRect();\n            const {left, top, width, height} = range.getBoundingClientRect();\n            const {style} = this.highlight;\n\n            style.left = px(left - hostRect.left);\n            style.top = px(top - hostRect.top);\n            style.width = px(width);\n            style.height = px(height);\n            style.display = 'block';\n\n            return;\n        } while (this.treeWalker.nextNode());\n    }\n\n    private indexOf(source: string | null): number {\n        return !source || !this.tuiHighlight\n            ? -1\n            : source.toLowerCase().indexOf(this.tuiHighlight.toLowerCase());\n    }\n\n    private setUpHighlight(): HTMLElement {\n        const highlight = this.renderer.createElement('div');\n        const {style} = highlight;\n\n        style.background = 'var(--tui-selection)';\n        style.zIndex = '-1';\n        style.position = 'absolute';\n        this.renderer.appendChild(this.elementRef.nativeElement, highlight);\n\n        return highlight;\n    }\n}\n"]}