fundamental-ngx
Version:
SAP Fiori Fundamentals, implemented in Angular
369 lines • 29.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, EventEmitter, forwardRef, HostBinding, Input, Output, QueryList, ViewChild, ViewChildren } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import { MenuItemDirective } from '../menu/menu-item.directive';
var SearchInputComponent = /** @class */ (function () {
function SearchInputComponent() {
this.dropdownValues = [];
this.filterFn = this.defaultFilter;
this.displayedValues = [];
this.inShellbar = false;
this.glyph = 'search';
this.compact = false;
this.highlight = true;
this.closeOnSelect = true;
this.fillOnSelect = true;
this.itemClicked = new EventEmitter();
this.isOpen = false;
this.searchInputClass = true;
this.shellBarClass = this.inShellbar;
this.onChange = (/**
* @return {?}
*/
function () { });
this.onTouched = (/**
* @return {?}
*/
function () { });
}
/**
* @param {?} event
* @return {?}
*/
SearchInputComponent.prototype.onInputKeydownHandler = /**
* @param {?} event
* @return {?}
*/
function (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();
}
}
};
/**
* @return {?}
*/
SearchInputComponent.prototype.onInputKeyupHandler = /**
* @return {?}
*/
function () {
if (this.inputText.length) {
this.isOpen = true;
}
};
/**
* @param {?} event
* @param {?=} term
* @return {?}
*/
SearchInputComponent.prototype.onMenuKeydownHandler = /**
* @param {?} event
* @param {?=} term
* @return {?}
*/
function (event, term) {
var _this = this;
if (event.code === 'Enter' && term.callback) {
term.callback(event);
this.itemClicked.emit(term);
}
else if (event.code === 'ArrowDown') {
event.preventDefault();
/** @type {?} */
var foundItem_1 = false;
/** @type {?} */
var menuItemsArray_1 = this.menuItems.toArray();
menuItemsArray_1.forEach((/**
* @param {?} item
* @param {?} index
* @return {?}
*/
function (item, index) {
if (document.activeElement === item.itemEl.nativeElement.children[0] && !foundItem_1) {
if (menuItemsArray_1[index + 1]) {
menuItemsArray_1[index + 1].itemEl.nativeElement.children[0].focus();
}
foundItem_1 = true;
}
}));
}
else if (event.code === 'ArrowUp') {
event.preventDefault();
/** @type {?} */
var foundItem_2 = false;
/** @type {?} */
var menuItemsArray_2 = this.menuItems.toArray();
menuItemsArray_2.forEach((/**
* @param {?} item
* @param {?} index
* @return {?}
*/
function (item, index) {
if (!foundItem_2) {
if (document.activeElement === item.itemEl.nativeElement.children[0] && index === 0) {
_this.searchInputElement.nativeElement.focus();
foundItem_2 = true;
}
else if (document.activeElement === item.itemEl.nativeElement.children[0]) {
if (menuItemsArray_2[index - 1]) {
menuItemsArray_2[index - 1].itemEl.nativeElement.children[0].focus();
}
foundItem_2 = true;
}
}
}));
}
};
/**
* @param {?} event
* @param {?} term
* @return {?}
*/
SearchInputComponent.prototype.onMenuClickHandler = /**
* @param {?} event
* @param {?} term
* @return {?}
*/
function (event, term) {
if (term.callback) {
term.callback(event);
this.handleClickActions(term);
this.itemClicked.emit(term);
}
};
/**
* @param {?} event
* @return {?}
*/
SearchInputComponent.prototype.shellbarSearchInputClicked = /**
* @param {?} event
* @return {?}
*/
function (event) {
event.stopPropagation();
};
Object.defineProperty(SearchInputComponent.prototype, "inputText", {
get: /**
* @return {?}
*/
function () {
return this.inputTextValue;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.inputTextValue = value;
this.onChange(value);
this.onTouched();
},
enumerable: true,
configurable: true
});
/**
* @param {?} value
* @return {?}
*/
SearchInputComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.inputTextValue = value;
};
/**
* @param {?} fn
* @return {?}
*/
SearchInputComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onChange = fn;
};
/**
* @param {?} fn
* @return {?}
*/
SearchInputComponent.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this.onTouched = fn;
};
/**
* @private
* @param {?} term
* @return {?}
*/
SearchInputComponent.prototype.handleClickActions = /**
* @private
* @param {?} term
* @return {?}
*/
function (term) {
if (this.closeOnSelect) {
this.isOpen = false;
}
if (this.fillOnSelect) {
this.inputText = term.text;
this.handleSearchTermChange();
}
};
/**
* @return {?}
*/
SearchInputComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
if (this.dropdownValues) {
this.displayedValues = this.dropdownValues;
}
};
/**
* @param {?} changes
* @return {?}
*/
SearchInputComponent.prototype.ngOnChanges = /**
* @param {?} changes
* @return {?}
*/
function (changes) {
if (this.dropdownValues && (changes.dropdownValues || changes.searchTerm)) {
if (this.inputText) {
this.displayedValues = this.filterFn(this.dropdownValues, this.inputText);
}
else {
this.displayedValues = this.dropdownValues;
}
}
};
/**
* @return {?}
*/
SearchInputComponent.prototype.handleSearchTermChange = /**
* @return {?}
*/
function () {
this.displayedValues = this.filterFn(this.dropdownValues, this.inputText);
};
/**
* @private
* @param {?} contentArray
* @param {?} searchTerm
* @return {?}
*/
SearchInputComponent.prototype.defaultFilter = /**
* @private
* @param {?} contentArray
* @param {?} searchTerm
* @return {?}
*/
function (contentArray, searchTerm) {
/** @type {?} */
var searchLower = searchTerm.toLocaleLowerCase();
return contentArray.filter((/**
* @param {?} item
* @return {?}
*/
function (item) {
if (item) {
return item.text.toLocaleLowerCase().includes(searchLower);
}
}));
};
SearchInputComponent.decorators = [
{ type: Component, args: [{
selector: 'fd-search-input',
template: "<fd-popover [(isOpen)]=\"isOpen\"\n [fillControl]=\"true\"\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>\n <ul fd-menu-list>\n <li fd-menu-item *ngFor=\"let term of displayedValues\"\n (click)=\"onMenuClickHandler($event, term)\" (keydown)=\"onMenuKeydownHandler($event, term)\">\n <a tabindex=\"0\">\n <div *ngIf=\"highlight && inputTextValue && inputTextValue.toLocaleLowerCase\">\n {{ term.text.substr(0, term.text.toLocaleLowerCase().indexOf(inputText.toLocaleLowerCase())) }}<strong>{{term.text.substr(term.text.toLocaleLowerCase().indexOf(inputText.toLocaleLowerCase()), inputText.length)}}</strong>{{ term.text.substring(term.text.toLocaleLowerCase().indexOf(inputText.toLocaleLowerCase()) + inputText.length, term.text.length) }}\n </div>\n <div *ngIf=\"!highlight || !inputTextValue\">\n {{ term.text }}\n </div>\n </a>\n </li>\n </ul>\n </fd-menu>\n </fd-popover-body>\n</fd-popover>\n",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
function () { return SearchInputComponent; })),
multi: true
}
],
styles: [".fd-popover-body--display-none ::ng-deep .fd-popover__body{display:none}.fd-search-input-popover-custom{display:block}"]
}] }
];
SearchInputComponent.propDecorators = {
dropdownValues: [{ type: Input }],
filterFn: [{ type: Input }],
disabled: [{ type: Input }],
placeholder: [{ type: Input }],
inShellbar: [{ type: Input }],
glyph: [{ type: Input }],
searchFunction: [{ type: Input }],
compact: [{ type: Input }],
highlight: [{ type: Input }],
closeOnSelect: [{ type: Input }],
fillOnSelect: [{ 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',] }]
};
return SearchInputComponent;
}());
export { SearchInputComponent };
if (false) {
/** @type {?} */
SearchInputComponent.prototype.dropdownValues;
/** @type {?} */
SearchInputComponent.prototype.filterFn;
/** @type {?} */
SearchInputComponent.prototype.displayedValues;
/** @type {?} */
SearchInputComponent.prototype.disabled;
/** @type {?} */
SearchInputComponent.prototype.placeholder;
/** @type {?} */
SearchInputComponent.prototype.inShellbar;
/** @type {?} */
SearchInputComponent.prototype.glyph;
/** @type {?} */
SearchInputComponent.prototype.searchFunction;
/** @type {?} */
SearchInputComponent.prototype.compact;
/** @type {?} */
SearchInputComponent.prototype.highlight;
/** @type {?} */
SearchInputComponent.prototype.closeOnSelect;
/** @type {?} */
SearchInputComponent.prototype.fillOnSelect;
/** @type {?} */
SearchInputComponent.prototype.itemClicked;
/** @type {?} */
SearchInputComponent.prototype.menuItems;
/** @type {?} */
SearchInputComponent.prototype.searchInputElement;
/** @type {?} */
SearchInputComponent.prototype.isOpen;
/** @type {?} */
SearchInputComponent.prototype.inputTextValue;
/** @type {?} */
SearchInputComponent.prototype.searchInputClass;
/** @type {?} */
SearchInputComponent.prototype.shellBarClass;
/** @type {?} */
SearchInputComponent.prototype.onChange;
/** @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":"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","sourcesContent":["import {\n    Component,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    SimpleChanges,\n    QueryList,\n    ViewChild,\n    ViewChildren\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { MenuItemDirective } from '../menu/menu-item.directive';\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})\nexport class SearchInputComponent implements ControlValueAccessor, OnInit, OnChanges {\n    @Input()\n    dropdownValues: any[] = [];\n\n    @Input()\n    filterFn: Function = this.defaultFilter;\n\n    displayedValues: any[] = [];\n\n    @Input()\n    disabled: boolean;\n\n    @Input()\n    placeholder: string;\n\n    @Input()\n    inShellbar: boolean = false;\n\n    @Input()\n    glyph: string = 'search';\n\n    @Input()\n    searchFunction: Function;\n\n    @Input()\n    compact: boolean = false;\n\n    @Input()\n    highlight: boolean = true;\n\n    @Input()\n    closeOnSelect: boolean = true;\n\n    @Input()\n    fillOnSelect: boolean = true;\n\n    @Output()\n    itemClicked = new EventEmitter<any>();\n\n    @ViewChildren(MenuItemDirective) menuItems: QueryList<MenuItemDirective>;\n\n    @ViewChild('searchInputElement') searchInputElement;\n\n    isOpen: boolean = false;\n\n    inputTextValue: string;\n\n    @HostBinding('class.fd-search-input')\n    searchInputClass = true;\n\n    @HostBinding('class.fd-search-input--closed')\n    shellBarClass = this.inShellbar;\n\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    onInputKeyupHandler() {\n        if (this.inputText.length) {\n            this.isOpen = true;\n        }\n    }\n\n    onMenuKeydownHandler(event, term?) {\n        if (event.code === 'Enter' && term.callback) {\n            term.callback(event);\n            this.itemClicked.emit(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    onMenuClickHandler(event, term) {\n        if (term.callback) {\n            term.callback(event);\n            this.handleClickActions(term);\n            this.itemClicked.emit(term);\n        }\n    }\n\n    shellbarSearchInputClicked(event) {\n        event.stopPropagation();\n    }\n\n    onChange: any = () => {};\n    onTouched: any = () => {};\n\n    get inputText() {\n        return this.inputTextValue;\n    }\n\n    set inputText(value) {\n        this.inputTextValue = value;\n        this.onChange(value);\n        this.onTouched();\n    }\n\n    writeValue(value: any) {\n        this.inputTextValue = value;\n    }\n\n    registerOnChange(fn) {\n        this.onChange = fn;\n    }\n\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 = term.text;\n            this.handleSearchTermChange();\n        }\n    }\n\n    ngOnInit() {\n        if (this.dropdownValues) {\n            this.displayedValues = this.dropdownValues;\n        }\n    }\n\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    handleSearchTermChange(): void {\n        this.displayedValues = this.filterFn(this.dropdownValues, this.inputText);\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 item.text.toLocaleLowerCase().includes(searchLower);\n            }\n        });\n    }\n}\n"]}