@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
115 lines • 17.7 kB
JavaScript
import { Component, Inject, Optional, ViewChild } from '@angular/core';
import { COMMA, ENTER } from '@angular/cdk/keycodes';
import { of } from 'rxjs';
import { MultichoiceAutocompleteFilterProperty } from './multichoice-autocomplete-filter-property';
import { DATA_FIELD_PORTAL_DATA } from "../../models/data-field-portal-data-injection-token";
import { AbstractBaseDataFieldComponent } from "../../base-component/abstract-base-data-field.component";
import * as i0 from "@angular/core";
export class AbstractMultichoiceAutocompleteFieldComponentComponent extends AbstractBaseDataFieldComponent {
input;
separatorKeysCodes = [ENTER, COMMA];
subscriptionChangeData$;
filteredOptions;
constructor(dataFieldPortalData) {
super(dataFieldPortalData);
}
ngOnInit() {
this.subscriptionChangeData$ = this.formControlRef.valueChanges.subscribe(newVal => {
this.filteredOptions = of(this._filter(newVal ?? '').filter((option) => !this.dataField.value?.includes(option.key)));
});
}
ngOnDestroy() {
this.filteredOptions = undefined;
this.subscriptionChangeData$.unsubscribe();
}
add(event) {
const value = event['key'] ?? '';
if (value) {
this.dataField.value = this.dataField.value === null ? [] : this.dataField.value;
const choiceArray = [...this.dataField.value];
choiceArray.push(value);
this.dataField.value = choiceArray;
this.input.nativeElement.value = '';
this.change();
}
else {
this.input.nativeElement.value = '';
this.change();
}
}
remove(value) {
const index = this.dataField.value.indexOf(value);
if (index >= 0) {
const choiceArray = [...this.dataField.value];
choiceArray.splice(index, 1);
this.dataField.value = choiceArray;
this.change();
}
}
change() {
if (this.input.nativeElement.value !== undefined) {
this.filteredOptions = of(this._filter(this.input.nativeElement.value).filter((option) => !this.dataField.value?.includes(option.key)));
}
}
filterType() {
if (this.checkPropertyInComponent('filter')) {
return this.dataField.component.properties.filter;
}
}
_filter(value) {
let filterType = this.filterType()?.toLowerCase();
switch (filterType) {
case MultichoiceAutocompleteFilterProperty.SUBSTRING:
return this._filterInclude(value);
case MultichoiceAutocompleteFilterProperty.PREFIX:
return this._filterIndexOf(value);
default:
return this._filterIndexOf(value);
}
}
_filterInclude(value) {
if (Array.isArray(value)) {
value = '';
}
const filterValue = value?.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, '');
return this.dataField.choices.filter(option => option.value.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, '').includes(filterValue));
}
_filterIndexOf(value) {
if (Array.isArray(value)) {
value = '';
}
const filterValue = value?.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, '');
return this.dataField.choices.filter(option => option.value.toLowerCase().normalize('NFD')
.replace(/[\u0300-\u036f]/g, '').indexOf(filterValue) === 0);
}
renderSelection = (key) => {
if (key !== undefined && key !== '' && key !== null) {
const choice = this.dataField.choices.find(c => c.key === key);
if (choice) {
return choice.value;
}
}
return key;
};
getValueFromKey(key) {
return this.dataField.choices.find(choice => choice.key === key)?.value;
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractMultichoiceAutocompleteFieldComponentComponent, deps: [{ token: DATA_FIELD_PORTAL_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractMultichoiceAutocompleteFieldComponentComponent, selector: "ncc-abstract-multichoice-autocomplete-field", viewQueries: [{ propertyName: "input", first: true, predicate: ["input"], descendants: true }], usesInheritance: true, ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractMultichoiceAutocompleteFieldComponentComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-multichoice-autocomplete-field',
template: ''
}]
}], ctorParameters: () => [{ type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [DATA_FIELD_PORTAL_DATA]
}] }], propDecorators: { input: [{
type: ViewChild,
args: ['input']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-multichoice-autocomplete-field-component.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/data-fields/multichoice-field/multichoice-autocomplete-field/abstract-multichoice-autocomplete-field-component.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Inject, OnDestroy, OnInit, Optional, ViewChild} from '@angular/core';\nimport {MultichoiceField, MultichoiceFieldValue} from '../models/multichoice-field';\nimport {COMMA, ENTER} from '@angular/cdk/keycodes';\nimport {MatChipInputEvent} from '@angular/material/chips';\nimport {Observable, of, Subscription} from 'rxjs';\nimport {MultichoiceAutocompleteFilterProperty} from './multichoice-autocomplete-filter-property';\nimport {DATA_FIELD_PORTAL_DATA, DataFieldPortalData} from \"../../models/data-field-portal-data-injection-token\";\nimport {AbstractBaseDataFieldComponent} from \"../../base-component/abstract-base-data-field.component\";\n\n@Component({\n    selector: 'ncc-abstract-multichoice-autocomplete-field',\n    template: ''\n})\nexport abstract class AbstractMultichoiceAutocompleteFieldComponentComponent extends AbstractBaseDataFieldComponent<MultichoiceField> implements OnInit, OnDestroy {\n\n    @ViewChild('input') input: ElementRef;\n\n    separatorKeysCodes: number[] = [ENTER, COMMA];\n\n    subscriptionChangeData$: Subscription;\n\n    filteredOptions: Observable<Array<MultichoiceFieldValue>>;\n\n    constructor(@Optional() @Inject(DATA_FIELD_PORTAL_DATA) dataFieldPortalData: DataFieldPortalData<MultichoiceField>) {\n        super(dataFieldPortalData);\n    }\n\n    ngOnInit() {\n        this.subscriptionChangeData$ = this.formControlRef.valueChanges.subscribe(newVal => {\n            this.filteredOptions = of(this._filter(newVal ?? '').filter((option) => !this.dataField.value?.includes(option.key)));\n        })\n    }\n\n    ngOnDestroy(): void {\n        this.filteredOptions = undefined;\n        this.subscriptionChangeData$.unsubscribe();\n    }\n\n    add(event: MatChipInputEvent): void {\n        const value = event['key'] ?? '';\n\n        if (value) {\n            this.dataField.value = this.dataField.value === null ? [] : this.dataField.value\n            const choiceArray = [...this.dataField.value];\n            choiceArray.push(value);\n            this.dataField.value = choiceArray;\n            this.input.nativeElement.value = '';\n            this.change();\n        } else {\n            this.input.nativeElement.value = '';\n            this.change();\n        }\n    }\n\n    remove(value: string): void {\n        const index = this.dataField.value.indexOf(value);\n\n        if (index >= 0) {\n            const choiceArray = [...this.dataField.value];\n            choiceArray.splice(index, 1);\n            this.dataField.value = choiceArray;\n            this.change();\n        }\n    }\n\n    change() {\n        if (this.input.nativeElement.value !== undefined) {\n            this.filteredOptions = of(this._filter(this.input.nativeElement.value).filter((option) => !this.dataField.value?.includes(option.key)));\n        }\n    }\n\n    protected filterType(): string | undefined {\n        if (this.checkPropertyInComponent('filter')) {\n            return this.dataField.component.properties.filter;\n        }\n    }\n\n    protected _filter(value: string): Array<MultichoiceFieldValue> {\n        let filterType = this.filterType()?.toLowerCase()\n        switch (filterType) {\n            case MultichoiceAutocompleteFilterProperty.SUBSTRING:\n                return this._filterInclude(value);\n            case MultichoiceAutocompleteFilterProperty.PREFIX:\n                return this._filterIndexOf(value);\n            default:\n                return this._filterIndexOf(value);\n        }\n    }\n\n    protected _filterInclude(value: string): Array<MultichoiceFieldValue> {\n        if (Array.isArray(value)) {\n            value = '';\n        }\n        const filterValue = value?.toLowerCase().normalize('NFD').replace(/[\\u0300-\\u036f]/g, '');\n        return this.dataField.choices.filter(option => option.value.toLowerCase().normalize('NFD').replace(/[\\u0300-\\u036f]/g, '').includes(filterValue));\n    }\n\n    protected _filterIndexOf(value: string): Array<MultichoiceFieldValue> {\n        if (Array.isArray(value)) {\n            value = '';\n        }\n        const filterValue = value?.toLowerCase().normalize('NFD').replace(/[\\u0300-\\u036f]/g, '');\n\n        return this.dataField.choices.filter(option => option.value.toLowerCase().normalize('NFD')\n            .replace(/[\\u0300-\\u036f]/g, '').indexOf(filterValue) === 0);\n    }\n\n    public renderSelection = (key) => {\n        if (key !== undefined && key !== '' && key !== null) {\n            const choice = this.dataField.choices.find(c => c.key === key);\n            if (choice) {\n                return choice.value\n            }\n        }\n        return key;\n    }\n\n    public getValueFromKey(key: string): string | undefined {\n        return this.dataField.choices.find(choice => choice.key === key)?.value;\n    }\n}\n"]}