forked from euglena1215/slide-viewer-gatsby
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgatsby-node.js
95 lines (76 loc) · 2.29 KB
/
gatsby-node.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
'use strict'
const axios = require('axios')
const path = require('path')
const fs = require('fs')
const https = require('https')
async function getAllSlideData() {
const { data: slides } = await axios.get(
`https://script.google.com/macros/s/AKfycbzzea8w5fE91z2yNCoNyoKd2F-c2hReVzb_gGrXEYH9lSL8LAqi/exec`
)
return slides.reverse()
}
exports.onPreBootstrap = async () => {
const allSlide = await getAllSlideData()
let assets = new Set()
allSlide.forEach(slide => {
assets.add([`${slide.fileId}.pdf`, slide.pdfUrl])
assets.add([`${slide.fileId}.png`, slide.imgUrl])
assets.add([`${slide.uploadUser.userId}.png`, slide.uploadUser.imgUrl])
})
const savedDir = './public/assets/'
if (!fs.existsSync(savedDir)) {
fs.mkdirSync(savedDir)
}
Array.from(assets).forEach(asset => {
const fileName = asset[0]
const url = asset[1]
const outFile = fs.createWriteStream(savedDir + fileName)
const req = https.get(url, res => {
res.pipe(outFile)
res.on('end', () => {
outFile.close()
})
})
req.on('error', err => {
console.log('Error: ', err)
return
})
req.end()
})
}
const toSelfHostedSlide = slide => {
slide.pdfUrl = `/assets/${slide.fileId}.pdf`
slide.imgUrl = `/assets/${slide.fileId}.png`
slide.uploadUser.imgUrl = `/assets/${slide.uploadUser.userId}.png`
return slide
}
const castTimestampToDate = slide => {
slide.timestamp = new Date(slide.timestamp * 1000)
return slide
}
exports.createPages = async ({ graphql, actions }) => {
const { createPage } = actions
let allSlide = await getAllSlideData()
allSlide = allSlide.map(toSelfHostedSlide).map(castTimestampToDate)
createPage({
path: `/`,
component: require.resolve('./src/templates/index.tsx'),
context: { allSlide }
})
allSlide.forEach(slide => {
createPage({
path: `/${slide.fileId}/`,
component: require.resolve('./src/templates/slide.tsx'),
context: { slide }
})
})
// User page
Array.from(new Set(allSlide.map(slide => slide.uploadUser))).forEach(user => {
const slides = allSlide.filter(slide => slide.uploadUser.userId === user.userId)
createPage({
path: `/${user.userId}/`,
component: require.resolve('./src/templates/user.tsx'),
context: { user, slides }
})
})
}