1234567891011121314151617181920212223242526272829303132333435363738394041 |
- import {useCallback} from 'react';
- import type {Location} from 'history';
- import {decodeScalar} from 'sentry/utils/queryString';
- import {useLocation} from 'sentry/utils/useLocation';
- import {useNavigate} from 'sentry/utils/useNavigate';
- interface Options {
- location: Location;
- navigate: ReturnType<typeof useNavigate>;
- }
- export function useUserQuery(): [string, (newQuery: string) => void] {
- const location = useLocation();
- const navigate = useNavigate();
- const options = {location, navigate};
- return useUserQueryImpl(options);
- }
- function useUserQueryImpl({
- location,
- navigate,
- }: Options): [string, (newQuery: string) => void] {
- const userQuery = decodeScalar(location.query.query, '');
- const setUserQuery = useCallback(
- (newQuery: string) => {
- navigate({
- ...location,
- query: {
- ...location.query,
- query: newQuery,
- },
- });
- },
- [location, navigate]
- );
- return [userQuery, setUserQuery];
- }
|