1
0
mirror of https://github.com/kremalicious/blog.git synced 2025-01-05 03:15:07 +01:00

fix meta tags for pages

This commit is contained in:
Matthias Kretschmann 2018-11-07 01:15:41 +01:00
parent a7f654805f
commit 0e8ac470d4
Signed by: m
GPG Key ID: 606EEEF3C479A91F
7 changed files with 63 additions and 25 deletions

View File

@ -1,4 +1,4 @@
import React, { Fragment } from 'react'
import React from 'react'
import PropTypes from 'prop-types'
import Container from './atoms/Container'
import Typekit from './atoms/Typekit'
@ -7,7 +7,7 @@ import Footer from './organisms/Footer'
import styles from './Layout.module.scss'
const Layout = ({ children }) => (
<Fragment>
<>
<Typekit />
<Header />
@ -18,7 +18,7 @@ const Layout = ({ children }) => (
</main>
<Footer />
</Fragment>
</>
)
Layout.propTypes = {

View File

@ -149,12 +149,14 @@ const SEO = ({ post, slug, postSEO }) => (
const postMeta = post.frontmatter
title = `${postMeta.title} ¦ ${siteMeta.siteTitle}`
description = postMeta.description ? postMeta.description : post.excerpt
image = postMeta.image ? postMeta.image.childImageSharp.fluid.src : logo
image = postMeta.image
? postMeta.image.childImageSharp.fluid.src
: `/${logo}`
postURL = `${siteMeta.siteUrl}${slug}`
} else {
title = `${siteMeta.siteTitle} ¦ ${siteMeta.siteDescription}`
description = siteMeta.siteDescription
image = logo
image = `/${logo}`
}
image = `${siteMeta.siteUrl}${image}`

View File

@ -4,8 +4,14 @@ import { Link } from 'gatsby'
import Page from '../templates/Page'
import styles from './404.module.scss'
const NotFound = () => (
<Page title="404 - Not Found">
const page = {
frontmatter: {
title: '404 - Not Found'
}
}
const NotFound = ({ location }) => (
<Page title={page.frontmatter.title} post={page} location={location}>
<div className={styles.hal9000} />
<div className={styles.wrapper}>

View File

@ -3,10 +3,17 @@ import PropTypes from 'prop-types'
import { graphql, Link } from 'gatsby'
import PostImage from '../components/Post/PostImage'
import Page from '../templates/Page'
import styles from './goodies.module.scss'
const Goodies = ({ data }) => {
const page = {
frontmatter: {
title: 'Goodies',
description:
'Goodies released by designer & developer Matthias Kretschmann.'
}
}
const Goodies = ({ data, location }) => {
const edges = data.goodies.edges
const GoodiesThumbs = edges.map(({ node }) => {
@ -25,7 +32,11 @@ const Goodies = ({ data }) => {
)
})
return <Page title="Goodies">{GoodiesThumbs}</Page>
return (
<Page title={page.frontmatter.title} post={page} location={location}>
{GoodiesThumbs}
</Page>
)
}
Goodies.propTypes = {

View File

@ -6,7 +6,14 @@ import Page from '../templates/Page'
import styles from './photos.module.scss'
const Photos = ({ data }) => {
const page = {
frontmatter: {
title: 'Photos',
description: 'Personal photos of designer & developer Matthias Kretschmann.'
}
}
const Photos = ({ data, location }) => {
const edges = data.photos.edges
const PhotoThumbs = edges.map(({ node }) => {
@ -25,7 +32,12 @@ const Photos = ({ data }) => {
})
return (
<Page title="Photos" section={styles.photos}>
<Page
title={page.frontmatter.title}
post={page}
location={location}
section={styles.photos}
>
{PhotoThumbs}
</Page>
)

View File

@ -1,15 +1,21 @@
import React from 'react'
import PropTypes from 'prop-types'
import Helmet from 'react-helmet'
import SEO from '../components/atoms/SEO'
import Layout from '../components/Layout'
import styles from './Page.module.scss'
const Page = ({ title, location, section, children }) => {
const Page = ({ title, location, section, children, post }) => {
return (
<>
<Helmet title={title} />
<SEO slug={location.pathname} postSEO post={post} />
<Layout location={location}>
<h1 className={styles.pageTitle}>{title}</h1>
{section ? <section className={section}>{children}</section> : children}
</Layout>
</>
)
}
@ -17,7 +23,8 @@ Page.propTypes = {
title: PropTypes.string.isRequired,
children: PropTypes.any.isRequired,
section: PropTypes.string,
location: PropTypes.object
location: PropTypes.object,
page: PropTypes.object
}
export default Page

View File

@ -32,13 +32,13 @@ const Post = ({ data, location }) => {
return (
<Fragment>
<Layout location={location}>
<Helmet title={title}>
{style && <link rel="stylesheet" href={style.publicURL} />}
</Helmet>
<SEO slug={slug} post={post} postSEO />
<Layout location={location}>
<article className={styles.hentry}>
<PostTitle type={type} linkurl={linkurl} title={title} />
{type === 'post' && <PostLead post={post} />}