@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
103 lines • 15.5 kB
JavaScript
import { Component, Inject, Input, Optional, ViewChild } from '@angular/core';
import { AbstractBaseDataFieldComponent } from '../base-component/abstract-base-data-field.component';
import { FileUploadMIMEType } from '../file-field/models/file-field';
import { DATA_FIELD_PORTAL_DATA } from './data-field-portal-data-injection-token';
import * as i0 from "@angular/core";
import * as i1 from "../../logger/services/logger.service";
import * as i2 from "../../snack-bar/services/snack-bar.service";
import * as i3 from "@ngx-translate/core";
export class AbstractFileFieldDefaultComponent extends AbstractBaseDataFieldComponent {
_log;
_snackbar;
_translate;
labelWidth;
cutProperty;
/**
* Task mongo string id is binding property from parent component.
*/
taskId;
/**
* File picker element reference from component template that is initialized after view init.
*/
fileUploadEl;
constructor(_log, _snackbar, _translate, dataFieldPortalData) {
super(dataFieldPortalData);
this._log = _log;
this._snackbar = _snackbar;
this._translate = _translate;
}
checkAllowedTypes() {
const files = this.fileUploadEl?.nativeElement?.files;
let bool = true;
for (let i = 0; i < files?.length; i++) {
if (!this.checkTypes(files.item(i).type)) {
this._log.error('File ' + files.item(i).name + ' cannot be uploaded. Its type is not allowed');
this._snackbar.openErrorSnackBar(this._translate.instant('dataField.file.notAllowed', { fileName: files.item(i).name }));
bool = false;
}
}
if (!bool) {
this.fileUploadEl.nativeElement.value = '';
}
return bool;
}
checkTypes(itemType) {
if (this.dataField.allowTypes === undefined || this.dataField.allowTypes === null) {
this._log.debug(`Types are not provided, returning true`);
return true;
}
const type = itemType.includes("/") ? itemType.split("/")[1] : itemType;
if (this.dataField.allowTypes.includes(type)) {
return true;
}
if (this.dataField.allowTypes.includes(FileUploadMIMEType.IMAGE) && itemType.includes("image/")) {
return true;
}
if (this.dataField.allowTypes.includes(FileUploadMIMEType.VIDEO) && itemType.includes("video/")) {
return true;
}
if (this.dataField.allowTypes.includes(FileUploadMIMEType.AUDIO) && itemType.includes("audio/")) {
return true;
}
return false;
}
getCutProperty(label) {
if (this.labelWidth !== label.offsetWidth) {
this.labelWidth = label.offsetWidth;
const calculatedWidth = 'calc(0.5em + ' + label.offsetWidth / 4 * 3 + 'px)';
this.cutProperty = `polygon(0 0, 0 100%, 100% 100%, 100% 0%, ${calculatedWidth} 0, ${calculatedWidth} 3px, 0.5em 3px, 0.5em 0)`;
}
return this.cutProperty;
}
resolveParentTaskId() {
return !!this.dataField.parentTaskId ? this.dataField.parentTaskId : this.taskId;
}
resolveMaxSizeMessage() {
if (this.dataField?.component?.properties?.maxSizeMessage) {
this._snackbar.openErrorSnackBar(this._translate.instant(this.dataField?.component?.properties?.maxSizeMessage));
}
else {
this._snackbar.openErrorSnackBar(this._translate.instant('dataField.snackBar.maxFilesSizeExceeded') + this.dataField.maxUploadSizeInBytes * 0.000001 + 'MB');
}
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractFileFieldDefaultComponent, deps: [{ token: i1.LoggerService }, { token: i2.SnackBarService }, { token: i3.TranslateService }, { token: DATA_FIELD_PORTAL_DATA, optional: true }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractFileFieldDefaultComponent, selector: "ncc-abstract-file-field-default-component", inputs: { taskId: "taskId" }, viewQueries: [{ propertyName: "fileUploadEl", first: true, predicate: ["fileUploadInput"], descendants: true }], usesInheritance: true, ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractFileFieldDefaultComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-file-field-default-component',
template: ''
}]
}], ctorParameters: () => [{ type: i1.LoggerService }, { type: i2.SnackBarService }, { type: i3.TranslateService }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [DATA_FIELD_PORTAL_DATA]
}] }], propDecorators: { taskId: [{
type: Input
}], fileUploadEl: [{
type: ViewChild,
args: ['fileUploadInput']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-file-field-default-component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/data-fields/models/abstract-file-field-default-component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Inject, Input, Optional, ViewChild} from '@angular/core';\nimport {AbstractBaseDataFieldComponent} from '../base-component/abstract-base-data-field.component';\nimport {FileField, FileUploadMIMEType} from '../file-field/models/file-field';\nimport {DATA_FIELD_PORTAL_DATA, DataFieldPortalData} from './data-field-portal-data-injection-token';\nimport {LoggerService} from '../../logger/services/logger.service';\nimport {SnackBarService} from '../../snack-bar/services/snack-bar.service';\nimport {TranslateService} from '@ngx-translate/core';\nimport {FileListField} from '../file-list-field/models/file-list-field';\n\n@Component({\n    selector: 'ncc-abstract-file-field-default-component',\n    template: ''\n})\nexport abstract class AbstractFileFieldDefaultComponent<T extends FileField | FileListField> extends AbstractBaseDataFieldComponent<T> {\n\n    private labelWidth: number;\n    public cutProperty: string;\n    /**\n     * Task mongo string id is binding property from parent component.\n     */\n    @Input() public taskId: string;\n    /**\n     * File picker element reference from component template that is initialized after view init.\n     */\n    @ViewChild('fileUploadInput') public fileUploadEl: ElementRef<HTMLInputElement>;\n\n    protected constructor(protected _log: LoggerService,\n                          protected _snackbar: SnackBarService,\n                          protected _translate: TranslateService,\n                          @Optional() @Inject(DATA_FIELD_PORTAL_DATA) dataFieldPortalData: DataFieldPortalData<T>) {\n        super(dataFieldPortalData);\n    }\n\n    protected checkAllowedTypes(): boolean {\n        const files = this.fileUploadEl?.nativeElement?.files;\n        let bool: boolean = true;\n        for (let i = 0; i < files?.length; i++) {\n            if (!this.checkTypes(files.item(i).type)) {\n                this._log.error('File ' + files.item(i).name + ' cannot be uploaded. Its type is not allowed');\n                this._snackbar.openErrorSnackBar(this._translate.instant('dataField.file.notAllowed', {fileName: files.item(i).name}));\n                bool = false;\n            }\n        }\n        if (!bool) {\n            this.fileUploadEl.nativeElement.value = '';\n        }\n        return bool;\n    }\n\n    protected checkTypes(itemType: string) {\n        if (this.dataField.allowTypes === undefined || this.dataField.allowTypes === null) {\n            this._log.debug(`Types are not provided, returning true`);\n            return true;\n        }\n        const type = itemType.includes(\"/\") ? itemType.split(\"/\")[1] : itemType;\n        if (this.dataField.allowTypes.includes(type)) {\n            return true;\n        }\n        if (this.dataField.allowTypes.includes(FileUploadMIMEType.IMAGE) && itemType.includes(\"image/\")) {\n            return true;\n        }\n        if (this.dataField.allowTypes.includes(FileUploadMIMEType.VIDEO) && itemType.includes(\"video/\")) {\n            return true;\n        }\n        if (this.dataField.allowTypes.includes(FileUploadMIMEType.AUDIO) && itemType.includes(\"audio/\")) {\n            return true;\n        }\n        return false;\n    }\n\n    public getCutProperty(label): string {\n        if (this.labelWidth !== label.offsetWidth) {\n            this.labelWidth = label.offsetWidth;\n            const calculatedWidth = 'calc(0.5em + ' + label.offsetWidth / 4 * 3 + 'px)';\n            this.cutProperty = `polygon(0 0, 0 100%, 100% 100%, 100% 0%, ${calculatedWidth} 0, ${calculatedWidth} 3px, 0.5em 3px, 0.5em 0)`;\n        }\n        return this.cutProperty;\n    }\n\n    protected resolveParentTaskId(): string {\n        return !!this.dataField.parentTaskId ? this.dataField.parentTaskId : this.taskId;\n    }\n\n    protected resolveMaxSizeMessage() {\n        if (this.dataField?.component?.properties?.maxSizeMessage) {\n            this._snackbar.openErrorSnackBar(this._translate.instant(this.dataField?.component?.properties?.maxSizeMessage));\n        } else {\n            this._snackbar.openErrorSnackBar(\n                this._translate.instant('dataField.snackBar.maxFilesSizeExceeded') + this.dataField.maxUploadSizeInBytes * 0.000001 + 'MB'\n            );\n        }\n    }\n}\n"]}