UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

103 lines 15.5 kB
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"]}