119 lines
3.3 KiB
JavaScript
119 lines
3.3 KiB
JavaScript
|
var outputWS = new WebSocket(config.channel.editor + '/output/ws');
|
||
|
outputWS.onopen = function() {
|
||
|
console.log('[output onopen] connected');
|
||
|
};
|
||
|
outputWS.onmessage = function(e) {
|
||
|
console.log('[output onmessage]' + e.data);
|
||
|
var data = JSON.parse(e.data);
|
||
|
if ('init-output' !== data.cmd) {
|
||
|
$('#output').val($('#output').val() + data.output);
|
||
|
}
|
||
|
};
|
||
|
outputWS.onclose = function(e) {
|
||
|
console.log('[output onclose] disconnected (' + e.code + ')');
|
||
|
delete outputWS;
|
||
|
};
|
||
|
outputWS.onerror = function(e) {
|
||
|
console.log('[output onerror] ' + e);
|
||
|
};
|
||
|
|
||
|
var shellWS = new WebSocket(config.channel.shell + '/shell/ws');
|
||
|
shellWS.onopen = function() {
|
||
|
console.log('[shell onopen] connected');
|
||
|
};
|
||
|
shellWS.onmessage = function(e) {
|
||
|
console.log('[shell onmessage]' + e.data);
|
||
|
var data = JSON.parse(e.data);
|
||
|
if ('init-shell' !== data.cmd) {
|
||
|
$('#shellOutput').val(data.output);
|
||
|
}
|
||
|
};
|
||
|
shellWS.onclose = function(e) {
|
||
|
console.log('[shell onclose] disconnected (' + e.code + ')');
|
||
|
delete shellWS;
|
||
|
};
|
||
|
shellWS.onerror = function(e) {
|
||
|
console.log('[shell onerror] ' + e);
|
||
|
};
|
||
|
|
||
|
var wide = {
|
||
|
curFile: "",
|
||
|
init: function() {
|
||
|
$('#shellInput').keydown(function(event) {
|
||
|
if (13 === event.which) {
|
||
|
var input = {
|
||
|
cmd: $('#shellInput').val()
|
||
|
};
|
||
|
shellWS.send(JSON.stringify(input));
|
||
|
$('#shellInput').val('');
|
||
|
}
|
||
|
});
|
||
|
|
||
|
$("body").bind("mousedown", function(event) {
|
||
|
if (!(event.target.id === "dirRMenu" || $(event.target).closest("#dirRMenu").length > 0)) {
|
||
|
$("#dirRMenu").hide();
|
||
|
}
|
||
|
|
||
|
if (!(event.target.id === "fileRMenu" || $(event.target).closest("#fileRMenu").length > 0)) {
|
||
|
$("#fileRMenu").hide();
|
||
|
}
|
||
|
});
|
||
|
},
|
||
|
save: function() {
|
||
|
var request = {
|
||
|
"file": wide.curFile,
|
||
|
"code": editor.getValue()
|
||
|
};
|
||
|
$.ajax({
|
||
|
type: 'POST',
|
||
|
url: '/save',
|
||
|
data: JSON.stringify(request),
|
||
|
dataType: "json",
|
||
|
success: function(data) {
|
||
|
console.log(data);
|
||
|
}
|
||
|
});
|
||
|
},
|
||
|
run: function() {
|
||
|
var request = {
|
||
|
"file": wide.curFile,
|
||
|
"code": editor.getValue()
|
||
|
};
|
||
|
$.ajax({
|
||
|
type: 'POST',
|
||
|
url: '/run',
|
||
|
data: JSON.stringify(request),
|
||
|
dataType: "json",
|
||
|
beforeSend: function(data) {
|
||
|
$('#output').val('');
|
||
|
},
|
||
|
success: function(data) {
|
||
|
console.log(data);
|
||
|
}
|
||
|
});
|
||
|
},
|
||
|
fmt: function() {
|
||
|
var request = {
|
||
|
"file": wide.curFile,
|
||
|
"code": editor.getValue(),
|
||
|
"cursorLine": editor.getCursor().line,
|
||
|
"cursorCh": editor.getCursor().ch
|
||
|
};
|
||
|
$.ajax({
|
||
|
type: 'POST',
|
||
|
url: '/fmt',
|
||
|
data: JSON.stringify(request),
|
||
|
dataType: "json",
|
||
|
success: function(data) {
|
||
|
if (data.succ) {
|
||
|
editor.setValue(data.code);
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
};
|
||
|
|
||
|
$(document).ready(function() {
|
||
|
wide.init();
|
||
|
tree.init();
|
||
|
});
|