From 0647812699fc3317cb65e408c9e755518a47389a Mon Sep 17 00:00:00 2001 From: shamoon <4887959+shamoon@users.noreply.github.com> Date: Thu, 5 Dec 2024 20:26:28 -0800 Subject: [PATCH] Enhancement: improved loading visuals (#8435) --- src-ui/messages.xlf | 380 +++++++++--------- .../admin/trash/trash.component.html | 2 +- .../admin/trash/trash.component.scss | 8 + .../admin/trash/trash.component.spec.ts | 2 + .../components/admin/trash/trash.component.ts | 23 +- .../dashboard/dashboard.component.html | 15 +- .../saved-view-widget.component.html | 123 +++--- .../saved-view-widget.component.scss | 14 + .../saved-view-widget.component.spec.ts | 5 +- .../saved-view-widget.component.ts | 17 +- .../statistics-widget.component.html | 82 +++- .../widget-frame/widget-frame.component.html | 2 +- .../widget-frame/widget-frame.component.scss | 9 + .../widget-frame.component.spec.ts | 7 + .../widget-frame/widget-frame.component.ts | 12 +- .../document-card-large.component.html | 121 +++--- .../document-card-small.component.html | 215 +++++----- .../correspondent-list.component.ts | 20 +- .../custom-fields.component.html | 13 +- .../custom-fields.component.scss | 9 + .../custom-fields.component.spec.ts | 3 + .../custom-fields/custom-fields.component.ts | 18 +- .../manage/mail/mail.component.html | 26 +- .../manage/mail/mail.component.scss | 9 + .../manage/mail/mail.component.spec.ts | 3 + .../components/manage/mail/mail.component.ts | 33 +- .../management-list.component.html | 2 +- .../management-list.component.scss | 9 + .../management-list.component.spec.ts | 1 + .../management-list.component.ts | 29 +- .../manage/workflows/workflows.component.html | 15 +- .../manage/workflows/workflows.component.scss | 9 + .../workflows/workflows.component.spec.ts | 3 +- .../manage/workflows/workflows.component.ts | 17 +- src-ui/src/theme.scss | 26 +- 35 files changed, 792 insertions(+), 490 deletions(-) diff --git a/src-ui/messages.xlf b/src-ui/messages.xlf index 61722b5ad..999413c35 100644 --- a/src-ui/messages.xlf +++ b/src-ui/messages.xlf @@ -255,20 +255,20 @@ src/app/components/admin/trash/trash.component.ts - 118 - - - src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html - 37 - - - src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html - 40 + 127 src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html 43 + + src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html + 46 + + + src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html + 49 + src/app/components/dashboard/widgets/upload-file-widget/upload-file-widget.component.html 73 @@ -327,7 +327,7 @@ src/app/components/manage/custom-fields/custom-fields.component.html - 54 + 61 src/app/components/manage/management-list/management-list.component.html @@ -728,10 +728,6 @@ src/app/components/common/system-status-dialog/system-status-dialog.component.html 10 - - src/app/components/dashboard/dashboard.component.html - 15 - src/app/components/dashboard/widgets/widget-frame/widget-frame.component.html 14 @@ -744,9 +740,21 @@ src/app/components/document-list/document-list.component.html 110 + + src/app/components/manage/custom-fields/custom-fields.component.html + 26 + src/app/components/manage/mail/mail.component.html - 164 + 40 + + + src/app/components/manage/mail/mail.component.html + 114 + + + src/app/components/manage/mail/mail.component.html + 178 src/app/components/manage/management-list/management-list.component.html @@ -768,6 +776,10 @@ src/app/components/manage/saved-views/saved-views.component.html 68 + + src/app/components/manage/workflows/workflows.component.html + 28 + Options to customize appearance, notifications and more. Settings apply to the <strong>current user only</strong>. @@ -1157,19 +1169,19 @@ src/app/components/manage/mail/mail.component.html - 59 + 66 src/app/components/manage/mail/mail.component.html - 69 + 76 src/app/components/manage/mail/mail.component.html - 126 + 140 src/app/components/manage/mail/mail.component.html - 138 + 152 src/app/components/manage/management-list/management-list.component.html @@ -1636,7 +1648,7 @@ src/app/components/manage/mail/mail.component.html - 96 + 103 src/app/components/manage/management-list/management-list.component.html @@ -1756,7 +1768,7 @@ src/app/components/manage/mail/mail.component.html - 100 + 107 src/app/components/manage/management-list/management-list.component.html @@ -1993,11 +2005,11 @@ src/app/components/admin/trash/trash.component.ts - 59 + 68 src/app/components/admin/trash/trash.component.ts - 88 + 97 src/app/components/admin/users-groups/users-groups.component.html @@ -2041,28 +2053,28 @@ src/app/components/manage/custom-fields/custom-fields.component.html - 36 + 43 src/app/components/manage/custom-fields/custom-fields.component.html - 48 + 55 src/app/components/manage/mail/mail.component.html - 60 + 67 src/app/components/manage/mail/mail.component.html - 72 - - - src/app/components/manage/mail/mail.component.html - 127 + 79 src/app/components/manage/mail/mail.component.html 141 + + src/app/components/manage/mail/mail.component.html + 155 + src/app/components/manage/management-list/management-list.component.html 9 @@ -2113,7 +2125,7 @@ src/app/components/manage/management-list/management-list.component.ts - 210 + 225 src/app/components/manage/saved-views/saved-views.component.html @@ -2121,11 +2133,11 @@ src/app/components/manage/workflows/workflows.component.html - 48 + 55 src/app/components/manage/workflows/workflows.component.html - 59 + 66 @@ -2139,37 +2151,37 @@ Confirm delete src/app/components/admin/trash/trash.component.ts - 55 + 64 src/app/components/admin/trash/trash.component.ts - 82 + 91 src/app/components/manage/management-list/management-list.component.ts - 206 + 221 src/app/components/manage/management-list/management-list.component.ts - 323 + 338 This operation will permanently delete this document. src/app/components/admin/trash/trash.component.ts - 56 + 65 This operation cannot be undone. src/app/components/admin/trash/trash.component.ts - 57 + 66 src/app/components/admin/trash/trash.component.ts - 86 + 95 src/app/components/admin/users-groups/users-groups.component.ts @@ -2181,37 +2193,37 @@ src/app/components/manage/custom-fields/custom-fields.component.ts - 83 + 93 src/app/components/manage/mail/mail.component.ts - 158 + 179 src/app/components/manage/mail/mail.component.ts - 238 + 259 src/app/components/manage/management-list/management-list.component.ts - 325 + 340 src/app/components/manage/workflows/workflows.component.ts - 115 + 124 Document deleted src/app/components/admin/trash/trash.component.ts - 66 + 75 Error deleting document src/app/components/admin/trash/trash.component.ts - 71 + 80 src/app/components/document-detail/document-detail.component.ts @@ -2222,56 +2234,56 @@ This operation will permanently delete the selected documents. src/app/components/admin/trash/trash.component.ts - 84 + 93 This operation will permanently delete all documents in the trash. src/app/components/admin/trash/trash.component.ts - 85 + 94 Document(s) deleted src/app/components/admin/trash/trash.component.ts - 96 + 105 Error deleting document(s) src/app/components/admin/trash/trash.component.ts - 103 + 112 Document restored src/app/components/admin/trash/trash.component.ts - 116 + 125 Error restoring document src/app/components/admin/trash/trash.component.ts - 126 + 135 Document(s) restored src/app/components/admin/trash/trash.component.ts - 136 + 145 Error restoring document(s) src/app/components/admin/trash/trash.component.ts - 142 + 151 @@ -2364,27 +2376,27 @@ src/app/components/manage/custom-fields/custom-fields.component.html - 35 + 42 src/app/components/manage/custom-fields/custom-fields.component.html - 45 + 52 src/app/components/manage/mail/mail.component.html - 58 + 65 src/app/components/manage/mail/mail.component.html - 66 + 73 src/app/components/manage/mail/mail.component.html - 125 + 139 src/app/components/manage/mail/mail.component.html - 135 + 149 src/app/components/manage/management-list/management-list.component.html @@ -2420,11 +2432,11 @@ src/app/components/manage/workflows/workflows.component.html - 47 + 54 src/app/components/manage/workflows/workflows.component.html - 56 + 63 @@ -2520,23 +2532,23 @@ src/app/components/manage/custom-fields/custom-fields.component.ts - 85 + 95 src/app/components/manage/mail/mail.component.ts - 160 + 181 src/app/components/manage/mail/mail.component.ts - 240 + 261 src/app/components/manage/management-list/management-list.component.ts - 327 + 342 src/app/components/manage/workflows/workflows.component.ts - 117 + 126 @@ -2686,7 +2698,7 @@ src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 72 + 106 @@ -2705,7 +2717,7 @@ src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 64 + 93 src/app/components/document-list/bulk-editor/bulk-editor.component.html @@ -2736,7 +2748,7 @@ src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 80 + 119 @@ -2751,7 +2763,7 @@ src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 88 + 132 @@ -2911,11 +2923,11 @@ src/app/components/document-list/document-card-large/document-card-large.component.html - 57 + 72 src/app/components/document-list/document-card-small/document-card-small.component.html - 129 + 143 @@ -2933,7 +2945,7 @@ src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html - 74 + 80 src/app/components/document-detail/document-detail.component.html @@ -2945,11 +2957,11 @@ src/app/components/document-list/document-card-large/document-card-large.component.html - 63 + 78 src/app/components/document-list/document-card-small/document-card-small.component.html - 135 + 149 @@ -3238,7 +3250,7 @@ src/app/components/document-list/document-card-large/document-card-large.component.html - 60 + 75 @@ -3263,7 +3275,7 @@ src/app/components/manage/custom-fields/custom-fields.component.ts - 65 + 75 @@ -3274,7 +3286,7 @@ src/app/components/manage/custom-fields/custom-fields.component.ts - 73 + 83 @@ -3758,7 +3770,7 @@ src/app/components/manage/mail/mail.component.html - 98 + 105 @@ -3780,11 +3792,11 @@ src/app/components/manage/mail/mail.component.html - 114 + 128 src/app/components/manage/workflows/workflows.component.html - 34 + 41 @@ -5381,19 +5393,19 @@ src/app/components/manage/mail/mail.component.html - 128 + 142 src/app/components/manage/mail/mail.component.html - 146 + 160 src/app/components/manage/workflows/workflows.component.html - 49 + 56 src/app/components/manage/workflows/workflows.component.html - 64 + 71 @@ -5787,7 +5799,7 @@ src/app/components/manage/mail/mail.component.html - 99 + 106 src/app/components/manage/workflows/workflows.component.html @@ -5921,11 +5933,11 @@ Filter by correspondent src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html - 47 + 53 src/app/components/document-list/document-card-large/document-card-large.component.html - 20 + 25 src/app/components/document-list/document-list.component.html @@ -5936,11 +5948,11 @@ Filter by document type src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html - 57 + 63 src/app/components/document-list/document-card-large/document-card-large.component.html - 74 + 96 src/app/components/document-list/document-list.component.html @@ -5951,11 +5963,11 @@ Filter by storage path src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html - 62 + 68 src/app/components/document-list/document-card-large/document-card-large.component.html - 80 + 102 src/app/components/document-list/document-list.component.html @@ -5966,7 +5978,7 @@ No documents src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html - 116 + 125 @@ -5980,42 +5992,42 @@ Go to inbox src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 5 + 28 Documents in inbox src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 6 + 29 Go to documents src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 10 + 33 Total documents src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 11 + 34 Total characters src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 15 + 38 Current ASN src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html - 20 + 43 @@ -6177,7 +6189,7 @@ src/app/components/document-list/document-card-large/document-card-large.component.html - 54 + 69 @@ -7152,7 +7164,7 @@ Filter by tag src/app/components/document-list/document-card-large/document-card-large.component.html - 31 + 36 src/app/components/document-list/document-list.component.html @@ -7163,74 +7175,74 @@ View notes src/app/components/document-list/document-card-large/document-card-large.component.html - 69 + 91 Created: src/app/components/document-list/document-card-large/document-card-large.component.html - 93,94 + 115,116 src/app/components/document-list/document-card-small/document-card-small.component.html - 66,67 + 76,77 src/app/components/document-list/document-card-small/document-card-small.component.html - 81,82 + 91,92 Added: src/app/components/document-list/document-card-large/document-card-large.component.html - 94,95 + 116,117 src/app/components/document-list/document-card-small/document-card-small.component.html - 67,68 + 77,78 src/app/components/document-list/document-card-small/document-card-small.component.html - 82,83 + 92,93 Modified: src/app/components/document-list/document-card-large/document-card-large.component.html - 95,96 + 117,118 src/app/components/document-list/document-card-small/document-card-small.component.html - 68,69 + 78,79 src/app/components/document-list/document-card-small/document-card-small.component.html - 83,84 + 93,94 {VAR_PLURAL, plural, =1 {1 page} other { pages}} src/app/components/document-list/document-card-large/document-card-large.component.html - 112 + 134 src/app/components/document-list/document-card-small/document-card-small.component.html - 96 + 106 Shared src/app/components/document-list/document-card-large/document-card-large.component.html - 122 + 144 src/app/components/document-list/document-card-small/document-card-small.component.html - 115 + 125 src/app/data/document.ts @@ -7245,35 +7257,35 @@ Score: src/app/components/document-list/document-card-large/document-card-large.component.html - 127 + 149 Toggle tag filter src/app/components/document-list/document-card-small/document-card-small.component.html - 16 + 20 Toggle correspondent filter src/app/components/document-list/document-card-small/document-card-small.component.html - 38 + 43 Toggle document type filter src/app/components/document-list/document-card-small/document-card-small.component.html - 49 + 59 Toggle storage path filter src/app/components/document-list/document-card-small/document-card-small.component.html - 56 + 66 @@ -7859,28 +7871,28 @@ correspondent src/app/components/manage/correspondent-list/correspondent-list.component.ts - 40 + 39 correspondents src/app/components/manage/correspondent-list/correspondent-list.component.ts - 41 + 40 Last used src/app/components/manage/correspondent-list/correspondent-list.component.ts - 46 + 45 Do you really want to delete the correspondent ""? src/app/components/manage/correspondent-list/correspondent-list.component.ts - 89 + 71 @@ -7908,7 +7920,7 @@ Filter Documents () src/app/components/manage/custom-fields/custom-fields.component.html - 38 + 45 src/app/components/manage/management-list/management-list.component.html @@ -7931,35 +7943,35 @@ No fields defined. src/app/components/manage/custom-fields/custom-fields.component.html - 63 + 70 Confirm delete field src/app/components/manage/custom-fields/custom-fields.component.ts - 81 + 91 This operation will permanently delete this field. src/app/components/manage/custom-fields/custom-fields.component.ts - 82 + 92 Deleted field src/app/components/manage/custom-fields/custom-fields.component.ts - 91 + 101 Error deleting field. src/app/components/manage/custom-fields/custom-fields.component.ts - 97 + 107 @@ -8029,197 +8041,197 @@ No mail accounts defined. src/app/components/manage/mail/mail.component.html - 80 + 87 Mail rules src/app/components/manage/mail/mail.component.html - 88 + 95 Add Rule src/app/components/manage/mail/mail.component.html - 90 + 97 Sort Order src/app/components/manage/mail/mail.component.html - 97 + 104 Disabled src/app/components/manage/mail/mail.component.html - 114 + 128 src/app/components/manage/workflows/workflows.component.html - 34 + 41 No mail rules defined. src/app/components/manage/mail/mail.component.html - 155 + 169 Error retrieving mail accounts src/app/components/manage/mail/mail.component.ts - 79 + 92 Error retrieving mail rules src/app/components/manage/mail/mail.component.ts - 93 + 114 OAuth2 authentication success src/app/components/manage/mail/mail.component.ts - 101 + 122 OAuth2 authentication failed, see logs for details src/app/components/manage/mail/mail.component.ts - 112 + 133 Saved account "". src/app/components/manage/mail/mail.component.ts - 136 + 157 Error saving account. src/app/components/manage/mail/mail.component.ts - 148 + 169 Confirm delete mail account src/app/components/manage/mail/mail.component.ts - 156 + 177 This operation will permanently delete this mail account. src/app/components/manage/mail/mail.component.ts - 157 + 178 Deleted mail account src/app/components/manage/mail/mail.component.ts - 166 + 187 Error deleting mail account. src/app/components/manage/mail/mail.component.ts - 176 + 197 Saved rule "". src/app/components/manage/mail/mail.component.ts - 195 + 216 Error saving rule. src/app/components/manage/mail/mail.component.ts - 206 + 227 Rule "" enabled. src/app/components/manage/mail/mail.component.ts - 222 + 243 Rule "" disabled. src/app/components/manage/mail/mail.component.ts - 223 + 244 Error toggling rule. src/app/components/manage/mail/mail.component.ts - 227 + 248 Confirm delete mail rule src/app/components/manage/mail/mail.component.ts - 236 + 257 This operation will permanently delete this mail rule. src/app/components/manage/mail/mail.component.ts - 237 + 258 Deleted mail rule src/app/components/manage/mail/mail.component.ts - 246 + 267 Error deleting mail rule. src/app/components/manage/mail/mail.component.ts - 255 + 276 Permissions updated src/app/components/manage/mail/mail.component.ts - 277 + 298 Error updating permissions src/app/components/manage/mail/mail.component.ts - 282 + 303 src/app/components/manage/management-list/management-list.component.ts - 310 + 325 @@ -8302,7 +8314,7 @@ Automatic src/app/components/manage/management-list/management-list.component.ts - 117 + 125 src/app/data/matching-model.ts @@ -8313,7 +8325,7 @@ None src/app/components/manage/management-list/management-list.component.ts - 119 + 127 src/app/data/matching-model.ts @@ -8324,70 +8336,70 @@ Successfully created . src/app/components/manage/management-list/management-list.component.ts - 163 + 178 Error occurred while creating . src/app/components/manage/management-list/management-list.component.ts - 168 + 183 Successfully updated . src/app/components/manage/management-list/management-list.component.ts - 183 + 198 Error occurred while saving . src/app/components/manage/management-list/management-list.component.ts - 188 + 203 Associated documents will not be deleted. src/app/components/manage/management-list/management-list.component.ts - 208 + 223 Error while deleting element src/app/components/manage/management-list/management-list.component.ts - 224 + 239 Permissions updated successfully src/app/components/manage/management-list/management-list.component.ts - 303 + 318 This operation will permanently delete all objects. src/app/components/manage/management-list/management-list.component.ts - 324 + 339 Objects deleted successfully src/app/components/manage/management-list/management-list.component.ts - 338 + 353 Error deleting objects src/app/components/manage/management-list/management-list.component.ts - 344 + 359 @@ -8520,70 +8532,70 @@ No workflows defined. src/app/components/manage/workflows/workflows.component.html - 73 + 80 Saved workflow "". src/app/components/manage/workflows/workflows.component.ts - 78 + 87 Error saving workflow. src/app/components/manage/workflows/workflows.component.ts - 86 + 95 Confirm delete workflow src/app/components/manage/workflows/workflows.component.ts - 113 + 122 This operation will permanently delete this workflow. src/app/components/manage/workflows/workflows.component.ts - 114 + 123 Deleted workflow src/app/components/manage/workflows/workflows.component.ts - 123 + 132 Error deleting workflow. src/app/components/manage/workflows/workflows.component.ts - 128 + 137 Enabled workflow src/app/components/manage/workflows/workflows.component.ts - 139 + 148 Disabled workflow src/app/components/manage/workflows/workflows.component.ts - 140 + 149 Error toggling workflow. src/app/components/manage/workflows/workflows.component.ts - 146 + 155 diff --git a/src-ui/src/app/components/admin/trash/trash.component.html b/src-ui/src/app/components/admin/trash/trash.component.html index 3dbf3db2b..a148f2033 100644 --- a/src-ui/src/app/components/admin/trash/trash.component.html +++ b/src-ui/src/app/components/admin/trash/trash.component.html @@ -47,7 +47,7 @@ } @for (document of documentsInTrash; track document.id) { - +
diff --git a/src-ui/src/app/components/admin/trash/trash.component.scss b/src-ui/src/app/components/admin/trash/trash.component.scss index e69de29bb..648aa7f4d 100644 --- a/src-ui/src/app/components/admin/trash/trash.component.scss +++ b/src-ui/src/app/components/admin/trash/trash.component.scss @@ -0,0 +1,8 @@ +.data-row { + opacity: 0; + transition: opacity .2s; +} + +.reveal { + opacity: 1; +} diff --git a/src-ui/src/app/components/admin/trash/trash.component.spec.ts b/src-ui/src/app/components/admin/trash/trash.component.spec.ts index 9ac89d9a5..066311726 100644 --- a/src-ui/src/app/components/admin/trash/trash.component.spec.ts +++ b/src-ui/src/app/components/admin/trash/trash.component.spec.ts @@ -69,6 +69,7 @@ describe('TrashComponent', () => { }) it('should call correct service method on reload', () => { + jest.useFakeTimers() const trashSpy = jest.spyOn(trashService, 'getTrash') trashSpy.mockReturnValue( of({ @@ -78,6 +79,7 @@ describe('TrashComponent', () => { }) ) component.reload() + jest.advanceTimersByTime(100) expect(trashSpy).toHaveBeenCalled() expect(component.documentsInTrash).toEqual(documentsInTrash) }) diff --git a/src-ui/src/app/components/admin/trash/trash.component.ts b/src-ui/src/app/components/admin/trash/trash.component.ts index 9364d4cce..055c5fa97 100644 --- a/src-ui/src/app/components/admin/trash/trash.component.ts +++ b/src-ui/src/app/components/admin/trash/trash.component.ts @@ -4,7 +4,7 @@ import { Document } from 'src/app/data/document' import { ToastService } from 'src/app/services/toast.service' import { TrashService } from 'src/app/services/trash.service' import { ConfirmDialogComponent } from '../../common/confirm-dialog/confirm-dialog.component' -import { Subject, takeUntil } from 'rxjs' +import { delay, Subject, takeUntil, tap } from 'rxjs' import { SettingsService } from 'src/app/services/settings.service' import { SETTINGS_KEYS } from 'src/app/data/ui-settings' import { Router } from '@angular/router' @@ -21,6 +21,7 @@ export class TrashComponent implements OnDestroy { public page: number = 1 public totalDocuments: number public isLoading: boolean = false + public reveal: boolean = false unsubscribeNotifier: Subject = new Subject() constructor( @@ -40,12 +41,20 @@ export class TrashComponent implements OnDestroy { reload() { this.isLoading = true - this.trashService.getTrash(this.page).subscribe((r) => { - this.documentsInTrash = r.results - this.totalDocuments = r.count - this.isLoading = false - this.selectedDocuments.clear() - }) + this.trashService + .getTrash(this.page) + .pipe( + tap((r) => { + this.documentsInTrash = r.results + this.totalDocuments = r.count + this.selectedDocuments.clear() + }), + delay(100) + ) + .subscribe(() => { + this.reveal = true + this.isLoading = false + }) } delete(document: Document) { diff --git a/src-ui/src/app/components/dashboard/dashboard.component.html b/src-ui/src/app/components/dashboard/dashboard.component.html index 4b217f8c3..27f19475c 100644 --- a/src-ui/src/app/components/dashboard/dashboard.component.html +++ b/src-ui/src/app/components/dashboard/dashboard.component.html @@ -11,8 +11,19 @@ > @if (savedViewService.loading) {
-
- Loading... +
+
+
+
+
+ +
+
+
+
+
+
 
+
} diff --git a/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html b/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html index 2846e0d04..2cce1a848 100644 --- a/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html +++ b/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.html @@ -9,8 +9,9 @@ Show all } - @if (documents.length && displayMode === DisplayMode.TABLE) { - +
+ @if (displayMode === DisplayMode.TABLE) { +
@for (field of displayFields; track field; let i = $index) { @@ -28,53 +29,59 @@ - @for (doc of documents; track doc.id) { + @for (doc of documents; track doc.id; let i = $index) { - @for (field of displayFields; track field; let i = $index) { - } @@ -82,13 +89,14 @@ }
- @switch (field) { - @case (DisplayField.ADDED) { - {{doc.added | customDate}} - } - @case (DisplayField.CREATED) { - {{doc.created_date | customDate}} - } - @case (DisplayField.TITLE) { - {{doc.title | documentTitle}} - } - @case (DisplayField.CORRESPONDENT) { - @if (doc.correspondent) { - {{(doc.correspondent$ | async)?.name}} - } - } - @case (DisplayField.TAGS) { - @for (t of doc.tags$ | async; track t) { - - } - } - @case (DisplayField.DOCUMENT_TYPE) { - @if (doc.document_type) { - {{(doc.document_type$ | async)?.name}} - } - } - @case (DisplayField.STORAGE_PATH) { - @if (doc.storage_path) { - {{(doc.storage_path$ | async)?.name}} - } - } - } - @if (field.startsWith(DisplayField.CUSTOM_FIELD)) { - - } - @if (i === displayFields.length - 1) { -
- - - - - - + @for (field of displayFields; track field; let j = $index) { +
+ @if (loading && reveal) { +
+
+ } @else { + @switch (field) { + @case (DisplayField.ADDED) { + {{doc.added | customDate}} + } + @case (DisplayField.CREATED) { + {{doc.created_date | customDate}} + } + @case (DisplayField.TITLE) { + {{doc.title | documentTitle}} + } + @case (DisplayField.CORRESPONDENT) { + @if (doc.correspondent) { + {{(doc.correspondent$ | async)?.name}} + } + } + @case (DisplayField.TAGS) { + @for (t of doc.tags$ | async; track t) { + + } + } + @case (DisplayField.DOCUMENT_TYPE) { + @if (doc.document_type) { + {{(doc.document_type$ | async)?.name}} + } + } + @case (DisplayField.STORAGE_PATH) { + @if (doc.storage_path) { + {{(doc.storage_path$ | async)?.name}} + } + } + } + @if (field.startsWith(DisplayField.CUSTOM_FIELD)) { + + } + @if (j === displayFields.length - 1) { +
+ + + + + + +
+ } }
- } @else if (documents.length && displayMode === DisplayMode.SMALL_CARDS) { -
- @for (d of documents; track d.id) { + } @else if (displayMode === DisplayMode.SMALL_CARDS) { +
+ @for (d of documents; track d.id; let i = $index) { }
- } @else if (documents.length && displayMode === DisplayMode.LARGE_CARDS) { -
- @for (d of documents; track d.id) { + } @else if (displayMode === DisplayMode.LARGE_CARDS) { +
+ @for (d of documents; track d.id; let i = $index) { } @else { -

No documents

+

No documents

} - +
diff --git a/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.scss b/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.scss index 8c445f18e..54156b448 100644 --- a/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.scss +++ b/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.scss @@ -1,3 +1,17 @@ +.wrapper { + transition: all .3s ease-out; + overflow: hidden; + max-height: 0; + opacity: .1; + width: 100%; +} + +.reveal { + max-height: 1000px; + opacity: 1; + overflow: visible; +} + table { overflow-wrap: anywhere; table-layout: fixed; diff --git a/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.spec.ts b/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.spec.ts index b4958b9b9..aa82cf765 100644 --- a/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.spec.ts +++ b/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.spec.ts @@ -187,7 +187,7 @@ describe('SavedViewWidgetComponent', () => { fixture.detectChanges() }) - it('should show a list of documents', () => { + it('should show a list of documents', fakeAsync(() => { jest.spyOn(documentService, 'listFiltered').mockReturnValue( of({ all: [2, 3], @@ -196,6 +196,7 @@ describe('SavedViewWidgetComponent', () => { }) ) component.ngOnInit() + tick(500) fixture.detectChanges() expect(fixture.debugElement.nativeElement.textContent).toContain('doc2') expect(fixture.debugElement.nativeElement.textContent).toContain('doc3') @@ -206,7 +207,7 @@ describe('SavedViewWidgetComponent', () => { expect( fixture.debugElement.queryAll(By.css('td a.btn'))[1].attributes['href'] ).toEqual(component.getDownloadUrl(documentResults[0])) - }) + })) it('should call api endpoint and load results', () => { const listAllSpy = jest.spyOn(documentService, 'listFiltered') diff --git a/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.ts b/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.ts index f788726d0..74c3af520 100644 --- a/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.ts +++ b/src-ui/src/app/components/dashboard/widgets/saved-view-widget/saved-view-widget.component.ts @@ -7,7 +7,7 @@ import { ViewChildren, } from '@angular/core' import { Router } from '@angular/router' -import { Subject, takeUntil } from 'rxjs' +import { delay, Subject, takeUntil, tap } from 'rxjs' import { DEFAULT_DASHBOARD_DISPLAY_FIELDS, DEFAULT_DASHBOARD_VIEW_PAGE_SIZE, @@ -52,7 +52,8 @@ export class SavedViewWidgetComponent public DisplayField = DisplayField public CustomFieldDataType = CustomFieldDataType - loading: boolean = true + public loading: boolean = true + public reveal: boolean = false private customFields: CustomField[] = [] @@ -133,16 +134,22 @@ export class SavedViewWidgetComponent this.documentService .listFiltered( 1, - this.savedView.page_size ?? DEFAULT_DASHBOARD_VIEW_PAGE_SIZE, + this.savedView?.page_size ?? DEFAULT_DASHBOARD_VIEW_PAGE_SIZE, this.savedView.sort_field, this.savedView.sort_reverse, this.savedView.filter_rules, { truncate_content: true } ) - .pipe(takeUntil(this.unsubscribeNotifier)) + .pipe( + takeUntil(this.unsubscribeNotifier), + tap((result) => { + this.reveal = true + this.documents = result.results + }), + delay(500) + ) .subscribe((result) => { this.loading = false - this.documents = result.results }) } diff --git a/src-ui/src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html b/src-ui/src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html index d89fc972c..718edf4ea 100644 --- a/src-ui/src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html +++ b/src-ui/src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html @@ -1,25 +1,49 @@ -
- @if (statistics?.documents_inbox !== null) { - - Documents in inbox: - {{statistics?.documents_inbox}} - - } - - Total documents: - {{statistics?.documents_total}} - -
- Total characters: - {{statistics?.character_count | number}} -
- @if (statistics?.current_asn) { -
- Current ASN: - {{statistics?.current_asn}} +
+ @if (loading) { +
+
+  
+
+
+   +
+
+
+   +
+
+
+   +
+
+
+
+
+
+ } @else { + @if (statistics?.documents_inbox !== null) { + + Documents in inbox: + {{statistics?.documents_inbox}} + + } + + Total documents: + {{statistics?.documents_total}} + +
+ Total characters: + {{statistics?.character_count | number}} +
+ @if (statistics?.current_asn) { +
+ Current ASN: + {{statistics?.current_asn}} +
+ } } @if (statistics?.document_file_type_counts?.length > 1) {
@@ -59,6 +83,11 @@
+ @if (loading) { +
+ +
+ } @if (statistics?.tag_count > 0) { Tags: @@ -67,6 +96,11 @@ }
+ @if (loading) { +
+ +
+ } @if (statistics?.correspondent_count > 0) {
Correspondents: @@ -75,6 +109,11 @@ } + @if (loading) { +
+ +
+ } @if (statistics?.document_type_count > 0) {
Document Types: @@ -83,6 +122,11 @@ } + @if (loading) { +
+ +
+ } @if (statistics?.storage_path_count > 0) {
Storage Paths: diff --git a/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.html b/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.html index b64d5e567..5f0091dc5 100644 --- a/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.html +++ b/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.html @@ -1,4 +1,4 @@ -
+
diff --git a/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.scss b/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.scss index 4efdb0876..521a97c6b 100644 --- a/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.scss +++ b/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.scss @@ -1,3 +1,12 @@ i-bs { cursor: move; } + +.card { + opacity: 0; + transition: opacity .2s; +} + +.reveal { + opacity: 1; +} diff --git a/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.spec.ts b/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.spec.ts index c4e27ecc7..cfd7edb3d 100644 --- a/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.spec.ts +++ b/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.spec.ts @@ -35,6 +35,7 @@ describe('WidgetFrameComponent', () => { fixture = TestBed.createComponent(WidgetFrameComponent) component = fixture.componentInstance + jest.useFakeTimers() fixture.detectChanges() }) @@ -51,4 +52,10 @@ describe('WidgetFrameComponent', () => { fixture.detectChanges() expect(fixture.debugElement.query(By.css('.spinner-border'))).not.toBeNull() }) + + it('should reveal', () => { + expect(component.reveal).toBeFalsy() + jest.advanceTimersByTime(100) + expect(component.reveal).toBeTruthy() + }) }) diff --git a/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.ts b/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.ts index a710a6a9d..2a141be7c 100644 --- a/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.ts +++ b/src-ui/src/app/components/dashboard/widgets/widget-frame/widget-frame.component.ts @@ -1,11 +1,11 @@ -import { Component, Input } from '@angular/core' +import { AfterViewInit, Component, Input } from '@angular/core' @Component({ selector: 'pngx-widget-frame', templateUrl: './widget-frame.component.html', styleUrls: ['./widget-frame.component.scss'], }) -export class WidgetFrameComponent { +export class WidgetFrameComponent implements AfterViewInit { constructor() {} @Input() @@ -16,4 +16,12 @@ export class WidgetFrameComponent { @Input() draggable: any + + public reveal: boolean = false + + ngAfterViewInit(): void { + setTimeout(() => { + this.reveal = true + }, 100) + } } 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 34557be31..810fea029 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 @@ -1,70 +1,92 @@ -
+
- + @if (document) { + -
-
- - +
+
+ + +
-
+ } @else { +
+ }
-
- @if (displayFields.includes(DisplayField.CORRESPONDENT) && document.correspondent) { - @if (clickCorrespondent.observers.length ) { - {{(document.correspondent$ | async)?.name}} - } @else { - {{(document.correspondent$ | async)?.name}} +
+ @if (document) { + @if (displayFields.includes(DisplayField.CORRESPONDENT) && document.correspondent) { + @if (clickCorrespondent.observers.length ) { + {{(document.correspondent$ | async)?.name}} + } @else { + {{(document.correspondent$ | async)?.name}} + } + @if (displayFields.includes(DisplayField.TITLE)) {:} } - @if (displayFields.includes(DisplayField.TITLE)) {:} - } - @if (displayFields.includes(DisplayField.TITLE)) { - {{document.title | documentTitle}} - } - @if (displayFields.includes(DisplayField.TAGS)) { - @for (t of document.tags$ | async; track t) { - + @if (displayFields.includes(DisplayField.TITLE)) { + {{document.title | documentTitle}} } + @if (displayFields.includes(DisplayField.TAGS)) { + @for (t of document.tags$ | async; track t) { + + } + } + } @else { +
 
}

- @if (document.__search_hit__ && document.__search_hit__.highlights) { - - } - @for (highlight of searchNoteHighlights; track highlight) { - - - - - } - @if (!document.__search_hit__?.score) { - {{contentTrimmed}} + @if (document) { + @if (document.__search_hit__ && document.__search_hit__.highlights) { + + } + @for (highlight of searchNoteHighlights; track highlight) { + + + + + } + @if (!document.__search_hit__?.score) { + {{contentTrimmed}} + } + } @else { +

+
+
}

-
+
+ @if (document) { @if (displayFields.includes(DisplayField.NOTES) && notesEnabled && document.notes.length) {
} } -
+ } @else { +
 
+
 
+
 
+
 
+
 
+ }
+
diff --git a/src-ui/src/app/components/document-list/document-card-small/document-card-small.component.html b/src-ui/src/app/components/document-list/document-card-small/document-card-small.component.html index 60713ef02..7b1b9bc93 100644 --- a/src-ui/src/app/components/document-list/document-card-small/document-card-small.component.html +++ b/src-ui/src/app/components/document-list/document-card-small/document-card-small.component.html @@ -1,16 +1,20 @@
-
+
- + @if (document) { + -
-
- - +
+
+ + +
-
+ } @else { +
+ } - @if (displayFields?.includes(DisplayField.TAGS)) { + @if (document && displayFields?.includes(DisplayField.TAGS)) {
@for (t of getTagsLimited$() | async; track t) { @@ -24,7 +28,7 @@ }
- @if (displayFields.includes(DisplayField.NOTES) && notesEnabled && document.notes.length) { + @if (document && displayFields.includes(DisplayField.NOTES) && notesEnabled && document.notes.length) { @@ -34,107 +38,122 @@

- @if (displayFields.includes(DisplayField.CORRESPONDENT) && document.correspondent) { - {{(document.correspondent$ | async)?.name ?? privateName}} - @if (displayFields.includes(DisplayField.TITLE)) {:} - } - @if (displayFields.includes(DisplayField.TITLE)) { - {{document.title | documentTitle}} + @if (document) { + @if (displayFields.includes(DisplayField.CORRESPONDENT) && document.correspondent) { + {{(document.correspondent$ | async)?.name ?? privateName}} + @if (displayFields.includes(DisplayField.TITLE)) {:} + } + @if (displayFields.includes(DisplayField.TITLE)) { + {{document.title | documentTitle}} + } + } @else { +

+
}