mirror of https://github.com/huashengdun/webssh
jslint compliant
parent
cce9371649
commit
2c36c38653
|
@ -1,9 +1,117 @@
|
||||||
|
var jQuery;
|
||||||
|
var wssh = {};
|
||||||
|
|
||||||
|
|
||||||
jQuery(function($){
|
jQuery(function($){
|
||||||
|
/*jslint browser:true */
|
||||||
|
|
||||||
var status = $('#status'),
|
var status = $('#status'),
|
||||||
btn = $('.btn-primary'),
|
btn = $('.btn-primary'),
|
||||||
style = {};
|
style = {};
|
||||||
|
|
||||||
|
|
||||||
|
function parse_xterm_style() {
|
||||||
|
var text = $('.xterm-helpers style').text();
|
||||||
|
var arr = text.split('xterm-normal-char{width:');
|
||||||
|
style.width = parseFloat(arr[1]);
|
||||||
|
arr = text.split('div{height:');
|
||||||
|
style.height = parseFloat(arr[1]);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function current_geometry() {
|
||||||
|
if (!style.width || !style.height) {
|
||||||
|
parse_xterm_style();
|
||||||
|
}
|
||||||
|
|
||||||
|
var cols = parseInt(window.innerWidth / style.width, 10) - 1;
|
||||||
|
var rows = parseInt(window.innerHeight / style.height, 10);
|
||||||
|
return {'cols': cols, 'rows': rows};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function resize_term(term, sock) {
|
||||||
|
var geometry = current_geometry(),
|
||||||
|
cols = geometry.cols,
|
||||||
|
rows = geometry.rows;
|
||||||
|
// console.log([cols, rows]);
|
||||||
|
// console.log(term.geometry);
|
||||||
|
|
||||||
|
if (cols !== term.geometry[0] || rows !== term.geometry[1]) {
|
||||||
|
console.log('resizing term');
|
||||||
|
term.resize(cols, rows);
|
||||||
|
sock.send(JSON.stringify({'resize': [cols, rows]}));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
function callback(msg) {
|
||||||
|
// console.log(msg);
|
||||||
|
if (msg.status) {
|
||||||
|
status.text(msg.status);
|
||||||
|
setTimeout(function(){
|
||||||
|
btn.prop('disabled', false);
|
||||||
|
}, 3000);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
var ws_url = window.location.href.replace('http', 'ws'),
|
||||||
|
join = (ws_url[ws_url.length-1] === '/' ? '' : '/'),
|
||||||
|
url = ws_url + join + 'ws?id=' + msg.id,
|
||||||
|
sock = new window.WebSocket(url),
|
||||||
|
terminal = document.getElementById('#terminal'),
|
||||||
|
term = new window.Terminal({
|
||||||
|
cursorBlink: true,
|
||||||
|
});
|
||||||
|
|
||||||
|
console.log(url);
|
||||||
|
wssh.sock = sock;
|
||||||
|
wssh.term = term;
|
||||||
|
|
||||||
|
term.on('data', function(data) {
|
||||||
|
// console.log(data);
|
||||||
|
sock.send(JSON.stringify({'data': data}));
|
||||||
|
});
|
||||||
|
|
||||||
|
sock.onopen = function() {
|
||||||
|
$('.container').hide();
|
||||||
|
term.open(terminal, true);
|
||||||
|
term.toggleFullscreen(true);
|
||||||
|
};
|
||||||
|
|
||||||
|
sock.onmessage = function(msg) {
|
||||||
|
var reader = new window.FileReader();
|
||||||
|
|
||||||
|
reader.onloadend = function(){
|
||||||
|
var decoder = new window.TextDecoder();
|
||||||
|
var text = decoder.decode(reader.result);
|
||||||
|
// console.log(text);
|
||||||
|
term.write(text);
|
||||||
|
if (!term.resized) {
|
||||||
|
resize_term(term, sock);
|
||||||
|
term.resized = true;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
reader.readAsArrayBuffer(msg.data);
|
||||||
|
};
|
||||||
|
|
||||||
|
sock.onerror = function(e) {
|
||||||
|
console.log(e);
|
||||||
|
};
|
||||||
|
|
||||||
|
sock.onclose = function(e) {
|
||||||
|
console.log(e);
|
||||||
|
term.destroy();
|
||||||
|
wssh.term = undefined;
|
||||||
|
wssh.sock = undefined;
|
||||||
|
$('.container').show();
|
||||||
|
status.text(e.reason);
|
||||||
|
btn.prop('disabled', false);
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
$('form#connect').submit(function(event) {
|
$('form#connect').submit(function(event) {
|
||||||
event.preventDefault();
|
event.preventDefault();
|
||||||
|
|
||||||
|
@ -39,104 +147,9 @@ jQuery(function($){
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
function parse_xterm_style() {
|
|
||||||
var text = $('.xterm-helpers style').text();
|
|
||||||
var arr = text.split('xterm-normal-char{width:');
|
|
||||||
style.width = parseFloat(arr[1]);
|
|
||||||
arr = text.split('div{height:');
|
|
||||||
style.height = parseFloat(arr[1]);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function current_geometry() {
|
|
||||||
if (!style.width || !style.height) {
|
|
||||||
parse_xterm_style();
|
|
||||||
}
|
|
||||||
cols = parseInt(window.innerWidth / style.width) - 1;
|
|
||||||
rows = parseInt(window.innerHeight / style.height);
|
|
||||||
return {'cols': cols, 'rows': rows};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function resize_term(term, socket) {
|
|
||||||
var geometry = current_geometry(),
|
|
||||||
cols = geometry.cols,
|
|
||||||
rows = geometry.rows;
|
|
||||||
// console.log([cols, rows]);
|
|
||||||
// console.log(term.geometry);
|
|
||||||
if (cols != term.geometry[0] || rows != term.geometry[1]) {
|
|
||||||
console.log('resizing term');
|
|
||||||
term.resize(cols, rows);
|
|
||||||
socket.send(JSON.stringify({'resize': [cols, rows]}));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function callback(msg) {
|
|
||||||
// console.log(msg);
|
|
||||||
if (msg.status) {
|
|
||||||
status.text(msg.status);
|
|
||||||
setTimeout(function(){
|
|
||||||
btn.prop('disabled', false);
|
|
||||||
}, 3000);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
var ws_url = window.location.href.replace('http', 'ws'),
|
|
||||||
join = (ws_url[ws_url.length-1] == '/' ? '' : '/'),
|
|
||||||
url = ws_url + join + 'ws?id=' + msg.id,
|
|
||||||
terminal = document.getElementById('#terminal');
|
|
||||||
socket = new WebSocket(url);
|
|
||||||
term = new Terminal({
|
|
||||||
cursorBlink: true,
|
|
||||||
});
|
|
||||||
|
|
||||||
console.log(url);
|
|
||||||
term.on('data', function(data) {
|
|
||||||
// console.log(data);
|
|
||||||
socket.send(JSON.stringify({'data': data}));
|
|
||||||
});
|
|
||||||
|
|
||||||
socket.onopen = function(e) {
|
|
||||||
$('.container').hide();
|
|
||||||
term.open(terminal, true);
|
|
||||||
term.toggleFullscreen(true);
|
|
||||||
};
|
|
||||||
|
|
||||||
socket.onmessage = function(msg) {
|
|
||||||
var reader = new FileReader();
|
|
||||||
reader.onloadend = function(event){
|
|
||||||
var decoder = new TextDecoder();
|
|
||||||
var text = decoder.decode(reader.result);
|
|
||||||
// console.log(text);
|
|
||||||
term.write(text);
|
|
||||||
if (!term.resized) {
|
|
||||||
resize_term(term, socket);
|
|
||||||
term.resized = true;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
reader.readAsArrayBuffer(msg.data);
|
|
||||||
};
|
|
||||||
|
|
||||||
socket.onerror = function(e) {
|
|
||||||
console.log(e);
|
|
||||||
};
|
|
||||||
|
|
||||||
socket.onclose = function(e) {
|
|
||||||
console.log(e);
|
|
||||||
term.destroy();
|
|
||||||
term = undefined;
|
|
||||||
socket = undefined;
|
|
||||||
$('.container').show();
|
|
||||||
status.text(e.reason);
|
|
||||||
btn.prop('disabled', false);
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
$(window).resize(function(){
|
$(window).resize(function(){
|
||||||
if (typeof term != 'undefined' && typeof socket != 'undefined') {
|
if (wssh.term && wssh.sock) {
|
||||||
resize_term(term, socket);
|
resize_term(wssh.term, wssh.sock);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue