mirror of
https://github.com/kremalicious/blog.git
synced 2024-06-26 11:16:25 +02:00
86 lines
1.8 KiB
JavaScript
86 lines
1.8 KiB
JavaScript
import React from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import { graphql, Link } from 'gatsby'
|
|
import Image from '../components/atoms/Image'
|
|
import Page from '../templates/Page'
|
|
|
|
import styles from './photos.module.scss'
|
|
|
|
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 }) => {
|
|
const { title, image } = node.frontmatter
|
|
const { slug } = node.fields
|
|
|
|
return (
|
|
<article className={styles.photo} key={node.id}>
|
|
{image && (
|
|
<Link to={slug}>
|
|
<Image fluid={image.childImageSharp.fluid} alt={title} />
|
|
</Link>
|
|
)}
|
|
</article>
|
|
)
|
|
})
|
|
|
|
return (
|
|
<Page
|
|
title={page.frontmatter.title}
|
|
post={page}
|
|
location={location}
|
|
section={styles.photos}
|
|
>
|
|
{PhotoThumbs}
|
|
</Page>
|
|
)
|
|
}
|
|
|
|
Photos.propTypes = {
|
|
location: PropTypes.object.isRequired,
|
|
data: PropTypes.object
|
|
}
|
|
|
|
export default Photos
|
|
|
|
export const photosQuery = graphql`
|
|
query {
|
|
photos: allMarkdownRemark(
|
|
filter: { frontmatter: { type: { eq: "photo" } } }
|
|
sort: { order: DESC, fields: [fields___date] }
|
|
) {
|
|
edges {
|
|
node {
|
|
id
|
|
frontmatter {
|
|
title
|
|
type
|
|
image {
|
|
childImageSharp {
|
|
fluid(
|
|
maxWidth: 400
|
|
maxHeight: 400
|
|
quality: 85
|
|
cropFocus: CENTER
|
|
) {
|
|
...GatsbyImageSharpFluid_withWebp
|
|
}
|
|
}
|
|
}
|
|
}
|
|
fields {
|
|
slug
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
`
|