From 710e8df5d3fcf1c618302db0b43c18829a0a93cf Mon Sep 17 00:00:00 2001 From: wendybujalski Date: Thu, 12 Dec 2024 14:26:16 -0500 Subject: [PATCH] fix(web) - actually navigate to the view a user is on --- .../layout/navbar/Collaborators.vue | 30 +++++++++---------- app/web/src/store/views.store.ts | 9 +++++- 2 files changed, 22 insertions(+), 17 deletions(-) diff --git a/app/web/src/components/layout/navbar/Collaborators.vue b/app/web/src/components/layout/navbar/Collaborators.vue index 49526747c8..3d79537257 100644 --- a/app/web/src/components/layout/navbar/Collaborators.vue +++ b/app/web/src/components/layout/navbar/Collaborators.vue @@ -102,13 +102,11 @@ import { useRoute, useRouter } from "vue-router"; import Popover from "@/components/Popover.vue"; import { usePresenceStore } from "@/store/presence.store"; import { useChangeSetsStore } from "@/store/change_sets.store"; -import { useViewsStore } from "@/store/views.store"; import UserIcon from "./UserIcon.vue"; import UserCard from "./UserCard.vue"; const presenceStore = usePresenceStore(); const changeSetsStore = useChangeSetsStore(); -const viewsStore = useViewsStore(); const router = useRouter(); const route = useRoute(); @@ -116,9 +114,10 @@ export type UserInfo = { name: string; color?: string | null; status?: string | null; - changeSet?: string; + changeSet?: string; // TODO(Wendy) - this should be called changeSetId pictureUrl?: string | null; - view?: string; + view?: string; // TODO(Wendy) - this should be called viewId + // TODO(Wendy) - we should probably also send the viewName so we can show it in the tooltip }; const moreUsersPopoverRef = ref(); @@ -284,24 +283,23 @@ function goToUserChangeSet(user: UserInfo) { if (!user || !user.changeSet) return; if (user.view) { - const viewId = viewsStore.viewsById[user.view]?.id; - if (viewId) { - router.push({ - name: "workspace-compose-view", - params: { - ...route.params, - viewId, - }, - query: route.query, - }); - } + router.push({ + name: "workspace-compose-view", + params: { + ...route.params, + changeSetId: user.changeSet, + viewId: user.view, + }, + query: route.query, + }); + return; } router.push({ name: "change-set-home", params: { ...route.params, - changeSetId: changeSetsStore.changeSetsById[user.changeSet]?.id || "auto", + changeSetId: user.changeSet, }, query: route.query, }); diff --git a/app/web/src/store/views.store.ts b/app/web/src/store/views.store.ts index c5e053cd86..1042c0fea2 100644 --- a/app/web/src/store/views.store.ts +++ b/app/web/src/store/views.store.ts @@ -1552,8 +1552,15 @@ export const useViewsStore = (forceChangeSetId?: ChangeSetId) => { const stopWatchingUrl = watch( router.currentRoute, () => { - if (router.currentRoute.value.name === "workspace-compose") + if ( + router.currentRoute.value.name === "workspace-compose" || + router.currentRoute.value.name === "workspace-compose-view" + ) this.syncUrlIntoSelection(); + const viewId = router.currentRoute.value.params.viewId; + if (viewId) { + this.selectView(viewId as string); + } }, { immediate: true,