upstream #1
@ -1,5 +1,6 @@
|
|||||||
const fs = require('fs')
|
const fs = require('fs')
|
||||||
const globby = require('globby')
|
const globby = require('globby')
|
||||||
|
const matter = require('gray-matter')
|
||||||
const prettier = require('prettier')
|
const prettier = require('prettier')
|
||||||
const siteMetadata = require('../data/siteMetadata')
|
const siteMetadata = require('../data/siteMetadata')
|
||||||
|
|
||||||
@ -7,10 +8,12 @@ const siteMetadata = require('../data/siteMetadata')
|
|||||||
const prettierConfig = await prettier.resolveConfig('./.prettierrc.js')
|
const prettierConfig = await prettier.resolveConfig('./.prettierrc.js')
|
||||||
const pages = await globby([
|
const pages = await globby([
|
||||||
'pages/*.js',
|
'pages/*.js',
|
||||||
|
'pages/*.tsx',
|
||||||
'data/blog/**/*.mdx',
|
'data/blog/**/*.mdx',
|
||||||
'data/blog/**/*.md',
|
'data/blog/**/*.md',
|
||||||
'public/tags/**/*.xml',
|
'public/tags/**/*.xml',
|
||||||
'!pages/_*.js',
|
'!pages/_*.js',
|
||||||
|
'!pages/_*.tsx',
|
||||||
'!pages/api',
|
'!pages/api',
|
||||||
])
|
])
|
||||||
|
|
||||||
@ -19,16 +22,26 @@ const siteMetadata = require('../data/siteMetadata')
|
|||||||
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
|
<urlset xmlns="http://www.sitemaps.org/schemas/sitemap/0.9">
|
||||||
${pages
|
${pages
|
||||||
.map((page) => {
|
.map((page) => {
|
||||||
|
// Exclude drafts from the sitemap
|
||||||
|
if (page.search('.md') >= 1 && fs.existsSync(page)) {
|
||||||
|
const source = fs.readFileSync(page, 'utf8')
|
||||||
|
const fm = matter(source)
|
||||||
|
if (fm.data.draft) {
|
||||||
|
return
|
||||||
|
}
|
||||||
|
}
|
||||||
const path = page
|
const path = page
|
||||||
.replace('pages/', '/')
|
.replace('pages/', '/')
|
||||||
.replace('data/blog', '/blog')
|
.replace('data/blog', '/blog')
|
||||||
.replace('public/', '/')
|
.replace('public/', '/')
|
||||||
.replace('.js', '')
|
.replace('.js', '')
|
||||||
|
.replace('.tsx', '')
|
||||||
.replace('.mdx', '')
|
.replace('.mdx', '')
|
||||||
.replace('.md', '')
|
.replace('.md', '')
|
||||||
.replace('/feed.xml', '')
|
.replace('/feed.xml', '')
|
||||||
const route = path === '/index' ? '' : path
|
const route = path === '/index' ? '' : path
|
||||||
if (page === `pages/404.js` || page === `pages/blog/[...slug].js`) {
|
|
||||||
|
if (page.search('pages/404.') > -1 || page.search(`pages/blog/[...slug].`) > -1) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
return `
|
return `
|
||||||
|
Loading…
x
Reference in New Issue
Block a user