UNPKG

fundamental-ngx

Version:

SAP Fiori Fundamentals, implemented in Angular

474 lines 35.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, EventEmitter, forwardRef, HostBinding, Input, Output, QueryList, ViewChild, ViewChildren, ViewEncapsulation } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; import { MenuItemDirective } from '../menu/menu-item.directive'; /** * Allows users to filter through results and select. * Can also be customized to execute a search function. * * Supports Angular Forms. */ export class SearchInputComponent { constructor() { /** * Values to be filtered in the search input. */ this.dropdownValues = []; /** * Filter function. Accepts an array of objects and a search term as arguments * and returns a string. See search input examples for details. */ this.filterFn = this.defaultFilter; /** * Whether the search input is in a shellbar * */ this.inShellbar = false; /** * Icon to display in the right-side button. */ this.glyph = 'search'; /** * Max height of the popover. Any overflowing elements will be accessible through scrolling. */ this.maxHeight = '200px'; /** * Whether the search input should be displayed in compact mode. */ this.compact = false; /** * Whether the matching string should be highlighted during filtration. */ this.highlight = true; /** * Whether the popover should close when a user selects a result. */ this.closeOnSelect = true; /** * Whether the input field should be populated with the result picked by the user. */ this.fillOnSelect = true; /** * Display function. Accepts an object of the same type as the * items passed to dropdownValues as argument, and outputs a string. * An arrow function can be used to access the *this* keyword in the calling component. * See search input examples for details. */ this.displayFn = this.defaultDisplay; /** * Event emitted when an item is clicked. Use *$event* to retrieve it. */ this.itemClicked = new EventEmitter(); /** * @hidden */ this.displayedValues = []; /** * @hidden */ this.isOpen = false; /** * @hidden */ this.searchInputClass = true; /** * @hidden */ this.shellBarClass = this.inShellbar; /** * @hidden */ this.onChange = (/** * @return {?} */ () => { }); /** * @hidden */ this.onTouched = (/** * @return {?} */ () => { }); } /** * @hidden * @param {?} event * @return {?} */ onInputKeydownHandler(event) { if (event.code === 'Enter' && this.searchFunction) { this.searchFunction(); } else if (event.code === 'ArrowDown') { event.preventDefault(); if (this.menuItems && this.menuItems.first) { this.menuItems.first.itemEl.nativeElement.children[0].focus(); } } } /** * @hidden * @return {?} */ onInputKeyupHandler() { if (this.inputText && this.inputText.length) { this.isOpen = true; } } /** * @hidden * @param {?} event * @param {?=} term * @return {?} */ onMenuKeydownHandler(event, term) { if (event.code === 'Enter' && term) { this.handleClickActions(term); this.itemClicked.emit({ item: term, index: this.dropdownValues.indexOf(term) }); } else if (event.code === 'ArrowDown') { event.preventDefault(); /** @type {?} */ let foundItem = false; /** @type {?} */ const menuItemsArray = this.menuItems.toArray(); menuItemsArray.forEach((/** * @param {?} item * @param {?} index * @return {?} */ (item, index) => { if (document.activeElement === item.itemEl.nativeElement.children[0] && !foundItem) { if (menuItemsArray[index + 1]) { menuItemsArray[index + 1].itemEl.nativeElement.children[0].focus(); } foundItem = true; } })); } else if (event.code === 'ArrowUp') { event.preventDefault(); /** @type {?} */ let foundItem = false; /** @type {?} */ const menuItemsArray = this.menuItems.toArray(); menuItemsArray.forEach((/** * @param {?} item * @param {?} index * @return {?} */ (item, index) => { if (!foundItem) { if (document.activeElement === item.itemEl.nativeElement.children[0] && index === 0) { this.searchInputElement.nativeElement.focus(); foundItem = true; } else if (document.activeElement === item.itemEl.nativeElement.children[0]) { if (menuItemsArray[index - 1]) { menuItemsArray[index - 1].itemEl.nativeElement.children[0].focus(); } foundItem = true; } } })); } } /** * @hidden * @param {?} event * @param {?} term * @return {?} */ onMenuClickHandler(event, term) { if (term) { this.handleClickActions(term); this.itemClicked.emit({ item: term, index: this.dropdownValues.indexOf(term) }); } } /** * @hidden * @param {?} event * @return {?} */ shellbarSearchInputClicked(event) { event.stopPropagation(); } /** * Get the input text of the input. * @return {?} */ get inputText() { return this.inputTextValue; } /** * Set the input text of the input. * @param {?} value * @return {?} */ set inputText(value) { this.inputTextValue = value; this.onChange(value); this.onTouched(); } /** * @hidden * @param {?} value * @return {?} */ writeValue(value) { this.inputTextValue = value; } /** * @hidden * @param {?} fn * @return {?} */ registerOnChange(fn) { this.onChange = fn; } /** * @hidden * @param {?} fn * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @private * @param {?} term * @return {?} */ handleClickActions(term) { if (this.closeOnSelect) { this.isOpen = false; } if (this.fillOnSelect) { this.inputText = this.displayFn(term); this.handleSearchTermChange(); } } /** * @hidden * @return {?} */ ngOnInit() { if (this.dropdownValues) { this.displayedValues = this.dropdownValues; } } /** * @hidden * @param {?} changes * @return {?} */ ngOnChanges(changes) { if (this.dropdownValues && (changes.dropdownValues || changes.searchTerm)) { if (this.inputText) { this.displayedValues = this.filterFn(this.dropdownValues, this.inputText); } else { this.displayedValues = this.dropdownValues; } } } /** * @hidden * @return {?} */ handleSearchTermChange() { this.displayedValues = this.filterFn(this.dropdownValues, this.inputText); } /** * @private * @param {?} str * @return {?} */ defaultDisplay(str) { return str; } /** * @private * @param {?} contentArray * @param {?} searchTerm * @return {?} */ defaultFilter(contentArray, searchTerm) { /** @type {?} */ const searchLower = searchTerm.toLocaleLowerCase(); return contentArray.filter((/** * @param {?} item * @return {?} */ item => { if (item) { return this.displayFn(item).toLocaleLowerCase().includes(searchLower); } })); } } SearchInputComponent.decorators = [ { type: Component, args: [{ selector: 'fd-search-input', template: "<fd-popover [(isOpen)]=\"isOpen\"\n [fillControl]=\"true\"\n [disabled]=\"disabled\"\n class=\"fd-search-input-popover-custom\"\n [ngClass]=\"{'fd-popover-body--display-none': displayedValues && !displayedValues.length}\">\n <fd-popover-control>\n <div *ngIf=\"!inShellbar\" class=\"fd-combobox-control\">\n <div class=\"fd-input-group fd-input-group--after\" [ngClass]=\"{'fd-input-group--compact': compact}\">\n <input #searchInputElement type=\"text\" class=\"fd-input\" [ngClass]=\"{'fd-input--compact': compact}\"\n (keydown)=\"onInputKeydownHandler($event)\"\n (keyup)=\"onInputKeyupHandler()\"\n [disabled]=\"disabled\"\n [(ngModel)]=\"inputText\"\n (ngModelChange)=\"handleSearchTermChange()\"\n placeholder=\"{{placeholder}}\">\n <span class=\"fd-input-group__addon fd-input-group__addon--after fd-input-group__addon--button\">\n <button type=\"button\" class=\"fd-button--light\" [ngClass]=\"('sap-icon--' + this.glyph)\"></button>\n </span>\n </div>\n </div>\n <div *ngIf=\"inShellbar\" class=\"fd-search-input__control\">\n <button tabindex=\"0\" type=\"button\" class=\"fd-button--shell\" [attr.aria-expanded]=\"isOpen\"\n [ngClass]=\"('sap-icon--' + this.glyph)\"></button>\n <div class=\"fd-search-input__closedcontrol\" [attr.aria-hidden]=\"!isOpen\">\n <div class=\"fd-search-input__controlinput\" [attr.aria-expanded]=\"isOpen\" aria-haspopup=\"true\">\n <input type=\"text\" class=\"fd-input\"\n (keydown)=\"onInputKeydownHandler($event)\"\n (keyup)=\"onInputKeyupHandler()\"\n [disabled]=\"disabled\"\n [(ngModel)]=\"inputText\"\n (ngModelChange)=\"handleSearchTermChange()\"\n placeholder=\"{{placeholder}}\"\n (click)=\"shellbarSearchInputClicked($event)\">\n </div>\n </div>\n </div>\n </fd-popover-control>\n <fd-popover-body *ngIf=\"displayedValues && displayedValues.length\">\n <fd-menu class=\"fd-search-input-menu-overflow\"\n [style.maxHeight]=\"maxHeight\">\n <ul fd-menu-list>\n <li fd-menu-item *ngFor=\"let term of displayedValues\"\n (click)=\"onMenuClickHandler($event, term)\"\n (keydown)=\"onMenuKeydownHandler($event, term)\">\n <a tabindex=\"0\" [innerHTML]=\"term | displayFnPipe:displayFn | highlight:inputText:highlight\"></a>\n </li>\n </ul>\n </fd-menu>\n </fd-popover-body>\n</fd-popover>\n", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ () => SearchInputComponent)), multi: true } ], host: { class: 'fd-search-input-custom' }, encapsulation: ViewEncapsulation.None, styles: [".fd-search-input-custom .fd-search-input-popover-custom{display:block}.fd-search-input-custom .fd-search-input-menu-overflow{overflow:auto}"] }] } ]; SearchInputComponent.propDecorators = { dropdownValues: [{ type: Input }], filterFn: [{ type: Input }], disabled: [{ type: Input }], placeholder: [{ type: Input }], inShellbar: [{ type: Input }], glyph: [{ type: Input }], maxHeight: [{ type: Input }], searchFunction: [{ type: Input }], compact: [{ type: Input }], highlight: [{ type: Input }], closeOnSelect: [{ type: Input }], fillOnSelect: [{ type: Input }], displayFn: [{ type: Input }], itemClicked: [{ type: Output }], menuItems: [{ type: ViewChildren, args: [MenuItemDirective,] }], searchInputElement: [{ type: ViewChild, args: ['searchInputElement',] }], searchInputClass: [{ type: HostBinding, args: ['class.fd-search-input',] }], shellBarClass: [{ type: HostBinding, args: ['class.fd-search-input--closed',] }] }; if (false) { /** * Values to be filtered in the search input. * @type {?} */ SearchInputComponent.prototype.dropdownValues; /** * Filter function. Accepts an array of objects and a search term as arguments * and returns a string. See search input examples for details. * @type {?} */ SearchInputComponent.prototype.filterFn; /** * Whether the search input is disabled. * * @type {?} */ SearchInputComponent.prototype.disabled; /** * Placeholder of the search input. * * @type {?} */ SearchInputComponent.prototype.placeholder; /** * Whether the search input is in a shellbar * * @type {?} */ SearchInputComponent.prototype.inShellbar; /** * Icon to display in the right-side button. * @type {?} */ SearchInputComponent.prototype.glyph; /** * Max height of the popover. Any overflowing elements will be accessible through scrolling. * @type {?} */ SearchInputComponent.prototype.maxHeight; /** * Search function to execute when the Enter key is pressed on the main input. * @type {?} */ SearchInputComponent.prototype.searchFunction; /** * Whether the search input should be displayed in compact mode. * @type {?} */ SearchInputComponent.prototype.compact; /** * Whether the matching string should be highlighted during filtration. * @type {?} */ SearchInputComponent.prototype.highlight; /** * Whether the popover should close when a user selects a result. * @type {?} */ SearchInputComponent.prototype.closeOnSelect; /** * Whether the input field should be populated with the result picked by the user. * @type {?} */ SearchInputComponent.prototype.fillOnSelect; /** * Display function. Accepts an object of the same type as the * items passed to dropdownValues as argument, and outputs a string. * An arrow function can be used to access the *this* keyword in the calling component. * See search input examples for details. * @type {?} */ SearchInputComponent.prototype.displayFn; /** * Event emitted when an item is clicked. Use *$event* to retrieve it. * @type {?} */ SearchInputComponent.prototype.itemClicked; /** * @hidden * @type {?} */ SearchInputComponent.prototype.menuItems; /** * @hidden * @type {?} */ SearchInputComponent.prototype.searchInputElement; /** * @hidden * @type {?} */ SearchInputComponent.prototype.displayedValues; /** * @hidden * @type {?} */ SearchInputComponent.prototype.isOpen; /** * @hidden * @type {?} */ SearchInputComponent.prototype.inputTextValue; /** * @hidden * @type {?} */ SearchInputComponent.prototype.searchInputClass; /** * @hidden * @type {?} */ SearchInputComponent.prototype.shellBarClass; /** * @hidden * @type {?} */ SearchInputComponent.prototype.onChange; /** * @hidden * @type {?} */ SearchInputComponent.prototype.onTouched; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-input.component.js","sourceRoot":"ng://fundamental-ngx/","sources":["lib/search-input/search-input.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACH,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EAGL,MAAM,EACN,SAAS,EAET,SAAS,EACT,YAAY,EACZ,iBAAiB,EACpB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,iBAAiB,EAAE,MAAM,6BAA6B,CAAC;;;;;;;AAwBhE,MAAM,OAAO,oBAAoB;IAhBjC;;;;QAoBI,mBAAc,GAAU,EAAE,CAAC;;;;;QAK3B,aAAQ,GAAa,IAAI,CAAC,aAAa,CAAC;;;;QAYxC,eAAU,GAAY,KAAK,CAAC;;;;QAI5B,UAAK,GAAW,QAAQ,CAAC;;;;QAIzB,cAAS,GAAW,OAAO,CAAC;;;;QAQ5B,YAAO,GAAY,KAAK,CAAC;;;;QAIzB,cAAS,GAAY,IAAI,CAAC;;;;QAI1B,kBAAa,GAAY,IAAI,CAAC;;;;QAI9B,iBAAY,GAAY,IAAI,CAAC;;;;;;;QAO7B,cAAS,GAAa,IAAI,CAAC,cAAc,CAAC;;;;QAI1C,gBAAW,GAA6C,IAAI,YAAY,EAA8B,CAAC;;;;QAWvG,oBAAe,GAAU,EAAE,CAAC;;;;QAG5B,WAAM,GAAY,KAAK,CAAC;;;;QAOxB,qBAAgB,GAAG,IAAI,CAAC;;;;QAIxB,kBAAa,GAAG,IAAI,CAAC,UAAU,CAAC;;;;QAwEhC,aAAQ;;;QAAQ,GAAG,EAAE,GAAE,CAAC,EAAC;;;;QAGzB,cAAS;;;QAAQ,GAAG,EAAE,GAAE,CAAC,EAAC;IA2E9B,CAAC;;;;;;IAnJG,qBAAqB,CAAC,KAAK;QACvB,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,IAAI,IAAI,CAAC,cAAc,EAAE;YAC/C,IAAI,CAAC,cAAc,EAAE,CAAC;SACzB;aAAM,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,EAAE;YACnC,KAAK,CAAC,cAAc,EAAE,CAAC;YACvB,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;gBACxC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;aACjE;SACJ;IACL,CAAC;;;;;IAGD,mBAAmB;QACf,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE;YACzC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;SACtB;IACL,CAAC;;;;;;;IAGD,oBAAoB,CAAC,KAAK,EAAE,IAAK;QAC7B,IAAI,KAAK,CAAC,IAAI,KAAK,OAAO,IAAI,IAAI,EAAE;YAChC,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,EAAC,CAAC,CAAC;SACjF;aAAM,IAAI,KAAK,CAAC,IAAI,KAAK,WAAW,EAAE;YACnC,KAAK,CAAC,cAAc,EAAE,CAAC;;gBACnB,SAAS,GAAG,KAAK;;kBACf,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE;YAC/C,cAAc,CAAC,OAAO;;;;;YAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBACnC,IAAI,QAAQ,CAAC,aAAa,KAAK,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,EAAE;oBAChF,IAAI,cAAc,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE;wBAC3B,cAAc,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;qBACtE;oBACD,SAAS,GAAG,IAAI,CAAC;iBACpB;YACL,CAAC,EAAC,CAAA;SACL;aAAM,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE;YACjC,KAAK,CAAC,cAAc,EAAE,CAAC;;gBACnB,SAAS,GAAG,KAAK;;kBACf,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE;YAC/C,cAAc,CAAC,OAAO;;;;;YAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;gBACnC,IAAI,CAAC,SAAS,EAAE;oBACZ,IAAI,QAAQ,CAAC,aAAa,KAAK,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,KAAK,KAAK,CAAC,EAAE;wBACjF,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;wBAC9C,SAAS,GAAG,IAAI,CAAC;qBACpB;yBAAM,IAAI,QAAQ,CAAC,aAAa,KAAK,IAAI,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE;wBACzE,IAAI,cAAc,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE;4BAC3B,cAAc,CAAC,KAAK,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;yBACtE;wBACD,SAAS,GAAG,IAAI,CAAC;qBACpB;iBACJ;YACL,CAAC,EAAC,CAAC;SACN;IACL,CAAC;;;;;;;IAGD,kBAAkB,CAAC,KAAK,EAAE,IAAI;QAC1B,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,IAAI,CAAC,EAAC,CAAC,CAAC;SACjF;IACL,CAAC;;;;;;IAGD,0BAA0B,CAAC,KAAK;QAC5B,KAAK,CAAC,eAAe,EAAE,CAAC;IAC5B,CAAC;;;;;IASD,IAAI,SAAS;QACT,OAAO,IAAI,CAAC,cAAc,CAAC;IAC/B,CAAC;;;;;;IAGD,IAAI,SAAS,CAAC,KAAK;QACf,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrB,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;;;;;;IAGD,UAAU,CAAC,KAAU;QACjB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAChC,CAAC;;;;;;IAGD,gBAAgB,CAAC,EAAE;QACf,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACvB,CAAC;;;;;;IAGD,iBAAiB,CAAC,EAAE;QAChB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;;;;;;IAEO,kBAAkB,CAAC,IAAI;QAC3B,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;SACvB;QACD,IAAI,IAAI,CAAC,YAAY,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;YACtC,IAAI,CAAC,sBAAsB,EAAE,CAAC;SACjC;IACL,CAAC;;;;;IAGD,QAAQ;QACJ,IAAI,IAAI,CAAC,cAAc,EAAE;YACrB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,cAAc,CAAC;SAC9C;IACL,CAAC;;;;;;IAGD,WAAW,CAAC,OAAsB;QAC9B,IAAI,IAAI,CAAC,cAAc,IAAI,CAAC,OAAO,CAAC,cAAc,IAAI,OAAO,CAAC,UAAU,CAAC,EAAE;YACvE,IAAI,IAAI,CAAC,SAAS,EAAE;gBAChB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;aAC7E;iBAAM;gBACH,IAAI,CAAC,eAAe,GAAI,IAAI,CAAC,cAAc,CAAC;aAC/C;SACJ;IACL,CAAC;;;;;IAGD,sBAAsB;QAClB,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAC9E,CAAC;;;;;;IAEO,cAAc,CAAC,GAAQ;QAC3B,OAAO,GAAG,CAAC;IACf,CAAC;;;;;;;IAEO,aAAa,CAAC,YAAmB,EAAE,UAAkB;;cACnD,WAAW,GAAG,UAAU,CAAC,iBAAiB,EAAE;QAClD,OAAO,YAAY,CAAC,MAAM;;;;QAAC,IAAI,CAAC,EAAE;YAC9B,IAAI,IAAI,EAAE;gBACN,OAAO,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,iBAAiB,EAAE,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAC;aACzE;QACL,CAAC,EAAC,CAAC;IACP,CAAC;;;YAzPJ,SAAS,SAAC;gBACP,QAAQ,EAAE,iBAAiB;gBAC3B,45FAA4C;gBAE5C,SAAS,EAAE;oBACP;wBACI,OAAO,EAAE,iBAAiB;wBAC1B,WAAW,EAAE,UAAU;;;wBAAC,GAAG,EAAE,CAAC,oBAAoB,EAAC;wBACnD,KAAK,EAAE,IAAI;qBACd;iBACJ;gBACD,IAAI,EAAE;oBACF,KAAK,EAAE,wBAAwB;iBAClC;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;;aACxC;;;6BAII,KAAK;uBAKL,KAAK;uBAIL,KAAK;0BAIL,KAAK;yBAIL,KAAK;oBAIL,KAAK;wBAIL,KAAK;6BAIL,KAAK;sBAIL,KAAK;wBAIL,KAAK;4BAIL,KAAK;2BAIL,KAAK;wBAOL,KAAK;0BAIL,MAAM;wBAIN,YAAY,SAAC,iBAAiB;iCAI9B,SAAS,SAAC,oBAAoB;+BAa9B,WAAW,SAAC,uBAAuB;4BAInC,WAAW,SAAC,+BAA+B;;;;;;;IAjF5C,8CAC2B;;;;;;IAI3B,wCACwC;;;;;IAGxC,wCACkB;;;;;IAGlB,2CACoB;;;;;IAGpB,0CAC4B;;;;;IAG5B,qCACyB;;;;;IAGzB,yCAC4B;;;;;IAG5B,8CACyB;;;;;IAGzB,uCACyB;;;;;IAGzB,yCAC0B;;;;;IAG1B,6CAC8B;;;;;IAG9B,4CAC6B;;;;;;;;IAM7B,yCAC0C;;;;;IAG1C,2CACuG;;;;;IAGvG,yCACwC;;;;;IAGxC,kDAC+B;;;;;IAG/B,+CAA4B;;;;;IAG5B,sCAAwB;;;;;IAGxB,8CAAuB;;;;;IAGvB,gDACwB;;;;;IAGxB,6CACgC;;;;;IAwEhC,wCAAyB;;;;;IAGzB,yCAA0B","sourcesContent":["import {\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n    ViewChild,\n    ViewChildren,\n    ViewEncapsulation\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { MenuItemDirective } from '../menu/menu-item.directive';\n\n/**\n * Allows users to filter through results and select.\n * Can also be customized to execute a search function.\n *\n * Supports Angular Forms.\n */\n@Component({\n    selector: 'fd-search-input',\n    templateUrl: './search-input.component.html',\n    styleUrls: ['./search-input.component.scss'],\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            useExisting: forwardRef(() => SearchInputComponent),\n            multi: true\n        }\n    ],\n    host: {\n        class: 'fd-search-input-custom'\n    },\n    encapsulation: ViewEncapsulation.None\n})\nexport class SearchInputComponent implements ControlValueAccessor, OnInit, OnChanges {\n\n    /** Values to be filtered in the search input. */\n    @Input()\n    dropdownValues: any[] = [];\n\n    /** Filter function. Accepts an array of objects and a search term as arguments\n     * and returns a string. See search input examples for details. */\n    @Input()\n    filterFn: Function = this.defaultFilter;\n\n    /** Whether the search input is disabled. **/\n    @Input()\n    disabled: boolean;\n\n    /** Placeholder of the search input. **/\n    @Input()\n    placeholder: string;\n\n    /** Whether the search input is in a shellbar **/\n    @Input()\n    inShellbar: boolean = false;\n\n    /** Icon to display in the right-side button. */\n    @Input()\n    glyph: string = 'search';\n\n    /** Max height of the popover. Any overflowing elements will be accessible through scrolling. */\n    @Input()\n    maxHeight: string = '200px';\n\n    /** Search function to execute when the Enter key is pressed on the main input. */\n    @Input()\n    searchFunction: Function;\n\n    /** Whether the search input should be displayed in compact mode. */\n    @Input()\n    compact: boolean = false;\n\n    /** Whether the matching string should be highlighted during filtration. */\n    @Input()\n    highlight: boolean = true;\n\n    /** Whether the popover should close when a user selects a result. */\n    @Input()\n    closeOnSelect: boolean = true;\n\n    /** Whether the input field should be populated with the result picked by the user. */\n    @Input()\n    fillOnSelect: boolean = true;\n\n    /** Display function. Accepts an object of the same type as the\n     * items passed to dropdownValues as argument, and outputs a string.\n     * An arrow function can be used to access the *this* keyword in the calling component.\n     * See search input examples for details. */\n    @Input()\n    displayFn: Function = this.defaultDisplay;\n\n    /** Event emitted when an item is clicked. Use *$event* to retrieve it. */\n    @Output()\n    itemClicked: EventEmitter<{item: any, index: number}> = new EventEmitter<{item: any, index: number}>();\n\n    /** @hidden */\n    @ViewChildren(MenuItemDirective)\n    menuItems: QueryList<MenuItemDirective>;\n\n    /** @hidden */\n    @ViewChild('searchInputElement')\n    searchInputElement: ElementRef;\n\n    /** @hidden */\n    displayedValues: any[] = [];\n\n    /** @hidden */\n    isOpen: boolean = false;\n\n    /** @hidden */\n    inputTextValue: string;\n\n    /** @hidden */\n    @HostBinding('class.fd-search-input')\n    searchInputClass = true;\n\n    /** @hidden */\n    @HostBinding('class.fd-search-input--closed')\n    shellBarClass = this.inShellbar;\n\n    /** @hidden */\n    onInputKeydownHandler(event) {\n        if (event.code === 'Enter' && this.searchFunction) {\n            this.searchFunction();\n        } else if (event.code === 'ArrowDown') {\n            event.preventDefault();\n            if (this.menuItems && this.menuItems.first) {\n                this.menuItems.first.itemEl.nativeElement.children[0].focus();\n            }\n        }\n    }\n\n    /** @hidden */\n    onInputKeyupHandler() {\n        if (this.inputText && this.inputText.length) {\n            this.isOpen = true;\n        }\n    }\n\n    /** @hidden */\n    onMenuKeydownHandler(event, term?) {\n        if (event.code === 'Enter' && term) {\n            this.handleClickActions(term);\n            this.itemClicked.emit({item: term, index: this.dropdownValues.indexOf(term)});\n        } else if (event.code === 'ArrowDown') {\n            event.preventDefault();\n            let foundItem = false;\n            const menuItemsArray = this.menuItems.toArray();\n            menuItemsArray.forEach((item, index) => {\n                if (document.activeElement === item.itemEl.nativeElement.children[0] && !foundItem) {\n                    if (menuItemsArray[index + 1]) {\n                        menuItemsArray[index + 1].itemEl.nativeElement.children[0].focus();\n                    }\n                    foundItem = true;\n                }\n            })\n        } else if (event.code === 'ArrowUp') {\n            event.preventDefault();\n            let foundItem = false;\n            const menuItemsArray = this.menuItems.toArray();\n            menuItemsArray.forEach((item, index) => {\n                if (!foundItem) {\n                    if (document.activeElement === item.itemEl.nativeElement.children[0] && index === 0) {\n                        this.searchInputElement.nativeElement.focus();\n                        foundItem = true;\n                    } else if (document.activeElement === item.itemEl.nativeElement.children[0]) {\n                        if (menuItemsArray[index - 1]) {\n                            menuItemsArray[index - 1].itemEl.nativeElement.children[0].focus();\n                        }\n                        foundItem = true;\n                    }\n                }\n            });\n        }\n    }\n\n    /** @hidden */\n    onMenuClickHandler(event, term) {\n        if (term) {\n            this.handleClickActions(term);\n            this.itemClicked.emit({item: term, index: this.dropdownValues.indexOf(term)});\n        }\n    }\n\n    /** @hidden */\n    shellbarSearchInputClicked(event) {\n        event.stopPropagation();\n    }\n\n    /** @hidden */\n    onChange: any = () => {};\n\n    /** @hidden */\n    onTouched: any = () => {};\n\n    /** Get the input text of the input. */\n    get inputText() {\n        return this.inputTextValue;\n    }\n\n    /** Set the input text of the input. */\n    set inputText(value) {\n        this.inputTextValue = value;\n        this.onChange(value);\n        this.onTouched();\n    }\n\n    /** @hidden */\n    writeValue(value: any) {\n        this.inputTextValue = value;\n    }\n\n    /** @hidden */\n    registerOnChange(fn) {\n        this.onChange = fn;\n    }\n\n    /** @hidden */\n    registerOnTouched(fn) {\n        this.onTouched = fn;\n    }\n\n    private handleClickActions(term): void {\n        if (this.closeOnSelect) {\n            this.isOpen = false;\n        }\n        if (this.fillOnSelect) {\n            this.inputText = this.displayFn(term);\n            this.handleSearchTermChange();\n        }\n    }\n\n    /** @hidden */\n    ngOnInit() {\n        if (this.dropdownValues) {\n            this.displayedValues = this.dropdownValues;\n        }\n    }\n\n    /** @hidden */\n    ngOnChanges(changes: SimpleChanges) {\n        if (this.dropdownValues && (changes.dropdownValues || changes.searchTerm)) {\n            if (this.inputText) {\n                this.displayedValues = this.filterFn(this.dropdownValues, this.inputText);\n            } else {\n                this.displayedValues =  this.dropdownValues;\n            }\n        }\n    }\n\n    /** @hidden */\n    handleSearchTermChange(): void {\n        this.displayedValues = this.filterFn(this.dropdownValues, this.inputText);\n    }\n\n    private defaultDisplay(str: any): string {\n        return str;\n    }\n\n    private defaultFilter(contentArray: any[], searchTerm: string): any[] {\n        const searchLower = searchTerm.toLocaleLowerCase();\n        return contentArray.filter(item => {\n            if (item) {\n                return this.displayFn(item).toLocaleLowerCase().includes(searchLower);\n            }\n        });\n    }\n\n}\n"]}