Skip to content

Commit

Permalink
upgrade to react router 7 in lib mode
Browse files Browse the repository at this point in the history
  • Loading branch information
alan2207 committed Dec 7, 2024
1 parent a55e984 commit b0fb641
Show file tree
Hide file tree
Showing 26 changed files with 178 additions and 151 deletions.
2 changes: 1 addition & 1 deletion apps/react-vite/.storybook/preview.tsx
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import React from 'react';
import { BrowserRouter as Router } from 'react-router-dom';
import { BrowserRouter as Router } from 'react-router';
import '../src/index.css';

export const parameters = {
Expand Down
2 changes: 1 addition & 1 deletion apps/react-vite/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@
"react-helmet-async": "^2.0.4",
"react-hook-form": "^7.51.3",
"react-query-auth": "^2.3.0",
"react-router-dom": "^6.23.0",
"react-router": "^7.0.2",
"tailwind-merge": "^2.3.0",
"tailwindcss-animate": "^1.0.7",
"zod": "^3.23.4",
Expand Down
10 changes: 1 addition & 9 deletions apps/react-vite/src/app/provider.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -35,15 +35,7 @@ export const AppProvider = ({ children }: AppProviderProps) => {
<QueryClientProvider client={queryClient}>
{import.meta.env.DEV && <ReactQueryDevtools />}
<Notifications />
<AuthLoader
renderLoading={() => (
<div className="flex h-screen w-screen items-center justify-center">
<Spinner size="xl" />
</div>
)}
>
{children}
</AuthLoader>
<AuthLoader>{children}</AuthLoader>
</QueryClientProvider>
</HelmetProvider>
</ErrorBoundary>
Expand Down
97 changes: 32 additions & 65 deletions apps/react-vite/src/app/router.tsx
Original file line number Diff line number Diff line change
@@ -1,34 +1,39 @@
import { QueryClient, useQueryClient } from '@tanstack/react-query';
import { useMemo } from 'react';
import { RouterProvider, createBrowserRouter } from 'react-router-dom';
import { createBrowserRouter } from 'react-router';
import { RouterProvider } from 'react-router/dom';

import { paths } from '@/config/paths';
import { ProtectedRoute } from '@/lib/auth';

import { AppRoot, AppRootErrorBoundary } from './routes/app/root';
import {
default as AppRoot,
ErrorBoundary as AppRootErrorBoundary,
} from './routes/app/root';

const convert = (queryClient: QueryClient) => (m: any) => {
const { clientLoader, clientAction, default: Component, ...rest } = m;
return {
...rest,
loader: clientLoader?.(queryClient),
action: clientAction?.(queryClient),
Component,
};
};

export const createAppRouter = (queryClient: QueryClient) =>
createBrowserRouter([
{
path: paths.home.path,
lazy: async () => {
const { LandingRoute } = await import('./routes/landing');
return { Component: LandingRoute };
},
lazy: () => import('./routes/landing').then(convert(queryClient)),
},
{
path: paths.auth.register.path,
lazy: async () => {
const { RegisterRoute } = await import('./routes/auth/register');
return { Component: RegisterRoute };
},
lazy: () => import('./routes/auth/register').then(convert(queryClient)),
},
{
path: paths.auth.login.path,
lazy: async () => {
const { LoginRoute } = await import('./routes/auth/login');
return { Component: LoginRoute };
},
lazy: () => import('./routes/auth/login').then(convert(queryClient)),
},
{
path: paths.app.root.path,
Expand All @@ -41,74 +46,36 @@ export const createAppRouter = (queryClient: QueryClient) =>
children: [
{
path: paths.app.discussions.path,
lazy: async () => {
const { DiscussionsRoute, discussionsLoader } = await import(
'./routes/app/discussions/discussions'
);
return {
Component: DiscussionsRoute,
loader: discussionsLoader(queryClient),
};
},
ErrorBoundary: AppRootErrorBoundary,
lazy: () =>
import('./routes/app/discussions/discussions').then(
convert(queryClient),
),
},
{
path: paths.app.discussion.path,
lazy: async () => {
const { DiscussionRoute, discussionLoader } = await import(
'./routes/app/discussions/discussion'
);
return {
Component: DiscussionRoute,
loader: discussionLoader(queryClient),
};
},
ErrorBoundary: AppRootErrorBoundary,
lazy: () =>
import('./routes/app/discussions/discussion').then(
convert(queryClient),
),
},
{
path: paths.app.users.path,
lazy: async () => {
const { UsersRoute, usersLoader } = await import(
'./routes/app/users'
);
return {
Component: UsersRoute,
loader: usersLoader(queryClient),
};
},
ErrorBoundary: AppRootErrorBoundary,
lazy: () => import('./routes/app/users').then(convert(queryClient)),
},
{
path: paths.app.profile.path,
lazy: async () => {
const { ProfileRoute } = await import('./routes/app/profile');
return {
Component: ProfileRoute,
};
},
ErrorBoundary: AppRootErrorBoundary,
lazy: () => import('./routes/app/profile').then(convert(queryClient)),
},
{
path: paths.app.dashboard.path,
lazy: async () => {
const { DashboardRoute } = await import('./routes/app/dashboard');
return {
Component: DashboardRoute,
};
},
ErrorBoundary: AppRootErrorBoundary,
lazy: () =>
import('./routes/app/dashboard').then(convert(queryClient)),
},
],
},
{
path: '*',
lazy: async () => {
const { NotFoundRoute } = await import('./routes/not-found');
return {
Component: NotFoundRoute,
};
},
ErrorBoundary: AppRootErrorBoundary,
lazy: () => import('./routes/not-found').then(convert(queryClient)),
},
]);

Expand Down
4 changes: 3 additions & 1 deletion apps/react-vite/src/app/routes/app/dashboard.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import { ContentLayout } from '@/components/layouts';
import { useUser } from '@/lib/auth';
import { ROLES } from '@/lib/authorization';

export const DashboardRoute = () => {
const DashboardRoute = () => {
const user = useUser();
return (
<ContentLayout title="Dashboard">
Expand Down Expand Up @@ -31,3 +31,5 @@ export const DashboardRoute = () => {
</ContentLayout>
);
};

export default DashboardRoute;
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import {
within,
} from '@/testing/test-utils';

import { DiscussionRoute } from '../discussion';
import { default as DiscussionRoute } from '../discussion';

const renderDiscussion = async () => {
const fakeUser = await createUser();
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ import {
} from '@/testing/test-utils';
import { formatDate } from '@/utils/format';

import { DiscussionsRoute } from '../discussions';
import { default as DiscussionsRoute } from '../discussions';

beforeAll(() => {
vi.spyOn(console, 'error').mockImplementation(() => {});
Expand Down
8 changes: 5 additions & 3 deletions apps/react-vite/src/app/routes/app/discussions/discussion.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { QueryClient } from '@tanstack/react-query';
import { ErrorBoundary } from 'react-error-boundary';
import { useParams, LoaderFunctionArgs } from 'react-router-dom';
import { useParams, LoaderFunctionArgs } from 'react-router';

import { ContentLayout } from '@/components/layouts';
import { Spinner } from '@/components/ui/spinner';
Expand All @@ -12,7 +12,7 @@ import {
} from '@/features/discussions/api/get-discussion';
import { DiscussionView } from '@/features/discussions/components/discussion-view';

export const discussionLoader =
export const clientLoader =
(queryClient: QueryClient) =>
async ({ params }: LoaderFunctionArgs) => {
const discussionId = params.discussionId as string;
Expand All @@ -35,7 +35,7 @@ export const discussionLoader =
};
};

export const DiscussionRoute = () => {
const DiscussionRoute = () => {
const params = useParams();
const discussionId = params.discussionId as string;
const discussionQuery = useDiscussion({
Expand Down Expand Up @@ -71,3 +71,5 @@ export const DiscussionRoute = () => {
</>
);
};

export default DiscussionRoute;
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
import { QueryClient, useQueryClient } from '@tanstack/react-query';
import { LoaderFunctionArgs } from 'react-router-dom';
import { LoaderFunctionArgs } from 'react-router';

import { ContentLayout } from '@/components/layouts';
import { getInfiniteCommentsQueryOptions } from '@/features/comments/api/get-comments';
import { getDiscussionsQueryOptions } from '@/features/discussions/api/get-discussions';
import { CreateDiscussion } from '@/features/discussions/components/create-discussion';
import { DiscussionsList } from '@/features/discussions/components/discussions-list';

export const discussionsLoader =
export const clientLoader =
(queryClient: QueryClient) =>
async ({ request }: LoaderFunctionArgs) => {
const url = new URL(request.url);
Expand All @@ -22,7 +22,7 @@ export const discussionsLoader =
);
};

export const DiscussionsRoute = () => {
const DiscussionsRoute = () => {
const queryClient = useQueryClient();
return (
<ContentLayout title="Discussions">
Expand All @@ -42,3 +42,5 @@ export const DiscussionsRoute = () => {
</ContentLayout>
);
};

export default DiscussionsRoute;
4 changes: 3 additions & 1 deletion apps/react-vite/src/app/routes/app/profile.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ const Entry = ({ label, value }: EntryProps) => (
</div>
);

export const ProfileRoute = () => {
const ProfileRoute = () => {
const user = useUser();

if (!user.data) return null;
Expand Down Expand Up @@ -47,3 +47,5 @@ export const ProfileRoute = () => {
</ContentLayout>
);
};

export default ProfileRoute;
12 changes: 7 additions & 5 deletions apps/react-vite/src/app/routes/app/root.tsx
Original file line number Diff line number Diff line change
@@ -1,15 +1,17 @@
import { Outlet } from 'react-router-dom';
import { Outlet } from 'react-router';

import { DashboardLayout } from '@/components/layouts';

export const AppRoot = () => {
export const ErrorBoundary = () => {
return <div>Something went wrong!</div>;
};

const AppRoot = () => {
return (
<DashboardLayout>
<Outlet />
</DashboardLayout>
);
};

export const AppRootErrorBoundary = () => {
return <div>Something went wrong!</div>;
};
export default AppRoot;
6 changes: 4 additions & 2 deletions apps/react-vite/src/app/routes/app/users.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ import { getUsersQueryOptions } from '@/features/users/api/get-users';
import { UsersList } from '@/features/users/components/users-list';
import { Authorization, ROLES } from '@/lib/authorization';

export const usersLoader = (queryClient: QueryClient) => async () => {
export const clientLoader = (queryClient: QueryClient) => async () => {
const query = getUsersQueryOptions();

return (
Expand All @@ -14,7 +14,7 @@ export const usersLoader = (queryClient: QueryClient) => async () => {
);
};

export const UsersRoute = () => {
const UsersRoute = () => {
return (
<ContentLayout title="Users">
<Authorization
Expand All @@ -26,3 +26,5 @@ export const UsersRoute = () => {
</ContentLayout>
);
};

export default UsersRoute;
6 changes: 4 additions & 2 deletions apps/react-vite/src/app/routes/auth/login.tsx
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import { useNavigate, useSearchParams } from 'react-router-dom';
import { useNavigate, useSearchParams } from 'react-router';

import { AuthLayout } from '@/components/layouts/auth-layout';
import { paths } from '@/config/paths';
import { LoginForm } from '@/features/auth/components/login-form';

export const LoginRoute = () => {
const LoginRoute = () => {
const navigate = useNavigate();
const [searchParams] = useSearchParams();
const redirectTo = searchParams.get('redirectTo');
Expand All @@ -24,3 +24,5 @@ export const LoginRoute = () => {
</AuthLayout>
);
};

export default LoginRoute;
6 changes: 4 additions & 2 deletions apps/react-vite/src/app/routes/auth/register.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import { useState } from 'react';
import { useNavigate, useSearchParams } from 'react-router-dom';
import { useNavigate, useSearchParams } from 'react-router';

import { AuthLayout } from '@/components/layouts/auth-layout';
import { paths } from '@/config/paths';
import { RegisterForm } from '@/features/auth/components/register-form';
import { useTeams } from '@/features/teams/api/get-teams';

export const RegisterRoute = () => {
const RegisterRoute = () => {
const navigate = useNavigate();
const [searchParams] = useSearchParams();
const redirectTo = searchParams.get('redirectTo');
Expand Down Expand Up @@ -36,3 +36,5 @@ export const RegisterRoute = () => {
</AuthLayout>
);
};

export default RegisterRoute;
6 changes: 4 additions & 2 deletions apps/react-vite/src/app/routes/landing.tsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import { useNavigate } from 'react-router-dom';
import { useNavigate } from 'react-router';

import logo from '@/assets/logo.svg';
import { Head } from '@/components/seo';
import { Button } from '@/components/ui/button';
import { paths } from '@/config/paths';
import { useUser } from '@/lib/auth';

export const LandingRoute = () => {
const LandingRoute = () => {
const navigate = useNavigate();
const user = useUser();

Expand Down Expand Up @@ -84,3 +84,5 @@ export const LandingRoute = () => {
</>
);
};

export default LandingRoute;
Loading

0 comments on commit b0fb641

Please sign in to comment.