UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

119 lines 14.2 kB
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"]}