From ed5366a58b9e2678c90f0bdda42ef428ab377629 Mon Sep 17 00:00:00 2001 From: Ian Liu <81595625+ianliuwk1019@users.noreply.github.com> Date: Thu, 4 Jan 2024 11:48:26 -0800 Subject: [PATCH] fix: #491 Detail Bookmark Link Not Accessible (#532) * Subscribe to onNavEnd observable early so directly using bookmark can work. * Remove subscription from constructor, load queryParam first and check for getting project details instead. * Adjust reading queryParam logic. * Dummy commit to triger api deploy. * Fix typo --- api/README.md | 2 +- .../details-panel/details-panel.component.ts | 32 +++++++++++-------- 2 files changed, 20 insertions(+), 14 deletions(-) diff --git a/api/README.md b/api/README.md index 9e3484327..6b22dd75b 100644 --- a/api/README.md +++ b/api/README.md @@ -78,5 +78,5 @@ These are the steps to generate the client library used by the frontend componen distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and - limitations under the License. + limitations under the License. \ No newline at end of file diff --git a/public/src/app/applications/details-panel/details-panel.component.ts b/public/src/app/applications/details-panel/details-panel.component.ts index 3c2265ed0..f7b4b6a43 100644 --- a/public/src/app/applications/details-panel/details-panel.component.ts +++ b/public/src/app/applications/details-panel/details-panel.component.ts @@ -56,28 +56,27 @@ export class DetailsPanelComponent implements OnDestroy, OnInit { private projectService: ProjectService, private spatialFeatureService: SpatialFeatureService, private attachmentService: AttachmentService, - private fss: FeatureSelectService + private fss: FeatureSelectService, ) {} ngOnInit(): void { // Note, can't seem to get stateService.ts to get codeTable working here. Instead, subscribe to it. + // Subscribe to this first, seems to be slower and can cause minor page render issue due to no code. this.projectService.workflowStateCodeControllerFindAll() .pipe(take(1)).subscribe((data) => { this.workflowStatus = _.keyBy(data, 'code'); }); - - // subscribe and watch for URL param changes + + // First time component init. The `urlService.onNavEnd$` already ends, so + // do this initially first since queryParam is ready from route. + // Works if user has bookmarks the detail link. + this.getProjectDetails(); + + // Subscribe to onNavEnd so the component knows subsequent clicks on other details. this.urlService.onNavEnd$.pipe(takeUntil(this.ngUnsubscribe)) - .subscribe(() => { - this.loadQueryParameters(); - if (!this.projectIdFilter.filter.value) { - // no project to display - this.project = null; - } else if (!this.project || this.project.id.toString() !== this.projectIdFilter.filter.value) { - // no project yet selected, or different project selected - this.getProjectDetails(); - } - }); + .subscribe(() => { + this.getProjectDetails(); + }); this.subscribeToFeatureSelectChange(); } @@ -87,7 +86,14 @@ export class DetailsPanelComponent implements OnDestroy, OnInit { * @memberof DetailsPanelComponent */ public getProjectDetails() { + this.loadQueryParameters(); const projectId = parseInt(this.projectIdFilter.filter.value); + if (!projectId) { + // no project to display + this.project = null; + return; + } + this.isAppLoading = true; forkJoin({ project: this.projectService.projectControllerFindOne(projectId),