spaCy/website/src/components/landing.js
2019-03-30 20:32:03 +01:00

165 lines
5.2 KiB
JavaScript

import React, { Fragment } from 'react'
import classNames from 'classnames'
import pattern from '../images/pattern_blue.jpg'
import patternOverlay from '../images/pattern_landing.jpg'
import logoSvgs from '../images/logos'
import Grid from './grid'
import { Content } from './main'
import Button from './button'
import CodeBlock from './code'
import { H1, H2, H3, Label, InlineList } from './typography'
import Link from './link'
import { chunkArray } from './util'
import classes from '../styles/landing.module.sass'
export const LandingHeader = ({ style = {}, children }) => {
const wrapperStyle = { backgroundImage: `url(${pattern})` }
const contentStyle = { backgroundImage: `url(${patternOverlay})`, ...style }
return (
<header className={classes.header}>
<div className={classes.headerWrapper} style={wrapperStyle}>
<div className={classes.headerContent} style={contentStyle}>
{children}
</div>
</div>
</header>
)
}
export const LandingTitle = ({ children }) => <h1 className={classes.title}>{children}</h1>
export const LandingSubtitle = ({ children }) => (
<h2>
<span className={classNames(classes.label, classes.subtitle)}>{children}</span>
</h2>
)
export const LandingGrid = ({ cols = 3, blocks = false, children }) => (
<Content className={classNames(classes.grid, { [classes.blocks]: blocks })}>
<Grid cols={cols} narrow={blocks}>
{children}
</Grid>
</Content>
)
export const LandingCol = ({ children }) => <div className={classes.col}>{children}</div>
export const LandingCard = ({ title, children }) => (
<div className={classes.card}>
{title && <H3>{title}</H3>}
{children}
</div>
)
export const LandingButton = ({ to, children }) => (
<Button to={to} variant="primary" large className={classes.button}>
{children}
</Button>
)
export const LandingDemo = ({ title, children }) => {
return (
<div className={classes.demo}>
<CodeBlock executable lang="python" title={title}>
{children}
</CodeBlock>
</div>
)
}
export const LandingBannerGrid = ({ children }) => (
<Grid cols={2} className={classes.bannerGrid}>
{children}
</Grid>
)
export const LandingBanner = ({
title,
label,
to,
button,
small,
background,
backgroundImage,
color,
children,
}) => {
const contentClassNames = classNames(classes.bannerContent, {
[classes.bannerContentSmall]: small,
})
const textClassNames = classNames(classes.bannerText, {
[classes.bannerTextSmall]: small,
})
const style = {
'--color-theme': background,
'--color-back': color,
backgroundImage: backgroundImage ? `url(${backgroundImage})` : null,
}
const Heading = small ? H2 : H1
return (
<div className={classes.banner} style={style}>
<Grid cols={small ? null : 3} narrow className={contentClassNames}>
<Heading Component="h3" className={classes.bannerTitle}>
{label && (
<div className={classes.bannerLabel}>
<span className={classes.label}>{label}</span>
</div>
)}
<Link to={to} hidden>
{title}
</Link>
</Heading>
<div className={textClassNames}>
<p>{children}</p>
{button && (
<LandingBannerButton to={to} small={small}>
{button}
</LandingBannerButton>
)}
</div>
</Grid>
</div>
)
}
export const LandingBannerButton = ({ to, small, children }) => (
<div className={classes.bannerButton}>
<Button to={to} variant="tertiary" large={!small} className={classes.bannerButtonElement}>
{children}
</Button>
</div>
)
export const LandingLogos = ({ logos = [], title, maxRow = 4, children }) => {
const rows = chunkArray(logos, maxRow)
return (
<Content className={classes.logos}>
{title && <Label>{title}</Label>}
{rows.map((logos, i) => (
<Fragment key={i}>
<InlineList className={classes.logosContent}>
{logos.map(({ id, url }, j) => {
const Component = logoSvgs[id]
return !Component ? null : (
<Link
to={url}
key={j}
aria-label={id}
hidden
className={classes.logo}
>
<Component />
</Link>
)
})}
{i === rows.length - 1 && children}
</InlineList>
</Fragment>
))}
</Content>
)
}