style: complete redo of the email layouts (#20)
This commit is contained in:
@@ -1,31 +1,76 @@
|
||||
import React from 'react';
|
||||
import Footer from './components/Footer';
|
||||
|
||||
interface TemplateProps {
|
||||
title: string;
|
||||
body: JSX.Element;
|
||||
variant?: string;
|
||||
}
|
||||
|
||||
export default function Template({ title, body }: TemplateProps) {
|
||||
export default function Template({
|
||||
title,
|
||||
body,
|
||||
variant = 'default'
|
||||
}: TemplateProps) {
|
||||
const isNewsletter = variant === 'newsletter';
|
||||
|
||||
return (
|
||||
<div
|
||||
style={{
|
||||
maxWidth: '720px',
|
||||
alignContent: 'center',
|
||||
alignItems: 'center',
|
||||
backgroundColor: '#F9FBFB'
|
||||
margin: '0 auto',
|
||||
fontFamily: 'system-ui, -apple-system, sans-serif',
|
||||
backgroundColor: '#ffffff'
|
||||
}}
|
||||
>
|
||||
<h2
|
||||
<div
|
||||
style={{
|
||||
padding: '20px',
|
||||
textAlign: 'center',
|
||||
color: 'white',
|
||||
backgroundColor: `#8230CC`
|
||||
background: 'linear-gradient(135deg, #9333EA 0%, #F5A162 100%)',
|
||||
padding: '28px 24px',
|
||||
borderTopLeftRadius: '8px',
|
||||
borderTopRightRadius: '8px'
|
||||
}}
|
||||
>
|
||||
{title}
|
||||
</h2>
|
||||
<div style={{ margin: '20px', padding: '20px' }}>{body}</div>
|
||||
<p
|
||||
style={{
|
||||
margin: '0 0 8px 0',
|
||||
fontSize: '12px',
|
||||
textTransform: 'uppercase',
|
||||
color: 'rgba(255, 255, 255, 0.9)',
|
||||
textAlign: 'center'
|
||||
}}
|
||||
>
|
||||
Hackernews + newsletter
|
||||
</p>
|
||||
<h2
|
||||
style={{
|
||||
fontSize: '24px',
|
||||
textAlign: 'center',
|
||||
color: 'white',
|
||||
fontWeight: '600',
|
||||
margin: '0',
|
||||
letterSpacing: '-0.02em'
|
||||
}}
|
||||
>
|
||||
{title}
|
||||
</h2>
|
||||
</div>
|
||||
<div
|
||||
style={{
|
||||
backgroundColor: '#ffffff',
|
||||
padding: '32px 24px'
|
||||
}}
|
||||
>
|
||||
<div
|
||||
style={{
|
||||
color: '#374151',
|
||||
fontSize: isNewsletter ? '16px' : '14px',
|
||||
lineHeight: '1.6'
|
||||
}}
|
||||
>
|
||||
{body}
|
||||
</div>
|
||||
</div>
|
||||
<Footer />
|
||||
</div>
|
||||
);
|
||||
|
||||
Reference in New Issue
Block a user