From 71feac2ea8533ab919b5f479170cd3c12128f766 Mon Sep 17 00:00:00 2001 From: Matthias Kretschmann Date: Sun, 28 Feb 2021 02:21:28 +0100 Subject: [PATCH] changes --- config.js | 2 +- .../molecules/PostTeaser.module.scss | 17 +-- src/components/molecules/PostTeaser.tsx | 16 ++- src/components/templates/Archive.module.scss | 4 + src/components/templates/Posts.module.scss | 39 ++++++ src/components/templates/Posts.test.tsx | 28 ++++ src/components/templates/Posts.tsx | 123 ++++++++++++++++++ src/pages/index.module.scss | 16 ++- src/pages/index.tsx | 28 ++-- 9 files changed, 250 insertions(+), 23 deletions(-) create mode 100644 src/components/templates/Posts.module.scss create mode 100644 src/components/templates/Posts.test.tsx create mode 100644 src/components/templates/Posts.tsx diff --git a/config.js b/config.js index d96b1812..67c13168 100644 --- a/config.js +++ b/config.js @@ -19,7 +19,7 @@ module.exports = { rss: '/feed.xml', jsonfeed: '/feed.json', typekitID: 'msu4qap', - itemsPerPage: 18, + itemsPerPage: 25, repoContentPath: 'https://github.com/kremalicious/blog/tree/main/content', menu: [ { diff --git a/src/components/molecules/PostTeaser.module.scss b/src/components/molecules/PostTeaser.module.scss index 9a6aafa4..e8d8ea7e 100644 --- a/src/components/molecules/PostTeaser.module.scss +++ b/src/components/molecules/PostTeaser.module.scss @@ -4,9 +4,8 @@ .title { padding-left: 0.2rem; padding-right: 0.2rem; - color: $brand-grey-light; margin-top: $spacer / 2; - margin-bottom: 0; + margin-bottom: $spacer / 6; font-size: $font-size-base; transition: color 0.2s ease-out; } @@ -19,18 +18,20 @@ } } +.time { + font-style: italic; + font-size: $font-size-small; + color: $text-color-light; +} + .empty { @include media-frame; - height: 100%; - min-height: 80px; + display: block; + min-height: 95px; background: url(); a:hover & { border-color: $link-color; } - - @media (min-width: $screen-md) { - min-height: 110px; - } } diff --git a/src/components/molecules/PostTeaser.tsx b/src/components/molecules/PostTeaser.tsx index 393b08a7..94b1b042 100644 --- a/src/components/molecules/PostTeaser.tsx +++ b/src/components/molecules/PostTeaser.tsx @@ -4,6 +4,7 @@ import { Image } from '../atoms/Image' import { Post } from '../../@types/Post' import PostTitle from '../templates/Post/Title' import styles from './PostTeaser.module.scss' +import Time from '../atoms/Time' export const postTeaserQuery = graphql` fragment PostTeaser on MarkdownRemark { @@ -13,6 +14,7 @@ export const postTeaserQuery = graphql` type title linkurl + updated image { childImageSharp { ...ImageFluidThumb @@ -22,6 +24,7 @@ export const postTeaserQuery = graphql` } fields { slug + date } } ` @@ -33,8 +36,8 @@ export default function PostTeaser({ post: Partial toggleSearch?: () => void }): ReactElement { - const { image, title, type } = post.frontmatter - const { slug } = post.fields + const { image, title, type, updated } = post.frontmatter + const { slug, date } = post.fields return ( - {image && ( + {image ? ( {title} + ) : ( + )} + {date && ( +
+
+ )} ) } diff --git a/src/components/templates/Archive.module.scss b/src/components/templates/Archive.module.scss index ad512751..15e6756a 100644 --- a/src/components/templates/Archive.module.scss +++ b/src/components/templates/Archive.module.scss @@ -11,3 +11,7 @@ grid-template-columns: repeat(2, 1fr); } } + +.posts h1 { + font-size: $font-size-h3; +} diff --git a/src/components/templates/Posts.module.scss b/src/components/templates/Posts.module.scss new file mode 100644 index 00000000..bf2a2b8f --- /dev/null +++ b/src/components/templates/Posts.module.scss @@ -0,0 +1,39 @@ +@import 'variables'; +@import 'mixins'; + +.hentry { + @include divider; + + margin-top: 0; + margin-bottom: 0; + padding-top: $spacer * 2; + padding-bottom: $spacer * 2; + + :global(.gatsby-image-wrapper) { + max-height: 100vh; + } + + @media (min-width: $screen-md) { + padding-top: $spacer * 4; + padding-bottom: $spacer * 4; + } +} + +.archivetitle { + @include divider; + + font-size: $font-size-h3; + margin-top: 0; + margin-bottom: 0; + padding-bottom: $spacer * $line-height; + + span { + color: $brand-grey-light; + padding-right: $spacer / 12; + font-size: $font-size-base; + } +} + +.paginationTitle { + composes: archivetitle; +} diff --git a/src/components/templates/Posts.test.tsx b/src/components/templates/Posts.test.tsx new file mode 100644 index 00000000..176c60b0 --- /dev/null +++ b/src/components/templates/Posts.test.tsx @@ -0,0 +1,28 @@ +import React from 'react' +import { render } from '@testing-library/react' +import { createHistory, createMemorySource } from '@reach/router' + +import Posts from './Posts' +import data from '../../../jest/__fixtures__/posts.json' + +describe('Post', () => { + const history = createHistory(createMemorySource('/photos')) + + const pageContext = { + tag: 'hello', + slug: '/hello', + currentPageNumber: 2, + numPages: 20 + } + + it('renders without crashing', () => { + const { container } = render( + + ) + expect(container.firstChild).toBeInTheDocument() + }) +}) diff --git a/src/components/templates/Posts.tsx b/src/components/templates/Posts.tsx new file mode 100644 index 00000000..e0172e70 --- /dev/null +++ b/src/components/templates/Posts.tsx @@ -0,0 +1,123 @@ +import React, { ReactElement } from 'react' +import { Link, graphql } from 'gatsby' +import { Post } from '../../@types/Post' +import Pagination from '../molecules/Pagination' +import Featured from '../molecules/Featured' +import PostTitle from './Post/Title' +import PostLead from './Post/Lead' +import PostContent from './Post/Content' +import PostMore from './Post/More' +import PostLinkActions from './Post/LinkActions' +import SEO from '../atoms/SEO' +import styles from './Posts.module.scss' +import { Image } from '../atoms/Image' + +export default function Posts({ + data, + location, + pageContext +}: { + data: any + location: Location + pageContext: { + tag: string + slug: string + currentPageNumber: number + numPages: number + } +}): ReactElement { + const edges = data.allMarkdownRemark.edges + const { tag, currentPageNumber, numPages } = pageContext + + const PostsList = edges.map(({ node }: { node: Post }) => { + const { type, linkurl, title, image } = node.frontmatter + const { slug } = node.fields + + return ( +
+ {type !== 'photo' && ( + + )} + + {image && ( + + {title} + + )} + + {type === 'post' && ( + <> + + Continue Reading + + )} + + {type === 'link' && ( + <> + + + + )} +
+ ) + }) + + return ( + <> + + {location.pathname === '/' && } + {tag && ( +

+ # + {tag} +

+ )} + {numPages > 1 && currentPageNumber > 1 && ( +

{`Page ${currentPageNumber} / ${numPages}`}

+ )} + {PostsList} + {numPages > 1 && } + + ) +} + +export const postsQuery = graphql` + query($tag: String, $skip: Int, $limit: Int) { + allMarkdownRemark( + filter: { frontmatter: { tags: { eq: $tag } } } + sort: { order: DESC, fields: [fields___date] } + skip: $skip + limit: $limit + ) { + edges { + node { + id + html + excerpt(pruneLength: 250) + frontmatter { + title + type + linkurl + image { + childImageSharp { + ...ImageFluid + } + } + tags + } + fields { + slug + date(formatString: "MMMM DD, YYYY") + } + } + } + } + } +` diff --git a/src/pages/index.module.scss b/src/pages/index.module.scss index cc910d2d..31bde583 100644 --- a/src/pages/index.module.scss +++ b/src/pages/index.module.scss @@ -24,11 +24,25 @@ } } +.articles:first-of-type h1 { + font-size: $font-size-h3; +} + +.articlesLast { + margin-top: $spacer * 1.5; + + @media (min-width: $screen-sm) { + gap: $spacer * 1.5; + grid-template-columns: repeat(3, 1fr); + } +} + .photos { grid-template-columns: repeat(2, 1fr); @media (min-width: $screen-sm) { - grid-template-columns: repeat(auto-fill, minmax(140px, 1fr)); + gap: $spacer * 1.5; + grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); } } diff --git a/src/pages/index.tsx b/src/pages/index.tsx index ac734f63..560b7ed4 100644 --- a/src/pages/index.tsx +++ b/src/pages/index.tsx @@ -1,26 +1,34 @@ -import React, { ReactElement } from 'react' import { graphql, PageProps } from 'gatsby' +import React, { ReactElement } from 'react' import { Post } from '../@types/Post' -import styles from './index.module.scss' -import Featured from '../components/molecules/Featured' -import { PhotoThumb } from '../components/templates/Photos' +import SEO from '../components/atoms/SEO' import PostTeaser from '../components/molecules/PostTeaser' +import { PhotoThumb } from '../components/templates/Photos' import PostMore from '../components/templates/Post/More' +import styles from './index.module.scss' export default function Home(props: PageProps): ReactElement { return ( <> +

Latest Articles All Articles

- {(props.data as any).latestArticles.edges.map( - ({ node }: { node: Post }) => ( + {(props.data as any).latestArticles.edges + .slice(0, 2) + .map(({ node }: { node: Post }) => ( - ) - )} + ))} +
+
+ {(props.data as any).latestArticles.edges + .slice(2, 8) + .map(({ node }: { node: Post }) => ( + + ))}
@@ -46,7 +54,7 @@ export const homeQuery = graphql` latestArticles: allMarkdownRemark( filter: { frontmatter: { type: { ne: "photo" } } } sort: { order: DESC, fields: [fields___date] } - limit: 6 + limit: 8 ) { edges { node { @@ -58,7 +66,7 @@ export const homeQuery = graphql` latestPhotos: allMarkdownRemark( filter: { frontmatter: { type: { eq: "photo" } } } sort: { order: DESC, fields: [fields___date] } - limit: 15 + limit: 12 ) { edges { node {