From 9880f9ebc7b72a2b7b57bd44ffca800136737856 Mon Sep 17 00:00:00 2001 From: shamoon <4887959+shamoon@users.noreply.github.com> Date: Thu, 19 Oct 2023 19:41:01 -0700 Subject: [PATCH] Feature: support sorting sidebar saved views (#4381) --- src-ui/messages.xlf | 172 ++++++++++-------- .../admin/settings/settings.component.spec.ts | 14 +- .../admin/settings/settings.component.ts | 8 + .../app-frame/app-frame.component.html | 17 +- .../app-frame/app-frame.component.scss | 9 + .../app-frame/app-frame.component.spec.ts | 97 +++++++++- .../app-frame/app-frame.component.ts | 54 +++++- .../dashboard/dashboard.component.scss | 16 -- .../dashboard/dashboard.component.ts | 17 +- .../statistics-widget.component.html | 2 +- .../welcome-widget.component.html | 2 +- src-ui/src/app/data/paperless-uisettings.ts | 7 + .../services/rest/saved-view.service.spec.ts | 48 ++++- .../app/services/rest/saved-view.service.ts | 39 +++- .../src/app/services/settings.service.spec.ts | 8 + src-ui/src/app/services/settings.service.ts | 18 +- src-ui/src/styles.scss | 14 ++ src-ui/src/theme.scss | 2 +- 18 files changed, 397 insertions(+), 147 deletions(-) diff --git a/src-ui/messages.xlf b/src-ui/messages.xlf index 5ce123943..fae11c3a8 100644 --- a/src-ui/messages.xlf +++ b/src-ui/messages.xlf @@ -421,11 +421,11 @@ src/app/components/app-frame/app-frame.component.html - 207 + 218 src/app/components/app-frame/app-frame.component.html - 210 + 221 @@ -511,11 +511,11 @@ src/app/components/app-frame/app-frame.component.html - 185 + 196 src/app/components/app-frame/app-frame.component.html - 188 + 199 @@ -1355,67 +1355,67 @@ Saved view "" deleted. src/app/components/admin/settings/settings.component.ts - 362 + 370 Settings saved src/app/components/admin/settings/settings.component.ts - 484 + 492 Settings were saved successfully. src/app/components/admin/settings/settings.component.ts - 485 + 493 Settings were saved successfully. Reload is required to apply some changes. src/app/components/admin/settings/settings.component.ts - 489 + 497 Reload now src/app/components/admin/settings/settings.component.ts - 490 + 498 An error occurred while saving settings. src/app/components/admin/settings/settings.component.ts - 500 + 508 src/app/components/app-frame/app-frame.component.ts - 104 + 114 Use system language src/app/components/admin/settings/settings.component.ts - 508 + 516 Use date format of display language src/app/components/admin/settings/settings.component.ts - 515 + 523 Error while storing settings on server. src/app/components/admin/settings/settings.component.ts - 538 + 546 @@ -1426,7 +1426,7 @@ src/app/components/app-frame/app-frame.component.html - 199 + 210 @@ -1635,11 +1635,11 @@ src/app/components/app-frame/app-frame.component.html - 192 + 203 src/app/components/app-frame/app-frame.component.html - 195 + 206 @@ -1969,11 +1969,11 @@ src/app/components/app-frame/app-frame.component.html - 214 + 225 src/app/components/app-frame/app-frame.component.html - 217 + 228 @@ -2026,36 +2026,36 @@ Open documents src/app/components/app-frame/app-frame.component.html - 107 + 118 Close all src/app/components/app-frame/app-frame.component.html - 123 + 134 src/app/components/app-frame/app-frame.component.html - 126 + 137 Manage src/app/components/app-frame/app-frame.component.html - 133 + 144 Correspondents src/app/components/app-frame/app-frame.component.html - 137 + 148 src/app/components/app-frame/app-frame.component.html - 140 + 151 src/app/components/dashboard/widgets/statistics-widget/statistics-widget.component.html @@ -2066,11 +2066,11 @@ Tags src/app/components/app-frame/app-frame.component.html - 144 + 155 src/app/components/app-frame/app-frame.component.html - 147 + 158 src/app/components/common/input/tags/tags.component.ts @@ -2097,102 +2097,116 @@ Document types src/app/components/app-frame/app-frame.component.html - 151 + 162 src/app/components/app-frame/app-frame.component.html - 154 + 165 Storage paths src/app/components/app-frame/app-frame.component.html - 158 + 169 src/app/components/app-frame/app-frame.component.html - 161 + 172 Consumption templates src/app/components/app-frame/app-frame.component.html - 165 + 176 Templates src/app/components/app-frame/app-frame.component.html - 168 + 179 Mail src/app/components/app-frame/app-frame.component.html - 172 + 183 src/app/components/app-frame/app-frame.component.html - 175 + 186 Administration src/app/components/app-frame/app-frame.component.html - 181 + 192 File Tasks src/app/components/app-frame/app-frame.component.html - 203 + 214 GitHub src/app/components/app-frame/app-frame.component.html - 223 + 234 is available. src/app/components/app-frame/app-frame.component.html - 229 + 240 Click to view. src/app/components/app-frame/app-frame.component.html - 229 + 240 Paperless-ngx can automatically check for updates src/app/components/app-frame/app-frame.component.html - 233 + 244 How does this work? src/app/components/app-frame/app-frame.component.html - 240,242 + 251,253 Update available src/app/components/app-frame/app-frame.component.html + 262 + + + + Sidebar views updated + + src/app/components/app-frame/app-frame.component.ts + 248 + + + + Error updating sidebar views + + src/app/components/app-frame/app-frame.component.ts 251 @@ -2200,7 +2214,7 @@ An error occurred while saving update checking settings. src/app/components/app-frame/app-frame.component.ts - 237 + 272 @@ -3612,28 +3626,28 @@ Hello , welcome to Paperless-ngx src/app/components/dashboard/dashboard.component.ts - 53 + 38 Welcome to Paperless-ngx src/app/components/dashboard/dashboard.component.ts - 55 + 40 Dashboard updated src/app/components/dashboard/dashboard.component.ts - 86 + 71 Error updating dashboard src/app/components/dashboard/dashboard.component.ts - 89 + 74 @@ -5999,224 +6013,224 @@ English (US) src/app/services/settings.service.ts - 154 + 155 Afrikaans src/app/services/settings.service.ts - 160 + 161 Arabic src/app/services/settings.service.ts - 166 + 167 Belarusian src/app/services/settings.service.ts - 172 + 173 Catalan src/app/services/settings.service.ts - 178 + 179 Czech src/app/services/settings.service.ts - 184 + 185 Danish src/app/services/settings.service.ts - 190 + 191 German src/app/services/settings.service.ts - 196 + 197 Greek src/app/services/settings.service.ts - 202 + 203 English (GB) src/app/services/settings.service.ts - 208 + 209 Spanish src/app/services/settings.service.ts - 214 + 215 Finnish src/app/services/settings.service.ts - 220 + 221 French src/app/services/settings.service.ts - 226 + 227 Italian src/app/services/settings.service.ts - 232 + 233 Luxembourgish src/app/services/settings.service.ts - 238 + 239 Dutch src/app/services/settings.service.ts - 244 + 245 Norwegian src/app/services/settings.service.ts - 250 + 251 Polish src/app/services/settings.service.ts - 256 + 257 Portuguese (Brazil) src/app/services/settings.service.ts - 262 + 263 Portuguese src/app/services/settings.service.ts - 268 + 269 Romanian src/app/services/settings.service.ts - 274 + 275 Russian src/app/services/settings.service.ts - 280 + 281 Slovak src/app/services/settings.service.ts - 286 + 287 Slovenian src/app/services/settings.service.ts - 292 + 293 Serbian src/app/services/settings.service.ts - 298 + 299 Swedish src/app/services/settings.service.ts - 304 + 305 Turkish src/app/services/settings.service.ts - 310 + 311 Ukrainian src/app/services/settings.service.ts - 316 + 317 Chinese Simplified src/app/services/settings.service.ts - 322 + 323 ISO 8601 src/app/services/settings.service.ts - 339 + 340 Successfully completed one-time migratration of settings to the database! src/app/services/settings.service.ts - 458 + 459 Unable to migrate settings to the database, please try saving manually. src/app/services/settings.service.ts - 459 + 460 diff --git a/src-ui/src/app/components/admin/settings/settings.component.spec.ts b/src-ui/src/app/components/admin/settings/settings.component.spec.ts index 7ea025fe5..73ac3c98a 100644 --- a/src-ui/src/app/components/admin/settings/settings.component.spec.ts +++ b/src-ui/src/app/components/admin/settings/settings.component.spec.ts @@ -180,11 +180,23 @@ describe('SettingsComponent', () => { activatedRoute.snapshot.fragment = '#notifications' const scrollSpy = jest.spyOn(viewportScroller, 'scrollToAnchor') component.ngOnInit() - expect(component.activeNavID).toEqual(3) // Users & Groups + expect(component.activeNavID).toEqual(3) // Notifications component.ngAfterViewInit() expect(scrollSpy).toHaveBeenCalledWith('#notifications') }) + it('should enable organizing of sidebar saved views even on direct navigation', () => { + completeSetup() + jest + .spyOn(activatedRoute, 'paramMap', 'get') + .mockReturnValue(of(convertToParamMap({ section: 'savedviews' }))) + activatedRoute.snapshot.fragment = '#savedviews' + component.ngOnInit() + expect(component.activeNavID).toEqual(4) // Saved Views + component.ngAfterViewInit() + expect(settingsService.organizingSidebarSavedViews).toBeTruthy() + }) + it('should support save saved views, show error', () => { completeSetup() diff --git a/src-ui/src/app/components/admin/settings/settings.component.ts b/src-ui/src/app/components/admin/settings/settings.component.ts index 14528d76d..3a7f837f3 100644 --- a/src-ui/src/app/components/admin/settings/settings.component.ts +++ b/src-ui/src/app/components/admin/settings/settings.component.ts @@ -194,6 +194,9 @@ export class SettingsComponent if (navIDKey) { this.activeNavID = SettingsNavIDs[navIDKey] } + if (this.activeNavID === SettingsNavIDs.SavedViews) { + this.settings.organizingSidebarSavedViews = true + } } }) } @@ -275,11 +278,15 @@ export class SettingsComponent this.router .navigate(['settings', foundNavIDkey.toLowerCase()]) .then((navigated) => { + this.settings.organizingSidebarSavedViews = false if (!navigated && this.isDirty) { this.activeNavID = navChangeEvent.activeId } else if (navigated && this.isDirty) { this.initialize() } + if (this.activeNavID === SettingsNavIDs.SavedViews) { + this.settings.organizingSidebarSavedViews = true + } }) } @@ -352,6 +359,7 @@ export class SettingsComponent ngOnDestroy() { if (this.isDirty) this.settings.updateAppearanceSettings() // in case user changed appearance but didnt save this.storeSub && this.storeSub.unsubscribe() + this.settings.organizingSidebarSavedViews = false } deleteSavedView(savedView: PaperlessSavedView) { diff --git a/src-ui/src/app/components/app-frame/app-frame.component.html b/src-ui/src/app/components/app-frame/app-frame.component.html index cd78e0b1a..c496ee4e7 100644 --- a/src-ui/src/app/components/app-frame/app-frame.component.html +++ b/src-ui/src/app/components/app-frame/app-frame.component.html @@ -87,17 +87,28 @@ - -