2021-03-31 17:08:38 +00:00
|
|
|
import * as React from "react";
|
2021-03-31 22:37:02 +00:00
|
|
|
import { graphql } from "gatsby";
|
2021-03-31 17:08:38 +00:00
|
|
|
import Layout, { Section, SectionTitle } from "../components/Layout";
|
2021-03-31 22:37:02 +00:00
|
|
|
import { Aside } from "../components/News";
|
2021-03-31 17:08:38 +00:00
|
|
|
import SEO from "../components/seo";
|
2021-03-31 22:37:02 +00:00
|
|
|
import { TwitterShareButton, LinkedinShareButton, FacebookShareButton } from "react-share";
|
2021-03-31 23:01:32 +00:00
|
|
|
import { TwitterSmall, LinkedinSmall } from "../components/Icons";
|
2021-03-31 17:08:38 +00:00
|
|
|
|
|
|
|
const BlogPostTemplate = ({ data, location }) => {
|
|
|
|
const post = data.markdownRemark;
|
|
|
|
const siteTitle = data.site.siteMetadata?.title || `Title`;
|
|
|
|
// const { previous, next } = data;
|
|
|
|
|
2021-03-31 23:01:32 +00:00
|
|
|
// console.log(post);
|
2021-03-31 22:37:02 +00:00
|
|
|
|
2021-03-31 17:08:38 +00:00
|
|
|
return (
|
|
|
|
<Layout location={location} title={siteTitle}>
|
|
|
|
<SEO title={post.frontmatter.title} description={post.frontmatter.description || post.excerpt} />
|
|
|
|
<Section className="bg-white" first={true}>
|
|
|
|
<article className="blog-post" itemScope itemType="http://schema.org/Article">
|
|
|
|
<SectionTitle itemProp="headline" className="mb-16">
|
|
|
|
{post.frontmatter.title}
|
|
|
|
</SectionTitle>
|
|
|
|
|
2021-03-31 22:37:02 +00:00
|
|
|
<div className="grid grid-cols-3 gap-8">
|
|
|
|
<aside className="space-y-5">
|
|
|
|
<Aside avatar={post.frontmatter.avatar} author={post.frontmatter.author} date={post.frontmatter.date} />
|
|
|
|
|
|
|
|
<hr className="text-palette-200" />
|
|
|
|
|
|
|
|
<div className="flex items-center">
|
|
|
|
<div class="text-xs uppercase mr-4">Share</div>
|
|
|
|
|
2021-03-31 23:01:32 +00:00
|
|
|
<TwitterShareButton url={location.href} title={post.frontmatter.title} hashtags={[]}>
|
2021-03-31 23:21:00 +00:00
|
|
|
<TwitterSmall className="fill-current hover:text-palette-400 transition-colors duration-200" />
|
2021-03-31 22:37:02 +00:00
|
|
|
</TwitterShareButton>
|
|
|
|
|
2021-03-31 23:01:32 +00:00
|
|
|
<LinkedinShareButton
|
|
|
|
url={location.href}
|
|
|
|
title={post.frontmatter.title}
|
|
|
|
summary={post.frontmatter.description}
|
|
|
|
>
|
2021-03-31 23:21:00 +00:00
|
|
|
<LinkedinSmall className="fill-current hover:text-palette-400 transition-colors duration-200" />
|
2021-03-31 22:37:02 +00:00
|
|
|
</LinkedinShareButton>
|
2021-03-31 23:01:32 +00:00
|
|
|
|
|
|
|
<FacebookShareButton url={location.href} quote={post.frontmatter.title}>
|
2021-03-31 23:21:00 +00:00
|
|
|
<LinkedinSmall className="fill-current hover:text-palette-400 transition-colors duration-200" />
|
2021-03-31 23:01:32 +00:00
|
|
|
</FacebookShareButton>
|
2021-03-31 22:37:02 +00:00
|
|
|
</div>
|
|
|
|
</aside>
|
|
|
|
<section dangerouslySetInnerHTML={{ __html: post.html }} itemProp="articleBody" className="col-span-2" />
|
|
|
|
</div>
|
2021-03-31 17:08:38 +00:00
|
|
|
</article>
|
|
|
|
</Section>
|
|
|
|
</Layout>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export default BlogPostTemplate;
|
|
|
|
|
|
|
|
export const pageQuery = graphql`
|
|
|
|
query BlogPostBySlug($id: String!, $previousPostId: String, $nextPostId: String) {
|
|
|
|
site {
|
|
|
|
siteMetadata {
|
|
|
|
title
|
|
|
|
}
|
|
|
|
}
|
|
|
|
markdownRemark(id: { eq: $id }) {
|
|
|
|
id
|
|
|
|
excerpt(pruneLength: 160)
|
|
|
|
html
|
|
|
|
frontmatter {
|
|
|
|
title
|
|
|
|
date(formatString: "MMMM DD, YYYY")
|
|
|
|
description
|
2021-03-31 22:37:02 +00:00
|
|
|
author
|
|
|
|
avatar {
|
|
|
|
childImageSharp {
|
|
|
|
gatsbyImageData(width: 40, placeholder: BLURRED, formats: [AUTO, WEBP, AVIF])
|
|
|
|
}
|
|
|
|
}
|
2021-03-31 17:08:38 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
previous: markdownRemark(id: { eq: $previousPostId }) {
|
|
|
|
fields {
|
|
|
|
slug
|
|
|
|
}
|
|
|
|
frontmatter {
|
|
|
|
title
|
|
|
|
}
|
|
|
|
}
|
|
|
|
next: markdownRemark(id: { eq: $nextPostId }) {
|
|
|
|
fields {
|
|
|
|
slug
|
|
|
|
}
|
|
|
|
frontmatter {
|
|
|
|
title
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
`;
|