diff --git a/src-ui/src/app/services/upload-documents.service.ts b/src-ui/src/app/services/upload-documents.service.ts index ba97f0d9c..5e7ef7fbe 100644 --- a/src-ui/src/app/services/upload-documents.service.ts +++ b/src-ui/src/app/services/upload-documents.service.ts @@ -6,11 +6,14 @@ import { FileStatusPhase, } from './consumer-status.service' import { DocumentService } from './rest/document.service' +import { Subscription } from 'rxjs' @Injectable({ providedIn: 'root', }) export class UploadDocumentsService { + private uploadSubscriptions: Array = [] + constructor( private documentService: DocumentService, private consumerStatusService: ConsumerStatusService @@ -27,36 +30,43 @@ export class UploadDocumentsService { status.message = $localize`Connecting...` - this.documentService.uploadDocument(formData).subscribe({ - next: (event) => { - if (event.type == HttpEventType.UploadProgress) { - status.updateProgress( - FileStatusPhase.UPLOADING, - event.loaded, - event.total - ) - status.message = $localize`Uploading...` - } else if (event.type == HttpEventType.Response) { - status.taskId = event.body['task_id'] - status.message = $localize`Upload complete, waiting...` - } - }, - error: (error) => { - switch (error.status) { - case 400: { - this.consumerStatusService.fail(status, error.error.document) - break - } - default: { - this.consumerStatusService.fail( - status, - $localize`HTTP error: ${error.status} ${error.statusText}` + this.uploadSubscriptions[file.name] = this.documentService + .uploadDocument(formData) + .subscribe({ + next: (event) => { + if (event.type == HttpEventType.UploadProgress) { + status.updateProgress( + FileStatusPhase.UPLOADING, + event.loaded, + event.total ) - break + status.message = $localize`Uploading...` + } else if (event.type == HttpEventType.Response) { + status.taskId = event.body['task_id'] + status.message = $localize`Upload complete, waiting...` + this.uploadSubscriptions[file.name]?.complete() } - } - }, - }) + }, + error: (error) => { + switch (error.status) { + case 400: { + this.consumerStatusService.fail( + status, + error.error.document + ) + break + } + default: { + this.consumerStatusService.fail( + status, + $localize`HTTP error: ${error.status} ${error.statusText}` + ) + break + } + } + this.uploadSubscriptions[file.name]?.complete() + }, + }) }) } }