layout.tsx 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758
  1. import type { Viewport } from 'next'
  2. import I18nServer from './components/i18n-server'
  3. import BrowerInitor from './components/browser-initor'
  4. import SentryInitor from './components/sentry-initor'
  5. import { getLocaleOnServer } from '@/i18n/server'
  6. import './styles/globals.css'
  7. import './styles/markdown.scss'
  8. export const metadata = {
  9. title: 'Dify',
  10. }
  11. export const viewport: Viewport = {
  12. width: 'device-width',
  13. initialScale: 1,
  14. maximumScale: 1,
  15. viewportFit: 'cover',
  16. userScalable: false,
  17. }
  18. const LocaleLayout = ({
  19. children,
  20. }: {
  21. children: React.ReactNode
  22. }) => {
  23. const locale = getLocaleOnServer()
  24. return (
  25. <html lang={locale ?? 'en'} className="h-full">
  26. <head>
  27. <meta name="theme-color" content="#FFFFFF" />
  28. <meta name="mobile-web-app-capable" content="yes" />
  29. <meta name="apple-mobile-web-app-capable" content="yes" />
  30. <meta name="apple-mobile-web-app-status-bar-style" content="default" />
  31. </head>
  32. <body
  33. className="h-full select-auto"
  34. data-api-prefix={process.env.NEXT_PUBLIC_API_PREFIX}
  35. data-pubic-api-prefix={process.env.NEXT_PUBLIC_PUBLIC_API_PREFIX}
  36. data-public-edition={process.env.NEXT_PUBLIC_EDITION}
  37. data-public-sentry-dsn={process.env.NEXT_PUBLIC_SENTRY_DSN}
  38. data-public-maintenance-notice={process.env.NEXT_PUBLIC_MAINTENANCE_NOTICE}
  39. data-public-site-about={process.env.NEXT_PUBLIC_SITE_ABOUT}
  40. >
  41. <BrowerInitor>
  42. <SentryInitor>
  43. {/* @ts-expect-error Async Server Component */}
  44. <I18nServer locale={locale}>{children}</I18nServer>
  45. </SentryInitor>
  46. </BrowerInitor>
  47. </body>
  48. </html>
  49. )
  50. }
  51. export default LocaleLayout