2025-04-01 10:38:02 +09:00

19 lines
638 B
TypeScript

import { useCallback, useMemo } from 'react';
import { useLocation } from 'react-router-dom-v5-compat';
import { locationService } from '@grafana/runtime';
export function useURLSearchParams(): [
URLSearchParams,
(searchValues: Record<string, string | string[] | undefined>, replace?: boolean) => void,
] {
const { search } = useLocation();
const queryParams = useMemo(() => new URLSearchParams(search), [search]);
const update = useCallback((searchValues: Record<string, string | string[] | undefined>, replace?: boolean) => {
locationService.partial(searchValues, replace);
}, []);
return [queryParams, update];
}