maxpou/gatsby-starter-morning-dew

View on GitHub
src/templates/blog-post-share-image.js

Summary

Maintainability
A
2 hrs
Test Coverage
import React from 'react'
import { graphql, withPrefix } from 'gatsby'
import styled from 'styled-components'
import { createGlobalStyle } from 'styled-components'
import useSiteMetadata from '../hooks/use-site-config'
import useSiteImages from '../hooks/use-site-images'

const GlobalPageStyle = createGlobalStyle`
  * {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
  }

  body {
    font-family: 'Rubik', sans-serif;
  }
`

const Wrapper = styled.div`
  width: ${props => props.width || 440}px;
  height: ${props => props.height || 220}px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  vertical-align: middle;
  text-align: center;
  background-color: #437abf;
  position: relative;
`

const Square = styled.div`
  width: ${props => props.width || 440}px;
  height: ${props => props.height || 220}px;
  position: absolute;
  outline: 3px solid #fff !important;
  outline-offset: -25px;
`

const Preview = styled.div`
  width: ${props => props.width || 440}px;
  height: ${props => props.height || 220}px;
  background-image: url("${props =>
    props.hero || withPrefix(props.siteCover)}");
  background-position: center;
  background-size: cover;
  position: absolute;
  opacity: 0.5;
`

const Title = styled.h1`
  font-weight: 700;
  font-size: 1.8rem;
  margin: 10px 60px;
  color: #fff;
  text-shadow: 1px 1px 4px rgba(34, 34, 34, 0.6);
  text-align: center;
  z-index: 1;
`

const SiteTitle = styled.p`
  font-size: 1rem;
  left: 50%;
  font-weight: 700;
  text-align: center;
  z-index: 1;
  position: absolute;
  top: 22px;
  background-color: #fff;
  padding: 1px 5px 1px 5px;
  transform: translate(-50%);
  width: max-content;
`

const AuthorImg = styled.img`
  height: 40px;
  width: 40px;
  border-radius: 40px;
  display: inline-block;
  vertical-align: middle;
`

const SubTitle = styled.div`
  vertical-align: middle;
  text-align: center;
  font-weight: 700;
  z-index: 1;
`

const ReadTime = styled.span`
  font-size: 1rem;
  text-shadow: 1px 1px 4px rgba(34, 34, 34, 0.6);
  color: #fff;
  padding-left: 8px;
`

const BlogPostShareImage = props => {
  const post = props.data.post
  const { width, height } = props.pageContext
  const heroImg = post.frontmatter.cover && post.frontmatter.cover.publicURL
  const { siteCover, authorAvatar, headerTitle } = useSiteMetadata()
  const { fixed } = useSiteImages(authorAvatar)
  const siteCoverPath = useSiteImages(siteCover).fluid.src

  return (
    <Wrapper width={width} height={height}>
      <link
        href="https://fonts.googleapis.com/css?family=Rubik&display=swap"
        rel="stylesheet"
      />
      <GlobalPageStyle />

      <SiteTitle>{headerTitle}</SiteTitle>
      <Title>{post.frontmatter.title}</Title>
      <SubTitle>
        <AuthorImg src={fixed.src} />
        <ReadTime>{post.timeToRead} min read</ReadTime>
      </SubTitle>
      <Preview
        width={width}
        height={height}
        hero={heroImg}
        siteCover={siteCoverPath}
      />
      <Square width={width} height={height} />
    </Wrapper>
  )
}

export default BlogPostShareImage

export const pageQuery = graphql`
  query BlogPostShareImage($slug: String!) {
    post: mdx(frontmatter: { slug: { eq: $slug } }) {
      timeToRead
      frontmatter {
        title
        cover {
          publicURL
        }
      }
    }
  }
`