mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-12 03:07:28 +03:00
23 lines
815 B
TypeScript
23 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>
|
|
);
|
|
};
|