1
0
mirror of https://github.com/kremalicious/portfolio.git synced 2025-01-03 18:35:00 +01:00
portfolio/gatsby-node.js

164 lines
3.7 KiB
JavaScript
Raw Normal View History

2019-05-26 17:50:19 +02:00
/* eslint-disable no-console */
2018-04-07 14:18:06 +02:00
const path = require('path')
const remark = require('remark')
const markdown = require('remark-parse')
const html = require('remark-html')
2019-05-26 17:50:19 +02:00
const axios = require('axios')
const fs = require('fs')
const yaml = require('js-yaml')
const reposYaml = yaml.load(fs.readFileSync('./content/repos.yml', 'utf8'))
2019-05-26 22:20:16 +02:00
const { performance } = require('perf_hooks')
const chalk = require('chalk')
function truncate(n, useWordBoundary) {
if (this.length <= n) {
return this
}
const subString = this.substr(0, n - 1)
return (
(useWordBoundary
? subString.substr(0, subString.lastIndexOf(' '))
: subString) + '...'
)
}
2019-05-26 22:55:28 +02:00
//
// Get GitHub repos
//
2019-05-26 17:50:19 +02:00
async function getGithubRepos(data) {
2019-10-10 00:40:57 +02:00
let repos = []
2019-07-04 09:48:48 +02:00
let holder = {}
2019-10-10 00:40:57 +02:00
for (let item of data) {
const user = item.split('/')[0]
const repoName = item.split('/')[1]
const repo = await axios.get(
`https://api.github.com/repos/${user}/${repoName}`,
{ headers: { 'User-Agent': 'kremalicious/portfolio' } }
)
holder.name = repo.data.name
holder.full_name = repo.data.full_name
holder.description = repo.data.description
holder.html_url = repo.data.html_url
holder.homepage = repo.data.homepage
holder.stargazers_count = repo.data.stargazers_count
holder.pushed_at = repo.data.pushed_at
repos.push(holder)
2019-07-04 09:48:48 +02:00
holder = {}
}
2019-10-10 00:40:57 +02:00
// sort by pushed to, newest first
repos = repos.sort((a, b) => b.pushed_at.localeCompare(a.pushed_at))
return repos
2019-05-26 17:50:19 +02:00
}
2019-05-26 22:55:28 +02:00
//
// Get GitHub repos once and store for later build stages
//
2019-05-26 17:50:19 +02:00
let repos
exports.onPreBootstrap = async () => {
2019-05-26 22:20:16 +02:00
const t0 = performance.now()
2019-05-26 17:50:19 +02:00
try {
2019-10-10 00:40:57 +02:00
repos = await getGithubRepos(reposYaml)
2019-05-26 22:20:16 +02:00
const t1 = performance.now()
const ms = t1 - t0
const s = ((ms / 1000) % 60).toFixed(3)
console.log(
chalk.green('success ') + `getGithubRepos: ${repos.length} repos - ${s} s`
)
2019-05-26 17:50:19 +02:00
} catch (error) {
2019-05-26 22:20:16 +02:00
throw Error(error.message)
2019-05-26 17:50:19 +02:00
}
}
2019-05-26 22:55:28 +02:00
//
// Add repos to front page's context
//
exports.onCreatePage = async ({ page, actions }) => {
const { createPage } = actions
if (page.path === '/')
createPage({
...page,
context: {
...page.context,
repos
}
})
}
exports.onCreateNode = ({ node, actions }) => {
const { createNodeField } = actions
// Projects YAML nodes
if (node.internal.type === 'ProjectsYaml') {
// Add transformed Markdown descriptions
const description = node.description
const descriptionWithLineBreaks = description.split('\n').join('\n\n')
let descriptionHtml
remark()
.use(markdown, { gfm: true, commonmark: true, pedantic: true })
.use(html)
.process(descriptionWithLineBreaks, (err, file) => {
if (err) throw Error('Could not transform project description')
descriptionHtml = file.contents
return descriptionHtml
})
createNodeField({
node,
name: 'descriptionHtml',
value: descriptionHtml
})
// Create excerpt from description
const excerpt = truncate.apply(description, [320, true])
createNodeField({
node,
name: 'excerpt',
value: excerpt
})
}
}
2018-04-06 17:24:35 +02:00
2018-06-19 22:48:33 +02:00
//
// Create project pages from projects.yml
//
2018-06-23 21:53:57 +02:00
exports.createPages = async ({ actions, graphql }) => {
const { createPage } = actions
2019-01-04 18:49:39 +01:00
const template = path.resolve('src/templates/Project.jsx')
2018-04-07 14:18:06 +02:00
2019-01-04 18:49:39 +01:00
const result = await graphql(`
{
allProjectsYaml {
edges {
node {
slug
2018-04-07 14:18:06 +02:00
}
}
2019-01-04 18:49:39 +01:00
}
}
`)
2018-04-07 14:18:06 +02:00
2019-01-04 18:49:39 +01:00
if (result.errors) throw result.errors
2018-04-07 14:18:06 +02:00
2019-01-04 18:49:39 +01:00
result.data.allProjectsYaml.edges.forEach(({ node }) => {
const { slug } = node
2018-04-07 14:18:06 +02:00
2019-01-04 18:49:39 +01:00
createPage({
path: slug,
component: template,
context: { slug }
})
2018-04-07 14:18:06 +02:00
})
}