-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathprsp-viewer.html
55 lines (48 loc) · 2.2 KB
/
prsp-viewer.html
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
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Perspective Viewer</title>
<link rel="stylesheet" crossorigin="anonymous" href="https://cdn.jsdelivr.net/npm/@finos/perspective-viewer/dist/css/pro.css" />
</head>
<body>
<script type="module" src="https://cdn.jsdelivr.net/npm/@finos/perspective/dist/cdn/perspective.js"></script>
<script type="module" src="https://cdn.jsdelivr.net/npm/@finos/perspective-viewer/dist/cdn/perspective-viewer.js"></script>
<script type="module" src="https://cdn.jsdelivr.net/npm/@finos/perspective-viewer-datagrid/dist/cdn/perspective-viewer-datagrid.js"></script>
<script type="module" src="https://cdn.jsdelivr.net/npm/@finos/perspective-viewer-d3fc/dist/cdn/perspective-viewer-d3fc.js"></script>
<style>
#viewer-container {
height: 95vh;
width: 95vw;
display: flex;
justify-content: center;
align-items: center;
}
perspective-viewer {
height: 100%;
width: 100%;
}
</style>
<script type="module">
import perspective from "https://cdn.jsdelivr.net/npm/@finos/[email protected]/dist/cdn/perspective.js";
document.addEventListener("DOMContentLoaded", function() {
async function load_viewer() {
const table_name = "stock_values";
const viewer = document.getElementById("prsp-viewer");
// Connect to the perspective websocket server
const websocket = await perspective.websocket("ws://localhost:8080/websocket");
// Bind the viewer to the perspective table on the server.
// Data transfer between the server and the viewer is optimized via apache arrow;
// exchanging delta changes only.
const server_table = await websocket.open_table(table_name);
await viewer.load(server_table);
}
load_viewer();
});
</script>
<div id="viewer-container">
<perspective-viewer id="prsp-viewer" theme="Pro Dark"></perspective-viewer>
</div>
</body>
</html>