mirror of
https://github.com/kremalicious/blog.git
synced 2025-01-05 03:15:07 +01:00
archive tweaks
This commit is contained in:
parent
592bdad6e6
commit
0180ad26b4
@ -28,4 +28,4 @@ author:
|
|||||||
|
|
||||||
|
|
||||||
typekitID: msu4qap
|
typekitID: msu4qap
|
||||||
itemsPerPage: 15
|
itemsPerPage: 10
|
||||||
|
@ -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,
|
||||||
|
@ -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",
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
@import 'mixins';
|
@import 'variables';
|
||||||
|
|
||||||
.lead {
|
.lead {
|
||||||
@include lead();
|
font-size: $font-size-large;
|
||||||
}
|
}
|
||||||
|
@ -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;
|
||||||
|
@ -8,14 +8,14 @@ const Pagination = ({ pageContext }) => {
|
|||||||
|
|
||||||
return (
|
return (
|
||||||
<div className={styles.pagination}>
|
<div className={styles.pagination}>
|
||||||
{previousPagePath ? (
|
|
||||||
<Link className={styles.paginationLink} to={previousPagePath}>
|
|
||||||
« Newer Posts
|
|
||||||
</Link>
|
|
||||||
) : null}
|
|
||||||
{nextPagePath ? (
|
{nextPagePath ? (
|
||||||
<Link className={styles.paginationLink} to={nextPagePath}>
|
<Link className={styles.paginationLink} to={nextPagePath}>
|
||||||
Older Posts »
|
« Older Posts
|
||||||
|
</Link>
|
||||||
|
) : null}
|
||||||
|
{previousPagePath ? (
|
||||||
|
<Link className={styles.paginationLink} to={previousPagePath}>
|
||||||
|
Newer Posts »
|
||||||
</Link>
|
</Link>
|
||||||
) : null}
|
) : null}
|
||||||
</div>
|
</div>
|
||||||
|
@ -13,4 +13,8 @@
|
|||||||
&:last-child {
|
&:last-child {
|
||||||
text-align: right;
|
text-align: right;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&:only-child {
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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>
|
||||||
)
|
)
|
||||||
|
@ -16,3 +16,8 @@
|
|||||||
display: block;
|
display: block;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.pageTitle {
|
||||||
|
composes: archiveTitle from '../templates/Posts.module.scss';
|
||||||
|
margin-bottom: $spacer * 2;
|
||||||
|
}
|
||||||
|
@ -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
|
||||||
/////////////////////////////////////
|
/////////////////////////////////////
|
||||||
|
|
||||||
|
@ -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")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
`
|
|
@ -1,9 +0,0 @@
|
|||||||
@import 'variables';
|
|
||||||
@import 'mixins';
|
|
||||||
|
|
||||||
.archiveTitle {
|
|
||||||
@include heading-band();
|
|
||||||
|
|
||||||
font-size: $font-size-h3;
|
|
||||||
margin-top: 0;
|
|
||||||
}
|
|
@ -2,31 +2,9 @@
|
|||||||
@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-bottom: $spacer * 3;
|
||||||
padding-top: $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
|
||||||
|
@ -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
|
||||||
|
@ -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
|
||||||
/////////////////////////////////////
|
/////////////////////////////////////
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user