2023-10-08 19:35:11 +02:00
|
|
|
import { useCallback, useMemo } from "react";
|
2023-12-23 06:24:43 +01:00
|
|
|
import { useLocation, useNavigate } from "react-router-dom";
|
2023-05-25 22:54:35 +02:00
|
|
|
|
|
|
|
export function useQueryParams() {
|
|
|
|
const loc = useLocation();
|
|
|
|
|
|
|
|
const queryParams = useMemo(() => {
|
2023-05-26 23:04:11 +02:00
|
|
|
const obj: Record<string, string> = Object.fromEntries(
|
2023-12-23 06:24:43 +01:00
|
|
|
new URLSearchParams(loc.search).entries(),
|
2023-05-26 23:04:11 +02:00
|
|
|
);
|
2023-05-25 22:54:35 +02:00
|
|
|
|
|
|
|
return obj;
|
2023-10-13 21:41:44 +02:00
|
|
|
}, [loc.search]);
|
2023-05-25 22:54:35 +02:00
|
|
|
|
|
|
|
return queryParams;
|
|
|
|
}
|
2023-10-08 19:35:11 +02:00
|
|
|
|
2023-10-09 21:00:58 +02:00
|
|
|
export function useQueryParam(
|
2023-12-23 06:24:43 +01:00
|
|
|
param: string,
|
2023-10-09 21:00:58 +02:00
|
|
|
): [string | null, (a: string | null) => void] {
|
2023-10-08 19:35:11 +02:00
|
|
|
const params = useQueryParams();
|
|
|
|
const location = useLocation();
|
2023-12-23 06:24:43 +01:00
|
|
|
const navigate = useNavigate();
|
2023-10-09 21:00:58 +02:00
|
|
|
const currentValue = params[param] ?? null;
|
2023-10-08 19:35:11 +02:00
|
|
|
|
|
|
|
const set = useCallback(
|
|
|
|
(value: string | null) => {
|
|
|
|
const parsed = new URLSearchParams(location.search);
|
|
|
|
if (value) parsed.set(param, value);
|
|
|
|
else parsed.delete(param);
|
2023-12-23 06:24:43 +01:00
|
|
|
navigate({
|
2023-10-08 20:12:31 +02:00
|
|
|
search: parsed.toString(),
|
|
|
|
});
|
2023-10-08 19:35:11 +02:00
|
|
|
},
|
2023-12-23 06:24:43 +01:00
|
|
|
[param, location.search, navigate],
|
2023-10-08 19:35:11 +02:00
|
|
|
);
|
|
|
|
|
2023-10-09 21:00:58 +02:00
|
|
|
return [currentValue, set];
|
2023-10-08 19:35:11 +02:00
|
|
|
}
|