diff --git a/web/src/components/layout/scaffold/Header.vue b/web/src/components/layout/scaffold/Header.vue
index 0b44ff0561..84de5f87a1 100644
--- a/web/src/components/layout/scaffold/Header.vue
+++ b/web/src/components/layout/scaffold/Header.vue
@@ -62,7 +62,10 @@ const props = defineProps<{
search?: string;
fullWidth?: boolean;
}>();
-defineEmits(['update:search']);
+
+defineEmits<{
+ (event: 'update:search', query: string): void;
+}>();
const searchBoxPresent = props.search !== undefined;
diff --git a/web/src/components/layout/scaffold/Scaffold.vue b/web/src/components/layout/scaffold/Scaffold.vue
index dd60494d51..f211b16620 100644
--- a/web/src/components/layout/scaffold/Scaffold.vue
+++ b/web/src/components/layout/scaffold/Scaffold.vue
@@ -18,7 +18,7 @@
diff --git a/web/src/components/layout/scaffold/Tabs.vue b/web/src/components/layout/scaffold/Tabs.vue
index 8dcf584a3d..e9ac69d056 100644
--- a/web/src/components/layout/scaffold/Tabs.vue
+++ b/web/src/components/layout/scaffold/Tabs.vue
@@ -26,7 +26,7 @@ import { Tab, useTabsClient } from '~/compositions/useTabs';
const router = useRouter();
const route = useRoute();
-const { activeTab, tabs, disableHashMode } = useTabsClient();
+const { activeTab, tabs, disableUrlHashMode } = useTabsClient();
async function selectTab(tab: Tab) {
if (tab.id === undefined) {
@@ -34,7 +34,8 @@ async function selectTab(tab: Tab) {
}
activeTab.value = tab.id;
- if (!disableHashMode.value) {
+
+ if (!disableUrlHashMode.value) {
await router.replace({ params: route.params, hash: `#${tab.id}` });
}
}
diff --git a/web/src/compositions/useTabs.ts b/web/src/compositions/useTabs.ts
index 657016b6d1..2da91300e1 100644
--- a/web/src/compositions/useTabs.ts
+++ b/web/src/compositions/useTabs.ts
@@ -1,4 +1,4 @@
-import { computed, inject, onMounted, provide, Ref, ref } from 'vue';
+import { inject, onMounted, provide, Ref, ref } from 'vue';
import { useRoute } from 'vue-router';
export type Tab = {
@@ -7,58 +7,39 @@ export type Tab = {
};
export function useTabsProvider({
- activeTabProp,
- disableHashMode,
- updateActiveTabProp,
+ activeTab,
+ disableUrlHashMode,
}: {
- activeTabProp: Ref;
- updateActiveTabProp: (tab: string) => void;
- disableHashMode: Ref;
+ activeTab: Ref;
+ disableUrlHashMode: Ref;
}) {
const route = useRoute();
const tabs = ref([]);
- const activeTab = ref('');
provide('tabs', tabs);
- provide(
- 'disable-hash-mode',
- computed(() => disableHashMode.value),
- );
- provide(
- 'active-tab',
- computed({
- get: () => activeTab.value,
- set: (value) => {
- activeTab.value = value;
- updateActiveTabProp(value);
- },
- }),
- );
+ provide('disable-url-hash-mode', disableUrlHashMode);
+ provide('active-tab', activeTab);
onMounted(() => {
- if (activeTabProp.value) {
- activeTab.value = activeTabProp.value;
+ if (activeTab.value !== undefined) {
return;
}
const hashTab = route.hash.replace(/^#/, '');
- if (hashTab) {
- activeTab.value = hashTab;
- return;
- }
- activeTab.value = tabs.value[0].id;
+ // eslint-disable-next-line no-param-reassign
+ activeTab.value = hashTab ?? tabs.value[0].id;
});
}
export function useTabsClient() {
const tabs = inject[>('tabs');
- const disableHashMode = inject][>('disable-hash-mode');
+ const disableUrlHashMode = inject][>('disable-url-hash-mode');
const activeTab = inject][>('active-tab');
- if (activeTab === undefined || tabs === undefined || disableHashMode === undefined) {
+ if (activeTab === undefined || tabs === undefined || disableUrlHashMode === undefined) {
throw new Error('Please use this "useTabsClient" composition inside a component running "useTabsProvider".');
}
- return { activeTab, tabs, disableHashMode };
+ return { activeTab, tabs, disableUrlHashMode };
}
diff --git a/web/src/views/repo/RepoWrapper.vue b/web/src/views/repo/RepoWrapper.vue
index ca3eb51baa..9ee57f4ad2 100644
--- a/web/src/views/repo/RepoWrapper.vue
+++ b/web/src/views/repo/RepoWrapper.vue
@@ -3,7 +3,7 @@
v-if="repo && repoPermissions && $route.meta.repoHeader"
v-model:activeTab="activeTab"
enable-tabs
- disable-hash-mode
+ disable-tab-url-hash-mode
>
diff --git a/web/src/views/repo/pipeline/PipelineWrapper.vue b/web/src/views/repo/pipeline/PipelineWrapper.vue
index aec2511513..0279617aea 100644
--- a/web/src/views/repo/pipeline/PipelineWrapper.vue
+++ b/web/src/views/repo/pipeline/PipelineWrapper.vue
@@ -3,7 +3,7 @@
v-if="pipeline && repo"
v-model:activeTab="activeTab"
enable-tabs
- disable-hash-mode
+ disable-tab-url-hash-mode
:go-back="goBack"
:fluid-content="activeTab === 'tasks'"
full-width-header
]