Files
myeasycms-v2/apps/web/lib/root-theme.ts
Giancarlo Buomprisco 7ebff31475 Next.js Supabase V3 (#463)
Version 3 of the kit:
- Radix UI replaced with Base UI (using the Shadcn UI patterns)
- next-intl replaces react-i18next
- enhanceAction deprecated; usage moved to next-safe-action
- main layout now wrapped with [locale] path segment
- Teams only mode
- Layout updates
- Zod v4
- Next.js 16.2
- Typescript 6
- All other dependencies updated
- Removed deprecated Edge CSRF
- Dynamic Github Action runner
2026-03-24 13:40:38 +08:00

48 lines
1.2 KiB
TypeScript

import { cookies } from 'next/headers';
import * as z from 'zod';
/**
* @name Theme
* @description The theme mode enum.
*/
const Theme = z.enum(['light', 'dark', 'system']);
/**
* @name appDefaultThemeMode
* @description The default theme mode set by the application.
*/
const appDefaultThemeMode = Theme.safeParse(
process.env.NEXT_PUBLIC_DEFAULT_THEME_MODE,
);
/**
* @name fallbackThemeMode
* @description The fallback theme mode if none of the other options are available.
*/
const fallbackThemeMode = `light`;
/**
* @name getRootTheme
* @description Get the root theme from the cookies or default theme.
* @returns The root theme.
*/
export async function getRootTheme() {
const cookiesStore = await cookies();
const themeCookieValue = cookiesStore.get('theme')?.value;
const theme = Theme.safeParse(themeCookieValue);
// pass the theme from the cookie if it exists
if (theme.success) {
return theme.data;
}
// pass the default theme from the environment variable if it exists
if (appDefaultThemeMode.success) {
return appDefaultThemeMode.data;
}
// in all other cases, fallback to the default theme
return fallbackThemeMode;
}