2016-06-01 10:04:56 -04:00
|
|
|
window.onload = function() {
|
|
|
|
// Lots of global variables to make debugging easier
|
|
|
|
var vm = new window.VirtualMachine();
|
|
|
|
window.vm = vm;
|
|
|
|
|
|
|
|
var toolbox = document.getElementById('toolbox');
|
|
|
|
var workspace = window.Blockly.inject('blocks', {
|
|
|
|
toolbox: toolbox,
|
|
|
|
media: '../node_modules/scratch-blocks/media/'
|
|
|
|
});
|
|
|
|
window.workspace = workspace;
|
|
|
|
|
2016-06-01 13:54:33 -04:00
|
|
|
// @todo: Also bind to flyout events.
|
2016-06-01 10:04:56 -04:00
|
|
|
// Block events.
|
|
|
|
workspace.addChangeListener(vm.blockListener);
|
|
|
|
|
2016-06-01 10:18:08 -04:00
|
|
|
var explorer = document.getElementById('blockexplorer');
|
|
|
|
workspace.addChangeListener(function() {
|
|
|
|
// On a change, update the block explorer.
|
|
|
|
explorer.innerHTML = JSON.stringify(vm.runtime.blocks, null, 2);
|
2016-06-01 10:47:47 -04:00
|
|
|
window.hljs.highlightBlock(explorer);
|
2016-06-01 10:18:08 -04:00
|
|
|
});
|
|
|
|
|
2016-06-01 13:54:33 -04:00
|
|
|
// Feedback for stacks running.
|
|
|
|
vm.runtime.on('STACK_GLOW_ON', function(blockId) {
|
|
|
|
workspace.glowStack(blockId, true);
|
|
|
|
});
|
|
|
|
vm.runtime.on('STACK_GLOW_OFF', function(blockId) {
|
|
|
|
workspace.glowStack(blockId, false);
|
|
|
|
});
|
|
|
|
|
2016-06-01 10:04:56 -04:00
|
|
|
// Run threads
|
|
|
|
vm.runtime.start();
|
|
|
|
};
|