2023-12-04 14:21:03 +01:00
|
|
|
import { useEffect } from 'react';
|
|
|
|
import { useSearchParams } from 'react-router-dom';
|
|
|
|
import { createLocalStorage } from 'utils/createLocalStorage';
|
2023-12-05 17:31:23 +01:00
|
|
|
import { useQueryParams, encodeQueryParams } from 'use-query-params';
|
|
|
|
import { QueryParamConfigMap } from 'serialize-query-params/src/types';
|
2023-12-04 14:21:03 +01:00
|
|
|
|
2023-12-05 17:31:23 +01:00
|
|
|
const usePersistentSearchParams = <T extends QueryParamConfigMap>(
|
|
|
|
key: string,
|
|
|
|
queryParamsDefinition: T,
|
|
|
|
) => {
|
2023-12-04 14:21:03 +01:00
|
|
|
const [searchParams, setSearchParams] = useSearchParams();
|
|
|
|
const { value, setValue } = createLocalStorage(key, {});
|
|
|
|
useEffect(() => {
|
|
|
|
const params = Object.fromEntries(searchParams.entries());
|
|
|
|
if (Object.keys(params).length > 0) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (Object.keys(value).length === 0) {
|
|
|
|
return;
|
|
|
|
}
|
2023-12-05 17:31:23 +01:00
|
|
|
setSearchParams(
|
|
|
|
encodeQueryParams(queryParamsDefinition, value) as Record<
|
|
|
|
string,
|
|
|
|
string
|
|
|
|
>,
|
|
|
|
{ replace: true },
|
|
|
|
);
|
2023-12-04 14:21:03 +01:00
|
|
|
}, []);
|
|
|
|
|
|
|
|
return setValue;
|
|
|
|
};
|
|
|
|
|
2023-12-05 17:31:23 +01:00
|
|
|
export const usePersistentTableState = <T extends QueryParamConfigMap>(
|
2023-12-04 14:21:03 +01:00
|
|
|
key: string,
|
|
|
|
queryParamsDefinition: T,
|
|
|
|
) => {
|
2023-12-05 17:31:23 +01:00
|
|
|
const updateStoredParams = usePersistentSearchParams(
|
|
|
|
key,
|
|
|
|
queryParamsDefinition,
|
|
|
|
);
|
2023-12-04 14:21:03 +01:00
|
|
|
|
|
|
|
const [tableState, setTableState] = useQueryParams(queryParamsDefinition);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
const { offset, ...rest } = tableState;
|
|
|
|
updateStoredParams(rest);
|
|
|
|
}, [JSON.stringify(tableState)]);
|
|
|
|
|
|
|
|
return [tableState, setTableState] as const;
|
|
|
|
};
|