From 43ca7e166713ee2b8a58a4b3bf825666d4e83924 Mon Sep 17 00:00:00 2001 From: alexm Date: Fri, 9 Aug 2024 11:40:05 +0200 Subject: [PATCH 1/3] fix(VnFilterPanel): emit userParams better --- src/components/VnTable/VnOrder.vue | 1 + src/components/VnTable/VnTable.vue | 4 ++-- src/components/ui/VnFilterPanel.vue | 15 ++++++++++----- 3 files changed, 13 insertions(+), 7 deletions(-) diff --git a/src/components/VnTable/VnOrder.vue b/src/components/VnTable/VnOrder.vue index 98c7ab392..f3cb74c1c 100644 --- a/src/components/VnTable/VnOrder.vue +++ b/src/components/VnTable/VnOrder.vue @@ -41,6 +41,7 @@ async function orderBy(name, direction) { break; } if (!direction) return await arrayData.deleteOrder(name); + console.log('name, direction: ', name, direction); await arrayData.addOrder(name, direction); } diff --git a/src/components/VnTable/VnTable.vue b/src/components/VnTable/VnTable.vue index be39570ee..dca30516f 100644 --- a/src/components/VnTable/VnTable.vue +++ b/src/components/VnTable/VnTable.vue @@ -154,7 +154,7 @@ watch( const isTableMode = computed(() => mode.value == TABLE_MODE); -function setUserParams(watchedParams) { +function setUserParams(watchedParams, watchedOrder) { if (!watchedParams) return; if (typeof watchedParams == 'string') watchedParams = JSON.parse(watchedParams); @@ -163,7 +163,7 @@ function setUserParams(watchedParams) { ? JSON.parse(watchedParams?.filter) : watchedParams?.filter; const where = filter?.where; - const order = filter?.order; + const order = watchedOrder ?? filter?.order; watchedParams = { ...watchedParams, ...where }; delete watchedParams.filter; diff --git a/src/components/ui/VnFilterPanel.vue b/src/components/ui/VnFilterPanel.vue index 430383e40..8adf25508 100644 --- a/src/components/ui/VnFilterPanel.vue +++ b/src/components/ui/VnFilterPanel.vue @@ -82,23 +82,28 @@ onMounted(() => { }); function setUserParams(watchedParams) { - if (!watchedParams) return; + if (!watchedParams || Object.keys(watchedParams).length == 0) return; if (typeof watchedParams == 'string') watchedParams = JSON.parse(watchedParams); + if (typeof watchedParams?.filter == 'string') + watchedParams.filter = JSON.parse(watchedParams.filter); + watchedParams = { ...watchedParams, ...watchedParams.filter?.where }; + const order = watchedParams.filter?.order; + delete watchedParams.filter; - userParams.value = { ...userParams.value, ...watchedParams }; - emit('setUserParams', userParams.value); + userParams.value = { ...userParams.value, ...sanitizer(watchedParams) }; + emit('setUserParams', userParams.value, order); } watch( () => route.query[$props.searchUrl], - (val) => setUserParams(val) + (val, oldValue) => (val || oldValue) && setUserParams(val) ); watch( () => arrayData.store.userParams, - (val) => setUserParams(val) + (val, oldValue) => (val || oldValue) && setUserParams(val) ); watch( -- 2.40.1 From bd05460b90d21152c9088f06c344a941f8370292 Mon Sep 17 00:00:00 2001 From: alexm Date: Fri, 9 Aug 2024 11:41:29 +0200 Subject: [PATCH 2/3] console.log --- src/components/VnTable/VnOrder.vue | 1 - 1 file changed, 1 deletion(-) diff --git a/src/components/VnTable/VnOrder.vue b/src/components/VnTable/VnOrder.vue index f3cb74c1c..98c7ab392 100644 --- a/src/components/VnTable/VnOrder.vue +++ b/src/components/VnTable/VnOrder.vue @@ -41,7 +41,6 @@ async function orderBy(name, direction) { break; } if (!direction) return await arrayData.deleteOrder(name); - console.log('name, direction: ', name, direction); await arrayData.addOrder(name, direction); } -- 2.40.1 From 02cfa54a409c22467ee7a218fe4068a109157c04 Mon Sep 17 00:00:00 2001 From: alexm Date: Fri, 9 Aug 2024 12:27:24 +0200 Subject: [PATCH 3/3] unify watchers --- src/components/ui/VnFilterPanel.vue | 12 +++++------- 1 file changed, 5 insertions(+), 7 deletions(-) diff --git a/src/components/ui/VnFilterPanel.vue b/src/components/ui/VnFilterPanel.vue index 8adf25508..4fd511631 100644 --- a/src/components/ui/VnFilterPanel.vue +++ b/src/components/ui/VnFilterPanel.vue @@ -97,13 +97,11 @@ function setUserParams(watchedParams) { } watch( - () => route.query[$props.searchUrl], - (val, oldValue) => (val || oldValue) && setUserParams(val) -); - -watch( - () => arrayData.store.userParams, - (val, oldValue) => (val || oldValue) && setUserParams(val) + () => [route.query[$props.searchUrl], arrayData.store.userParams], + ([newSearchUrl, newUserParams], [oldSearchUrl, oldUserParams]) => { + if (newSearchUrl || oldSearchUrl) setUserParams(newSearchUrl); + if (newUserParams || oldUserParams) setUserParams(newUserParams); + } ); watch( -- 2.40.1