UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

95 lines 15.5 kB
import { Subject } from 'rxjs'; import { DataField } from '../../models/abstract-data-field'; import { ComponentPrefixes } from '../../models/component'; import { distinctUntilChanged } from 'rxjs/operators'; export var FileListFieldValidation; (function (FileListFieldValidation) { FileListFieldValidation["MAX_FILES"] = "maxFiles"; })(FileListFieldValidation || (FileListFieldValidation = {})); export class FileListField extends DataField { _maxUploadSizeInBytes; _allowTypes; /** * Used to forward the result of the upload file backend call to the task content */ _changedFields$; downloaded; set value(value) { if (!this.valueEquality(this._value.getValue(), value) && !this.reverting) { this.changed = true; this.waitingForResponse = true; this.resolvePrevValue(value ?? { namesPaths: [] }); } this._value.next(value ?? { namesPaths: [] }); this.reverting = false; } get value() { return this._value.getValue(); } getTypedComponentType() { return ComponentPrefixes.FILE_LIST + this.getComponentType(); } valueWithoutChange(value) { this.changed = false; this._value.next(value ?? { namesPaths: [] }); } /** * Create new instance for file field with all his properties. * * Placeholder is a substitute for the value name if not set value. */ constructor(stringId, title, behavior, value, placeholder, description, layout, validations, _maxUploadSizeInBytes, _allowTypes, component, parentTaskId) { super(stringId, title, value, behavior, placeholder, description, layout, validations, component, parentTaskId); this._maxUploadSizeInBytes = _maxUploadSizeInBytes; this._allowTypes = _allowTypes; this._changedFields$ = new Subject(); this.downloaded = new Array(); } get maxUploadSizeInBytes() { return this._maxUploadSizeInBytes; } get allowTypes() { return this._allowTypes instanceof Array ? this._allowTypes.toString() : this._allowTypes; } get changedFields$() { return this._changedFields$.asObservable(); } emitChangedFields(change) { this._changedFields$.next(change); } /** * We assume that files are always given in the same order. */ valueEquality(a, b) { let array = (JSON.stringify(a) === '{}' || !a.namesPaths || a.namesPaths.length === 0) && (JSON.stringify(b) === '{}' || !b.namesPaths || b.namesPaths.length === 0); if (a && a.namesPaths && a.namesPaths.length !== 0 && b && b.namesPaths && b.namesPaths.length !== 0) { array = a.namesPaths.every((element, index) => element.name === b.namesPaths[index].name); } return (!a && !b) || (!!a && !!b && array); } registerFormControl(formControl) { if (this.initialized) { throw new Error('Data field can be initialized only once!' + ' Disconnect the previous form control before initializing the data field again!'); } this.formControlRef = formControl; formControl.setValidators(this.resolveFormControlValidators()); this._myValueSubscription = this._value.pipe(distinctUntilChanged(this.valueEquality)).subscribe(newValue => { this.valid = this._determineFormControlValidity(formControl); formControl.setValue(!newValue || !newValue.namesPaths ? '' : newValue.namesPaths.map(namePath => { return namePath.name; }).join('/')); this.update(); }); this.updateFormControlState(formControl); this._initialized$.next(true); this.changed = false; this.waitingForResponse = false; } updateFormControlState(formControl) { this.subscribeToInnerSubjects(formControl); this.update(); } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-list-field.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/data-fields/file-list-field/models/file-list-field.ts"],"names":[],"mappings":"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","sourcesContent":["import {Observable, Subject} from 'rxjs';\nimport {Behavior} from '../../models/behavior';\nimport {Layout} from '../../models/layout';\nimport {FileUploadMIMEType} from '../../file-field/models/file-field';\nimport {DataField} from '../../models/abstract-data-field';\nimport {FileListFieldValue} from './file-list-field-value';\nimport {Validation} from '../../models/validation';\nimport {Component, ComponentPrefixes} from '../../models/component';\nimport {FormControl} from '@angular/forms';\nimport {ChangedFieldsMap} from '../../../event/services/interfaces/changed-fields-map';\nimport {distinctUntilChanged} from 'rxjs/operators';\n\nexport enum FileListFieldValidation {\n    MAX_FILES = 'maxFiles'\n}\n\nexport class FileListField extends DataField<FileListFieldValue> {\n    /**\n     * Used to forward the result of the upload file backend call to the task content\n     */\n    private _changedFields$: Subject<ChangedFieldsMap>;\n    public downloaded: Array<string>;\n\n    set value(value: FileListFieldValue) {\n        if (!this.valueEquality(this._value.getValue(), value) && !this.reverting) {\n            this.changed = true;\n            this.waitingForResponse = true;\n            this.resolvePrevValue(value ?? {namesPaths: []});\n        }\n        this._value.next(value ?? {namesPaths: []});\n        this.reverting = false;\n    }\n\n    get value(): FileListFieldValue {\n        return this._value.getValue();\n    }\n\n    public getTypedComponentType(): string {\n        return ComponentPrefixes.FILE_LIST + this.getComponentType();\n    }\n\n    public valueWithoutChange(value: FileListFieldValue) {\n        this.changed = false;\n        this._value.next(value ?? {namesPaths: []});\n    }\n\n    /**\n     * Create new instance for file field with all his properties.\n     *\n     * Placeholder is a substitute for the value name if not set value.\n     */\n    constructor(stringId: string, title: string, behavior: Behavior, value?: FileListFieldValue, placeholder?: string, description?: string,\n                layout?: Layout, validations?: Array<Validation>, private _maxUploadSizeInBytes?: number,\n                private _allowTypes?: string | FileUploadMIMEType | Array<FileUploadMIMEType>,\n                component?: Component, parentTaskId?: string) {\n        super(stringId, title, value, behavior, placeholder, description, layout, validations, component, parentTaskId);\n        this._changedFields$ = new Subject<ChangedFieldsMap>();\n        this.downloaded = new Array<string>();\n    }\n\n    get maxUploadSizeInBytes(): number {\n        return this._maxUploadSizeInBytes;\n    }\n\n    get allowTypes(): string {\n        return this._allowTypes instanceof Array ? this._allowTypes.toString() : this._allowTypes;\n    }\n\n    get changedFields$(): Observable<ChangedFieldsMap> {\n        return this._changedFields$.asObservable();\n    }\n\n    public emitChangedFields(change: ChangedFieldsMap): void {\n        this._changedFields$.next(change);\n    }\n\n    /**\n     * We assume that files are always given in the same order.\n     */\n    protected valueEquality(a: FileListFieldValue, b: FileListFieldValue): boolean {\n        let array = (JSON.stringify(a) === '{}' || !a.namesPaths || a.namesPaths.length === 0) &&\n            (JSON.stringify(b) === '{}' || !b.namesPaths || b.namesPaths.length === 0);\n        if (a && a.namesPaths && a.namesPaths.length !== 0 && b && b.namesPaths && b.namesPaths.length !== 0) {\n            array = a.namesPaths.every((element, index) => element.name === b.namesPaths[index].name);\n        }\n        return (!a && !b) || (!!a && !!b && array);\n    }\n\n    public registerFormControl(formControl: FormControl): void {\n        if (this.initialized) {\n            throw new Error('Data field can be initialized only once!'\n                + ' Disconnect the previous form control before initializing the data field again!');\n        }\n\n        this.formControlRef = formControl;\n        formControl.setValidators(this.resolveFormControlValidators());\n\n        this._myValueSubscription = this._value.pipe(\n            distinctUntilChanged(this.valueEquality)\n        ).subscribe(newValue => {\n            this.valid = this._determineFormControlValidity(formControl);\n            formControl.setValue(!newValue || !newValue.namesPaths ? '' : newValue.namesPaths.map(namePath => {\n                return namePath.name;\n            }).join('/'));\n            this.update();\n        });\n\n        this.updateFormControlState(formControl);\n        this._initialized$.next(true);\n        this.changed = false;\n        this.waitingForResponse = false;\n    }\n\n    protected updateFormControlState(formControl: FormControl): void {\n        this.subscribeToInnerSubjects(formControl);\n        this.update();\n    }\n}\n"]}