/** * Copyright (c) 2013-present, Facebook, Inc. * * @providesModule theme * @flow */ /** * Theme contains variables shared by styles of multiple components. */ import hex2rgba from 'hex2rgba'; const colors = { lighter: '#373940', // light blue dark: '#282c34', // dark blue darker: '#20232a', // really dark blue brand: '#61dafb', // electric blue brandLight: '#bbeffd', text: '#1a1a1a', // very dark grey / black substitute subtle: '#6d6d6d', // light grey for text subtleOnDark: '#999', divider: '#ececec', // very light grey note: '#ffe564', // yellow error: '#ff6464', // yellow white: '#ffffff', black: '#000000', }; const SIZES = { xsmall: {min: 0, max: 599}, small: {min: 600, max: 779}, medium: {min: 780, max: 979}, large: {min: 980, max: 1279}, xlarge: {min: 1280, max: 1339}, xxlarge: {min: 1340, max: Infinity}, // Sidebar/nav related tweakpoints largerSidebar: {min: 1100, max: 1339}, sidebarFixed: {min: 2000, max: Infinity}, }; type Size = $Keys; const media = { between(smallKey: Size, largeKey: Size, excludeLarge: boolean = false) { if (excludeLarge) { return `@media (min-width: ${ SIZES[smallKey].min }px) and (max-width: ${SIZES[largeKey].min - 1}px)`; } else { if (SIZES[largeKey].max === Infinity) { return `@media (min-width: ${SIZES[smallKey].min}px)`; } else { return `@media (min-width: ${SIZES[smallKey].min}px) and (max-width: ${ SIZES[largeKey].max }px)`; } } }, greaterThan(key: Size) { return `@media (min-width: ${SIZES[key].min}px)`; }, lessThan(key: Size) { return `@media (max-width: ${SIZES[key].min - 1}px)`; }, size(key: Size) { const size = SIZES[key]; if (size.min == null) { return media.lessThan(key); } else if (size.max == null) { return media.greaterThan(key); } else { return media.between(key, key); } }, }; const fonts = { header: { fontSize: 60, lineHeight: '65px', fontWeight: 700, [media.lessThan('medium')]: { fontSize: 40, lineHeight: '45px', }, }, small: { fontSize: 14, }, }; // Shared styles are generally better as components, // Except when they must be used within nested CSS selectors. // This is the case for eg markdown content. const linkStyle = { backgroundColor: hex2rgba(colors.brandLight, 0.3), borderBottom: `1px solid ${hex2rgba(colors.black, 0.2)}`, color: colors.text, ':hover': { backgroundColor: colors.brandLight, borderBottomColor: colors.text, }, }; const sharedStyles = { link: linkStyle, articleLayout: { container: { display: 'flex', minHeight: 'calc(100vh - 60px)', [media.greaterThan('sidebarFixed')]: { maxWidth: 840, marginLeft: 'auto', marginRight: 'auto', }, }, content: { marginTop: 40, marginBottom: 120, [media.greaterThan('medium')]: { marginTop: 50, }, }, sidebar: { display: 'flex', flexDirection: 'column', [media.between('small', 'sidebarFixed')]: { borderLeft: '1px solid #ececec', marginLeft: 80, }, [media.between('small', 'largerSidebar')]: { flex: '0 0 200px', marginLeft: 80, }, [media.between('small', 'medium')]: { marginLeft: 40, }, [media.greaterThan('largerSidebar')]: { flex: '0 0 300px', }, [media.greaterThan('sidebarFixed')]: { position: 'fixed', right: 0, width: 300, zIndex: 2, }, }, editLink: { color: colors.subtle, borderColor: colors.divider, transition: 'all 0.2s ease', transitionPropery: 'color, border-color', whiteSpace: 'nowrap', borderBottomWidth: 1, borderBottomStyle: 'solid', ':hover': { color: colors.text, borderColor: colors.text, }, }, }, markdown: { lineHeight: '25px', '& .gatsby-highlight': { marginTop: 25, marginLeft: -30, marginRight: -30, marginBottom: 25, paddingLeft: 15, paddingRight: 15, [media.lessThan('small')]: { marginLeft: -20, marginRight: -20, borderRadius: 0, }, }, '& a:not(.anchor):not(.gatsby-resp-image-link)': linkStyle, '& > p:first-child': { fontSize: 18, fontWeight: 300, color: colors.subtle, [media.greaterThan('xlarge')]: { fontSize: 24, }, '& a, & strong': { fontWeight: 400, }, }, '& p': { marginTop: 30, fontSize: 17, lineHeight: 1.7, maxWidth: '42em', '&:first-of-type': { marginTop: 15, }, '&:first-child': { marginTop: 0, }, [media.lessThan('large')]: { fontSize: 16, marginTop: 25, }, }, '& h3 + p, & h3 + p:first-of-type': { marginTop: 20, }, '& p > code, & li > code': { background: hex2rgba(colors.note, 0.2), color: colors.text, }, '& p > code, & li > code, & p > a > code, & li > a > code': { padding: '0 3px', fontSize: '0.94em', // 16px on 17px text, smaller in smaller text wordBreak: 'break-word', }, '& hr': { height: 1, marginBottom: -1, border: 'none', borderBottom: `1px solid ${colors.divider}`, marginTop: 40, ':first-child': { marginTop: 0, }, }, '& h1': { lineHeight: 1.2, [media.size('xsmall')]: { fontSize: 30, }, [media.between('small', 'large')]: { fontSize: 45, }, [media.greaterThan('xlarge')]: { fontSize: 60, }, }, '& h2': { borderTop: `1px solid ${colors.divider}`, marginTop: 44, paddingTop: 40, lineHeight: 1.2, ':first-child': { borderTop: 0, marginTop: 0, paddingTop: 0, }, [media.lessThan('large')]: { fontSize: 20, }, [media.greaterThan('xlarge')]: { fontSize: 35, }, }, '& hr + h2': { borderTop: 0, marginTop: 0, }, '& h3': { paddingTop: 45, [media.lessThan('small')]: { overflowWrap: 'break-word', wordBreak: 'break-word', }, [media.greaterThan('xlarge')]: { fontSize: 25, lineHeight: 1.3, }, }, '& h2 + h3, & h2 + h3:first-of-type': { paddingTop: 30, }, '& h4': { fontSize: 20, color: colors.subtle, lineHeight: 1.3, marginTop: 50, fontWeight: 400, }, '& h4 + p': { marginTop: 20, }, '& ol, & ul': { marginTop: 20, fontSize: 16, color: colors.text, paddingLeft: 20, '& p, & p:first-of-type': { fontSize: 16, marginTop: 0, lineHeight: 1.2, }, '& li': { marginTop: 10, }, '& li.button-newapp': { marginTop: 0, }, '& ol, & ul': { marginLeft: 20, marginTop: 10, }, }, '& img': { maxWidth: '100%', }, '& ol': { listStyle: 'decimal', }, '& ul': { listStyle: 'disc', }, '& blockquote': { backgroundColor: hex2rgba('#ffe564', 0.3), borderLeftColor: colors.note, borderLeftWidth: 9, borderLeftStyle: 'solid', padding: '20px 45px 20px 26px', marginBottom: 30, marginTop: 20, marginLeft: -30, marginRight: -30, [media.lessThan('small')]: { marginLeft: -20, marginRight: -20, }, '& p': { marginTop: 15, '&:first-of-type': { fontWeight: 700, marginTop: 0, }, '&:nth-of-type(2)': { marginTop: 0, }, }, }, '& .gatsby-highlight + blockquote': { marginTop: 40, }, }, }; export {colors, fonts, media, sharedStyles};