@progress/telerik-angular-native-report-viewer
Version:
Progress® Telerik® Native Report Viewer for Angular
394 lines (388 loc) • 47.6 kB
JavaScript
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"]}