From 89c639f8501d392d2430b287e4940780f77f72c3 Mon Sep 17 00:00:00 2001 From: shamoon <4887959+shamoon@users.noreply.github.com> Date: Fri, 17 Mar 2023 15:08:12 -0700 Subject: [PATCH] Just include comments on document object --- .../cypress/fixtures/documents/documents.json | 42 ++++++++++- src-ui/messages.xlf | 74 ++++++++++--------- .../document-comments.component.ts | 32 ++------ .../document-detail.component.html | 4 +- .../document-detail.component.ts | 5 +- .../document-card-large.component.html | 4 +- .../document-card-small.component.html | 4 +- .../document-card-small.component.ts | 2 +- .../document-list.component.html | 6 +- src-ui/src/app/data/paperless-document.ts | 3 +- ...ter_comment_document_alter_comment_user.py | 40 ++++++++++ src/documents/models.py | 4 +- src/documents/serialisers.py | 9 +-- src/documents/views.py | 3 +- 14 files changed, 147 insertions(+), 85 deletions(-) create mode 100644 src/documents/migrations/1034_alter_comment_document_alter_comment_user.py diff --git a/src-ui/cypress/fixtures/documents/documents.json b/src-ui/cypress/fixtures/documents/documents.json index 715ac8e16..b67cfa4df 100644 --- a/src-ui/cypress/fixtures/documents/documents.json +++ b/src-ui/cypress/fixtures/documents/documents.json @@ -22,7 +22,41 @@ "archived_file_name": "2022-03-22 no latin title.pdf", "owner": null, "permissions": [], - "n_comments": 3 + "comments": [ + { + "id": 30, + "comment": "One more time", + "created": "2023-03-17T22:02:14.357575Z", + "user": { + "id": 2, + "username": "username", + "first_name": "", + "last_name": "" + } + }, + { + "id": 6, + "comment": "Lets keep going", + "created": "2023-03-16T06:57:32.014027Z", + "user": { + "id": 2, + "username": "username", + "first_name": "", + "last_name": "" + } + }, + { + "id": 5, + "comment": "And just one more", + "created": "2023-03-16T06:57:27.022729Z", + "user": { + "id": 2, + "username": "username", + "first_name": "", + "last_name": "" + } + } + ] }, { "id": 2, @@ -41,7 +75,7 @@ "archived_file_name": "2022-03-23 llorem ipsum dolor sit amet.pdf", "owner": null, "permissions": [], - "n_comments": 0 + "comments": [] }, { "id": 3, @@ -62,7 +96,7 @@ "archived_file_name": "2022-03-24 dolor.pdf", "owner": null, "permissions": [], - "n_comments": 0 + "comments": [] }, { "id": 4, @@ -83,7 +117,7 @@ "archived_file_name": "2022-06-01 sit amet.pdf", "owner": null, "permissions": [], - "n_comments": 0 + "comments": [] } ] } diff --git a/src-ui/messages.xlf b/src-ui/messages.xlf index eee391f14..c10758158 100644 --- a/src-ui/messages.xlf +++ b/src-ui/messages.xlf @@ -2157,7 +2157,7 @@ src/app/components/document-list/document-list.component.html - 159 + 165 src/app/components/document-list/filter-editor/filter-editor.component.html @@ -2364,14 +2364,14 @@ Error saving comment: src/app/components/document-comments/document-comments.component.ts - 75 + 59 Error deleting comment: src/app/components/document-comments/document-comments.component.ts - 91 + 75 @@ -2514,7 +2514,7 @@ src/app/components/document-list/document-list.component.html - 147 + 153 src/app/components/document-list/filter-editor/filter-editor.component.html @@ -2537,7 +2537,7 @@ src/app/components/document-list/document-list.component.html - 153 + 159 src/app/components/document-list/filter-editor/filter-editor.component.html @@ -2665,7 +2665,7 @@ - Comments + Comments src/app/components/document-detail/document-detail.component.html 175,176 @@ -2689,32 +2689,32 @@ Error retrieving metadata src/app/components/document-detail/document-detail.component.ts - 340 + 341 Error retrieving suggestions src/app/components/document-detail/document-detail.component.ts - 360 + 361 Error saving document src/app/components/document-detail/document-detail.component.ts - 474 + 475 src/app/components/document-detail/document-detail.component.ts - 518 + 519 Confirm delete src/app/components/document-detail/document-detail.component.ts - 547 + 548 src/app/components/manage/management-list/management-list.component.ts @@ -2725,35 +2725,35 @@ Do you really want to delete document ""? src/app/components/document-detail/document-detail.component.ts - 548 + 549 The files for this document will be deleted permanently. This operation cannot be undone. src/app/components/document-detail/document-detail.component.ts - 549 + 550 Delete document src/app/components/document-detail/document-detail.component.ts - 551 + 552 Error deleting document: src/app/components/document-detail/document-detail.component.ts - 567 + 568 Redo OCR confirm src/app/components/document-detail/document-detail.component.ts - 587 + 588 src/app/components/document-list/bulk-editor/bulk-editor.component.ts @@ -2764,14 +2764,14 @@ This operation will permanently redo OCR for this document. src/app/components/document-detail/document-detail.component.ts - 588 + 589 This operation cannot be undone. src/app/components/document-detail/document-detail.component.ts - 589 + 590 src/app/components/document-list/bulk-editor/bulk-editor.component.ts @@ -2802,7 +2802,7 @@ Proceed src/app/components/document-detail/document-detail.component.ts - 591 + 592 src/app/components/document-list/bulk-editor/bulk-editor.component.ts @@ -2829,7 +2829,7 @@ Redo OCR operation will begin in the background. Close and re-open or reload this document after the operation has completed to see new content. src/app/components/document-detail/document-detail.component.ts - 599 + 600 @@ -2838,7 +2838,7 @@ )"/> src/app/components/document-detail/document-detail.component.ts - 610,612 + 611,613 @@ -3159,7 +3159,7 @@ src/app/components/document-list/document-list.component.html - 180 + 186 @@ -3170,7 +3170,7 @@ src/app/components/document-list/document-list.component.html - 185 + 191 @@ -3181,7 +3181,7 @@ - Comments + Comments src/app/components/document-list/document-card-large/document-card-large.component.html 74 @@ -3195,7 +3195,7 @@ src/app/components/document-list/document-list.component.html - 189 + 204 @@ -3206,7 +3206,7 @@ src/app/components/document-list/document-list.component.html - 194 + 209 @@ -3373,11 +3373,22 @@ 18 + + Comments + + src/app/components/document-list/document-list.component.html + 147 + + + src/app/components/manage/settings/settings.component.html + 159 + + Added src/app/components/document-list/document-list.component.html - 165 + 171 src/app/components/document-list/filter-editor/filter-editor.component.html @@ -3392,7 +3403,7 @@ Edit document src/app/components/document-list/document-list.component.html - 184 + 190 @@ -4039,13 +4050,6 @@ 155 - - Comments - - src/app/components/manage/settings/settings.component.html - 159 - - Enable comments diff --git a/src-ui/src/app/components/document-comments/document-comments.component.ts b/src-ui/src/app/components/document-comments/document-comments.component.ts index 316a2ff28..405ddd208 100644 --- a/src-ui/src/app/components/document-comments/document-comments.component.ts +++ b/src-ui/src/app/components/document-comments/document-comments.component.ts @@ -17,21 +17,16 @@ export class DocumentCommentsComponent extends ComponentWithPermissions { }) networkActive = false - comments: PaperlessDocumentComment[] = [] newCommentError: boolean = false - private _documentId: number + @Input() + documentId: number @Input() - set documentId(id: number) { - if (id != this._documentId) { - this._documentId = id - this.update() - } - } + comments: PaperlessDocumentComment[] = [] @Output() - updated: EventEmitter = new EventEmitter() + updated: EventEmitter = new EventEmitter() constructor( private commentsService: DocumentCommentsService, @@ -40,17 +35,6 @@ export class DocumentCommentsComponent extends ComponentWithPermissions { super() } - update(): void { - this.networkActive = true - this.commentsService - .getComments(this._documentId) - .pipe(first()) - .subscribe((comments) => { - this.comments = comments - this.networkActive = false - }) - } - addComment() { const comment: string = this.commentForm .get('newComment') @@ -62,12 +46,12 @@ export class DocumentCommentsComponent extends ComponentWithPermissions { } this.newCommentError = false this.networkActive = true - this.commentsService.addComment(this._documentId, comment).subscribe({ + this.commentsService.addComment(this.documentId, comment).subscribe({ next: (result) => { this.comments = result this.commentForm.get('newComment').reset() this.networkActive = false - this.updated.emit(this.comments.length) + this.updated.emit(this.comments) }, error: (e) => { this.networkActive = false @@ -79,11 +63,11 @@ export class DocumentCommentsComponent extends ComponentWithPermissions { } deleteComment(commentId: number) { - this.commentsService.deleteComment(this._documentId, commentId).subscribe({ + this.commentsService.deleteComment(this.documentId, commentId).subscribe({ next: (result) => { this.comments = result this.networkActive = false - this.updated.emit(this.comments.length) + this.updated.emit(this.comments) }, error: (e) => { this.networkActive = false diff --git a/src-ui/src/app/components/document-detail/document-detail.component.html b/src-ui/src/app/components/document-detail/document-detail.component.html index c5d727459..ee1c15913 100644 --- a/src-ui/src/app/components/document-detail/document-detail.component.html +++ b/src-ui/src/app/components/document-detail/document-detail.component.html @@ -172,9 +172,9 @@
  • - Comments {{document.n_comments}} + Comments {{document.comments.length}} - +
  • 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 029fab642..3ca7755e2 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 @@ -42,6 +42,7 @@ import { } from 'src/app/services/permissions.service' import { PaperlessUser } from 'src/app/data/paperless-user' import { UserService } from 'src/app/services/rest/user.service' +import { PaperlessDocumentComment } from 'src/app/data/paperless-document-comment' enum DocumentDetailNavIDs { Details = 1, @@ -667,8 +668,8 @@ export class DocumentDetailComponent ) } - commentsUpdated(n_comments: number) { - this.document.n_comments = n_comments + commentsUpdated(comments: PaperlessDocumentComment[]) { + this.document.comments = comments this.openDocumentService.refreshDocument(this.documentId) } diff --git a/src-ui/src/app/components/document-list/document-card-large/document-card-large.component.html b/src-ui/src/app/components/document-list/document-card-large/document-card-large.component.html index b6417ceb1..01ea1e8b6 100644 --- a/src-ui/src/app/components/document-list/document-card-large/document-card-large.component.html +++ b/src-ui/src/app/components/document-list/document-card-large/document-card-large.component.html @@ -67,11 +67,11 @@
    -
    - + - {{document.n_comments}} + {{document.comments.length}}
    diff --git a/src-ui/src/app/components/document-list/document-card-small/document-card-small.component.ts b/src-ui/src/app/components/document-list/document-card-small/document-card-small.component.ts index 99d64e711..745f2b3e4 100644 --- a/src-ui/src/app/components/document-list/document-card-small/document-card-small.component.ts +++ b/src-ui/src/app/components/document-list/document-card-small/document-card-small.component.ts @@ -74,7 +74,7 @@ export class DocumentCardSmallComponent extends ComponentWithPermissions { } getTagsLimited$() { - const limit = this.document.n_comments > 0 ? 6 : 7 + const limit = this.document.comments.length > 0 ? 6 : 7 return this.document.tags$.pipe( map((tags) => { if (tags.length > limit) { diff --git a/src-ui/src/app/components/document-list/document-list.component.html b/src-ui/src/app/components/document-list/document-list.component.html index c46206d61..02015380e 100644 --- a/src-ui/src/app/components/document-list/document-list.component.html +++ b/src-ui/src/app/components/document-list/document-list.component.html @@ -140,7 +140,7 @@ (sort)="onSort($event)" i18n>Title - + - {{d.n_comments}} + {{d.comments.length}} diff --git a/src-ui/src/app/data/paperless-document.ts b/src-ui/src/app/data/paperless-document.ts index 009b33a03..be15efb01 100644 --- a/src-ui/src/app/data/paperless-document.ts +++ b/src-ui/src/app/data/paperless-document.ts @@ -4,6 +4,7 @@ import { PaperlessDocumentType } from './paperless-document-type' import { Observable } from 'rxjs' import { PaperlessStoragePath } from './paperless-storage-path' import { ObjectWithPermissions } from './object-with-permissions' +import { PaperlessDocumentComment } from './paperless-document-comment' export interface SearchHit { score?: number @@ -54,7 +55,7 @@ export interface PaperlessDocument extends ObjectWithPermissions { archive_serial_number?: number - n_comments?: number + comments?: PaperlessDocumentComment[] __search_hit__?: SearchHit } diff --git a/src/documents/migrations/1034_alter_comment_document_alter_comment_user.py b/src/documents/migrations/1034_alter_comment_document_alter_comment_user.py new file mode 100644 index 000000000..1583e7635 --- /dev/null +++ b/src/documents/migrations/1034_alter_comment_document_alter_comment_user.py @@ -0,0 +1,40 @@ +# Generated by Django 4.1.5 on 2023-03-17 21:23 + +from django.conf import settings +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + dependencies = [ + migrations.swappable_dependency(settings.AUTH_USER_MODEL), + ("documents", "1033_alter_documenttype_options_alter_tag_options_and_more"), + ] + + operations = [ + migrations.AlterField( + model_name="comment", + name="document", + field=models.ForeignKey( + blank=True, + null=True, + on_delete=django.db.models.deletion.CASCADE, + related_name="comments", + to="documents.document", + verbose_name="document", + ), + ), + migrations.AlterField( + model_name="comment", + name="user", + field=models.ForeignKey( + blank=True, + null=True, + on_delete=django.db.models.deletion.SET_NULL, + related_name="comments", + to=settings.AUTH_USER_MODEL, + verbose_name="user", + ), + ), + ] diff --git a/src/documents/models.py b/src/documents/models.py index c42cb4f91..d820f32d2 100644 --- a/src/documents/models.py +++ b/src/documents/models.py @@ -652,7 +652,7 @@ class Comment(models.Model): Document, blank=True, null=True, - related_name="documents", + related_name="comments", on_delete=models.CASCADE, verbose_name=_("document"), ) @@ -661,7 +661,7 @@ class Comment(models.Model): User, blank=True, null=True, - related_name="users", + related_name="comments", on_delete=models.SET_NULL, verbose_name=_("user"), ) diff --git a/src/documents/serialisers.py b/src/documents/serialisers.py index c672ee07c..9746dea40 100644 --- a/src/documents/serialisers.py +++ b/src/documents/serialisers.py @@ -16,7 +16,6 @@ from rest_framework import serializers from rest_framework.fields import SerializerMethodField from . import bulk_edit -from .models import Comment from .models import Correspondent from .models import Document from .models import DocumentType @@ -383,7 +382,7 @@ class DocumentSerializer(OwnedObjectSerializer, DynamicFieldsModelSerializer): archived_file_name = SerializerMethodField() created_date = serializers.DateField(required=False) - n_comments = SerializerMethodField() + num_comments = serializers.IntegerField(read_only=True) owner = serializers.PrimaryKeyRelatedField( queryset=User.objects.all(), @@ -400,9 +399,6 @@ class DocumentSerializer(OwnedObjectSerializer, DynamicFieldsModelSerializer): else: return None - def get_n_comments(self, obj): - return Comment.objects.filter(document=obj).count() - def to_representation(self, instance): doc = super().to_representation(instance) if self.truncate_content: @@ -448,7 +444,8 @@ class DocumentSerializer(OwnedObjectSerializer, DynamicFieldsModelSerializer): "owner", "permissions", "set_permissions", - "n_comments", + "comments", + "num_comments", ) diff --git a/src/documents/views.py b/src/documents/views.py index e7b0fdaa5..6226d99cd 100644 --- a/src/documents/views.py +++ b/src/documents/views.py @@ -230,7 +230,7 @@ class DocumentViewSet( GenericViewSet, ): model = Document - queryset = Document.objects.all() + queryset = Document.objects.annotate(num_comments=Count("comments")) serializer_class = DocumentSerializer pagination_class = StandardPagination permission_classes = (IsAuthenticated, PaperlessObjectPermissions) @@ -251,6 +251,7 @@ class DocumentViewSet( "modified", "added", "archive_serial_number", + "num_comments", ) def get_queryset(self):