mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-10 10:17:28 +03:00
24 lines
815 B
TypeScript
24 lines
815 B
TypeScript
|
import type { FC, PropsWithChildren } from 'react';
|
||
|
import { useMemo } from 'react';
|
||
|
import { MemoryRouter, Route, Routes } from 'react-router-dom';
|
||
|
|
||
|
export type MemoryRouterWithParamsProps = PropsWithChildren<{
|
||
|
params: Record<string, string>;
|
||
|
}>;
|
||
|
|
||
|
/**
|
||
|
* Wrap any component using useParams() with MemoryRouterWithParams, in order to determine wat the hook should return
|
||
|
*/
|
||
|
export const MemoryRouterWithParams: FC<MemoryRouterWithParamsProps> = ({ children, params }) => {
|
||
|
const pathname = useMemo(() => `/${Object.values(params).join('/')}`, [params]);
|
||
|
const pathPattern = useMemo(() => `/:${Object.keys(params).join('/:')}`, [params]);
|
||
|
|
||
|
return (
|
||
|
<MemoryRouter>
|
||
|
<Routes location={{ pathname }}>
|
||
|
<Route path={pathPattern} element={children} />
|
||
|
</Routes>
|
||
|
</MemoryRouter>
|
||
|
);
|
||
|
};
|