2017-11-23 12:48:34 +00:00
|
|
|
import NextHead from 'next/head'
|
|
|
|
import { string } from 'prop-types'
|
|
|
|
|
|
|
|
const defaultDescription = ''
|
|
|
|
const defaultOGURL = ''
|
|
|
|
const defaultOGImage = ''
|
|
|
|
|
|
|
|
const Head = (props) => (
|
|
|
|
<NextHead>
|
2017-11-25 11:03:25 +00:00
|
|
|
<meta charset='UTF-8' />
|
2017-11-23 12:48:34 +00:00
|
|
|
<title>{props.title || ''}</title>
|
2017-11-25 11:03:25 +00:00
|
|
|
<meta name='description' content={props.description || defaultDescription} />
|
|
|
|
<meta name='viewport' content='width=device-width, initial-scale=1' />
|
|
|
|
<link rel='icon' sizes='192x192' href='/static/touch-icon.png' />
|
|
|
|
<link rel='apple-touch-icon' href='/static/touch-icon.png' />
|
|
|
|
<link rel='mask-icon' href='/static/favicon-mask.svg' color='#49B882' />
|
|
|
|
<link rel='icon' href='/static/favicon.ico' />
|
|
|
|
<meta property='og:url' content={props.url || defaultOGURL} />
|
|
|
|
<meta property='og:title' content={props.title || ''} />
|
|
|
|
<meta property='og:description' content={props.description || defaultDescription} />
|
|
|
|
<meta name='twitter:site' content={props.url || defaultOGURL} />
|
|
|
|
<meta name='twitter:card' content='summary_large_image' />
|
|
|
|
<meta name='twitter:image' content={props.ogImage || defaultOGImage} />
|
|
|
|
<meta property='og:image' content={props.ogImage || defaultOGImage} />
|
|
|
|
<meta property='og:image:width' content='1200' />
|
|
|
|
<meta property='og:image:height' content='630' />
|
2017-11-23 12:48:34 +00:00
|
|
|
</NextHead>
|
|
|
|
)
|
|
|
|
|
|
|
|
Head.propTypes = {
|
|
|
|
title: string,
|
|
|
|
description: string,
|
|
|
|
url: string,
|
|
|
|
ogImage: string
|
|
|
|
}
|
|
|
|
|
|
|
|
export default Head
|