From 9408db00c2276a0b8cada9cc197880fb176f1936 Mon Sep 17 00:00:00 2001 From: Jennifer Grange Date: Thu, 26 Oct 2023 11:45:29 -0400 Subject: [PATCH] add a check for isEqual to reduce duplicate queries --- src/useRouteQueryParam/useRouteQueryParam.ts | 26 ++++++++++++++------ 1 file changed, 18 insertions(+), 8 deletions(-) diff --git a/src/useRouteQueryParam/useRouteQueryParam.ts b/src/useRouteQueryParam/useRouteQueryParam.ts index 3475685c..7e510007 100644 --- a/src/useRouteQueryParam/useRouteQueryParam.ts +++ b/src/useRouteQueryParam/useRouteQueryParam.ts @@ -1,5 +1,6 @@ /* eslint-disable @typescript-eslint/unified-signatures */ -import { computed, Ref } from 'vue' +import isEqual from 'lodash.isequal' +import { ref, Ref, watch } from 'vue' import { NoInfer } from '@/types/generics' import { MaybeArray } from '@/types/maybe' import { useRouteQuery } from '@/useRouteQuery/useRouteQuery' @@ -43,12 +44,21 @@ export function useRouteQueryParam(key: string, formatterOrDefaultValue?: RouteP const defaultValue = maybeDefaultValue const format = new formatter({ key, defaultValue, multiple }) - return computed({ - get() { - return format.get(query) - }, - set(value) { - format.set(query, value) - }, + const param = ref(format.get(query)) + + watch(() => query, query => { + const newValue = format.get(query) + + if (isEqual(newValue, param)) { + return + } + + param.value = newValue }) + + watch(param, param => { + format.set(query, param) + }) + + return param } \ No newline at end of file