UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

120 lines 16.2 kB
import { DataField } from '../../models/abstract-data-field'; import { Subject } from 'rxjs'; import { ComponentPrefixes } from '../../models/component'; import { distinctUntilChanged } from 'rxjs/operators'; /** * Supported types of files a user can select through a file picker. */ export var FileUploadMIMEType; (function (FileUploadMIMEType) { FileUploadMIMEType["IMAGE"] = "image/*"; FileUploadMIMEType["VIDEO"] = "video/*"; FileUploadMIMEType["AUDIO"] = "audio/*"; FileUploadMIMEType["PDF"] = ".pdf"; FileUploadMIMEType["JPG_JPEG"] = ".jpg,.jpeg"; FileUploadMIMEType["XML"] = ".xml"; FileUploadMIMEType["DOC_DOCX"] = ".doc,.docx"; FileUploadMIMEType["XLS_XLSX"] = ".xls,.xlsx"; })(FileUploadMIMEType || (FileUploadMIMEType = {})); /** * Supported types for file preview */ export var FilePreviewType; (function (FilePreviewType) { FilePreviewType[FilePreviewType["pdf"] = 0] = "pdf"; FilePreviewType[FilePreviewType["jpg"] = 1] = "jpg"; FilePreviewType[FilePreviewType["jpeg"] = 2] = "jpeg"; FilePreviewType[FilePreviewType["png"] = 3] = "png"; })(FilePreviewType || (FilePreviewType = {})); /** * Holds information represent file field implements in Petri Net */ export class FileField extends DataField { _maxUploadSizeInBytes; _allowTypes; /** * Specifies the size of all uploaded files in bytes. * * It is an indicator for checking the oversized size in the Petri Net. */ filesSize = 0; /** * 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 ?? {}); } this._value.next(value ?? {}); this.reverting = false; } get value() { return this._value.getValue(); } get updated() { return this._update.asObservable(); } getTypedComponentType() { return ComponentPrefixes.FILE + this.getComponentType(); } valueWithoutChange(value) { this.changed = false; this._value.next(value ?? {}); } /** * 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, _maxUploadSizeInBytes, _allowTypes, validations, component, parentTaskId) { super(stringId, title, value, behavior, placeholder, description, layout, validations, component, parentTaskId); this._maxUploadSizeInBytes = _maxUploadSizeInBytes; this._allowTypes = _allowTypes; this._changedFields$ = new Subject(); } 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); } valueEquality(a, b) { let file = JSON.stringify(a) === JSON.stringify(b); if (a && a.file && b && b.file) { file = a.file.name === b.file.name; } return (!a && !b) || (!!a && !!b && a.name === b.name && file); } 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?.name ?? ''); 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-field.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/data-fields/file-field/models/file-field.ts"],"names":[],"mappings":"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","sourcesContent":["import {DataField} from '../../models/abstract-data-field';\nimport {Behavior} from '../../models/behavior';\nimport {Layout} from '../../models/layout';\nimport {FileFieldValue} from './file-field-value';\nimport {Observable, Subject} from 'rxjs';\nimport {Component, ComponentPrefixes} from '../../models/component';\nimport {FormControl} from '@angular/forms';\nimport {Validation} from '../../models/validation';\nimport {ChangedFieldsMap} from '../../../event/services/interfaces/changed-fields-map';\nimport {distinctUntilChanged} from 'rxjs/operators';\n\n/**\n * Supported types of files a user can select through a file picker.\n */\nexport enum FileUploadMIMEType {\n    IMAGE = 'image/*',\n    VIDEO = 'video/*',\n    AUDIO = 'audio/*',\n    PDF = '.pdf',\n    JPG_JPEG = '.jpg,.jpeg',\n    XML = '.xml',\n    DOC_DOCX = '.doc,.docx',\n    XLS_XLSX = '.xls,.xlsx'\n}\n\n/**\n * Supported types for file preview\n */\nexport enum FilePreviewType {\n    pdf,\n    jpg,\n    jpeg,\n    png\n}\n\n/**\n * Extended structure for file by name and extension.\n */\nexport interface FileUploadDataModel {\n    file: File;\n    name: string;\n    extension: string;\n}\n\n/**\n * Holds information represent file field implements in Petri Net\n */\nexport class FileField extends DataField<FileFieldValue> {\n    /**\n     * Specifies the size of all uploaded files in bytes.\n     *\n     * It is an indicator for checking the oversized size in the Petri Net.\n     */\n    public filesSize = 0;\n\n    /**\n     * Used to forward the result of the upload file backend call to the task content\n     */\n    private _changedFields$: Subject<ChangedFieldsMap>;\n\n    public downloaded: boolean;\n\n    set value(value: FileFieldValue) {\n        if (!this.valueEquality(this._value.getValue(), value) && !this.reverting) {\n            this.changed = true;\n            this.waitingForResponse = true;\n            this.resolvePrevValue(value ?? {});\n        }\n        this._value.next(value ?? {});\n        this.reverting = false;\n    }\n\n    get value(): FileFieldValue {\n        return this._value.getValue();\n    }\n\n    get updated(): Observable<void> {\n        return this._update.asObservable();\n    }\n\n    public getTypedComponentType(): string {\n        return ComponentPrefixes.FILE + this.getComponentType();\n    }\n\n    public valueWithoutChange(value: FileFieldValue) {\n        this.changed = false;\n        this._value.next(value ?? {});\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?: FileFieldValue, placeholder?: string, description?: string,\n                layout?: Layout, private _maxUploadSizeInBytes?: number,\n                private _allowTypes?: string | FileUploadMIMEType | Array<FileUploadMIMEType>,\n                validations?: Array<Validation>, component?: Component, parentTaskId?: string) {\n        super(stringId, title, value, behavior, placeholder, description, layout, validations, component, parentTaskId);\n        this._changedFields$ = new Subject<ChangedFieldsMap>();\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    protected valueEquality(a: FileFieldValue, b: FileFieldValue): boolean {\n        let file = JSON.stringify(a) === JSON.stringify(b);\n        if (a && a.file && b && b.file) {\n            file = a.file.name === b.file.name;\n        }\n        return (!a && !b) || (!!a && !!b && a.name === b.name && file);\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        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?.name ?? '');\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"]}