Skip to content

Commit

Permalink
refactor: Split up build into multiple chunks
Browse files Browse the repository at this point in the history
  • Loading branch information
tklein1801 committed Jan 4, 2024
1 parent b51e5dd commit 35f28f6
Show file tree
Hide file tree
Showing 4 changed files with 63 additions and 48 deletions.
66 changes: 35 additions & 31 deletions src/App.tsx
Original file line number Diff line number Diff line change
@@ -1,38 +1,42 @@
import React from 'react';
import { BrowserRouter, Navigate, Route, Routes } from 'react-router-dom';
import DashboardRoute from '@/routes/Dashboard.route';
import TransactionsRoute from './routes/Transactions.route';
import SubscriptionsRoute from './routes/Subscriptions.route';
import PaymentMethodsRoute from './routes/PaymentMethods.route';
import CategoriesRoute from './routes/Categories.route';
import NotFoundPage from '@/routes/NotFound.route';
import SignInRoute from './routes/SignIn.route';
import SignUpRoute from './routes/SignUp.route';
import BudgetRoute from './routes/Budget.route';
import VerifyMailRoute from './routes/VerifyMail.route';
import RequestPasswordResetRoute from './routes/RequestPasswordReset.route';
import ResetPasswordRoute from './routes/ResetPassword.route';
import SettingsRoute from './routes/Settings.route';
import { FullPageLoader } from './components/Loading/FullPageLoader.component';
const DashboardRoute = React.lazy(() => import('./routes/Dashboard.route'));
const TransactionsRoute = React.lazy(() => import('./routes/Transactions.route'));
const SubscriptionsRoute = React.lazy(() => import('./routes/Subscriptions.route'));
const PaymentMethodsRoute = React.lazy(() => import('./routes/PaymentMethods.route'));
const CategoriesRoute = React.lazy(() => import('./routes/Categories.route'));
const NotFoundPage = React.lazy(() => import('./routes/NotFound.route'));
const SignInRoute = React.lazy(() => import('./routes/SignIn.route'));
const SignUpRoute = React.lazy(() => import('./routes/SignUp.route'));
const BudgetRoute = React.lazy(() => import('./routes/Budget.route'));
const VerifyMailRoute = React.lazy(() => import('./routes/VerifyMail.route'));
const RequestPasswordResetRoute = React.lazy(() => import('./routes/RequestPasswordReset.route'));
const ResetPasswordRoute = React.lazy(() => import('./routes/ResetPassword.route'));
const SettingsRoute = React.lazy(() => import('./routes/Settings.route'));

const App = () => {
return (
<BrowserRouter>
<Routes>
<Route index element={<DashboardRoute />} />
<Route path="/dashboard" element={<Navigate to="/" />} />
<Route path="/transactions" element={<TransactionsRoute />} />
<Route path="/subscriptions" element={<SubscriptionsRoute />} />
<Route path="/budgets" element={<BudgetRoute />} />
<Route path="/payment-methods" element={<PaymentMethodsRoute />} />
<Route path="/categories" element={<CategoriesRoute />} />
<Route path="/settings/profile" element={<SettingsRoute />} />
<Route path="/sign-in" element={<SignInRoute />} />
<Route path="/sign-up" element={<SignUpRoute />} />
<Route path="/verify-email" element={<VerifyMailRoute />} />
<Route path="/request-password-reset" element={<RequestPasswordResetRoute />} />
<Route path="/reset-password" element={<ResetPasswordRoute />} />
<Route path="*" element={<NotFoundPage />} />
</Routes>
</BrowserRouter>
<React.Suspense fallback={<FullPageLoader />}>
<BrowserRouter>
<Routes>
<Route index element={<DashboardRoute />} />
<Route path="/dashboard" element={<Navigate to="/" />} />
<Route path="/transactions" element={<TransactionsRoute />} />
<Route path="/subscriptions" element={<SubscriptionsRoute />} />
<Route path="/budgets" element={<BudgetRoute />} />
<Route path="/payment-methods" element={<PaymentMethodsRoute />} />
<Route path="/categories" element={<CategoriesRoute />} />
<Route path="/settings/profile" element={<SettingsRoute />} />
<Route path="/sign-in" element={<SignInRoute />} />
<Route path="/sign-up" element={<SignUpRoute />} />
<Route path="/verify-email" element={<VerifyMailRoute />} />
<Route path="/request-password-reset" element={<RequestPasswordResetRoute />} />
<Route path="/reset-password" element={<ResetPasswordRoute />} />
<Route path="*" element={<NotFoundPage />} />
</Routes>
</BrowserRouter>
</React.Suspense>
);
};

Expand Down
40 changes: 25 additions & 15 deletions src/components/Brand.component.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,26 +14,36 @@ export type TBrandProps = {
boxStyle?: BoxProps['sx'];
iconStyle?: IconProps['sx'];
typographyStyle?: TypographyProps['sx'];
asLink?: boolean;
};

export const Brand: React.FC<TBrandProps> = ({ boxStyle, iconStyle, typographyStyle }) => {
export const Brand: React.FC<TBrandProps> = ({
boxStyle,
iconStyle,
typographyStyle,
asLink = false,
}) => {
const baseProps: TypographyProps = {
variant: 'h5',
noWrap: true,
sx: {
fontWeight: 700,
color: 'inherit',
textDecoration: 'none',
...typographyStyle,
},
};

return (
<Box sx={{ display: 'flex', alignItems: 'center', ...boxStyle }}>
<SavingsIcon sx={{ mr: 1, ...iconStyle }} />
<Typography
variant="h5"
component={Link}
to="/"
noWrap
sx={{
fontWeight: 700,
color: 'inherit',
textDecoration: 'none',
...typographyStyle,
}}
>
{AppConfig.appName}
</Typography>
{asLink ? (
<Typography component={Link} to="/" {...baseProps}>
{AppConfig.appName}
</Typography>
) : (
<Typography {...baseProps}>{AppConfig.appName}</Typography>
)}
</Box>
);
};
4 changes: 2 additions & 2 deletions src/components/Layout/AppBar.component.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -65,15 +65,15 @@ export const AppBar = () => {
<Container maxWidth="xl">
<Toolbar disableGutters>
{/* Desktop: Brand */}
<Brand boxStyle={{ display: { xs: 'none', md: 'flex' }, mr: 1 }} />
<Brand asLink boxStyle={{ display: { xs: 'none', md: 'flex' }, mr: 1 }} />

{/* Menu: Mobile */}
<Box sx={{ flexGrow: 1, display: { xs: 'flex', md: 'none' } }}>
<DrawerHamburger size="large" />
</Box>

{/* Modile: Brand */}
<Brand boxStyle={{ display: { xs: 'flex', md: 'none' }, flexGrow: 1 }} />
<Brand asLink boxStyle={{ display: { xs: 'flex', md: 'none' }, flexGrow: 1 }} />

{/* Menu: Desktop */}
<Box sx={{ display: { xs: 'none', md: 'flex' }, marginLeft: 'auto', marginRight: 2 }}>
Expand Down
1 change: 1 addition & 0 deletions src/components/Layout/Drawer/DrawerHeader.component.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ export const DrawerHeader = () => {
}}
>
<Brand
asLink
boxStyle={{
display: { xs: 'flex', md: open ? 'flex' : 'none' },
ml: 2,
Expand Down

0 comments on commit 35f28f6

Please sign in to comment.