@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
120 lines • 16.2 kB
JavaScript
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"]}