UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

88 lines 14.6 kB
import { Component, Input } from '@angular/core'; import { FormControl } from '@angular/forms'; import { map, startWith } from 'rxjs/operators'; import { orderBy } from 'natural-orderby'; import { AbstractHeaderModeComponent } from '../abstract-header-mode.component'; import * as i0 from "@angular/core"; import * as i1 from "@ngx-translate/core"; import * as i2 from "../../../logger/services/logger.service"; export class AbstractEditModeComponent extends AbstractHeaderModeComponent { _translate; _log; formControls = []; filterOptions = []; subHeader; headerService; constructor(_translate, _log) { super(); this._translate = _translate; this._log = _log; } ngOnInit() { this.subHeader = this.headerService.headerColumnCount$.subscribe(newCount => this.updateHeaderCount(newCount)); } ngOnDestroy() { this.subHeader.unsubscribe(); } updateHeaderCount(newCount) { if (this.formControls.length > newCount) { this.formControls = this.formControls.slice(0, newCount); this.filterOptions = this.filterOptions.slice(0, newCount); return; } while (this.formControls.length < newCount) { const i = this.formControls.length; const formControl = new FormControl(); formControl.setValue(this.headerService.headerState.selectedHeaders[i] ?? this.headerService.headerState.lastSelectedHeaders[i] ?? null); this.formControls.push(formControl); this.filterOptions.push(formControl.valueChanges.pipe(startWith(''), map(inputText => this._filter(inputText)))); } } _filter(value) { let filterValue; if (typeof value === 'string') { filterValue = value.toLowerCase().normalize('NFD').replace(/[\u0300-\u036f]/g, ''); } else { filterValue = ''; } const arrayGroup = []; arrayGroup.push(...this.headerService.fieldsGroup); const meta = arrayGroup.splice(0, 1); // TODO IMPROVEMENT 17.7.2020 - don't sort the fieldsGroup array here, but sort it once in the headerService and maintain // the sorted order there meta.push(...orderBy(arrayGroup, v => v.groupTitle, 'asc')); meta.forEach(group => group.fields = orderBy(group.fields, v => v.title, 'asc')); return meta.map(group => ({ groupTitle: group.groupTitle, fields: group.fields.filter(option => this.checkImmediateTitle(option) && this._translate.instant(option.title).toLowerCase().normalize('NFD') .replace(/[\u0300-\u036f]/g, '').indexOf(filterValue) === 0) })).filter(group => group.fields.length > 0); } headerColumnSelected(columnIndex, newHeaderColumn) { this.headerService.headerColumnSelected(columnIndex, newHeaderColumn); } renderSelection = (header) => { return header ? this._translate.instant(header.title) : ''; }; checkImmediateTitle(option) { if (option.title === undefined || option.title === '') { this._log.warn('Immediate field in column [' + option.uniqueId + '] does not have a title'); return false; } return true; } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractEditModeComponent, deps: [{ token: i1.TranslateService }, { token: i2.LoggerService }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractEditModeComponent, selector: "ncc-abstract-edit-mode", inputs: { headerService: "headerService" }, usesInheritance: true, ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractEditModeComponent, decorators: [{ type: Component, args: [{ selector: 'ncc-abstract-edit-mode', template: '' }] }], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.LoggerService }], propDecorators: { headerService: [{ type: Input }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-edit-mode.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/header/header-modes/edit-mode/abstract-edit-mode.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, Input, OnDestroy, OnInit} from '@angular/core';\nimport {AbstractHeaderService} from '../../abstract-header-service';\nimport {HeaderColumn} from '../../models/header-column';\nimport {FormControl} from '@angular/forms';\nimport {map, startWith} from 'rxjs/operators';\nimport {TranslateService} from '@ngx-translate/core';\nimport {FieldsGroup} from '../../models/fields-group';\nimport {orderBy} from 'natural-orderby';\nimport {Observable, Subscription} from 'rxjs';\nimport {LoggerService} from '../../../logger/services/logger.service';\nimport {AbstractHeaderModeComponent} from '../abstract-header-mode.component';\n\nexport interface HeaderOption {\n    groupTitle: string;\n    fields: Array<HeaderColumn>;\n}\n\n@Component({\n    selector: 'ncc-abstract-edit-mode',\n    template: ''\n})\nexport abstract class AbstractEditModeComponent extends AbstractHeaderModeComponent implements OnInit, OnDestroy {\n    public formControls: Array<FormControl<any>> = [];\n    public filterOptions: Array<Observable<Array<HeaderOption>>> = [];\n    protected subHeader: Subscription;\n\n    @Input() public headerService: AbstractHeaderService;\n\n    protected constructor(protected _translate: TranslateService,\n                          protected _log: LoggerService) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.subHeader = this.headerService.headerColumnCount$.subscribe(newCount => this.updateHeaderCount(newCount));\n    }\n\n    ngOnDestroy(): void {\n        this.subHeader.unsubscribe();\n    }\n\n    protected updateHeaderCount(newCount: number): void {\n        if (this.formControls.length > newCount) {\n            this.formControls = this.formControls.slice(0, newCount);\n            this.filterOptions = this.filterOptions.slice(0, newCount);\n            return;\n        }\n\n        while (this.formControls.length < newCount) {\n            const i = this.formControls.length;\n            const formControl = new FormControl();\n            formControl.setValue(this.headerService.headerState.selectedHeaders[i] ?? this.headerService.headerState.lastSelectedHeaders[i] ?? null);\n            this.formControls.push(formControl);\n            this.filterOptions.push(formControl.valueChanges.pipe(\n                startWith(''),\n                map(inputText => this._filter(inputText)))\n            );\n        }\n    }\n\n    protected _filter(value): Array<HeaderOption> {\n        let filterValue;\n        if (typeof value === 'string') {\n            filterValue = (value as string).toLowerCase().normalize('NFD').replace(/[\\u0300-\\u036f]/g, '');\n        } else {\n            filterValue = '';\n        }\n\n        const arrayGroup: Array<FieldsGroup> = [];\n        arrayGroup.push(...this.headerService.fieldsGroup);\n        const meta = arrayGroup.splice(0, 1);\n        // TODO IMPROVEMENT 17.7.2020 - don't sort the fieldsGroup array here, but sort it once in the headerService and maintain\n        //  the sorted order there\n        meta.push(...orderBy(arrayGroup, v => v.groupTitle, 'asc'));\n        meta.forEach(group => group.fields = orderBy(group.fields, v => v.title, 'asc'));\n\n        return meta.map(group => ({\n            groupTitle: group.groupTitle,\n            fields: group.fields.filter(option => this.checkImmediateTitle(option) &&\n                this._translate.instant(option.title).toLowerCase().normalize('NFD')\n                .replace(/[\\u0300-\\u036f]/g, '').indexOf(filterValue) === 0)\n        })).filter(group => group.fields.length > 0);\n    }\n\n    public headerColumnSelected(columnIndex: number, newHeaderColumn: HeaderColumn) {\n        this.headerService.headerColumnSelected(columnIndex, newHeaderColumn);\n    }\n\n    public renderSelection = (header) => {\n        return header ? this._translate.instant(header.title) : '';\n    }\n\n    private checkImmediateTitle(option: HeaderColumn): boolean {\n        if (option.title === undefined || option.title === '') {\n            this._log.warn('Immediate field in column [' + option.uniqueId + '] does not have a title');\n            return false;\n        }\n        return true;\n    }\n}\n"]}