UNPKG

4.29 kBJavaScriptView Raw
1/* eslint-disable max-len */
2const path = require('path');
3const fs = require('fs');
4
5const _ = require('lodash');
6
7const projectRoot = path.resolve(__dirname, '..');
8const assetsRoot = path.join(projectRoot, 'public');
9
10exports.renderViewer = renderViewer;
11
12/**
13 * Escapes `<` characters in JSON to safely use it in `<script>` tag.
14 */
15function escapeJson(json) {
16 return JSON.stringify(json).replace(/</gu, '\\u003c');
17}
18
19function getAssetContent(filename) {
20 const assetPath = path.join(assetsRoot, filename);
21
22 if (!assetPath.startsWith(assetsRoot)) {
23 throw new Error(`"${filename}" is outside of the assets root`);
24 }
25
26 return fs.readFileSync(assetPath, 'utf8');
27}
28
29function html(strings, ...values) {
30 return strings.map((string, index) => `${string}${values[index] || ''}`).join('');
31}
32
33function getScript(filename, mode) {
34 if (mode === 'static') {
35 return `<!-- ${_.escape(filename)} -->
36<script>${getAssetContent(filename)}</script>`;
37 } else {
38 return `<script src="${_.escape(filename)}"></script>`;
39 }
40}
41
42function renderViewer({title, enableWebSocket, chartData, defaultSizes, mode} = {}) {
43 return html`<!DOCTYPE html>
44<html>
45 <head>
46 <meta charset="UTF-8"/>
47 <meta name="viewport" content="width=device-width, initial-scale=1"/>
48 <title>${_.escape(title)}</title>
49 <link rel="shortcut icon" href="" type="image/x-icon" />
50
51 <script>
52 window.enableWebSocket = ${escapeJson(enableWebSocket)};
53 </script>
54 ${getScript('viewer.js', mode)}
55 </head>
56
57 <body>
58 <div id="app"></div>
59 <script>
60 window.chartData = ${escapeJson(chartData)};
61 window.defaultSizes = ${escapeJson(defaultSizes)};
62 </script>
63 </body>
64</html>`;
65}