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>
  );
};