diff --git a/src/components/ui/VnFilterPanel.vue b/src/components/ui/VnFilterPanel.vue index 7504e819e..5d35c4162 100644 --- a/src/components/ui/VnFilterPanel.vue +++ b/src/components/ui/VnFilterPanel.vue @@ -63,6 +63,19 @@ onMounted(() => { emit('init', { params: userParams.value }); }); +watch( + () => route.query.params, + (val) => { + if (!val) { + userParams.value = {}; + } else { + const parsedParams = JSON.parse(val); + userParams.value = { ...parsedParams }; + search(); + } + } +); + const isLoading = ref(false); async function search() { isLoading.value = true; @@ -70,9 +83,9 @@ async function search() { store.userParamsChanged = true; store.filter.skip = 0; store.skip = 0; + store.userParams = params; const { params: newParams } = await arrayData.addFilter({ params }); userParams.value = newParams; - if (!props.showAll && !Object.values(params).length) store.data = []; isLoading.value = false; diff --git a/src/composables/useArrayData.js b/src/composables/useArrayData.js index b6b81f2d5..f17778585 100644 --- a/src/composables/useArrayData.js +++ b/src/composables/useArrayData.js @@ -27,6 +27,8 @@ export function useArrayData(key, userOptions) { const query = route.query; if (query.params) { store.userParams = JSON.parse(query.params); + store.skip = 0; + store.filter.skip = 0; } });