48 lines
1.2 KiB
TypeScript
48 lines
1.2 KiB
TypeScript
|
import type { LoaderFunction } from "@remix-run/node";
|
||
|
import { Outlet, useCatch, useMatches } from "@remix-run/react";
|
||
|
|
||
|
import { requireLoggedIn } from "~/utils/auth.server";
|
||
|
import Footer from "~/features/core/components/footer";
|
||
|
|
||
|
export const loader:LoaderFunction = async ({ request }) => {
|
||
|
return requireLoggedIn(request);
|
||
|
}
|
||
|
|
||
|
export default function __App() {
|
||
|
const hideFooter = false;
|
||
|
const matches = useMatches();
|
||
|
// matches[0].handle
|
||
|
console.log("matches", matches);
|
||
|
|
||
|
return (
|
||
|
<div className="h-full w-full overflow-hidden fixed bg-gray-100">
|
||
|
<div className="flex flex-col w-full h-full">
|
||
|
<div className="flex flex-col flex-1 w-full overflow-y-auto">
|
||
|
<main className="flex flex-col flex-1 my-0 h-full">
|
||
|
<Outlet />
|
||
|
</main>
|
||
|
</div>
|
||
|
{!hideFooter ? <Footer /> : null}
|
||
|
</div>
|
||
|
</div>
|
||
|
);
|
||
|
}
|
||
|
|
||
|
export function CatchBoundary() {
|
||
|
const caught = useCatch();
|
||
|
console.log("caught", caught);
|
||
|
|
||
|
return (
|
||
|
<div className="h-full w-full overflow-hidden fixed bg-gray-100">
|
||
|
<div className="flex flex-col w-full h-full">
|
||
|
<div className="flex flex-col flex-1 w-full overflow-y-auto">
|
||
|
<main className="flex flex-col flex-1 my-0 h-full">
|
||
|
{caught.status}
|
||
|
</main>
|
||
|
</div>
|
||
|
<Footer />
|
||
|
</div>
|
||
|
</div>
|
||
|
);
|
||
|
}
|