From 4d513c1fca1061a89e7d7242b0a13c03b273d3fb Mon Sep 17 00:00:00 2001 From: Joseph Ojoko Date: Wed, 18 Oct 2023 13:43:35 +0100 Subject: [PATCH] chore: refactor btn group and handle empty tables on page re-visit --- example/src/views/DataTableView.vue | 29 ++++++++++++++----- .../buttons/button-group/ButtonGroup.vue | 14 +++++++-- 2 files changed, 33 insertions(+), 10 deletions(-) diff --git a/example/src/views/DataTableView.vue b/example/src/views/DataTableView.vue index f9f12a52..8db65a5b 100644 --- a/example/src/views/DataTableView.vue +++ b/example/src/views/DataTableView.vue @@ -37,9 +37,11 @@ interface _User { }; } -const { data: _users, isFetching } = useFetch( - 'https://jsonplaceholder.typicode.com/users', -); +const { + data: _users, + isFetching, + execute, +} = useFetch('https://jsonplaceholder.typicode.com/users'); interface BaseUser { id: number; @@ -270,7 +272,10 @@ const emptyTables = ref< ]); const datatables = ref< - { title: string; table: DataTableProps }[] + { + title: string; + table: DataTableProps; + }[] >([ { title: 'With Column definitions', @@ -373,7 +378,10 @@ const datatables = ref< ]); const apiDatatables = ref< - { title: string; table: DataTableProps }[] + { + title: string; + table: DataTableProps; + }[] >([ { title: 'API: With Column definitions', @@ -503,7 +511,10 @@ const fakeFetch = async ( options?: DataTableOptions, search?: string, api?: boolean, -): Promise<{ data: ExtendedUser[]; total: number }> => { +): Promise<{ + data: ExtendedUser[]; + total: number; +}> => { await new Promise((resolve) => { setTimeout(resolve, 1500); }); @@ -615,7 +626,11 @@ const onSearch = useDebounceFn(async (query: string, index: number) => { } }, 500); -onBeforeMount(() => { +onBeforeMount(async () => { + if (get(isFetching)) { + await execute().catch(); + } + get(datatables).forEach((row, i) => { fetchData( i, diff --git a/src/components/buttons/button-group/ButtonGroup.vue b/src/components/buttons/button-group/ButtonGroup.vue index cb3de84d..da624919 100644 --- a/src/components/buttons/button-group/ButtonGroup.vue +++ b/src/components/buttons/button-group/ButtonGroup.vue @@ -29,7 +29,16 @@ const emit = defineEmits<{ const slots = useSlots(); const { modelValue, required } = toRefs(props); -const children = computed(() => slots.default?.() ?? []); +const children = computed(() => + (slots.default?.() ?? []).map((child, i) => { + child.props = { + ...child.props, + active: activeItem(child.props?.value ?? i), + }; + + return child; + }), +); const activeItem = (id: T) => { const selected = get(modelValue); @@ -77,13 +86,12 @@ const css = useCssModule(); :is="child" v-for="(child, i) in children" :key="i" - :active="activeItem(child.props?.value ?? i)" :class="css.button" :color="color" :disabled="disabled" :size="size" :variant="variant" - @update:value="onClick(child.props?.value ?? i)" + @update:value="onClick($event ?? i)" />