UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

154 lines 22.4 kB
import { Component } from '@angular/core'; import { FormControl } from '@angular/forms'; import { ProgressType } from '../../../resources/resource-provider.service'; import * as i0 from "@angular/core"; import * as i1 from "../../models/side-menu-control"; import * as i2 from "../../../resources/engine-endpoint/petri-net-resource.service"; import * as i3 from "../../../navigation/service/path.service"; import * as i4 from "../../../logger/services/logger.service"; import * as i5 from "../../../snack-bar/services/snack-bar.service"; import * as i6 from "@ngx-translate/core"; export class FileUploadModel { stringId; data; inProgress; progress; completed; error; uploaded; downloading; sub; } export class AbstractImportNetComponent { _sideMenuControl; _petriNetResource; _pathService; _log; _snackbar; _translate; files = {}; releaseTypes = ['Major', 'Minor', 'Patch']; releaseTypeControl = new FormControl(this.releaseTypes[0]); _response = undefined; _fileInput; constructor(_sideMenuControl, _petriNetResource, _pathService, _log, _snackbar, _translate) { this._sideMenuControl = _sideMenuControl; this._petriNetResource = _petriNetResource; this._pathService = _pathService; this._log = _log; this._snackbar = _snackbar; this._translate = _translate; } ngAfterViewInit() { this._fileInput = document.getElementById('sidemenu-fileUpload'); this._fileInput.onchange = () => { for (const fileIndex of Array.from(Array(this._fileInput.files.length).keys())) { const file = this._fileInput.files[fileIndex]; if (this.files[file.name]) { const knownFile = this.files[file.name].data; if (knownFile.type !== file.type || knownFile.lastModified !== file.lastModified) { this.files[file.name] = this.setupFile(file); } } else { this.files[file.name] = this.setupFile(file); } } this.uploadFiles(); }; } get fileList() { return Object.values(this.files); } get isAllFinished() { return Object.values(this.files).every(file => !file.inProgress && file.progress === 100); } onProcessFileChosen() { if (this._fileInput) { this._fileInput.click(); } } cancelFile(file) { file.sub.unsubscribe(); this.removeFile(file); } retryFile(file) { this.uploadFile(file); } close() { this._sideMenuControl.close({ opened: false, message: 'All process files were processed', data: this._response ? { net: this._response.net } : undefined }); } setupFile(file) { return { data: file, stringId: '', downloading: false, inProgress: false, progress: 0, completed: false, uploaded: false }; } uploadFiles() { this._fileInput.value = ''; this.fileList.filter(fileModel => !fileModel.completed && fileModel.progress === 0).forEach(file => { this.uploadFile(file); }); } removeFile(file) { if (this.files[file.data.name]) { delete this.files[file.data.name]; this._sideMenuControl.publish({ opened: true, message: 'Process ' + file.data.name + ' was deleted from the list', data: file }); } } uploadFile(file) { const fileFormData = new FormData(); fileFormData.append('file', file.data); fileFormData.append('meta', this.releaseTypeControl.value.toString().toUpperCase()); file.inProgress = true; file.completed = false; file.error = false; file.sub = this._petriNetResource.importPetriNet(fileFormData).subscribe((response) => { if (response.type && response.type === ProgressType.UPLOAD) { file.progress = response.progress; if (file.progress === 100) { file.uploaded = true; } } else { this._log.info(response.success); this._response = response.outcome; file.inProgress = false; file.completed = true; this._snackbar.openSuccessSnackBar(response.outcome.message === undefined ? this._translate.instant('workflow.snackBar.uploadSuccess') : response.outcome.message); this._sideMenuControl.publish({ opened: true, message: response.outcome.message === undefined ? 'Process ' + file.data.name + ' successfully uploaded' : response.outcome.message, data: { net: response.outcome.net } }); } }, error => { file.inProgress = false; file.completed = false; file.error = true; this._log.error('Importing process file has failed!', error); this._snackbar.openErrorSnackBar(`${this._translate.instant('workflow.snackBar.uploadFailed')} ${error?.error?.message ?? ''}`); }); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractImportNetComponent, deps: [{ token: i1.SideMenuControl }, { token: i2.PetriNetResourceService }, { token: i3.PathService }, { token: i4.LoggerService }, { token: i5.SnackBarService }, { token: i6.TranslateService }], target: i0.ɵɵFactoryTarget.Component }); static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractImportNetComponent, selector: "ncc-abstract-import-net", ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractImportNetComponent, decorators: [{ type: Component, args: [{ selector: 'ncc-abstract-import-net', template: '' }] }], ctorParameters: () => [{ type: i1.SideMenuControl }, { type: i2.PetriNetResourceService }, { type: i3.PathService }, { type: i4.LoggerService }, { type: i5.SnackBarService }, { type: i6.TranslateService }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-import-net.component.js","sourceRoot":"","sources":["../../../../../../../projects/netgrif-components-core/src/lib/side-menu/content-components/import-net/abstract-import-net.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {AfterViewInit, Component} from '@angular/core';\nimport {FormControl} from '@angular/forms';\nimport {SideMenuControl} from '../../models/side-menu-control';\nimport {PetriNetResourceService} from '../../../resources/engine-endpoint/petri-net-resource.service';\nimport {LoggerService} from '../../../logger/services/logger.service';\nimport {EventOutcomeMessageResource} from '../../../resources/interface/message-resource';\nimport {ProgressType, ProviderProgress} from '../../../resources/resource-provider.service';\nimport {SnackBarService} from '../../../snack-bar/services/snack-bar.service';\nimport {FileUploadDataModel} from '../../../data-fields/file-field/models/file-field';\nimport {Subscription} from 'rxjs';\nimport {TranslateService} from '@ngx-translate/core';\nimport {PetriNetEventOutcome} from '../../../event/model/event-outcomes/petrinet-outcomes/petri-net-event-outcome';\nimport {PathService} from \"../../../navigation/service/path.service\";\n\nexport class FileUploadModel {\n    stringId: string;\n    data: File | FileUploadDataModel;\n    inProgress: boolean;\n    progress: number;\n    completed: boolean;\n    error?: boolean;\n    uploaded?: boolean;\n    downloading: boolean;\n    sub?: Subscription;\n}\n\ninterface FileList {\n    [key: string]: FileUploadModel;\n}\n\n@Component({\n    selector: 'ncc-abstract-import-net',\n    template: ''\n})\nexport abstract class AbstractImportNetComponent implements AfterViewInit {\n\n    public files: FileList = {};\n    public releaseTypes: Array<string> = ['Major', 'Minor', 'Patch'];\n    public releaseTypeControl = new FormControl(this.releaseTypes[0]);\n\n    protected _response: PetriNetEventOutcome = undefined;\n    protected _fileInput: HTMLInputElement;\n\n    constructor(protected _sideMenuControl: SideMenuControl,\n                protected _petriNetResource: PetriNetResourceService,\n                protected _pathService: PathService,\n                protected _log: LoggerService,\n                protected _snackbar: SnackBarService,\n                protected _translate: TranslateService) {\n    }\n\n    ngAfterViewInit(): void {\n        this._fileInput = document.getElementById('sidemenu-fileUpload') as HTMLInputElement;\n        this._fileInput.onchange = () => {\n            for (const fileIndex of Array.from(Array(this._fileInput.files.length).keys())) {\n                const file = this._fileInput.files[fileIndex];\n                if (this.files[file.name]) {\n                    const knownFile = this.files[file.name].data as File;\n                    if (knownFile.type !== file.type || knownFile.lastModified !== file.lastModified) {\n                        this.files[file.name] = this.setupFile(file);\n                    }\n                } else {\n                    this.files[file.name] = this.setupFile(file);\n                }\n            }\n            this.uploadFiles();\n        };\n    }\n\n    get fileList(): Array<FileUploadModel> {\n        return Object.values(this.files);\n    }\n\n    get isAllFinished(): boolean {\n        return Object.values(this.files).every(file => !file.inProgress && file.progress === 100);\n    }\n\n    public onProcessFileChosen() {\n        if (this._fileInput) {\n            this._fileInput.click();\n        }\n    }\n\n    public cancelFile(file: FileUploadModel) {\n        file.sub.unsubscribe();\n        this.removeFile(file);\n    }\n\n    public retryFile(file: FileUploadModel) {\n        this.uploadFile(file);\n    }\n\n    public close(): void {\n        this._sideMenuControl.close({\n            opened: false,\n            message: 'All process files were processed',\n            data: this._response ? { net: this._response.net } : undefined\n        });\n    }\n\n    protected setupFile(file: File): FileUploadModel {\n        return {\n            data: file, stringId: '', downloading: false, inProgress: false, progress: 0, completed: false, uploaded: false\n        };\n    }\n\n    protected uploadFiles() {\n        this._fileInput.value = '';\n\n        this.fileList.filter(fileModel => !fileModel.completed && fileModel.progress === 0).forEach(file => {\n            this.uploadFile(file);\n        });\n    }\n\n    protected removeFile(file: FileUploadModel) {\n        if (this.files[file.data.name]) {\n            delete this.files[file.data.name];\n            this._sideMenuControl.publish({\n                opened: true,\n                message: 'Process ' + file.data.name + ' was deleted from the list',\n                data: file\n            });\n        }\n    }\n\n    protected uploadFile(file: FileUploadModel) {\n        const fileFormData = new FormData();\n        fileFormData.append('file', file.data as File);\n        fileFormData.append('meta', this.releaseTypeControl.value.toString().toUpperCase());\n\n        file.inProgress = true;\n        file.completed = false;\n        file.error = false;\n        file.sub = this._petriNetResource.importPetriNet(fileFormData).subscribe((response: EventOutcomeMessageResource) => {\n            if ((response as ProviderProgress).type && (response as ProviderProgress).type === ProgressType.UPLOAD) {\n                file.progress = (response as ProviderProgress).progress;\n                if (file.progress === 100) {\n                    file.uploaded = true;\n                }\n            } else {\n                this._log.info(response.success);\n                this._response = response.outcome as PetriNetEventOutcome;\n                file.inProgress = false;\n                file.completed = true;\n                this._snackbar.openSuccessSnackBar(response.outcome.message === undefined\n                    ? this._translate.instant('workflow.snackBar.uploadSuccess')\n                    : response.outcome.message);\n                this._sideMenuControl.publish({\n                    opened: true,\n                    message: response.outcome.message === undefined\n                        ? 'Process ' + file.data.name + ' successfully uploaded'\n                        : response.outcome.message\n                    ,\n                    data: {net: (response.outcome as PetriNetEventOutcome).net}\n                });\n            }\n        }, error => {\n            file.inProgress = false;\n            file.completed = false;\n            file.error = true;\n            this._log.error('Importing process file has failed!', error);\n            this._snackbar.openErrorSnackBar(\n                `${this._translate.instant('workflow.snackBar.uploadFailed')} ${error?.error?.message ?? ''}`);\n        });\n    }\n\n}\n"]}