2018-11-09 18:08:48 +01:00
|
|
|
'use strict';
|
|
|
|
|
|
|
|
const path = require('path');
|
|
|
|
const siteConfig = require('../../config.js');
|
|
|
|
|
|
|
|
module.exports = async (graphql, actions) => {
|
|
|
|
const { createPage } = actions;
|
|
|
|
|
|
|
|
const result = await graphql(`
|
|
|
|
{
|
|
|
|
allMarkdownRemark(
|
|
|
|
filter: { frontmatter: { layout: { eq: "post" }, draft: { ne: true } } }
|
|
|
|
) { totalCount }
|
|
|
|
}
|
|
|
|
`);
|
|
|
|
|
2018-11-11 12:19:06 +01:00
|
|
|
const { postsPerPage } = siteConfig;
|
|
|
|
const numPages = Math.ceil(result.data.allMarkdownRemark.totalCount / postsPerPage);
|
2018-11-09 18:08:48 +01:00
|
|
|
|
|
|
|
for (let i = 0; i < numPages; i += 1) {
|
|
|
|
createPage({
|
|
|
|
path: i === 0 ? '/' : `/page/${i}`,
|
|
|
|
component: path.resolve('./src/templates/index-template.js'),
|
|
|
|
context: {
|
2018-11-11 12:19:06 +01:00
|
|
|
currentPage: i,
|
|
|
|
postsLimit: postsPerPage,
|
|
|
|
postsOffset: i * postsPerPage,
|
|
|
|
prevPagePath: i <= 1 ? '/' : `/page/${i - 1}`,
|
|
|
|
nextPagePath: `/page/${i + 1}`,
|
|
|
|
hasPrevPage: i !== 0,
|
|
|
|
hasNextPage: i !== numPages - 1
|
2018-11-09 18:08:48 +01:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
};
|