From 30440d94d9c823df9d6a10b5083668c511e508bb Mon Sep 17 00:00:00 2001 From: Pranav C Date: Mon, 19 Sep 2022 18:05:06 +0530 Subject: [PATCH 1/8] fix(gui): get table meta only after loading project table list re #3702 Signed-off-by: Pranav C --- packages/nc-gui/composables/useProject.ts | 8 ++++++++ .../index/[type]/[title]/[[viewTitle]].vue | 18 ++++++++++-------- 2 files changed, 18 insertions(+), 8 deletions(-) diff --git a/packages/nc-gui/composables/useProject.ts b/packages/nc-gui/composables/useProject.ts index f5b728d4f0..c412e25f8c 100644 --- a/packages/nc-gui/composables/useProject.ts +++ b/packages/nc-gui/composables/useProject.ts @@ -42,6 +42,8 @@ const [setup, use] = useInjectionState((_projectId?: MaybeRef) => { const projectId = computed(() => (_projectId ? unref(_projectId) : (route.params.projectId as string))) + const projectAndTablesLoaded = ref(false) + // todo: refactor path param name and variable name const projectType = $computed(() => route.params.projectType as string) @@ -93,6 +95,7 @@ const [setup, use] = useInjectionState((_projectId?: MaybeRef) => { } async function loadTables() { + projectAndTablesLoaded.value = false if (project.value.id) { const tablesResponse = await api.dbTable.list(project.value.id, { includeM2M: includeM2M.value, @@ -100,9 +103,11 @@ const [setup, use] = useInjectionState((_projectId?: MaybeRef) => { if (tablesResponse.list) tables.value = tablesResponse.list } + projectAndTablesLoaded.value = true } async function loadProject(id?: string) { + projectAndTablesLoaded.value = false if (id) { project.value = await api.project.read(projectId.value) } else if (projectType === 'base') { @@ -128,6 +133,8 @@ const [setup, use] = useInjectionState((_projectId?: MaybeRef) => { setTheme(projectMeta.value?.theme) projectLoadedHook.trigger(project.value) + + projectAndTablesLoaded.value = true } async function updateProject(data: Partial) { @@ -196,6 +203,7 @@ const [setup, use] = useInjectionState((_projectId?: MaybeRef) => { projectLoadedHook: projectLoadedHook.on, reset, isLoading, + projectAndTablesLoaded, } }, 'useProject') diff --git a/packages/nc-gui/pages/[projectType]/[projectId]/index/index/[type]/[title]/[[viewTitle]].vue b/packages/nc-gui/pages/[projectType]/[projectId]/index/index/[type]/[title]/[[viewTitle]].vue index a6c85c05bd..18b4da43fe 100644 --- a/packages/nc-gui/pages/[projectType]/[projectId]/index/index/[type]/[title]/[[viewTitle]].vue +++ b/packages/nc-gui/pages/[projectType]/[projectId]/index/index/[type]/[title]/[[viewTitle]].vue @@ -4,7 +4,7 @@ import { TabMetaInj } from '#imports' const { getMeta } = useMetas() -const { project, projectLoadedHook } = useProject() +const { project, projectLoadedHook, projectAndTablesLoaded } = useProject() const route = useRoute() @@ -15,14 +15,16 @@ const activeTab = inject( computed(() => ({} as TabItem)), ) -if (!project.value.id) { - projectLoadedHook(async () => { - await getMeta(route.params.title as string, true) +/** wait until project and table loads since meta load requires table list **/ +watch( + projectAndTablesLoaded, + (nextVal) => { + if (!nextVal) return + getMeta(route.params.title as string, true).finally(() => (loading.value = false)) loading.value = false - }) -} else { - getMeta(route.params.title as string, true).finally(() => (loading.value = false)) -} + }, + { immediate: true }, +)