grafana/public/app/core/hooks/useQueryParams.ts

13 lines
592 B
TypeScript
Raw Normal View History

import { useCallback, useMemo } from 'react';
import { useLocation } from 'react-router-dom';
import { UrlQueryMap } from '@grafana/data';
import { locationSearchToObject, locationService } from '@grafana/runtime';
export function useQueryParams(): [UrlQueryMap, (values: UrlQueryMap, replace?: boolean) => void] {
const { search } = useLocation();
const queryParams = useMemo(() => locationSearchToObject(search || ''), [search]);
const update = useCallback((values: UrlQueryMap, replace?: boolean) => locationService.partial(values, replace), []);
return [queryParams, update];
}