1
0
mirror of https://github.com/kremalicious/blog.git synced 2025-01-06 19:55:40 +01:00

archive tweaks

This commit is contained in:
Matthias Kretschmann 2018-09-07 00:36:08 +02:00
parent 592bdad6e6
commit 0180ad26b4
Signed by: m
GPG Key ID: 606EEEF3C479A91F
15 changed files with 75 additions and 138 deletions

View File

@ -28,4 +28,4 @@ author:
typekitID: msu4qap typekitID: msu4qap
itemsPerPage: 15 itemsPerPage: 10

View File

@ -93,9 +93,10 @@ exports.createPages = ({ graphql, actions }) => {
}) })
} }
const postsTemplate = path.resolve('src/templates/Posts.jsx')
const generateContent = (createPage, posts) => { const generateContent = (createPage, posts) => {
const postTemplate = path.resolve('src/templates/Post.jsx') const postTemplate = path.resolve('src/templates/Post.jsx')
const postsTemplate = path.resolve('src/templates/Posts.jsx')
// Create Post pages // Create Post pages
posts.forEach(post => { posts.forEach(post => {
@ -119,8 +120,6 @@ const generateContent = (createPage, posts) => {
} }
const createTagPages = (createPage, posts) => { const createTagPages = (createPage, posts) => {
const archiveTemplate = path.resolve('src/templates/Archive.jsx')
const tagSet = new Set() const tagSet = new Set()
const tagMap = new Map() const tagMap = new Map()
@ -139,17 +138,10 @@ const createTagPages = (createPage, posts) => {
const tagList = Array.from(tagSet) const tagList = Array.from(tagSet)
tagList.forEach(tag => { tagList.forEach(tag => {
// Create paginated tag pages // Create tag pages
// paginate({
// createPage,
// items: tagList, // An array of objects
// itemsPerPage: 5,
// pathPrefix: `/tag/${tag.toLowerCase()}`,
// component: archiveTemplate
// })
createPage({ createPage({
path: `/tag/${tag}/`, path: `/tag/${tag}/`,
component: archiveTemplate, component: postsTemplate,
context: { tag } context: { tag }
}) })
}) })
@ -164,7 +156,7 @@ const createTagPages = (createPage, posts) => {
// page === 1 // page === 1
// ? `/tag/${tagName.toLowerCase()}` // ? `/tag/${tagName.toLowerCase()}`
// : `/tag/${tagName.toLowerCase()}/page/${page}`, // : `/tag/${tagName.toLowerCase()}/page/${page}`,
// component: tagTemplate, // component: postsTemplate,
// context: { // context: {
// posts: paginate(posts[tagName], pageSize, page), // posts: paginate(posts[tagName], pageSize, page),
// tag: tagName, // tag: tagName,

View File

@ -25,6 +25,8 @@
"gatsby": "^2.0.0-rc.13", "gatsby": "^2.0.0-rc.13",
"gatsby-awesome-pagination": "^0.1.1", "gatsby-awesome-pagination": "^0.1.1",
"gatsby-image": "^2.0.0-rc.1", "gatsby-image": "^2.0.0-rc.1",
"gatsby-paginate": "^1.0.16",
"gatsby-pagination": "^1.2.0",
"gatsby-plugin-catch-links": "^2.0.2-rc.1", "gatsby-plugin-catch-links": "^2.0.2-rc.1",
"gatsby-plugin-lunr": "^1.1.0", "gatsby-plugin-lunr": "^1.1.0",
"gatsby-plugin-matomo": "^0.5.0", "gatsby-plugin-matomo": "^0.5.0",

View File

@ -1,5 +1,5 @@
@import 'mixins'; @import 'variables';
.lead { .lead {
@include lead(); font-size: $font-size-large;
} }

View File

@ -6,7 +6,6 @@
.hentry__title { .hentry__title {
font-size: $font-size-h1; font-size: $font-size-h1;
text-align: center;
color: $color-headings; color: $color-headings;
margin-top: 0; margin-top: 0;
margin-bottom: $spacer; margin-bottom: $spacer;

View File

@ -8,14 +8,14 @@ const Pagination = ({ pageContext }) => {
return ( return (
<div className={styles.pagination}> <div className={styles.pagination}>
{previousPagePath ? (
<Link className={styles.paginationLink} to={previousPagePath}>
&laquo; Newer Posts
</Link>
) : null}
{nextPagePath ? ( {nextPagePath ? (
<Link className={styles.paginationLink} to={nextPagePath}> <Link className={styles.paginationLink} to={nextPagePath}>
Older Posts &raquo; &laquo; Older Posts
</Link>
) : null}
{previousPagePath ? (
<Link className={styles.paginationLink} to={previousPagePath}>
Newer Posts &raquo;
</Link> </Link>
) : null} ) : null}
</div> </div>

View File

@ -13,4 +13,8 @@
&:last-child { &:last-child {
text-align: right; text-align: right;
} }
&:only-child {
text-align: left;
}
} }

View File

@ -5,7 +5,6 @@ import Layout from '../components/Layout'
import Image from '../components/atoms/Image' import Image from '../components/atoms/Image'
import styles from './photos.module.scss' import styles from './photos.module.scss'
import stylesArchive from '../templates/Archive.module.scss'
const Photos = ({ data, location }) => { const Photos = ({ data, location }) => {
const edges = data.photos.edges const edges = data.photos.edges
@ -27,7 +26,7 @@ const Photos = ({ data, location }) => {
return ( return (
<Layout location={location}> <Layout location={location}>
<h1 className={stylesArchive.archiveTitle}>Photos</h1> <h1 className={styles.pageTitle}>Photos</h1>
<section className={styles.photos}>{PhotoThumbs}</section> <section className={styles.photos}>{PhotoThumbs}</section>
</Layout> </Layout>
) )

View File

@ -16,3 +16,8 @@
display: block; display: block;
} }
} }
.pageTitle {
composes: archiveTitle from '../templates/Posts.module.scss';
margin-bottom: $spacer * 2;
}

View File

@ -84,7 +84,7 @@
@mixin divider() { @mixin divider() {
position: relative; position: relative;
border-bottom: 1px dashed #afc3cb; border-bottom: 1px dashed lighten($brand-grey-light, 7%);
margin-top: $spacer * $line-height; margin-top: $spacer * $line-height;
margin-bottom: $spacer * $line-height; margin-bottom: $spacer * $line-height;
@ -101,7 +101,7 @@
@mixin divider-top() { @mixin divider-top() {
position: relative; position: relative;
border-top: 1px dashed #afc3cb; border-top: 1px dashed lighten($brand-grey-light, 7%);
margin-top: $spacer * $line-height; margin-top: $spacer * $line-height;
margin-bottom: $spacer * $line-height; margin-bottom: $spacer * $line-height;
@ -126,13 +126,6 @@
margin-left: -100%; margin-left: -100%;
} }
// Lead paragraph
/////////////////////////////////////
@mixin lead() {
font-size: $font-size-large;
}
// Layout breakout // Layout breakout
///////////////////////////////////// /////////////////////////////////////

View File

@ -1,61 +0,0 @@
import React from 'react'
import PropTypes from 'prop-types'
import { Link, graphql } from 'gatsby'
import Layout from '../components/Layout'
import styles from './Archive.module.scss'
const Archive = ({ data, location, pageContext }) => {
let posts
let archiveTitle
if (pageContext.category) {
posts = data.category.edges
archiveTitle = pageContext.category
} else {
posts = data.tag.edges
archiveTitle = pageContext.tag
}
const Posts = posts.map(post => (
<li key={post.node.id}>
<Link to={post.node.fields.slug}>{post.node.frontmatter.title}</Link>
</li>
))
return (
<Layout location={location}>
<h1 className={styles.archiveTitle}>{archiveTitle}</h1>
<ul>{Posts}</ul>
</Layout>
)
}
Archive.propTypes = {
data: PropTypes.object.isRequired,
location: PropTypes.object.isRequired,
pageContext: PropTypes.object.isRequired
}
export default Archive
export const archiveQuery = graphql`
query($tag: String!) {
tag: allMarkdownRemark(
filter: { frontmatter: { tags: { eq: $tag } } }
sort: { order: DESC, fields: [fields___date] }
) {
edges {
node {
id
frontmatter {
title
}
fields {
slug
date(formatString: "MMMM DD, YYYY")
}
}
}
}
}
`

View File

@ -1,9 +0,0 @@
@import 'variables';
@import 'mixins';
.archiveTitle {
@include heading-band();
font-size: $font-size-h3;
margin-top: 0;
}

View File

@ -2,33 +2,11 @@
@import 'mixins'; @import 'mixins';
.hentry { .hentry {
@include divider;
margin-top: 0;
margin-bottom: 0;
padding-top: $spacer * 2;
padding-bottom: $spacer * 2;
width: 100%; width: 100%;
padding-top: $spacer;
@media (min-width: $screen-sm) {
padding-top: $spacer * 3;
padding-bottom: $spacer * 3; padding-bottom: $spacer * 3;
} }
&:first-child {
padding-top: 0;
}
&:only-child,
&:last-child {
border: 0;
&::before {
display: none;
}
}
}
// Post/photo teaser // Post/photo teaser
///////////////////////////////////// /////////////////////////////////////

View File

@ -10,19 +10,18 @@ import PostMore from '../components/atoms/PostMore'
import PostLinkActions from '../components/atoms/PostLinkActions' import PostLinkActions from '../components/atoms/PostLinkActions'
import Pagination from '../components/molecules/Pagination' import Pagination from '../components/molecules/Pagination'
import Featured from '../components/molecules/Featured' import Featured from '../components/molecules/Featured'
import postStyles from '../templates/Post.module.scss'
import styles from './Posts.module.scss' import styles from './Posts.module.scss'
const IndexPage = ({ data, location, pageContext }) => { const Posts = ({ data, location, pageContext }) => {
const edges = data.allMarkdownRemark.edges const edges = data.allMarkdownRemark.edges
const { humanPageNumber } = pageContext const { tag, previousPagePath, humanPageNumber, numberOfPages } = pageContext
const Posts = edges.map(({ node }) => { const PostsList = edges.map(({ node }) => {
const { type, linkurl, title, image } = node.frontmatter const { type, linkurl, title, image } = node.frontmatter
const { slug } = node.fields const { slug } = node.fields
return ( return (
<article className={postStyles.hentry} key={node.id}> <article className={styles.hentry} key={node.id}>
<PostTitle type={type} slug={slug} linkurl={linkurl} title={title} /> <PostTitle type={type} slug={slug} linkurl={linkurl} title={title} />
{image && ( {image && (
@ -49,24 +48,31 @@ const IndexPage = ({ data, location, pageContext }) => {
return ( return (
<Layout location={location}> <Layout location={location}>
{humanPageNumber === 1 && <Featured />} {location.pathname === '/' && <Featured />}
{Posts} {tag && <h1 className={styles.archiveTitle}>{tag}</h1>}
{previousPagePath && (
<h1
className={styles.archiveTitle}
>{`Page ${humanPageNumber} / ${numberOfPages}`}</h1>
)}
{PostsList}
<Pagination pageContext={pageContext} /> <Pagination pageContext={pageContext} />
</Layout> </Layout>
) )
} }
IndexPage.propTypes = { Posts.propTypes = {
data: PropTypes.object.isRequired, data: PropTypes.object.isRequired,
pageContext: PropTypes.object.isRequired, pageContext: PropTypes.object.isRequired,
location: PropTypes.object.isRequired location: PropTypes.object.isRequired
} }
export default IndexPage export default Posts
export const indexQuery = graphql` export const indexQuery = graphql`
query($skip: Int!, $limit: Int!) { query($tag: String, $skip: Int, $limit: Int) {
allMarkdownRemark( allMarkdownRemark(
filter: { frontmatter: { tags: { eq: $tag } } }
sort: { order: DESC, fields: [fields___date] } sort: { order: DESC, fields: [fields___date] }
skip: $skip skip: $skip
limit: $limit limit: $limit
@ -85,6 +91,7 @@ export const indexQuery = graphql`
...ImageFluid ...ImageFluid
} }
} }
tags
} }
fields { fields {
slug slug

View File

@ -1,6 +1,34 @@
@import 'variables'; @import 'variables';
@import 'mixins'; @import 'mixins';
.hentry {
composes: hentry from '../templates/Post.module.scss';
@include divider;
margin-top: 0;
margin-bottom: 0;
padding-top: $spacer * 2;
padding-bottom: $spacer * 2;
@media (min-width: $screen-sm) {
padding-top: $spacer * 3;
padding-bottom: $spacer * 3;
}
}
.archiveTitle {
@include heading-band();
font-size: $font-size-h4;
margin-top: 0;
margin-bottom: 0;
@media (min-width: $screen-md) {
margin-left: -117%;
}
}
// Post/photo teaser // Post/photo teaser
///////////////////////////////////// /////////////////////////////////////