mirror of
https://github.com/grafana/grafana.git
synced 2025-02-20 11:48:34 -06:00
15 lines
623 B
TypeScript
15 lines
623 B
TypeScript
import { UrlQueryMap } from '@grafana/data';
|
|
import { locationSearchToObject, locationService } from '@grafana/runtime';
|
|
import { useCallback, useMemo } from 'react';
|
|
import { useLocation } from 'react-router-dom';
|
|
|
|
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) => setImmediate(() => locationService.partial(values, replace)),
|
|
[]
|
|
);
|
|
return [queryParams, update];
|
|
}
|