-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmakeThumbnails.js
106 lines (92 loc) · 2.89 KB
/
makeThumbnails.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
96
97
98
99
100
101
102
103
104
105
106
const path = require('path')
, fs = require('fs')
, Webpack = require('webpack')
, WebpackDevServer = require('webpack-dev-server');
const config = require('./webpack.config.dev')
, compiler = Webpack(config)
, devServerOptions = {
...config.devServer,
open: false,
client: {
logging: 'none'
}
}
, server = new WebpackDevServer(devServerOptions, compiler);
const puppeteer = require('puppeteer');
const visualizationsMetas = require('./src/data/viz.json');
const vizList = Object.keys(visualizationsMetas);
const langFlags = ['fr', 'en'];
const basePath = path.join(__dirname, 'public');
[
path.join(basePath, 'thumbnails'),
path.join(basePath, 'thumbnails', 'fr'),
path.join(basePath, 'thumbnails', 'en')
].forEach((pathToLangDir) => {
if (fs.existsSync(pathToLangDir) === false) {
fs.mkdirSync(pathToLangDir);
}
});
function delay(time) {
return new Promise(function(resolve) {
setTimeout(resolve, time)
});
}
(async () => {
console.log('preparation');
await server.start();
const browser = await puppeteer.launch({
// headless: false
});
console.log('launch');
for (const vizId of vizList) {
console.log('screenshot for ', vizId);
for (const lang of langFlags) {
const page = await browser.newPage();
await page.setViewport({
width: 1200,
height: 800,
deviceScaleFactor: 1,
});
const pathToSave = path.join(basePath, 'thumbnails', lang, `${vizId}.png`)
const url = `http://localhost:${devServerOptions.port}/#/${lang}/visualization/${vizId}`;
console.log('goto', url);
await page.goto(url);
await delay(2000);
try {
await page.waitForSelector('.viz-render', {
visible: true,
timeout: 5000 // five seconds
});
} catch (error) {
console.log('failed');
await page.close();
continue;
}
await page.screenshot({
path: pathToSave,
fullPage: true
});
await page.close();
console.log('done');
}
}
const homePage = await browser.newPage();
console.log('screenshot for ', 'social networks');
try {
await homePage.setViewport({
width: 1905,
height: 952,
deviceScaleFactor: 1,
});
await homePage.goto(`http://localhost:${devServerOptions.port}/#/fr/`);
} catch (error) {
console.log('failed');
await page.close();
}
await homePage.screenshot({
path: path.join(basePath, 'thumbnails', `dunkerque-rs.png`),
fullPage: false
});
await browser.close();
await server.stop();
})();