mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
fixes an issue with open documents not refreshing after bulk operations
This commit is contained in:
parent
cd8f99d2c3
commit
2f599ca1d3
@ -2,8 +2,7 @@ import { Component, OnInit, ViewChild } from '@angular/core';
|
|||||||
import { ActivatedRoute, Router } from '@angular/router';
|
import { ActivatedRoute, Router } from '@angular/router';
|
||||||
import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
|
import { NgbModal } from '@ng-bootstrap/ng-bootstrap';
|
||||||
import { Observable } from 'rxjs';
|
import { Observable } from 'rxjs';
|
||||||
import { map } from 'rxjs/operators';
|
import { tap } from 'rxjs/operators';
|
||||||
import { FILTER_CORRESPONDENT } from 'src/app/data/filter-rule-type';
|
|
||||||
import { PaperlessDocument } from 'src/app/data/paperless-document';
|
import { PaperlessDocument } from 'src/app/data/paperless-document';
|
||||||
import { PaperlessSavedView } from 'src/app/data/paperless-saved-view';
|
import { PaperlessSavedView } from 'src/app/data/paperless-saved-view';
|
||||||
import { DocumentListViewService } from 'src/app/services/document-list-view.service';
|
import { DocumentListViewService } from 'src/app/services/document-list-view.service';
|
||||||
@ -17,6 +16,7 @@ import { FilterEditorComponent } from '../filter-editor/filter-editor.component'
|
|||||||
import { ConfirmDialogComponent } from '../common/confirm-dialog/confirm-dialog.component';
|
import { ConfirmDialogComponent } from '../common/confirm-dialog/confirm-dialog.component';
|
||||||
import { SelectDialogComponent } from '../common/select-dialog/select-dialog.component';
|
import { SelectDialogComponent } from '../common/select-dialog/select-dialog.component';
|
||||||
import { SaveViewConfigDialogComponent } from './save-view-config-dialog/save-view-config-dialog.component';
|
import { SaveViewConfigDialogComponent } from './save-view-config-dialog/save-view-config-dialog.component';
|
||||||
|
import { OpenDocumentsService } from 'src/app/services/open-documents.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-document-list',
|
selector: 'app-document-list',
|
||||||
@ -35,7 +35,8 @@ export class DocumentListComponent implements OnInit {
|
|||||||
private correspondentService: CorrespondentService,
|
private correspondentService: CorrespondentService,
|
||||||
private documentTypeService: DocumentTypeService,
|
private documentTypeService: DocumentTypeService,
|
||||||
private tagService: TagService,
|
private tagService: TagService,
|
||||||
private documentService: DocumentService) { }
|
private documentService: DocumentService,
|
||||||
|
private openDocumentService: OpenDocumentsService) { }
|
||||||
|
|
||||||
@ViewChild("filterEditor")
|
@ViewChild("filterEditor")
|
||||||
private filterEditor: FilterEditorComponent
|
private filterEditor: FilterEditorComponent
|
||||||
@ -131,12 +132,12 @@ export class DocumentListComponent implements OnInit {
|
|||||||
|
|
||||||
private executeBulkOperation(method: string, args): Observable<any> {
|
private executeBulkOperation(method: string, args): Observable<any> {
|
||||||
return this.documentService.bulkEdit(Array.from(this.list.selected), method, args).pipe(
|
return this.documentService.bulkEdit(Array.from(this.list.selected), method, args).pipe(
|
||||||
map(r => {
|
tap(() => {
|
||||||
|
|
||||||
this.list.reload()
|
this.list.reload()
|
||||||
|
this.list.selected.forEach(id => {
|
||||||
|
this.openDocumentService.refreshDocument(id)
|
||||||
|
})
|
||||||
this.list.selectNone()
|
this.list.selectNone()
|
||||||
|
|
||||||
return r
|
|
||||||
})
|
})
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
import { Injectable } from '@angular/core';
|
import { Injectable } from '@angular/core';
|
||||||
import { PaperlessDocument } from '../data/paperless-document';
|
import { PaperlessDocument } from '../data/paperless-document';
|
||||||
import { OPEN_DOCUMENT_SERVICE } from '../data/storage-keys';
|
import { OPEN_DOCUMENT_SERVICE } from '../data/storage-keys';
|
||||||
|
import { DocumentService } from './rest/document.service';
|
||||||
|
|
||||||
@Injectable({
|
@Injectable({
|
||||||
providedIn: 'root'
|
providedIn: 'root'
|
||||||
@ -9,7 +10,7 @@ export class OpenDocumentsService {
|
|||||||
|
|
||||||
private MAX_OPEN_DOCUMENTS = 5
|
private MAX_OPEN_DOCUMENTS = 5
|
||||||
|
|
||||||
constructor() {
|
constructor(private documentService: DocumentService) {
|
||||||
if (sessionStorage.getItem(OPEN_DOCUMENT_SERVICE.DOCUMENTS)) {
|
if (sessionStorage.getItem(OPEN_DOCUMENT_SERVICE.DOCUMENTS)) {
|
||||||
try {
|
try {
|
||||||
this.openDocuments = JSON.parse(sessionStorage.getItem(OPEN_DOCUMENT_SERVICE.DOCUMENTS))
|
this.openDocuments = JSON.parse(sessionStorage.getItem(OPEN_DOCUMENT_SERVICE.DOCUMENTS))
|
||||||
@ -22,6 +23,15 @@ export class OpenDocumentsService {
|
|||||||
|
|
||||||
private openDocuments: PaperlessDocument[] = []
|
private openDocuments: PaperlessDocument[] = []
|
||||||
|
|
||||||
|
refreshDocument(id: number) {
|
||||||
|
let index = this.openDocuments.findIndex(doc => doc.id == id)
|
||||||
|
if (index > -1) {
|
||||||
|
this.documentService.get(id).subscribe(doc => {
|
||||||
|
this.openDocuments[index] = doc
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
getOpenDocuments(): PaperlessDocument[] {
|
getOpenDocuments(): PaperlessDocument[] {
|
||||||
return this.openDocuments
|
return this.openDocuments
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user