import clsx from 'clsx'; import React, { useMemo } from 'react'; import { FormattedMessage } from 'react-intl'; import { defaultSettings } from 'soapbox/actions/settings'; import SiteLogo from 'soapbox/components/site-logo'; import BackgroundShapes from 'soapbox/features/ui/components/background-shapes'; import { useSystemTheme } from 'soapbox/hooks'; import { normalizeSoapboxConfig } from 'soapbox/normalizers'; import { generateThemeCss } from 'soapbox/utils/theme'; interface ISitePreview { /** Raw Soapbox configuration. */ soapbox: any, } /** Renders a preview of the website's style with the configuration applied. */ const SitePreview: React.FC = ({ soapbox }) => { const soapboxConfig = useMemo(() => normalizeSoapboxConfig(soapbox), [soapbox]); const settings = defaultSettings.mergeDeep(soapboxConfig.defaultSettings); const userTheme = settings.get('themeMode'); const systemTheme = useSystemTheme(); const dark = userTheme === 'dark' || (userTheme === 'system' && systemTheme === 'dark'); const bodyClass = clsx( 'site-preview', 'relative flex justify-center align-center text-base', 'border border-solid border-gray-200 dark:border-gray-600', 'h-40 rounded-lg overflow-hidden', { 'bg-white': !dark, 'bg-gray-900': dark, }); return (
); }; export default SitePreview;