Skip to content

Commit

Permalink
Fix incorrect placements of plots
Browse files Browse the repository at this point in the history
The `element` variable is reassigned on every cell - so any asynchronous code will claim the wrong value.

Fixes gh-34
  • Loading branch information
eric-wieser committed Oct 31, 2019
1 parent 97c2524 commit 4ebfabd
Showing 1 changed file with 37 additions and 34 deletions.
71 changes: 37 additions & 34 deletions pyganja/script_api.py
Original file line number Diff line number Diff line change
Expand Up @@ -67,40 +67,43 @@ def generate_notebook_js(script_json, sig=None, grid=True, scale=1.0, gl=True):
)
js = read_ganja()
js += """
requirejs(['Algebra'], function(Algebra) {
var opts = """ + json.dumps(opts) + """; // injected from python
var output = Algebra({p: opts.p, q: opts.q, r: opts.r, baseType: Float64Array}).inline((opts)=>{
var data = """ + script_json + """; // injected from python
// When we get a file, we load and display.
var canvas;
var h=0, p=0;
// convert arrays of floats back to CGA elements.
data = data.map(x=>x.length==opts.mv_length?new Element(x):x);
// add the graph to the page.
canvas = this.graph(data, {gl: opts.gl, conformal: opts.conformal, grid: opts.grid, scale: opts.scale, useUnnaturalLineDisplayForPointPairs: true});
canvas.options.h = h; canvas.options.p = p;
// make it big.
canvas.style.width = '100%';
canvas.style.height = '50vh';
return canvas;
})(opts);
element.append(output);
var a = document.createElement("button");
var t = document.createTextNode("\N{FLOPPY DISK} Save");
a.appendChild(t);
function screenshot(){
//output.width = 1920; output.height = 1080;
output.update(output.value);
output.toBlob(function(blob) {
var url = URL.createObjectURL(blob);
window.open(url, '_blank');
});
}
a.onclick = screenshot
var butnelem = element.append(a);
});
// take a closure on element before the next cell replaces it
(function(element) {
requirejs(['Algebra'], function(Algebra) {
var opts = """ + json.dumps(opts) + """; // injected from python
var output = Algebra({p: opts.p, q: opts.q, r: opts.r, baseType: Float64Array}).inline((opts)=>{
var data = """ + script_json + """; // injected from python
// When we get a file, we load and display.
var canvas;
var h=0, p=0;
// convert arrays of floats back to CGA elements.
data = data.map(x=>x.length==opts.mv_length?new Element(x):x);
// add the graph to the page.
canvas = this.graph(data, {gl: opts.gl, conformal: opts.conformal, grid: opts.grid, scale: opts.scale, useUnnaturalLineDisplayForPointPairs: true});
canvas.options.h = h; canvas.options.p = p;
// make it big.
canvas.style.width = '100%';
canvas.style.height = '50vh';
return canvas;
})(opts);
element.append(output);
var a = document.createElement("button");
var t = document.createTextNode("\N{FLOPPY DISK} Save");
a.appendChild(t);
function screenshot(){
//output.width = 1920; output.height = 1080;
output.update(output.value);
output.toBlob(function(blob) {
var url = URL.createObjectURL(blob);
window.open(url, '_blank');
});
}
a.onclick = screenshot
var butnelem = element.append(a);
});
})(element);
"""
else:
raise ValueError('Algebra not yet supported')
Expand Down

0 comments on commit 4ebfabd

Please sign in to comment.