diff --git a/src-ui/src/app/components/document-detail/document-detail.component.ts b/src-ui/src/app/components/document-detail/document-detail.component.ts index 4d66ea384..3d4289ad8 100644 --- a/src-ui/src/app/components/document-detail/document-detail.component.ts +++ b/src-ui/src/app/components/document-detail/document-detail.component.ts @@ -85,6 +85,7 @@ export class DocumentDetailComponent store: BehaviorSubject isDirty$: Observable unsubscribeNotifier: Subject = new Subject() + docChangeNotifier: Subject = new Subject() requiresPassword: boolean = false password: string @@ -117,18 +118,7 @@ export class DocumentDetailComponent private toastService: ToastService, private settings: SettingsService, private queryParamsService: QueryParamsService - ) { - this.titleSubject - .pipe( - debounceTime(1000), - distinctUntilChanged(), - takeUntil(this.unsubscribeNotifier) - ) - .subscribe((titleValue) => { - this.title = titleValue - this.documentForm.patchValue({ title: titleValue }) - }) - } + ) {} titleKeyUp(event) { this.titleSubject.next(event.target?.value) @@ -184,6 +174,7 @@ export class DocumentDetailComponent .pipe( switchMap((paramMap) => { const documentId = +paramMap.get('id') + this.docChangeNotifier.next(documentId) return this.documentsService.get(documentId) }) ) @@ -208,6 +199,18 @@ export class DocumentDetailComponent this.updateComponent(doc) } + this.titleSubject + .pipe( + debounceTime(1000), + distinctUntilChanged(), + takeUntil(this.docChangeNotifier), + takeUntil(this.unsubscribeNotifier) + ) + .subscribe((titleValue) => { + this.title = titleValue + this.documentForm.patchValue({ title: titleValue }) + }) + this.ogDate = new Date(normalizeDateStr(doc.created.toString())) // Initialize dirtyCheck