mirror of
https://github.com/kremalicious/blog.git
synced 2025-01-05 11:25:07 +01:00
cleanup location
This commit is contained in:
parent
44bf9b24a7
commit
569b6cb35d
@ -81,7 +81,7 @@ exports.onPostBuild = async ({ graphql }) => {
|
|||||||
// JSON Feed query
|
// JSON Feed query
|
||||||
const result = await graphql(`
|
const result = await graphql(`
|
||||||
{
|
{
|
||||||
allMarkdownRemark {
|
allMarkdownRemark(sort: { order: DESC, fields: [fields___date] }) {
|
||||||
edges {
|
edges {
|
||||||
node {
|
node {
|
||||||
html
|
html
|
||||||
|
@ -1,7 +1,9 @@
|
|||||||
const path = require('path')
|
const path = require('path')
|
||||||
const archiveTemplate = path.resolve('src/components/templates/Posts.tsx')
|
|
||||||
const { itemsPerPage } = require('../config')
|
const { itemsPerPage } = require('../config')
|
||||||
|
|
||||||
|
const postTemplate = path.resolve('src/components/templates/Post/index.tsx')
|
||||||
|
const archiveTemplate = path.resolve('src/components/templates/Archive.tsx')
|
||||||
|
|
||||||
const redirects = [
|
const redirects = [
|
||||||
{ f: '/feed', t: '/feed.xml' },
|
{ f: '/feed', t: '/feed.xml' },
|
||||||
{ f: '/feed/', t: '/feed.xml' },
|
{ f: '/feed/', t: '/feed.xml' },
|
||||||
@ -24,8 +26,6 @@ function getPaginationData(i, numPages, slug) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
exports.generatePostPages = (createPage, posts) => {
|
exports.generatePostPages = (createPage, posts) => {
|
||||||
const postTemplate = path.resolve('src/components/templates/Post/index.tsx')
|
|
||||||
|
|
||||||
// Create Post pages
|
// Create Post pages
|
||||||
posts.forEach((post) => {
|
posts.forEach((post) => {
|
||||||
createPage({
|
createPage({
|
||||||
|
@ -35,7 +35,7 @@ async function jsonItems(posts) {
|
|||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
const createJsonFeed = (posts) => ({
|
const createJsonFeed = async (posts) => ({
|
||||||
version: 'https://jsonfeed.org/version/1',
|
version: 'https://jsonfeed.org/version/1',
|
||||||
title: siteTitle,
|
title: siteTitle,
|
||||||
description: siteDescription,
|
description: siteDescription,
|
||||||
@ -49,19 +49,18 @@ const createJsonFeed = (posts) => ({
|
|||||||
name: author.name,
|
name: author.name,
|
||||||
url: author.uri
|
url: author.uri
|
||||||
},
|
},
|
||||||
items: jsonItems(posts)
|
items: await jsonItems(posts)
|
||||||
})
|
})
|
||||||
|
|
||||||
const generateJsonFeed = async (posts) => {
|
const generateJsonFeed = async (posts) => {
|
||||||
await writeFile(
|
await writeFile(
|
||||||
path.join('./public', 'feed.json'),
|
path.join('./public', 'feed.json'),
|
||||||
JSON.stringify(createJsonFeed(posts)),
|
JSON.stringify(await createJsonFeed(posts)),
|
||||||
'utf8'
|
'utf8'
|
||||||
).catch((err) => {
|
).catch((err) => {
|
||||||
throw Error('\nFailed to write JSON Feed file: ', err)
|
throw Error('\nFailed to write JSON Feed file: ', err)
|
||||||
})
|
})
|
||||||
|
|
||||||
// eslint-disable-next-line no-console
|
|
||||||
console.log('\nsuccess Generating JSON feed')
|
console.log('\nsuccess Generating JSON feed')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -11,12 +11,7 @@ import styles from './Layout.module.scss'
|
|||||||
// whyDidYouRender(React)
|
// whyDidYouRender(React)
|
||||||
// }
|
// }
|
||||||
|
|
||||||
export default function Layout({
|
export default function Layout({ children }: { children: any }): ReactElement {
|
||||||
children
|
|
||||||
}: {
|
|
||||||
location?: Location
|
|
||||||
children: any
|
|
||||||
}): ReactElement {
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<Typekit />
|
<Typekit />
|
||||||
|
@ -10,10 +10,6 @@ export const postTeaserQuery = graphql`
|
|||||||
fileAbsolutePath
|
fileAbsolutePath
|
||||||
frontmatter {
|
frontmatter {
|
||||||
title
|
title
|
||||||
type
|
|
||||||
linkurl
|
|
||||||
tags
|
|
||||||
featured
|
|
||||||
image {
|
image {
|
||||||
childImageSharp {
|
childImageSharp {
|
||||||
...ImageFluidThumb
|
...ImageFluidThumb
|
||||||
@ -22,7 +18,6 @@ export const postTeaserQuery = graphql`
|
|||||||
}
|
}
|
||||||
fields {
|
fields {
|
||||||
slug
|
slug
|
||||||
date(formatString: "MMMM DD, YYYY")
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
`
|
`
|
||||||
@ -31,7 +26,7 @@ export default function PostTeaser({
|
|||||||
post,
|
post,
|
||||||
toggleSearch
|
toggleSearch
|
||||||
}: {
|
}: {
|
||||||
post: Post
|
post: Partial<Post>
|
||||||
toggleSearch?: () => void
|
toggleSearch?: () => void
|
||||||
}): ReactElement {
|
}): ReactElement {
|
||||||
const { image, title } = post.frontmatter
|
const { image, title } = post.frontmatter
|
||||||
|
@ -1,13 +1,10 @@
|
|||||||
import React from 'react'
|
import React from 'react'
|
||||||
import { render } from '@testing-library/react'
|
import { render } from '@testing-library/react'
|
||||||
import { createHistory, createMemorySource } from '@reach/router'
|
|
||||||
|
|
||||||
import Archive from './Archive'
|
import Archive from './Archive'
|
||||||
import data from '../../../jest/__fixtures__/posts.json'
|
import data from '../../../jest/__fixtures__/posts.json'
|
||||||
|
|
||||||
describe('Archive', () => {
|
describe('Archive', () => {
|
||||||
const history = createHistory(createMemorySource('/photos'))
|
|
||||||
|
|
||||||
const pageContext = {
|
const pageContext = {
|
||||||
tag: 'hello',
|
tag: 'hello',
|
||||||
slug: '/hello',
|
slug: '/hello',
|
||||||
@ -17,11 +14,7 @@ describe('Archive', () => {
|
|||||||
|
|
||||||
it('renders without crashing', () => {
|
it('renders without crashing', () => {
|
||||||
const { container } = render(
|
const { container } = render(
|
||||||
<Archive
|
<Archive data={data} pageContext={pageContext} />
|
||||||
data={data}
|
|
||||||
pageContext={pageContext}
|
|
||||||
location={history.location}
|
|
||||||
/>
|
|
||||||
)
|
)
|
||||||
expect(container.firstChild).toBeInTheDocument()
|
expect(container.firstChild).toBeInTheDocument()
|
||||||
})
|
})
|
||||||
|
@ -8,16 +8,14 @@ import PostContent from './Post/Content'
|
|||||||
import PostMore from './Post/More'
|
import PostMore from './Post/More'
|
||||||
import PostLinkActions from './Post/LinkActions'
|
import PostLinkActions from './Post/LinkActions'
|
||||||
import SEO from '../atoms/SEO'
|
import SEO from '../atoms/SEO'
|
||||||
import styles from './Posts.module.scss'
|
import styles from './Archive.module.scss'
|
||||||
import { Image } from '../atoms/Image'
|
import { Image } from '../atoms/Image'
|
||||||
|
|
||||||
export default function Archive({
|
export default function Archive({
|
||||||
data,
|
data,
|
||||||
location,
|
|
||||||
pageContext
|
pageContext
|
||||||
}: {
|
}: {
|
||||||
data: any
|
data: any
|
||||||
location: Location
|
|
||||||
pageContext: {
|
pageContext: {
|
||||||
tag: string
|
tag: string
|
||||||
slug: string
|
slug: string
|
||||||
|
@ -1,6 +1,6 @@
|
|||||||
@import 'variables';
|
@import 'variables';
|
||||||
|
|
||||||
.pageTitle {
|
.pageTitle {
|
||||||
composes: archivetitle from './Posts.module.scss';
|
composes: archivetitle from './Archive.module.scss';
|
||||||
margin-bottom: $spacer * 2;
|
margin-bottom: $spacer * 2;
|
||||||
}
|
}
|
||||||
|
@ -1,12 +1,12 @@
|
|||||||
import React, { ReactElement } from 'react'
|
import React, { ReactElement } from 'react'
|
||||||
import { Helmet } from 'react-helmet'
|
import { Helmet } from 'react-helmet'
|
||||||
|
import { useLocation } from '@reach/router'
|
||||||
import { Post } from '../../@types/Post'
|
import { Post } from '../../@types/Post'
|
||||||
import SEO from '../atoms/SEO'
|
import SEO from '../atoms/SEO'
|
||||||
import styles from './Page.module.scss'
|
import styles from './Page.module.scss'
|
||||||
|
|
||||||
export default function Page({
|
export default function Page({
|
||||||
title,
|
title,
|
||||||
location,
|
|
||||||
section,
|
section,
|
||||||
children,
|
children,
|
||||||
post
|
post
|
||||||
@ -14,13 +14,14 @@ export default function Page({
|
|||||||
title: string
|
title: string
|
||||||
children: any
|
children: any
|
||||||
section?: string
|
section?: string
|
||||||
location: Location
|
|
||||||
post?: Post
|
post?: Post
|
||||||
}): ReactElement {
|
}): ReactElement {
|
||||||
|
const { pathname } = useLocation()
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<>
|
<>
|
||||||
<Helmet title={title} />
|
<Helmet title={title} />
|
||||||
<SEO slug={location.pathname} postSEO post={post} />
|
<SEO slug={pathname} postSEO post={post} />
|
||||||
|
|
||||||
<h1 className={styles.pageTitle}>{title}</h1>
|
<h1 className={styles.pageTitle}>{title}</h1>
|
||||||
{section ? <section className={section}>{children}</section> : children}
|
{section ? <section className={section}>{children}</section> : children}
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import React, { ReactElement } from 'react'
|
import React, { ReactElement } from 'react'
|
||||||
import { Link } from 'gatsby'
|
import { Link, PageProps } from 'gatsby'
|
||||||
import Page from '../components/templates/Page'
|
import Page from '../components/templates/Page'
|
||||||
import styles from './404.module.scss'
|
import styles from './404.module.scss'
|
||||||
|
|
||||||
@ -9,14 +9,12 @@ const page = {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
const NotFound = ({ location }: { location: Location }): ReactElement => (
|
const NotFound = (props: PageProps): ReactElement => (
|
||||||
<Page title={page.frontmatter.title} post={page} location={location}>
|
<Page title={page.frontmatter.title} post={page}>
|
||||||
<div className={styles.hal9000} />
|
<div className={styles.hal9000} />
|
||||||
|
|
||||||
<div className={styles.wrapper}>
|
<div className={styles.wrapper}>
|
||||||
{/* eslint-disable-next-line quotes */}
|
|
||||||
<h1 className={styles.title}>{"I'm sorry Dave"}</h1>{' '}
|
<h1 className={styles.title}>{"I'm sorry Dave"}</h1>{' '}
|
||||||
{/* eslint-disable-next-line quotes */}
|
|
||||||
<p className={styles.text}>{"I'm afraid I can't do that"}</p>
|
<p className={styles.text}>{"I'm afraid I can't do that"}</p>
|
||||||
<Link to={'/'}>Back to homepage</Link>
|
<Link to={'/'}>Back to homepage</Link>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import React, { ReactElement } from 'react'
|
import React, { ReactElement } from 'react'
|
||||||
import { graphql, Link } from 'gatsby'
|
import { graphql, Link, PageProps } from 'gatsby'
|
||||||
import Page from '../components/templates/Page'
|
import Page from '../components/templates/Page'
|
||||||
import { Post } from '../@types/Post'
|
import { Post } from '../@types/Post'
|
||||||
import { Image } from '../components/atoms/Image'
|
import { Image } from '../components/atoms/Image'
|
||||||
@ -13,20 +13,9 @@ const page = {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function Home({
|
export default function Home(props: PageProps): ReactElement {
|
||||||
data,
|
|
||||||
location
|
|
||||||
}: {
|
|
||||||
data: any
|
|
||||||
location: Location
|
|
||||||
}): ReactElement {
|
|
||||||
return (
|
return (
|
||||||
<Page
|
<Page title={page.frontmatter.title} post={page} section={styles.home}>
|
||||||
title={page.frontmatter.title}
|
|
||||||
post={page}
|
|
||||||
location={location}
|
|
||||||
section={styles.home}
|
|
||||||
>
|
|
||||||
<Featured />
|
<Featured />
|
||||||
Latest Posts & Links
|
Latest Posts & Links
|
||||||
<br />
|
<br />
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import React, { ReactElement } from 'react'
|
import React, { ReactElement } from 'react'
|
||||||
import { graphql, Link } from 'gatsby'
|
import { graphql, Link, PageProps } from 'gatsby'
|
||||||
import Page from '../components/templates/Page'
|
import Page from '../components/templates/Page'
|
||||||
import { Post } from '../@types/Post'
|
import { Post } from '../@types/Post'
|
||||||
import { Image } from '../components/atoms/Image'
|
import { Image } from '../components/atoms/Image'
|
||||||
@ -28,21 +28,10 @@ const PhotoThumb = ({ photo }: { photo: Post }): ReactElement => {
|
|||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
||||||
export default function Photos({
|
export default function Photos(props: PageProps): ReactElement {
|
||||||
data,
|
|
||||||
location
|
|
||||||
}: {
|
|
||||||
data: any
|
|
||||||
location: Location
|
|
||||||
}): ReactElement {
|
|
||||||
return (
|
return (
|
||||||
<Page
|
<Page title={page.frontmatter.title} post={page} section={styles.photos}>
|
||||||
title={page.frontmatter.title}
|
{(props.data as any).photos.edges.map(({ node }: { node: Post }) => (
|
||||||
post={page}
|
|
||||||
location={location}
|
|
||||||
section={styles.photos}
|
|
||||||
>
|
|
||||||
{data.photos.edges.map(({ node }: { node: Post }) => (
|
|
||||||
<PhotoThumb key={node.id} photo={node} />
|
<PhotoThumb key={node.id} photo={node} />
|
||||||
))}
|
))}
|
||||||
</Page>
|
</Page>
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
import React, { ReactElement } from 'react'
|
import React, { ReactElement } from 'react'
|
||||||
import { graphql } from 'gatsby'
|
import { graphql, PageProps } from 'gatsby'
|
||||||
import Page from '../components/templates/Page'
|
import Page from '../components/templates/Page'
|
||||||
import Tag from '../components/atoms/Tag'
|
import Tag from '../components/atoms/Tag'
|
||||||
import styles from './tags.module.scss'
|
import styles from './tags.module.scss'
|
||||||
@ -16,15 +16,14 @@ interface Tag {
|
|||||||
totalCount: number
|
totalCount: number
|
||||||
}
|
}
|
||||||
|
|
||||||
interface TagsPageProps {
|
interface TagsPageProps extends PageProps {
|
||||||
data: {
|
data: {
|
||||||
allMarkdownRemark: { group: Tag[] }
|
allMarkdownRemark: { group: Tag[] }
|
||||||
}
|
}
|
||||||
location: Location
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const TagsPage = ({ data, location }: TagsPageProps): ReactElement => (
|
const TagsPage = ({ data }: TagsPageProps): ReactElement => (
|
||||||
<Page title={page.frontmatter.title} location={location} post={page}>
|
<Page title={page.frontmatter.title} post={page}>
|
||||||
<ul className={styles.tags}>
|
<ul className={styles.tags}>
|
||||||
{data.allMarkdownRemark.group
|
{data.allMarkdownRemark.group
|
||||||
.sort((a, b) => b.totalCount - a.totalCount)
|
.sort((a, b) => b.totalCount - a.totalCount)
|
||||||
|
Loading…
Reference in New Issue
Block a user