drone/web/src/hooks/useQueryParams.ts
Tan Nhu 7116c2fbe4 Implement Create Branch (#78)
* Update new icons

* Implement Create Branch
2022-11-17 00:16:57 -08:00

25 lines
684 B
TypeScript

import React from 'react'
import { useLocation } from 'react-router-dom'
import qs from 'qs'
import type { IParseOptions } from 'qs'
export interface UseQueryParamsOptions<T> extends IParseOptions {
processQueryParams?(data: Unknown): T
}
export function useQueryParams<T = unknown>(options?: UseQueryParamsOptions<T>): T {
const { search } = useLocation()
const queryParams = React.useMemo(() => {
const params = qs.parse(search, { ignoreQueryPrefix: true, ...options })
if (typeof options?.processQueryParams === 'function') {
return options.processQueryParams(params)
}
return params
}, [search, options])
return queryParams as unknown as T
}