UNPKG

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