@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
119 lines • 14.2 kB
JavaScript
import { Component, Input, ViewChild } from '@angular/core';
import { SearchInputType } from '../models/category/search-input-type';
import { debounceTime } from 'rxjs/operators';
import * as i0 from "@angular/core";
export class AbstractSearchOperandInputComponent {
/**
* Whether the contents displayed in this component can be edited by the user or not.
*
* Defaults to `true`
*/
editable = true;
inputFormControl;
inputType;
first;
/**
* Only if the input is of type [AUTOCOMPLETE{@link SearchInputType#AUTOCOMPLETE}
*/
filterOptionsFunction;
_inputConfirmed = false;
_filteredOptions$;
_autocompleteChange;
_initialExpansion = true;
renderSelection = (selection) => this._renderSelection(selection);
ngOnInit() {
if (this.inputType === SearchInputType.AUTOCOMPLETE) {
this._autocompleteChange = this.inputFormControl.valueChanges.subscribe(val => {
setTimeout(() => {
this._inputConfirmed = !!val && (typeof val !== 'string');
});
});
}
if (this.isInputValueSet()) {
this._inputConfirmed = true;
}
}
ngOnDestroy() {
if (this._autocompleteChange && !this._autocompleteChange.closed) {
this._autocompleteChange.unsubscribe();
}
}
get filteredOptions$() {
if (!this._filteredOptions$) {
this._filteredOptions$ = this.filterOptionsFunction(this.inputFormControl.valueChanges.pipe(debounceTime(600)));
}
return this._filteredOptions$;
}
isInputFilled() {
if (!this._inputConfirmed) {
return false;
}
return this.isInputValueSet();
}
set categoryInput(input) {
if (input) {
if (!this.first && this._initialExpansion) {
this._initialExpansion = false;
return;
}
this._initialExpansion = false;
if (!this.isInputFilled()) {
setTimeout(() => {
input.nativeElement.focus();
});
}
}
}
confirmInput() {
this._inputConfirmed = true;
}
editInput() {
if (!this.editable) {
return;
}
this._inputConfirmed = false;
}
/**
* Autocomplete `displayWith` function
* @param selection the selected option
*/
_renderSelection(selection) {
return selection ? selection.text : '';
}
isInputValueSet() {
if (this.inputType === SearchInputType.AUTOCOMPLETE) {
return !!this.inputFormControl.value
&& (typeof this.inputFormControl.value !== 'string');
}
if (this.inputType === SearchInputType.TEXT) {
return this.inputFormControl.value !== undefined
&& this.inputFormControl.value !== null
&& this.inputFormControl.value.length > 0;
}
return this.inputFormControl.value !== undefined
&& this.inputFormControl.value !== null;
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractSearchOperandInputComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractSearchOperandInputComponent, selector: "ncc-abstract-search-operand-input", inputs: { editable: "editable", inputFormControl: "inputFormControl", inputType: "inputType", first: "first", filterOptionsFunction: "filterOptionsFunction" }, viewQueries: [{ propertyName: "categoryInput", first: true, predicate: ["operandInput"], descendants: true }], ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractSearchOperandInputComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-search-operand-input',
template: ''
}]
}], propDecorators: { editable: [{
type: Input
}], inputFormControl: [{
type: Input
}], inputType: [{
type: Input
}], first: [{
type: Input
}], filterOptionsFunction: [{
type: Input
}], categoryInput: [{
type: ViewChild,
args: ['operandInput']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-search-operand-input.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/search/search-operand-input-component/abstract-search-operand-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Input, OnDestroy, OnInit, ViewChild} from '@angular/core';\nimport {FormControl} from '@angular/forms';\nimport {SearchInputType} from '../models/category/search-input-type';\nimport {Observable, Subscription} from 'rxjs';\nimport {SearchAutocompleteOption} from '../models/category/search-autocomplete-option';\nimport {debounceTime} from 'rxjs/operators';\n\n@Component({\n    selector: 'ncc-abstract-search-operand-input',\n    template: ''\n})\nexport abstract class AbstractSearchOperandInputComponent implements OnInit, OnDestroy {\n\n    /**\n     * Whether the contents displayed in this component can be edited by the user or not.\n     *\n     * Defaults to `true`\n     */\n    @Input() editable = true;\n    @Input() inputFormControl: FormControl;\n    @Input() inputType: SearchInputType;\n    @Input() first: boolean;\n    /**\n     * Only if the input is of type [AUTOCOMPLETE{@link SearchInputType#AUTOCOMPLETE}\n     */\n    @Input() filterOptionsFunction: (userInput: Observable<string>) => Observable<Array<SearchAutocompleteOption<unknown>>>;\n\n    protected _inputConfirmed = false;\n\n    private _filteredOptions$: Observable<Array<SearchAutocompleteOption<unknown>>>;\n\n    private _autocompleteChange: Subscription;\n\n    private _initialExpansion = true;\n\n    public renderSelection = (selection: SearchAutocompleteOption<unknown>) => this._renderSelection(selection);\n\n    ngOnInit(): void {\n        if (this.inputType === SearchInputType.AUTOCOMPLETE) {\n            this._autocompleteChange = this.inputFormControl.valueChanges.subscribe(val => {\n                setTimeout(() => {\n                    this._inputConfirmed = !!val && (typeof val !== 'string');\n                });\n            });\n        }\n\n        if (this.isInputValueSet()) {\n            this._inputConfirmed = true;\n        }\n    }\n\n    ngOnDestroy(): void {\n        if (this._autocompleteChange && !this._autocompleteChange.closed) {\n            this._autocompleteChange.unsubscribe();\n        }\n    }\n\n    public get filteredOptions$(): Observable<Array<SearchAutocompleteOption<unknown>>> {\n        if (!this._filteredOptions$) {\n            this._filteredOptions$ = this.filterOptionsFunction(this.inputFormControl.valueChanges.pipe(debounceTime(600)));\n        }\n        return this._filteredOptions$;\n    }\n\n    public isInputFilled(): boolean {\n        if (!this._inputConfirmed) {\n            return false;\n        }\n\n        return this.isInputValueSet();\n    }\n\n    @ViewChild('operandInput')\n    public set categoryInput(input: ElementRef<HTMLInputElement>) {\n        if (input) {\n            if (!this.first && this._initialExpansion) {\n                this._initialExpansion = false;\n                return;\n            }\n            this._initialExpansion = false;\n\n            if (!this.isInputFilled()) {\n                setTimeout(() => {\n                    input.nativeElement.focus();\n                });\n            }\n        }\n    }\n\n    public confirmInput(): void {\n        this._inputConfirmed = true;\n    }\n\n    public editInput(): void {\n        if (!this.editable) {\n            return;\n        }\n\n        this._inputConfirmed = false;\n    }\n\n    /**\n     * Autocomplete `displayWith` function\n     * @param selection the selected option\n     */\n    protected _renderSelection(selection: SearchAutocompleteOption<unknown>): string {\n        return selection ? selection.text : '';\n    }\n\n    protected isInputValueSet(): boolean {\n        if (this.inputType === SearchInputType.AUTOCOMPLETE) {\n            return !!this.inputFormControl.value\n                && (typeof this.inputFormControl.value !== 'string');\n        }\n        if (this.inputType === SearchInputType.TEXT) {\n            return this.inputFormControl.value !== undefined\n                && this.inputFormControl.value !== null\n                && this.inputFormControl.value.length > 0;\n        }\n        return this.inputFormControl.value !== undefined\n            && this.inputFormControl.value !== null;\n    }\n}\n"]}