-
-
Notifications
You must be signed in to change notification settings - Fork 1.9k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #6083 from plotly/regl-build-setup
Provide regl-based traces in the strict bundle
- Loading branch information
Showing
54 changed files
with
24,216 additions
and
155 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,160 @@ | ||
'use strict'; | ||
|
||
/* global Plotly:false */ | ||
|
||
var mocks = require('../../build/test_dashboard_mocks.json'); | ||
var reglTraces = require('../../build/regl_traces.json'); | ||
var Lib = require('@src/lib'); | ||
|
||
// Our gracious testing object | ||
var Tabs = { | ||
|
||
// Return the specified plot container (or default one) | ||
getGraph: function(id) { | ||
id = id || 'graph'; | ||
return document.getElementById(id); | ||
}, | ||
|
||
// Create a new plot container | ||
fresh: function(id) { | ||
id = id || 'graph'; | ||
|
||
var graphDiv = Tabs.getGraph(id); | ||
|
||
if(graphDiv) { | ||
graphDiv.parentNode.removeChild(graphDiv); | ||
} | ||
|
||
graphDiv = document.createElement('div'); | ||
graphDiv.className = 'dashboard-plot'; | ||
graphDiv.id = id; | ||
|
||
var plotArea = document.getElementById('plots'); | ||
plotArea.appendChild(graphDiv); | ||
|
||
return graphDiv; | ||
}, | ||
|
||
// Plot a mock by name (without .json) to the default or specified container | ||
plotMock: function(mockName, id) { | ||
return new Promise(function(res) { | ||
var mockURL = '/test/image/mocks/' + mockName + '.json'; | ||
|
||
console.warn('Plotting:', mockURL); | ||
|
||
var request = new XMLHttpRequest(); | ||
request.open('GET', mockURL, true); | ||
request.responseType = ''; | ||
request.send(); | ||
|
||
request.onreadystatechange = function() { | ||
if(this.readyState === 4) { | ||
if(this.status === 200) { | ||
var fig = JSON.parse(this.responseText); | ||
var graphDiv = Tabs.fresh(id); | ||
|
||
Plotly.newPlot(graphDiv, fig); | ||
|
||
graphDiv.on('plotly_afterplot', function() { | ||
res(graphDiv); | ||
}); | ||
} else { | ||
console.error(this.statusText); | ||
} | ||
} | ||
}; | ||
}); | ||
}, | ||
}; | ||
|
||
|
||
// Bind things to the window | ||
window.Tabs = Tabs; | ||
window.Lib = Lib; | ||
window.onload = handleOnLoad; | ||
setInterval(function() { | ||
window.gd = Tabs.getGraph() || Tabs.fresh(); | ||
window.fullLayout = window.gd._fullLayout; | ||
window.fullData = window.gd._fullData; | ||
}, 1000); | ||
|
||
var mocksList = document.getElementById('mocks-list'); | ||
|
||
function handleOnLoad() { | ||
var mocksByReglTrace = {}; | ||
|
||
reglTraces.forEach(function(trace) { | ||
mocksByReglTrace[trace] = []; | ||
mocks.forEach(function(mock) { | ||
if(mock.keywords.indexOf(trace) !== -1) { | ||
mocksByReglTrace[trace].push(mock); | ||
} | ||
}); | ||
}); | ||
|
||
Object.keys(mocksByReglTrace).forEach(function(trace) { | ||
var thisMocks = mocksByReglTrace[trace]; | ||
var div = document.createElement('div'); | ||
div.className = 'mock-group'; | ||
div.innerHTML = '<h3>' + trace + '</h3>'; | ||
mocksList.appendChild(div); | ||
thisMocks.forEach(function(mock) { | ||
var a = document.createElement('a'); | ||
a.className = 'mock-link'; | ||
a.innerHTML = mock.name; | ||
a.href = '#' + mock.name; | ||
a.onclick = function() { | ||
Tabs.plotMock(this.innerHTML); | ||
}; | ||
div.appendChild(a); | ||
div.appendChild(document.createElement('br')); | ||
}); | ||
}); | ||
|
||
// visit the mocks one by one. | ||
return Object.keys(mocksByReglTrace).reduce(function(p, trace) { | ||
return p.then(function() { | ||
var thisMocks = mocksByReglTrace[trace]; | ||
var generated = {}; | ||
|
||
return thisMocks.reduce(function(p, mock) { | ||
return p.then(function() { | ||
return Tabs.plotMock(mock.name).then(function(gd) { | ||
var fullLayout = gd._fullLayout; | ||
fullLayout._glcanvas.each(function(d) { | ||
if(d.regl) { | ||
console.log('found regl', d.regl); | ||
var cachedCode = d.regl.getCachedCode(); | ||
Object.entries(cachedCode).forEach(function(kv) { | ||
generated[kv[0]] = kv[1].toString(); | ||
}); | ||
console.log('merging entries', Object.keys(cachedCode)); | ||
} | ||
}); | ||
}); | ||
}); | ||
}, Promise.resolve()) | ||
.then(function() { | ||
console.log(window.__regl_codegen_cache); | ||
var body = JSON.stringify({ | ||
generated: generated, | ||
trace: trace | ||
}); | ||
window.__regl_codegen_cache = {}; | ||
return fetch('/api/submit-code', { | ||
method: 'POST', | ||
headers: { | ||
'Content-Type': 'application/json' | ||
}, | ||
body: body | ||
}); | ||
}); | ||
}); | ||
}, Promise.resolve()) | ||
.then(function() { | ||
return fetch('/api/codegen-done'); | ||
}) | ||
.then(function() { | ||
window.close(); | ||
}); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
<!DOCTYPE html> | ||
<html> | ||
<head> | ||
<title>REGL Codegen</title> | ||
<link rel="stylesheet" type="text/css" href="//fonts.googleapis.com/css?family=Open+Sans:600,400,300,200|Droid+Sans|PT+Sans+Narrow|Gravitas+One|Droid+Sans+Mono|Droid+Serif|Raleway|Old+Standard+TT"/> | ||
<link rel="stylesheet" type="text/css" href="../test_dashboard/style.css"> | ||
</head> | ||
<body> | ||
<section id="mocks-list"></section> | ||
<div id="plots"> | ||
<div id="graph"></div> | ||
</div> | ||
<div id="snapshot"></div> | ||
|
||
<script src="../../node_modules/mathjax/MathJax.js?config=TeX-AMS-MML_SVG"></script> | ||
<script charset="utf-8" id="source" type="module">import "../../build/plotly.js"</script> | ||
<script charset="utf-8" src="../../build/regl_codegen-bundle.js"></script> | ||
</body> | ||
</html> |
Oops, something went wrong.