diff options
| author | Bertrand Yuan <bert.yuan@outlook.com> | 2025-12-15 23:48:10 +0800 |
|---|---|---|
| committer | Bertrand Yuan <bert.yuan@outlook.com> | 2025-12-15 23:48:10 +0800 |
| commit | 5b7ccf0b671e2999b62befc729a3e517a0433728 (patch) | |
| tree | 8bf476dc7c75914c221042546840dc76267366df /src/app/layout.client.tsx | |
initial commit -- the front-end prototype
The initial code is base on Anirudh's work.
More to see at:
https://github.com/techwithanirudh/shadcn-blog
Therefore, the code in this commit is under MIT license.
Diffstat (limited to 'src/app/layout.client.tsx')
| -rw-r--r-- | src/app/layout.client.tsx | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/src/app/layout.client.tsx b/src/app/layout.client.tsx new file mode 100644 index 0000000..35726ba --- /dev/null +++ b/src/app/layout.client.tsx @@ -0,0 +1,26 @@ +'use client'; + +import { cn } from '@/lib/utils'; +import { useParams } from 'next/navigation'; +import type { ReactNode } from 'react'; + +export function Body({ + children, +}: { + children: ReactNode; +}): React.ReactElement { + const mode = useMode(); + + return ( + <body + className={cn(mode, 'relative flex min-h-svh flex-col overflow-x-hidden')} + > + {children} + </body> + ); +} + +export function useMode(): string | undefined { + const { slug } = useParams(); + return Array.isArray(slug) && slug.length > 0 ? slug[0] : undefined; +} |
