bigbuffet-rw/app/soapbox/features/soapbox_config/components/site-preview.tsx

52 lines
1.7 KiB
TypeScript
Raw Normal View History

import classNames from 'classnames';
2022-05-05 11:23:25 -07:00
import React, { useMemo } from 'react';
2020-10-01 16:57:11 -07:00
import { defaultSettings } from 'soapbox/actions/settings';
2022-05-05 11:23:25 -07:00
import { normalizeSoapboxConfig } from 'soapbox/normalizers';
import { generateThemeCss } from 'soapbox/utils/theme';
2020-10-01 16:57:11 -07:00
2022-05-05 11:23:25 -07:00
interface ISitePreview {
/** Raw Soapbox configuration. */
soapbox: any,
}
2020-10-01 16:57:11 -07:00
2022-05-05 11:23:25 -07:00
/** Renders a preview of the website's style with the configuration applied. */
const SitePreview: React.FC<ISitePreview> = ({ soapbox }) => {
const soapboxConfig = useMemo(() => normalizeSoapboxConfig(soapbox), [soapbox]);
const settings = defaultSettings.mergeDeep(soapboxConfig.defaultSettings);
2020-10-01 16:57:11 -07:00
2022-03-21 11:09:01 -07:00
const bodyClass = classNames('site-preview', `theme-mode-${settings.get('themeMode')}`, {
2020-10-01 16:57:11 -07:00
'no-reduce-motion': !settings.get('reduceMotion'),
'underline-links': settings.get('underlineLinks'),
2020-10-01 16:57:11 -07:00
'dyslexic': settings.get('dyslexicFont'),
'demetricator': settings.get('demetricator'),
});
return (
<div className={bodyClass}>
2022-05-05 11:23:25 -07:00
<style>{`.site-preview {${generateThemeCss(soapboxConfig)}}`}</style>
2020-10-01 16:57:11 -07:00
<div className='app-holder'>
<div>
<div className='ui'>
<nav className='tabs-bar'>
<div className='tabs-bar__container'>
<div className='tabs-bar__split tabs-bar__split--left'>
<a className='tabs-bar__link--logo' href='#'>
2022-05-05 11:23:25 -07:00
<img alt='Logo' src={soapboxConfig.logo} />
2020-10-01 16:57:11 -07:00
</a>
</div>
</div>
</nav>
<div className='page'>
<span className='spoiler-button__overlay__label'>Site Preview</span>
</div>
</div>
</div>
</div>
</div>
);
};
2022-05-05 11:23:25 -07:00
export default SitePreview;