UNPKG

@progress/telerik-angular-native-report-viewer

Version:

Progress® Telerik® Native Report Viewer for Angular

394 lines (388 loc) 47.6 kB
import { Component, Input, ViewChild, ViewEncapsulation } from '@angular/core'; import { chevronDownIcon, chevronUpIcon, convertLowercaseIcon, regularExpressionIcon, wholeWordIcon } from '@progress/kendo-svg-icons'; import { Subscription, take } from 'rxjs'; import * as i0 from "@angular/core"; import * as i1 from "../reporting-angular-viewer.service"; import * as i2 from "@angular/common"; import * as i3 from "@progress/kendo-angular-dialog"; import * as i4 from "@progress/kendo-angular-dropdowns"; import * as i5 from "@progress/kendo-angular-listbox"; import * as i6 from "@progress/kendo-angular-buttons"; import * as i7 from "../directives/after-filter-changed.directive"; export class SearchComponent { constructor(ngZone, service) { this.ngZone = ngZone; this.service = service; this.chevronUpIcon = chevronUpIcon; this.wholeWordIcon = wholeWordIcon; this.chevronDownIcon = chevronDownIcon; this.convertToLowerCaseIcon = convertLowercaseIcon; this.regularExpressionIcon = regularExpressionIcon; this.windowTop = 30; this.searchResults = []; this.isComboboxOpen = false; this.searchText = ''; this.opened = true; this.selectedIndex = 0; this.searchInfo = { searchToken: '', matchCase: false, matchWholeWord: false, useRegularExpressions: false }; this.subs = new Subscription(); } ngOnInit() { const reportElemWidth = this.service.reportWidth; this.windowHeight = this.service.windowHeight; this.windowWidth = this.service.windowWidth; this.windowLeft = reportElemWidth - (this.windowWidth + 40); } ngAfterViewInit() { this.service.searchManager?.on('searchComplete', (results) => this.onSearchComplete(results)); this.ngZone.onStable.pipe(take(1)).subscribe(_ => this.comboBox?.focus()); const combobox = this.comboBox?.wrapper?.nativeElement; this.subs.add(combobox.addEventListener('keydown', (event) => this.onArrowEvent(event), true)); } ngOnDestroy() { this.subs.unsubscribe(); } toggle(isOpened) { this.service.isSearchWindowOpen = isOpened; this.searchResults = []; this.service.searchManager.closeSearch(); } handleFilter(value) { if (value === "") { return; } this.searchText = value; this.search(value, true); } onWidthChange(width) { this.service.windowWidth = width; } onHeightChange(height) { this.service.windowHeight = height; } onBlur() { this.searchText = this.comboBox.text = this.comboBox?.searchbar.value; } search(text, isTextFilter = false) { if (typeof text !== 'string' && !isTextFilter) return; if (text && this.searchTerms.indexOf(text) === -1) { this.searchTerms.push(text); } if (this.searchInfo.searchToken !== text) { this.selectedIndex = 0; } this.comboBox.value = text; this.comboBox.searchBarChange(text); this.searchInfo.searchToken = text; this.service.searchManager?.search(this.searchInfo); this.ngZone.onStable.pipe(take(1)).subscribe(_ => this.comboBox?.focus()); } onSearchFilter(filterName) { this.selectedIndex = 0; this.searchInfo[filterName] = !this.searchInfo[filterName]; this.search(this.searchInfo.searchToken); } onSelectionChange(item) { const searchResultItem = this.searchResults[item.index]; this.service.searchManager?.highlightSearchItem(searchResultItem); } open(event, comboBox) { if (event.target.closest('button') && !this.isComboboxOpen) { this.isComboboxOpen = true; comboBox.toggle(true); } } onClose() { setTimeout(() => this.isComboboxOpen = false); } onNavigateButtons(direction, sourceTarget = 'listboxNav') { const topReached = direction === 'up' && this.selectedIndex <= 0; const bottomReached = direction === 'down' && this.selectedIndex >= this.searchResults.length - 1; if (topReached || bottomReached) { return; } this.selectedIndex = this.selectedIndex + (direction === 'up' ? -1 : 1); this.listbox?.selectionService.select(this.selectedIndex); } getLocaleMessage(message) { return this.service.options.messages[`ReportViewer_SearchDialog${message}`]; } onArrowEvent(event) { event.stopImmediatePropagation(); const searchResultItems = this.searchResults.length; if (searchResultItems > 0) { const isArrowUp = event.key === 'ArrowUp'; const isArrowDown = event.key === 'ArrowDown'; if (isArrowUp || isArrowDown) { event.preventDefault(); const dir = isArrowUp ? 'up' : 'down'; this.onNavigateButtons(dir, 'comboboxNav'); } const currentListboxItem = this.listbox.listboxItems.toArray()[this.selectedIndex].nativeElement; currentListboxItem?.focus(); this.ngZone.onStable.pipe(take(1)).subscribe(() => this.comboBox?.focus()); } } onSearchComplete(results) { let totalCount = results.length; if (totalCount > 250) { results = results.slice(0, 250); } this.searchResults = results; if (results) { this.listbox?.selectItem(0); } if (totalCount > 0) { this.service.searchManager?.navigateToPage(results[0]); } } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchComponent, deps: [{ token: i0.NgZone }, { token: i1.ReportingAngularViewerService }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: SearchComponent, selector: "search-window", inputs: { searchTerms: "searchTerms" }, viewQueries: [{ propertyName: "listbox", first: true, predicate: ["listBox"], descendants: true }, { propertyName: "comboBox", first: true, predicate: ["comboBox"], descendants: true }], ngImport: i0, template: ` <kendo-window (close)="toggle(false)" class="trv-search trv-search-dialog" [height]="390" [(top)]="windowTop" [(left)]="windowLeft" (widthChange)="onWidthChange($event)" (heightChange)="onHeightChange($event)" [width]="windowWidth" [height]="windowHeight" [minHeight]="390" [minWidth]="330" > <kendo-window-titlebar> <span class="k-window-title"> {{ getLocaleMessage('Title') }} </span> <button kendoWindowMinimizeAction></button> <button kendoWindowRestoreAction></button> <button kendoWindowCloseAction></button> </kendo-window-titlebar> <div class="trv-search-window trv-window k-window-content"> <div class="search-dialog-wrapper"> <kendo-combobox #comboBox [data]="searchTerms" [value]="searchText" [allowCustom]="true" [filterable]="true" [placeholder]="getLocaleMessage('ComboBoxPlaceholderText')" (afterFilterChanged)="handleFilter($event)" (click)="open($event, comboBox)" (close)="onClose()" (blur)="onBlur()" (valueChange)="search($event)" (open)="$event.preventDefault()" ></kendo-combobox> <div class="k-hstack k-gap-2 k-ml-2"> <button kendoButton fillMode="flat" icon="convert-lowercase" [svgIcon]="convertToLowerCaseIcon" [title]="getLocaleMessage('MatchCaseTitle')" [selected]="searchInfo.matchCase" (click)="onSearchFilter('matchCase')"> </button> <button kendoButton fillMode="flat" icon="whole-word" [svgIcon]="wholeWordIcon" [title]="getLocaleMessage('MatchWholeWordTitle')" [selected]="searchInfo.matchWholeWord" (click)="onSearchFilter('matchWholeWord')"> </button> <button kendoButton fillMode="flat" icon="regular-expression" [svgIcon]="regularExpressionIcon" [title]="getLocaleMessage('UseRegexTitle')" [selected]="searchInfo.useRegularExpressions" (click)="onSearchFilter('useRegularExpressions')"> </button> </div> </div> <div class="trv-search-dialog-results k-hstack k-gap-3 k-align-items-center k-mt-3 k-mb-2"> <span *ngIf="searchResults.length > 0" class="trv-search-dialog-results-label"> Result {{ listBox.selectedIndex + 1}} of {{searchResults.length }} </span> <span *ngIf="searchResults.length === 0" class="trv-search-dialog-results-label"> {{ getLocaleMessage('NoResultsLabel') }} </span> <kendo-buttongroup> <button kendoButton fillMode="flat" icon="chevron-up" [svgIcon]="chevronUpIcon" [title]="getLocaleMessage('NavigateUpTitle')" (click)="onNavigateButtons('up')" [disabled]="selectedIndex <= 0"> </button> <button kendoButton fillMode="flat" icon="chevron-down" [svgIcon]="chevronDownIcon" [title]="getLocaleMessage('NavigateDownTitle')" (click)="onNavigateButtons('down');" [disabled]="selectedIndex + 1 >= searchResults.length"> </button> </kendo-buttongroup> </div> <kendo-listbox #listBox [style.width.%]="100" [data]="searchResults" [toolbar]="false" (selectionChange)="onSelectionChange($event)" > <ng-template kendoListBoxItemTemplate let-dataItem> <div [attr.data-uid]="dataItem.id" class="trv-search-dialog-results-row k-listview-item k-selected" role="option" > <span class="k-search-dialog-result-desc">{{dataItem.description}}</span> <span class="trv-search-dialog-results-pageSpan">page {{dataItem.page}}</span> </div> </ng-template> </kendo-listbox> </div> </kendo-window> `, isInline: true, styles: [".k-window-content .k-listbox{overflow:hidden;position:relative;flex-grow:1;height:auto}.k-window-content .k-list{max-height:100%}.trv-search{max-height:700px}.k-listview-item .k-search-dialog-result-desc{flex:1;margin-right:1em}.k-listview-item.trv-search-dialog-results-row{width:100%;display:flex;justify-content:space-between}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.WindowComponent, selector: "kendo-window", inputs: ["autoFocusedElement", "title", "draggable", "resizable", "themeColor", "keepContent", "state", "minWidth", "minHeight", "width", "height", "top", "left"], outputs: ["dragStart", "dragEnd", "resizeStart", "resizeEnd", "close", "widthChange", "heightChange", "topChange", "leftChange", "stateChange"], exportAs: ["kendoWindow"] }, { kind: "component", type: i3.WindowCloseActionDirective, selector: "button[kendoWindowCloseAction]", inputs: ["window"], exportAs: ["kendoWindowCloseAction"] }, { kind: "component", type: i3.WindowMinimizeActionDirective, selector: "button[kendoWindowMinimizeAction]", inputs: ["window"], exportAs: ["kendoWindowMinimizeAction"] }, { kind: "component", type: i3.WindowRestoreActionDirective, selector: "button[kendoWindowRestoreAction]", inputs: ["window"], exportAs: ["kendoWindowRestoreAction"] }, { kind: "component", type: i3.WindowTitleBarComponent, selector: "kendo-window-titlebar", inputs: ["template", "id"] }, { kind: "component", type: i4.ComboBoxComponent, selector: "kendo-combobox", inputs: ["icon", "svgIcon", "inputAttributes", "showStickyHeader", "focusableId", "allowCustom", "data", "value", "textField", "valueField", "valuePrimitive", "valueNormalizer", "placeholder", "adaptiveMode", "title", "subtitle", "popupSettings", "listHeight", "loading", "suggest", "clearButton", "disabled", "itemDisabled", "readonly", "tabindex", "tabIndex", "filterable", "virtual", "size", "rounded", "fillMode"], outputs: ["valueChange", "selectionChange", "filterChange", "open", "opened", "close", "closed", "focus", "blur", "inputFocus", "inputBlur", "escape"], exportAs: ["kendoComboBox"] }, { kind: "component", type: i5.ListBoxComponent, selector: "kendo-listbox", inputs: ["textField", "data", "size", "toolbar", "listboxLabel", "listboxToolbarLabel", "itemDisabled"], outputs: ["selectionChange", "actionClick", "getChildListbox"] }, { kind: "directive", type: i5.ItemTemplateDirective, selector: "[kendoListBoxItemTemplate]" }, { kind: "component", type: i6.ButtonComponent, selector: "button[kendoButton]", inputs: ["arrowIcon", "toggleable", "togglable", "selected", "tabIndex", "imageUrl", "iconClass", "icon", "disabled", "size", "rounded", "fillMode", "themeColor", "svgIcon", "primary", "look"], outputs: ["selectedChange", "click"], exportAs: ["kendoButton"] }, { kind: "component", type: i6.ButtonGroupComponent, selector: "kendo-buttongroup", inputs: ["disabled", "selection", "width", "tabIndex", "navigable"], outputs: ["navigate"], exportAs: ["kendoButtonGroup"] }, { kind: "directive", type: i7.afterFilterChangedDirective, selector: "[afterFilterChanged]", inputs: ["filterChangeDelay"], outputs: ["afterFilterChanged"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: SearchComponent, decorators: [{ type: Component, args: [{ selector: 'search-window', template: ` <kendo-window (close)="toggle(false)" class="trv-search trv-search-dialog" [height]="390" [(top)]="windowTop" [(left)]="windowLeft" (widthChange)="onWidthChange($event)" (heightChange)="onHeightChange($event)" [width]="windowWidth" [height]="windowHeight" [minHeight]="390" [minWidth]="330" > <kendo-window-titlebar> <span class="k-window-title"> {{ getLocaleMessage('Title') }} </span> <button kendoWindowMinimizeAction></button> <button kendoWindowRestoreAction></button> <button kendoWindowCloseAction></button> </kendo-window-titlebar> <div class="trv-search-window trv-window k-window-content"> <div class="search-dialog-wrapper"> <kendo-combobox #comboBox [data]="searchTerms" [value]="searchText" [allowCustom]="true" [filterable]="true" [placeholder]="getLocaleMessage('ComboBoxPlaceholderText')" (afterFilterChanged)="handleFilter($event)" (click)="open($event, comboBox)" (close)="onClose()" (blur)="onBlur()" (valueChange)="search($event)" (open)="$event.preventDefault()" ></kendo-combobox> <div class="k-hstack k-gap-2 k-ml-2"> <button kendoButton fillMode="flat" icon="convert-lowercase" [svgIcon]="convertToLowerCaseIcon" [title]="getLocaleMessage('MatchCaseTitle')" [selected]="searchInfo.matchCase" (click)="onSearchFilter('matchCase')"> </button> <button kendoButton fillMode="flat" icon="whole-word" [svgIcon]="wholeWordIcon" [title]="getLocaleMessage('MatchWholeWordTitle')" [selected]="searchInfo.matchWholeWord" (click)="onSearchFilter('matchWholeWord')"> </button> <button kendoButton fillMode="flat" icon="regular-expression" [svgIcon]="regularExpressionIcon" [title]="getLocaleMessage('UseRegexTitle')" [selected]="searchInfo.useRegularExpressions" (click)="onSearchFilter('useRegularExpressions')"> </button> </div> </div> <div class="trv-search-dialog-results k-hstack k-gap-3 k-align-items-center k-mt-3 k-mb-2"> <span *ngIf="searchResults.length > 0" class="trv-search-dialog-results-label"> Result {{ listBox.selectedIndex + 1}} of {{searchResults.length }} </span> <span *ngIf="searchResults.length === 0" class="trv-search-dialog-results-label"> {{ getLocaleMessage('NoResultsLabel') }} </span> <kendo-buttongroup> <button kendoButton fillMode="flat" icon="chevron-up" [svgIcon]="chevronUpIcon" [title]="getLocaleMessage('NavigateUpTitle')" (click)="onNavigateButtons('up')" [disabled]="selectedIndex <= 0"> </button> <button kendoButton fillMode="flat" icon="chevron-down" [svgIcon]="chevronDownIcon" [title]="getLocaleMessage('NavigateDownTitle')" (click)="onNavigateButtons('down');" [disabled]="selectedIndex + 1 >= searchResults.length"> </button> </kendo-buttongroup> </div> <kendo-listbox #listBox [style.width.%]="100" [data]="searchResults" [toolbar]="false" (selectionChange)="onSelectionChange($event)" > <ng-template kendoListBoxItemTemplate let-dataItem> <div [attr.data-uid]="dataItem.id" class="trv-search-dialog-results-row k-listview-item k-selected" role="option" > <span class="k-search-dialog-result-desc">{{dataItem.description}}</span> <span class="trv-search-dialog-results-pageSpan">page {{dataItem.page}}</span> </div> </ng-template> </kendo-listbox> </div> </kendo-window> `, encapsulation: ViewEncapsulation.None, styles: [".k-window-content .k-listbox{overflow:hidden;position:relative;flex-grow:1;height:auto}.k-window-content .k-list{max-height:100%}.trv-search{max-height:700px}.k-listview-item .k-search-dialog-result-desc{flex:1;margin-right:1em}.k-listview-item.trv-search-dialog-results-row{width:100%;display:flex;justify-content:space-between}\n"] }] }], ctorParameters: function () { return [{ type: i0.NgZone }, { type: i1.ReportingAngularViewerService }]; }, propDecorators: { searchTerms: [{ type: Input }], listbox: [{ type: ViewChild, args: ['listBox'] }], comboBox: [{ type: ViewChild, args: ['comboBox'] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-window.component.js","sourceRoot":"","sources":["../../../../src/lib/search/search-window.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, Input, NgZone, OnDestroy, OnInit, ViewChild, ViewEncapsulation } from '@angular/core';\nimport { ReportingAngularViewerService } from '../reporting-angular-viewer.service';\nimport { SearchInfo, SearchResult } from '@progress/telerik-common-report-viewer';\nimport { ListBoxComponent, ListBoxSelectionEvent } from '@progress/kendo-angular-listbox';\nimport {\n    SVGIcon,\n    chevronDownIcon,\n    chevronUpIcon,\n    convertLowercaseIcon,\n    regularExpressionIcon,\n    wholeWordIcon\n} from '@progress/kendo-svg-icons';\nimport { ComboBoxComponent } from '@progress/kendo-angular-dropdowns';\nimport { Subscription, take } from 'rxjs';\n\n@Component({\n    selector: 'search-window',\n    template: `\n        <kendo-window\n            (close)=\"toggle(false)\"\n            class=\"trv-search trv-search-dialog\"\n            [height]=\"390\"\n            [(top)]=\"windowTop\"\n            [(left)]=\"windowLeft\"\n            (widthChange)=\"onWidthChange($event)\"\n            (heightChange)=\"onHeightChange($event)\"\n            [width]=\"windowWidth\"\n            [height]=\"windowHeight\"\n            [minHeight]=\"390\"\n            [minWidth]=\"330\"\n        >\n            <kendo-window-titlebar>\n                <span class=\"k-window-title\"> {{ getLocaleMessage('Title') }} </span>\n                <button kendoWindowMinimizeAction></button>\n                <button kendoWindowRestoreAction></button>\n                <button kendoWindowCloseAction></button>\n            </kendo-window-titlebar>\n            <div class=\"trv-search-window trv-window k-window-content\">\n                <div class=\"search-dialog-wrapper\">\n                    <kendo-combobox\n                        #comboBox\n                        [data]=\"searchTerms\"\n                        [value]=\"searchText\"\n                        [allowCustom]=\"true\"\n                        [filterable]=\"true\"\n                        [placeholder]=\"getLocaleMessage('ComboBoxPlaceholderText')\"\n                        (afterFilterChanged)=\"handleFilter($event)\"\n                        (click)=\"open($event, comboBox)\"\n                        (close)=\"onClose()\"\n                        (blur)=\"onBlur()\"\n                        (valueChange)=\"search($event)\"\n                        (open)=\"$event.preventDefault()\"\n                    ></kendo-combobox>\n\n                    <div class=\"k-hstack k-gap-2 k-ml-2\">\n                        <button \n                            kendoButton\n                            fillMode=\"flat\"\n                            icon=\"convert-lowercase\"\n                            [svgIcon]=\"convertToLowerCaseIcon\"\n                            [title]=\"getLocaleMessage('MatchCaseTitle')\"\n                            [selected]=\"searchInfo.matchCase\"\n                            (click)=\"onSearchFilter('matchCase')\">\n                        </button>\n                        <button\n                            kendoButton\n                            fillMode=\"flat\"\n                            icon=\"whole-word\"\n                            [svgIcon]=\"wholeWordIcon\"\n                            [title]=\"getLocaleMessage('MatchWholeWordTitle')\"\n                            [selected]=\"searchInfo.matchWholeWord\"\n                            (click)=\"onSearchFilter('matchWholeWord')\">\n                        </button>\n                        <button\n                            kendoButton\n                            fillMode=\"flat\"\n                            icon=\"regular-expression\"\n                            [svgIcon]=\"regularExpressionIcon\"\n                            [title]=\"getLocaleMessage('UseRegexTitle')\"\n                            [selected]=\"searchInfo.useRegularExpressions\"\n                            (click)=\"onSearchFilter('useRegularExpressions')\">\n                        </button>\n                    </div>\n                </div>\n\n                <div class=\"trv-search-dialog-results k-hstack k-gap-3 k-align-items-center k-mt-3 k-mb-2\">\n                    <span *ngIf=\"searchResults.length > 0\" class=\"trv-search-dialog-results-label\">\n                        Result {{ listBox.selectedIndex + 1}} of {{searchResults.length }}\n                    </span>\n                    <span *ngIf=\"searchResults.length === 0\" class=\"trv-search-dialog-results-label\">\n                        {{ getLocaleMessage('NoResultsLabel') }}\n                    </span>\n                    <kendo-buttongroup>\n                        <button\n                            kendoButton\n                            fillMode=\"flat\"\n                            icon=\"chevron-up\"\n                            [svgIcon]=\"chevronUpIcon\"\n                            [title]=\"getLocaleMessage('NavigateUpTitle')\"\n                            (click)=\"onNavigateButtons('up')\"\n                            [disabled]=\"selectedIndex <= 0\">\n                    </button>\n                    <button\n                        kendoButton\n                        fillMode=\"flat\"\n                        icon=\"chevron-down\"\n                        [svgIcon]=\"chevronDownIcon\"\n                        [title]=\"getLocaleMessage('NavigateDownTitle')\"\n                        (click)=\"onNavigateButtons('down');\"\n                        [disabled]=\"selectedIndex + 1 >= searchResults.length\">\n                    </button>\n                    </kendo-buttongroup>\n                </div>\n\n                <kendo-listbox\n                    #listBox\n                    [style.width.%]=\"100\"\n                    [data]=\"searchResults\"\n                    [toolbar]=\"false\"\n                    (selectionChange)=\"onSelectionChange($event)\"\n                >\n                    <ng-template kendoListBoxItemTemplate let-dataItem>\n                        <div\n                            [attr.data-uid]=\"dataItem.id\"\n                            class=\"trv-search-dialog-results-row k-listview-item k-selected\"\n                            role=\"option\"\n                        >\n                            <span class=\"k-search-dialog-result-desc\">{{dataItem.description}}</span>\n                            <span class=\"trv-search-dialog-results-pageSpan\">page {{dataItem.page}}</span>\n                        </div>\n                    </ng-template>\n                </kendo-listbox>\n            </div>\n        </kendo-window>\n    `,\n    styles: [`\n         .k-window-content .k-listbox {\n            overflow: hidden;\n            position: relative;\n            flex-grow: 1;\n            height: auto;\n        }\n\n        .k-window-content .k-list {\n            max-height: 100%;\n        }\n\n        .trv-search {\n            max-height: 700px;\n        }\n\n        .k-listview-item .k-search-dialog-result-desc {\n            flex: 1;\n            margin-right: 1em;\n        }\n\n        .k-listview-item.trv-search-dialog-results-row {\n            width: 100%;\n            display: flex;\n            justify-content: space-between;\n        }\n    `],\n    encapsulation: ViewEncapsulation.None\n})\nexport class SearchComponent implements OnInit, AfterViewInit, OnDestroy {\n    @Input() searchTerms: string[];\n\n    @ViewChild('listBox') public listbox!: ListBoxComponent;\n    @ViewChild('comboBox') public comboBox!: ComboBoxComponent;\n\n    public chevronUpIcon: SVGIcon = chevronUpIcon;\n    public wholeWordIcon: SVGIcon = wholeWordIcon;\n    public chevronDownIcon: SVGIcon = chevronDownIcon;\n    public convertToLowerCaseIcon: SVGIcon = convertLowercaseIcon;\n    public regularExpressionIcon: SVGIcon = regularExpressionIcon;\n\n    public windowTop: number = 30;\n    public windowLeft!: number;\n    public windowWidth!: number;\n    public windowHeight!: number;\n\n    public searchResults: SearchResult[] = [];\n    public isComboboxOpen: boolean = false;\n    public searchText: string = '';\n    public opened = true;\n    public selectedIndex: number = 0;\n\n    public searchInfo: SearchInfo = {\n        searchToken: '',\n        matchCase: false,\n        matchWholeWord: false,\n        useRegularExpressions: false\n    }\n\n    private subs: Subscription = new Subscription();\n\n    public constructor(\n        private ngZone: NgZone,\n        public service: ReportingAngularViewerService) {}\n\n    public ngOnInit(): void {\n        const reportElemWidth = this.service.reportWidth;\n\n        this.windowHeight = this.service.windowHeight;\n        this.windowWidth = this.service.windowWidth;\n        this.windowLeft = reportElemWidth - (this.windowWidth + 40);\n    }\n\n    public ngAfterViewInit(): void {\n        this.service.searchManager?.on('searchComplete', (results: SearchResult[]) => this.onSearchComplete(results));\n\n        this.ngZone.onStable.pipe(take(1)).subscribe(_ => this.comboBox?.focus());\n\n        const combobox = this.comboBox?.wrapper?.nativeElement;\n        this.subs.add(combobox.addEventListener('keydown', (event: any) => this.onArrowEvent(event), true));\n    }\n\n    public ngOnDestroy(): void {\n        this.subs.unsubscribe();\n    }\n\n    public toggle(isOpened: boolean): void {\n        this.service.isSearchWindowOpen = isOpened;\n        this.searchResults = [];\n        this.service.searchManager.closeSearch();\n    }\n\n    public handleFilter(value: any) {\n         if(value === \"\") {\n             return;\n         }\n\n        this.searchText = value;\n        this.search(value, true);\n    }\n\n    public onWidthChange(width: number): void {\n        this.service.windowWidth = width;\n    }\n\n    public onHeightChange(height: number): void {\n        this.service.windowHeight = height;\n    }\n\n    public onBlur() {\n        this.searchText = this.comboBox.text = this.comboBox?.searchbar.value;\n    }\n\n    public search(text: string, isTextFilter: boolean = false): void {\n        if (typeof text !== 'string' && !isTextFilter) return;\n\n        if (text && this.searchTerms.indexOf(text) === -1) {\n            this.searchTerms.push(text);\n        }\n\n        if (this.searchInfo.searchToken !== text) {\n            this.selectedIndex = 0;\n        }\n\n        this.comboBox.value = text;\n        this.comboBox.searchBarChange(text);\n        this.searchInfo.searchToken = text;\n\n        this.service.searchManager?.search(this.searchInfo);\n\n        this.ngZone.onStable.pipe(take(1)).subscribe(_ => this.comboBox?.focus());\n    }\n\n    public onSearchFilter(filterName: 'matchCase' | 'matchWholeWord' | 'useRegularExpressions'): void {\n        this.selectedIndex = 0;\n        this.searchInfo[filterName] = !this.searchInfo[filterName];\n\n        this.search(this.searchInfo.searchToken);\n    }\n\n    public onSelectionChange(item: ListBoxSelectionEvent): void {\n        const searchResultItem: SearchResult = this.searchResults[item.index];\n        this.service.searchManager?.highlightSearchItem(searchResultItem);\n    }\n\n    public open(event: any, comboBox: ComboBoxComponent): void {\n        if (event.target.closest('button') && !this.isComboboxOpen) {\n            this.isComboboxOpen = true;\n            comboBox.toggle(true);\n        }\n    }\n\n    public onClose(): void {\n        setTimeout(() => this.isComboboxOpen = false )\n    }\n\n    public onNavigateButtons(direction: 'up' | 'down', sourceTarget: 'comboboxNav' | 'listboxNav' = 'listboxNav'): void {\n        const topReached = direction === 'up' && this.selectedIndex <= 0;\n        const bottomReached = direction === 'down' && this.selectedIndex >= this.searchResults.length - 1;\n\n        if (topReached || bottomReached) {\n            return;\n        }\n\n        this.selectedIndex = this.selectedIndex + (direction === 'up' ? -1 : 1);\n\n        this.listbox?.selectionService.select(this.selectedIndex);\n    }\n\n    public getLocaleMessage(message: string): string {\n        return this.service.options.messages[`ReportViewer_SearchDialog${message}`];\n    }\n\n    private onArrowEvent(event: any): void {\n        event.stopImmediatePropagation();\n        const searchResultItems = this.searchResults.length;\n\n        if (searchResultItems > 0) {\n            const isArrowUp = event.key === 'ArrowUp';\n            const isArrowDown = event.key === 'ArrowDown'\n\n            if (isArrowUp || isArrowDown) {\n                event.preventDefault();\n\n                const dir: 'up' | 'down' = isArrowUp ? 'up' : 'down';\n                this.onNavigateButtons(dir, 'comboboxNav');\n            }\n\n            const currentListboxItem = this.listbox.listboxItems.toArray()[this.selectedIndex].nativeElement;\n            currentListboxItem?.focus();\n\n            this.ngZone.onStable.pipe(take(1)).subscribe(() => this.comboBox?.focus());\n        }\n    }\n\n    private onSearchComplete(results: SearchResult[]): void {\n        let totalCount = results.length;\n\n        if (totalCount > 250) {\n            results = results.slice(0, 250);\n        }\n\n        this.searchResults = results;\n\n        if (results) {\n            this.listbox?.selectItem(0);\n        }\n        \n        if (totalCount > 0) {\n            this.service.searchManager?.navigateToPage(results[0]);\n        }\n    }\n}\n"]}