mock: start mocking real dashboard settings

Signed-off-by: Sean Cross <sean@xobs.io>
This commit is contained in:
Sean Cross 2023-12-03 17:54:18 +08:00
parent 0a3b6fe96e
commit efe0397fab
20 changed files with 1742 additions and 26 deletions

View File

@ -10,4 +10,6 @@ npm install
## Usage
This repository installs things within the `node_modules` directory. To run commands, prefix them with `npx`. For example, to run the Typescript compiler, run `npx tsc`. Or to run the Speedy Web Compiler, run `npx swc`.
This repository installs things within the `node_modules` directory. To run commands, prefix them with `npx`. For example, to run the Typescript compiler, run `npx tsc`. Or to run Webpack, run `npx webpack`.
You will likely be using `npm run build` to build software, and `npm run start` to start interactive development.

View File

@ -1,10 +1,207 @@
import { Request, Application, Response } from 'express';
export function getVoltages(request: Request, response: Response) {
// ...
response.send('these are some voltages');
var CONNECTED: boolean = false;
var SSID: string = '';
var TASKS = [
{ 'id': 1, 'name': "ipc0", 'prio': 24, 'state': 'eSuspended', 'stack_hwm': 1244, 'core': '0', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 2, 'name': "ipc1", 'prio': 24, 'state': 'eSuspended', 'stack_hwm': 1236, 'core': '1', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 3, 'name': "esp_timer", 'prio': 22, 'state': 'eSuspended', 'stack_hwm': 2572, 'core': '0', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 5, 'name': "IDLE0", 'prio': 0, 'state': 'eReady', 'stack_hwm': 2340, 'core': '0', 'cpu': 98, 'pc': 0x400559e0 },
{ 'id': 6, 'name': "IDLE1", 'prio': 0, 'state': 'eReady', 'stack_hwm': 2336, 'core': '1', 'cpu': 99, 'pc': 0x4037d30a },
{ 'id': 7, 'name': "Tmr Svc", 'prio': 1, 'state': 'eBlocked', 'stack_hwm': 1164, 'core': '0', 'cpu': 0, 'pc': 0x40380e79 },
{ 'id': 8, 'name': "dbg_log_main", 'prio': 4, 'state': 'eBlocked', 'stack_hwm': 1296, 'core': 'ANY', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 9, 'name': "wifi_manager", 'prio': 5, 'state': 'eBlocked', 'stack_hwm': 1400, 'core': 'ANY', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 10, 'name': "tiT", 'prio': 18, 'state': 'eBlocked', 'stack_hwm': 844, 'core': 'ANY', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 11, 'name': "sys_evt", 'prio': 20, 'state': 'eBlocked', 'stack_hwm': 760, 'core': '0', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 12, 'name': "wifi", 'prio': 23, 'state': 'eBlocked', 'stack_hwm': 3484, 'core': '0', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 13, 'name': "httpd", 'prio': 5, 'state': 'eRunning', 'stack_hwm': 1392, 'core': 'ANY', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 14, 'name': "mdns", 'prio': 1, 'state': 'eBlocked', 'stack_hwm': 2108, 'core': '0', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 15, 'name': "uart_rx_task", 'prio': 1, 'state': 'eBlocked', 'stack_hwm': 1456, 'core': '1', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 16, 'name': "net_uart_task", 'prio': 1, 'state': 'eBlocked', 'stack_hwm': 3848, 'core': 'ANY', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 17, 'name': "gdb_net", 'prio': 1, 'state': 'eBlocked', 'stack_hwm': 592, 'core': 'ANY', 'cpu': 0, 'pc': 0x400559e0 },
{ 'id': 18, 'name': "tftpOTATask", 'prio': 4, 'state': 'eBlocked', 'stack_hwm': 1520, 'core': 'ANY', 'cpu': 0, 'pc': 0x400559e0 },
];
const GET_ENDPOINTS: { [key: string]: (request: Request, response: Response) => any } = {
'voltages': getVoltages,
'target': getTarget,
'version': getVersion,
'network': getNetworkStatus,
'tasks': getTasks,
'serial': getSerialPort,
'update': getUpdate,
'system': getSystem,
'ap': getAccessPoints,
};
const POST_ENDPOINTS: { [key: string]: (request: Request, response: Response) => any } = {
'connect': postConnect,
};
const DELETE_ENDPOINTS: { [key: string]: (request: Request, response: Response) => any } = {
'connect': deleteConnect,
};
function getTasks(_request: Request, response: Response) {
response.send(TASKS);
}
function getVoltages(_request: Request, response: Response) {
var voltages: { [key: string]: number } = {
'3.3V': 3.3,
'Target': 1.8,
'USB': 5.02,
'Debug': 5.01,
'EXT': 3.7,
};
response.send(voltages);
}
function getTarget(_request: Request, response: Response) {
var target = {
'name': 'nrf52840',
'ram': 256 * 1024,
'flash': 1024 * 1024,
'cpu': 'ARM Cortex-M4F',
}
var targets = [
'nrf52840',
'mdf',
];
response.send({
'current': target,
'available': targets,
});
}
function getSerialPort(request: Request, response: Response) {
var serialPorts = {
'uart': {
'name': 'serial',
'baud_rate': 115200,
'parity': 'none',
'stop_bits': 1,
'data_bits': 8,
'flow_control': 'none',
},
'swo': {
'name': 'swo',
'baud_rate': 0,
'parity': 'none',
'stop_bits': 1,
'data_bits': 8,
'flow_control': 'none',
},
'uuart': {
'name': 'uuart',
'baud_rate': 0,
'parity': 'none',
'stop_bits': 1,
'data_bits': 8,
'flow_control': 'none',
},
}
response.send(serialPorts);
}
function getUpdate(request: Request, response: Response) {
response.send({
'current_partition': {
'addr': 0x00010000,
'index': 2,
},
'next_partition': {
'addr': 0x00380000,
'index': -1,
},
});
}
function getSystem(request: Request, response: Response) {
response.send({
'heap': 149552,
'uptime': 1551000,
});
}
function getVersion(_request: Request, response: Response) {
response.send({
'farpatch': '0.1.0',
'bmp': '0.1.0',
'hardware': 'DVT5',
});
}
function getNetworkStatus(request: Request, response: Response) {
if (CONNECTED) {
response.send({ "ssid": SSID, "ip": "10.0.237.133", "netmask": "255.255.255.0", "gw": "10.0.237.1", "urc": 0 });
} else {
response.send({ "ssid": "", "ip": "0", "netmask": "0", "gw": "0", "urc": 2 });
}
}
function getAccessPoints(_request: Request, response: Response) {
response.send([{ "ssid": "Omicron Persei 8", "chan": 6, "rssi": -50, "auth": 3 },
{ "ssid": "Parelivingroom", "chan": 1, "rssi": -71, "auth": 4 },
{ "ssid": "HappyWifiHappyLife", "chan": 8, "rssi": -71, "auth": 3 },
{ "ssid": "SINGTEL-AV4U", "chan": 1, "rssi": -77, "auth": 3 },
{ "ssid": "TP Living Room", "chan": 9, "rssi": -77, "auth": 3 },
{ "ssid": "Brett_Home", "chan": 1, "rssi": -80, "auth": 3 },
{ "ssid": "黄 Fam", "chan": 6, "rssi": -80, "auth": 3 }]);
}
function postConnect(request: Request, response: Response) {
var ssid = request.headers['x-custom-ssid'];
var password = request.headers['x-custom-pwd'];
if (!ssid || !password) {
response.status(400).send({ 'error': 'Missing SSID or password' });
return;
}
response.send('{}');
CONNECTED = true;
if (typeof ssid === 'string') {
SSID = ssid;
} else {
SSID = ssid[0];
}
}
function deleteConnect(_request: Request, response: Response) {
console.log("Deleting connection");
response.send('{}');
CONNECTED = false;
SSID = '';
}
function reportEndpoints(_request: Request, response: Response) {
var getEndpointsArray = [];
for (var endpoint in GET_ENDPOINTS) {
getEndpointsArray.push('/fp/' + endpoint);
}
var postEndpointsArray = [];
for (var endpoint in POST_ENDPOINTS) {
postEndpointsArray.push('/fp/' + endpoint);
}
response.send({
'endpoints': {
'get': getEndpointsArray,
'post': postEndpointsArray,
}
});
}
export function installMiddlewares(app: Application) {
app.get('/voltages', getVoltages);
app.get('/fp/', reportEndpoints);
for (var endpoint in GET_ENDPOINTS) {
app.get('/fp/' + endpoint, GET_ENDPOINTS[endpoint]);
}
for (var endpoint in POST_ENDPOINTS) {
app.post('/fp/' + endpoint, POST_ENDPOINTS[endpoint]);
}
for (var endpoint in DELETE_ENDPOINTS) {
app.delete('/fp/' + endpoint, DELETE_ENDPOINTS[endpoint]);
}
}

View File

@ -16,32 +16,11 @@ class DashboardItem {
var itemTitle = document.createElement("span");
itemTitle.classList.add("dashboard-item-title");
itemTitle.innerText = this.name;
// itemTitle.setAttribute("aria-hidden", "true");
// itemTitle.classList.add("las");
// itemTitle.classList.add("la-3x");
// itemTitle.classList.add("la-" + this.id);
// itemTitle.classList.add("icon");
var itemValue: HTMLElement = document.createElement("span");
itemValue.classList.add("dashboard-item-value");
itemValue.innerHTML = this.value;
// // var label: HTMLElement = document.createElement("label");
// // label.setAttribute("for", this.id);
// // label.setAttribute("id", this.id);
// // label.setAttribute("aria-hidden", "true");
// // label.innerText = this.name;
// var input: HTMLElement = document.createElement("input");
// input.setAttribute("name", this.id);
// input.setAttribute("aria-labelledby", this.id);
// input.setAttribute("type", "range");
// input.setAttribute("value", this.value);
// input.setAttribute("max", "10");
// input.setAttribute("style", "--track-fill: 30%");
// inputStack.appendChild(label);
// inputStack.appendChild(input);
field.appendChild(itemTitle);
field.appendChild(itemValue);
@ -132,10 +111,12 @@ export class DashboardWidget implements FarpatchWidget {
console.log("Initialized Dashboard Widget");
}
onFocus(element: HTMLElement): void {
console.log("Displaying Dashboard Widget");
element.appendChild(this.view);
}
onBlur(element: HTMLElement): void {
console.log("Archiving Dashboard Widget");
element.removeChild(this.view);

2
static/old/140medley.min.js vendored Normal file
View File

@ -0,0 +1,2 @@
var t=function(a,b){return function(c,d){return a.replace(/#{([^}]*)}/g,function(a,f){return Function("x","with(x)return "+f).call(c,d||b||{})})}},s=function(a,b){return b?{get:function(c){return a[c]&&b.parse(a[c])},set:function(c,d){a[c]=b.stringify(d)}}:{}}(this.localStorage||{},JSON),p=function(a,b,c,d){c=c||document;d=c[b="on"+b];a=c[b]=function(e){d=d&&d(e=e||c.event);return(a=a&&b(e))?b:d};c=this},m=function(a,b,c){b=document;c=b.createElement("p");c.innerHTML=a;for(a=b.createDocumentFragment();b=
c.firstChild;)a.appendChild(b);return a},$=function(a,b){a=a.match(/^(\W)?(.*)/);return(b||document)["getElement"+(a[1]?a[1]=="#"?"ById":"sByClassName":"sByTagName")](a[2])},j=function(a){for(a=0;a<4;a++)try{return a?new ActiveXObject([,"Msxml2","Msxml3","Microsoft"][a]+".XMLHTTP"):new XMLHttpRequest}catch(b){}};

321
static/old/code.js Normal file
View File

@ -0,0 +1,321 @@
// First, checks if it isn't implemented yet.
if (!String.prototype.format) {
String.prototype.format = function () {
var args = arguments;
return this.replace(/{(\d+)}/g, function (match, number) {
return typeof args[number] != 'undefined'
? args[number]
: match
;
});
};
}
var apList = null;
var selectedSSID = "";
var refreshAPInterval = null;
var checkStatusInterval = null;
function stopCheckStatusInterval() {
if (checkStatusInterval != null) {
clearInterval(checkStatusInterval);
checkStatusInterval = null;
}
}
function stopRefreshAPInterval() {
if (refreshAPInterval != null) {
clearInterval(refreshAPInterval);
refreshAPInterval = null;
}
}
function startCheckStatusInterval() {
checkStatusInterval = setInterval(checkStatus, 950);
}
function startRefreshAPInterval() {
refreshAPInterval = setInterval(refreshAP, 2800);
}
$(document).ready(function () {
$("#wifi-status").on("click", ".ape", function () {
$("#wifi").slideUp("fast", function () { });
$("#connect-details").slideDown("fast", function () { });
});
$("#manual_add").on("click", ".ape", function () {
selectedSSID = $(this).text();
$("#ssid-pwd").text(selectedSSID);
$("#wifi").slideUp("fast", function () { });
$("#connect_manual").slideDown("fast", function () { });
$("#connect").slideUp("fast", function () { });
//update wait screen
$("#loading").show();
$("#connect-success").hide();
$("#connect-fail").hide();
});
$("#wifi-list").on("click", ".ape", function () {
selectedSSID = $(this).text();
$("#ssid-pwd").text(selectedSSID);
$("#wifi").slideUp("fast", function () { });
$("#connect_manual").slideUp("fast", function () { });
$("#connect").slideDown("fast", function () { });
//update wait screen
$("#loading").show();
$("#connect-success").hide();
$("#connect-fail").hide();
});
$("#cancel").on("click", function () {
selectedSSID = "";
$("#connect").slideUp("fast", function () { });
$("#connect_manual").slideUp("fast", function () { });
$("#wifi").slideDown("fast", function () { });
});
$("#manual_cancel").on("click", function () {
selectedSSID = "";
$("#connect").slideUp("fast", function () { });
$("#connect_manual").slideUp("fast", function () { });
$("#wifi").slideDown("fast", function () { });
});
$("#join").on("click", function () {
performConnect();
});
$("#manual_join").on("click", function () {
performConnect($(this).data('connect'));
});
$("#ok-details").on("click", function () {
$("#connect-details").slideUp("fast", function () { });
$("#wifi").slideDown("fast", function () { });
});
$("#ok-credits").on("click", function () {
$("#credits").slideUp("fast", function () { });
$("#app").slideDown("fast", function () { });
});
$("#acredits").on("click", function (event) {
event.preventDefault();
$("#app").slideUp("fast", function () { });
$("#credits").slideDown("fast", function () { });
});
$("#ok-connect").on("click", function () {
$("#connect-wait").slideUp("fast", function () { });
$("#wifi").slideDown("fast", function () { });
});
$("#disconnect").on("click", function () {
$("#connect-details-wrap").addClass('blur');
$("#diag-disconnect").slideDown("fast", function () { });
});
$("#no-disconnect").on("click", function () {
$("#diag-disconnect").slideUp("fast", function () { });
$("#connect-details-wrap").removeClass('blur');
});
$("#yes-disconnect").on("click", function () {
stopCheckStatusInterval();
selectedSSID = "";
$("#diag-disconnect").slideUp("fast", function () { });
$("#connect-details-wrap").removeClass('blur');
$.ajax({
url: '/fp/connect',
dataType: 'json',
method: 'DELETE',
cache: false,
data: { 'timestamp': Date.now() }
});
startCheckStatusInterval();
$("#connect-details").slideUp("fast", function () { });
$("#wifi").slideDown("fast", function () { })
});
//first time the page loads: attempt get the connection status and start the wifi scan
refreshAP();
startCheckStatusInterval();
startRefreshAPInterval();
});
function performConnect(conntype) {
//stop the status refresh. This prevents a race condition where a status
//request would be refreshed with wrong ip info from a previous connection
//and the request would automatically shows as succesful.
stopCheckStatusInterval();
//stop refreshing wifi list
stopRefreshAPInterval();
var pwd;
if (conntype == 'manual') {
//Grab the manual SSID and PWD
selectedSSID = $('#manual_ssid').val();
pwd = $("#manual_pwd").val();
} else {
pwd = $("#pwd").val();
}
//reset connection
$("#loading").show();
$("#connect-success").hide();
$("#connect-fail").hide();
$("#ok-connect").prop("disabled", true);
$("#ssid-wait").text(selectedSSID);
$("#connect").slideUp("fast", function () { });
$("#connect_manual").slideUp("fast", function () { });
$("#connect-wait").slideDown("fast", function () { });
$.ajax({
url: '/fp/connect',
dataType: 'json',
method: 'POST',
cache: false,
headers: { 'X-Custom-ssid': selectedSSID, 'X-Custom-pwd': pwd },
data: { 'timestamp': Date.now() }
});
//now we can re-set the intervals regardless of result
startCheckStatusInterval();
startRefreshAPInterval();
}
function rssiToIcon(rssi) {
if (rssi >= -60) {
return 'w0';
}
else if (rssi >= -67) {
return 'w1';
}
else if (rssi >= -75) {
return 'w2';
}
else {
return 'w3';
}
}
function refreshAP() {
$.getJSON("/fp/ap", function (data) {
if (data.length > 0) {
//sort by signal strength
data.sort(function (a, b) {
var x = a["rssi"]; var y = b["rssi"];
return ((x < y) ? 1 : ((x > y) ? -1 : 0));
});
apList = data;
refreshAPHTML(apList);
}
});
}
function refreshAPHTML(data) {
var h = "";
data.forEach(function (e, idx, array) {
h += '<div class="ape{0}"><div class="{1}"><div class="{2}">{3}</div></div></div>'.format(idx === array.length - 1 ? '' : ' brdb', rssiToIcon(e.rssi), e.auth == 0 ? '' : 'pw', e.ssid);
h += "\n";
});
$("#wifi-list").html(h)
}
function checkStatus() {
$.getJSON("/fp/network", function (data) {
if (data.hasOwnProperty('ssid') && data['ssid'] != "") {
if (data["ssid"] === selectedSSID) {
//that's a connection attempt
if (data["urc"] === 0) {
//got connection
$("#connected-to span").text(data["ssid"]);
$("#connect-details h1").text(data["ssid"]);
$("#ip").text(data["ip"]);
$("#netmask").text(data["netmask"]);
$("#gw").text(data["gw"]);
$("#wifi-status").slideDown("fast", function () { });
//unlock the wait screen if needed
$("#ok-connect").prop("disabled", false);
//update wait screen
$("#loading").hide();
$("#connect-success").show();
$("#connect-fail").hide();
// Redirect to the main page after 5 seconds
window.setTimeout(function () {
// Move to a new location or you can do something else
window.location.href = "http://" + data["ip"];
}, 5000);
}
else if (data["urc"] === 1) {
//failed attempt
$("#connected-to span").text('');
$("#connect-details h1").text('');
$("#ip").text('0.0.0.0');
$("#netmask").text('0.0.0.0');
$("#gw").text('0.0.0.0');
//don't show any connection
$("#wifi-status").slideUp("fast", function () { });
//unlock the wait screen
$("#ok-connect").prop("disabled", false);
//update wait screen
$("#loading").hide();
$("#connect-fail").show();
$("#connect-success").hide();
}
}
else if (data.hasOwnProperty('urc') && data['urc'] === 0) {
//ESP32 is already connected to a wifi without having the user do anything
if (!($("#wifi-status").is(":visible"))) {
$("#connected-to span").text(data["ssid"]);
$("#connect-details h1").text(data["ssid"]);
$("#ip").text(data["ip"]);
$("#netmask").text(data["netmask"]);
$("#gw").text(data["gw"]);
$("#wifi-status").slideDown("fast", function () { });
}
}
}
else if (data.hasOwnProperty('urc') && data['urc'] === 2) {
//that's a manual disconnect
if ($("#wifi-status").is(":visible")) {
$("#wifi-status").slideUp("fast", function () { });
}
}
})
.fail(function () {
//don't do anything, the server might be down while esp32 recalibrates radio
});
}

92
static/old/debug.html Normal file
View File

@ -0,0 +1,92 @@
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="xterm.css" />
<script src="xterm.js"></script>
<script src="xterm-addon-fit.js"></script>
<script src="jquery.js"></script>
</head>
<style>
body {
font-family: sans;
}
</style>
<body>
<div id="terminal" style="height: 90vh"></div>
<div id="status">Connecting...</div>
<script>
var line_items = [];
var idx = -1;
var term = new Terminal({ cursorBlink: true, convertEol: true });
var fitAddon = new FitAddon.FitAddon();
term.loadAddon(fitAddon);
var socket;
var firstConnection = true;
function createSocket() {
if (socket && !socket.replacementCreated) {
socket.close();
}
socket = new WebSocket("ws://" + window.location.host + "/ws/debug");
socket.binaryType = 'arraybuffer';
socket.replacementCreated = false;
socket.ontimeout = function () {
if (socket.readyState == WebSocket.OPEN) {
socket.send('');
}
};
socket.onmessage = function (event) {
term.write(new Uint8Array(event.data));
};
socket.onerror = function (event) {
socket.close();
}
socket.onclose = function (event) {
socket.onerror = undefined;
socket.onclose = undefined;
if (event.wasClean) {
$("#status").text("Connection closed");
} else {
$("#status").text("Reconnecting...");
}
clearInterval(socket.intervalId);
if (!socket.replacementCreated) {
socket.replacementCreated = true;
createSocket();
} else {
console.log("a replacement socket was already being created -- skipping");
}
};
socket.onopen = function (event) {
$("#status").text("Connected");
if (firstConnection) {
term.write("\x1B[1;3;31m[Websocket] Connection established\x1B[0m\r\n");
} else {
term.write("[Websocket] Connection reestablished\n");
}
firstConnection = false;
};
socket.intervalId = setInterval(socket.ontimeout, 2000, socket);
}
createSocket();
term.open(document.getElementById('terminal'));
fitAddon.activate(term)
fitAddon.fit()
term.focus()
window.addEventListener('resize', () => { fitAddon.fit() });
</script>
</body>
</html>

BIN
static/old/favicon.ico Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 5.3 KiB

2
static/old/flash/140medley.min.js vendored Normal file
View File

@ -0,0 +1,2 @@
var t=function(a,b){return function(c,d){return a.replace(/#{([^}]*)}/g,function(a,f){return Function("x","with(x)return "+f).call(c,d||b||{})})}},s=function(a,b){return b?{get:function(c){return a[c]&&b.parse(a[c])},set:function(c,d){a[c]=b.stringify(d)}}:{}}(this.localStorage||{},JSON),p=function(a,b,c,d){c=c||document;d=c[b="on"+b];a=c[b]=function(e){d=d&&d(e=e||c.event);return(a=a&&b(e))?b:d};c=this},m=function(a,b,c){b=document;c=b.createElement("p");c.innerHTML=a;for(a=b.createDocumentFragment();b=
c.firstChild;)a.appendChild(b);return a},$=function(a,b){a=a.match(/^(\W)?(.*)/);return(b||document)["getElement"+(a[1]?a[1]=="#"?"ById":"sByClassName":"sByTagName")](a[2])},j=function(a){for(a=0;a<4;a++)try{return a?new ActiveXObject([,"Msxml2","Msxml3","Microsoft"][a]+".XMLHTTP"):new XMLHttpRequest}catch(b){}};

View File

@ -0,0 +1,86 @@
<!DOCTYPE html>
<html>
<head>
<title>Update firmware</title>
<link rel="stylesheet" type="text/css" href="style.css">
<script type="text/javascript" src="../jquery.js"></script>
<script type="text/javascript">
var xhr = new XMLHttpRequest();
function doReboot() {
xhr.open("GET", "/flash/reboot");
xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status >= 200 && xhr.status < 300) {
window.setTimeout(function () {
location.reload(true);
}, 3000);
}
}
xhr.send();
}
function setProgress(amt) {
$("#progressbarinner")[0].style.width = String(amt * 200) + "px";
}
function doUpgrade() {
var f = $("#file")[0].files[0];
if (typeof f == 'undefined') {
$("#remark")[0].innerHTML = "Can't read file!";
return
}
xhr.onreadystatechange = function () {
console.log("Ready state changed: " + xhr.readyState);
if (xhr.readyState == 4 && xhr.status >= 200 && xhr.status < 300) {
setProgress(1);
let response = JSON.parse(xhr.responseText);
if (!response["success"]) {
$("#remark")[0].innerHTML = "Error: " + xhr.responseText;
} else {
$("#remark")[0].innerHTML = "Uploading done. Rebooting.";
doReboot();
}
}
}
if (typeof xhr.upload.onprogress != 'undefined') {
xhr.upload.onprogress = function (e) {
console.log("Upload progress: " + e.loaded + " / " + e.total);
setProgress(e.loaded / e.total);
}
}
xhr.open("POST", "/flash/upload");
xhr.send(f);
return false;
}
window.onload = function (e) {
xhr.open("GET", "/flash/init");
xhr.onreadystatechange = function () {
if (xhr.readyState == 4 && xhr.status >= 200 && xhr.status < 300) {
var txt = "Please upload " + xhr.responseText + " or ota file.";
$("#remark")[0].innerHTML = txt;
setProgress(0);
}
}
xhr.send();
}
</script>
</head>
<body>
<div id="main">
<h1>Update firmware</h1>
<div id="remark">Loading...</div>
<input type="file" id="file" />
<input type="submit" value="Update!" onclick="doUpgrade()" />
<div id="progressbar">
<div id="progressbarinner"></div>
</div>
</div>
</body>

View File

@ -0,0 +1,34 @@
body {
background-color: #404040;
font-family: sans-serif;
}
#main {
background-color: #d0d0FF;
-moz-border-radius: 5px;
-webkit-border-radius: 5px;
border-radius: 5px;
border: 2px solid #000000;
width: 800px;
margin: 0 auto;
padding: 20px
}
#progressbar {
margin: 10px;
padding: 0;
border: 1px solid #000000;
height: 20px;
width: 200px;
background-color: #808080;
}
#progressbarinner {
width: 10px;
height: 20px;
border: none;
background-color: #00ff00;
}

207
static/old/index.html Normal file
View File

@ -0,0 +1,207 @@
<!doctype html>
<html>
<head>
<link rel="stylesheet" href="xterm.css" />
<script src="xterm.js"></script>
<script src="xterm-addon-fit.js"></script>
</head>
<style>
body {
font-family: sans;
}
</style>
<body>
<div id="terminal" style="height: 90vh"></div>
<input type="text" id="line" style="width: 50%"></input>
<select id="eol">
<option value="cr">CR</option>
<option value="lf">LF</option>
<option value="crlf">CR/LF</option>
<option value="none">None</option>
<option value="hex">Hex</option>
</select>
<button id="sendbtn" type="button">SEND</button>
<button id="sendbrk" type="button">BRK</button>
<input type="checkbox" id="echo" checked>Echo</input>
<button type="button" id="setbaud">SET BAUD</button>
<button type="button" id="clear">CLEAR</button>
<br>
Baud: <span id="curbaud">-</span>
<script>
var line_items = [];
var idx = -1;
function parseHexString(str) {
str = str.replace("0x", "")
str = str.replace(" ", "")
var result = [];
// Ignore any trailing single digit; I don't know what your needs
// are for this case, so you may want to throw an error or convert
// the lone digit depending on your needs.
while (str.length >= 2) {
result.push(parseInt(str.substring(0, 2), 16));
str = str.substring(2, str.length);
}
return result;
}
let xhr = new XMLHttpRequest();
// 2. Configure it: GET-request for the URL /article/.../load
xhr.open('GET', '/uart/baud');
// 3. Send the request over the network
xhr.send();
// 4. This will be called after the response is received
xhr.onload = function () {
if (xhr.status != 200) { // analyze HTTP status of the response
alert(`Error ${xhr.status}: ${xhr.statusText}`); // e.g. 404: Not Found
} else { // show the result
let d = xhr.response
d = JSON.parse(d)
document.querySelector("#curbaud").textContent = d["baudrate"]
}
};
function sendBreak() {
let xhr = new XMLHttpRequest();
xhr.open('GET', '/uart/break');
// 3. Send the request over the network
xhr.send();
}
function setBaud(baud) {
let xhr = new XMLHttpRequest();
// 2. Configure it: GET-request for the URL /article/.../load
xhr.open('GET', '/uart/baud?set=' + baud);
// 3. Send the request over the network
xhr.send();
xhr.onload = function () {
let d = xhr.response
d = JSON.parse(d)
document.querySelector("#curbaud").textContent = d["baudrate"]
};
}
function sendLine() {
var line = document.querySelector("#line").value
var type = document.querySelector("#eol").value
var echo = document.querySelector("#echo").checked
//console.log(type)
if (!line_items.includes(line)) {
line_items.push(line)
idx = line_items.length - 1
}
if (type == "cr") line += "\r"
else if (type == "lf") line += "\n"
else if (type == "crlf") line += "\r\n"
else if (type == "hex") {
line = parseHexString(line)
}
if (echo)
term.write(line)
socket.send(line)
}
document.querySelector("#setbaud").onclick = event => {
let baud = window.prompt("Enter baud rate", "115200")
if (baud) {
baud = parseInt(baud);
setBaud(baud);
}
}
document.querySelector("#clear").onclick = event => {
term.clear();
}
document.querySelector("#sendbtn").onclick = event => {
sendLine();
}
document.querySelector("#sendbrk").onclick = event => {
sendBreak();
}
document.querySelector("#line").addEventListener("keydown", event => {
//console.log(event.key)
if (event.key == "ArrowUp") {
console.log(idx)
if (line_items.length - 1 == idx) idx--;
event.srcElement.value = line_items[idx]
if (idx > 0) idx--;
}
if (event.key == "ArrowDown") {
console.log(idx)
if (idx < line_items.length - 1) {
idx++;
}
event.srcElement.value = line_items[idx]
}
if (event.key !== "Enter") return;
sendLine();
event.preventDefault(); // No need to `return false;`.
});
var term = new Terminal({ cursorBlink: true, convertEol: true });
var fitAddon = new FitAddon.FitAddon();
term.loadAddon(fitAddon);
var socket;
function createSocket() {
socket = new WebSocket("ws://" + window.location.host + "/ws/uart");
socket.binaryType = 'arraybuffer';
socket.onopen = function (e) {
term.write("\x1B[1;3;31m[Websocket] Connection established\x1B[0m\r\n");
};
socket.onmessage = function (event) {
term.write(new Uint8Array(event.data));
};
socket.onclose = function (event) {
if (event.wasClean) {
term.write("[Websocket] Connection closed");
} else {
// e.g. server process killed or network down
// event.code is usually 1006 in this case
term.write("[Websocket] Connection died");
}
createSocket();
};
}
createSocket();
term.open(document.getElementById('terminal'));
term.onData(chunk => {
socket.send(chunk)
})
fitAddon.activate(term)
fitAddon.fit()
term.focus()
window.addEventListener('resize', () => { fitAddon.fit() });
</script>
</body>
</html>

4
static/old/index.js Normal file
View File

@ -0,0 +1,4 @@
import { Terminal } from './xterm.js';
import { FitAddon } from './xterm-addon-fit.js';

4
static/old/jquery.js vendored Normal file

File diff suppressed because one or more lines are too long

178
static/old/rtt.html Normal file
View File

@ -0,0 +1,178 @@
<!DOCTYPE html>
<html>
<head>
<link rel="stylesheet" href="xterm.css" />
<script src="xterm.js"></script>
<script src="xterm-addon-fit.js"></script>
<script src="jquery.js"></script>
</head>
<style>
body {
font-family: sans;
}
</style>
<body>
<div id="terminal" style="height: 90vh"></div>
<input type="text" id="line" style="width: 50%"></input>
<select id="eol">
<option value="cr">CR</option>
<option value="lf">LF</option>
<option value="crlf">CR/LF</option>
<option value="none">None</option>
<option value="hex">Hex</option>
</select>
<button id="sendbtn" type="button">SEND</button>
<input type="checkbox" id="echo" checked>Echo</input>
<button type="button" id="clear">CLEAR</button>
<br>
<span id="status">Connecting...</span>
<script>
var line_items = [];
var idx = -1;
function parseHexString(str) {
str = str.replace("0x", "");
str = str.replace(" ", "");
var result = [];
while (str.length >= 2) {
result.push(parseInt(str.substring(0, 2), 16));
str = str.substring(2, str.length);
}
return result;
}
function sendLine() {
var line = document.querySelector("#line").value;
var type = document.querySelector("#eol").value;
var echo = document.querySelector("#echo").checked;
if (!line_items.includes(line)) {
line_items.push(line)
idx = line_items.length - 1
}
if (type == "cr") line += "\r"
else if (type == "lf") line += "\n"
else if (type == "crlf") line += "\r\n"
else if (type == "hex") {
line = parseHexString(line)
}
if (echo)
term.write(line)
socket.send(line)
}
document.querySelector("#clear").onclick = event => {
term.clear();
}
document.querySelector("#sendbtn").onclick = event => {
sendLine();
}
document.querySelector("#line").addEventListener("keydown", event => {
if (event.key == "ArrowUp") {
console.log(idx)
if (line_items.length - 1 == idx) idx--;
event.srcElement.value = line_items[idx]
if (idx > 0) idx--;
}
if (event.key == "ArrowDown") {
console.log(idx)
if (idx < line_items.length - 1) {
idx++;
}
event.srcElement.value = line_items[idx]
}
if (event.key !== "Enter") return;
sendLine();
event.preventDefault(); // No need to `return false;`.
});
var term = new Terminal({ cursorBlink: true, convertEol: true });
var fitAddon = new FitAddon.FitAddon();
term.loadAddon(fitAddon);
var socket;
function createSocket() {
if (socket && !socket.replacementCreated) {
socket.close();
}
socket = new WebSocket("ws://" + window.location.host + "/ws/rtt");
socket.binaryType = 'arraybuffer';
socket.replacementCreated = false;
socket.ontimeout = function () {
if (socket.readyState == WebSocket.OPEN) {
socket.send('');
}
};
socket.onopen = function (event) {
$("#status").text("Connected");
if (firstConnection) {
term.write("\x1B[1;3;31m[Websocket] Connection established\x1B[0m\r\n");
} else {
term.write("[Websocket] Connection reestablished\n");
}
firstConnection = false;
};
socket.onmessage = function (event) {
term.write(new Uint8Array(event.data));
};
socket.onerror = function (event) {
socket.close();
}
socket.onclose = function (event) {
socket.onerror = undefined;
socket.onclose = undefined;
if (event.wasClean) {
$("#status").text("Connection closed");
} else {
$("#status").text("Reconnecting...");
}
clearInterval(socket.intervalId);
if (!socket.replacementCreated) {
socket.replacementCreated = true;
createSocket();
} else {
console.log("a replacement socket was already being created -- skipping");
}
};
socket.intervalId = setInterval(socket.ontimeout, 2000, socket);
}
createSocket();
term.open(document.getElementById('terminal'));
term.onData(chunk => {
socket.send(chunk)
})
fitAddon.activate(term)
fitAddon.fit()
term.focus()
window.addEventListener('resize', () => { fitAddon.fit() });
</script>
</body>
</html>

35
static/old/status.html Normal file
View File

@ -0,0 +1,35 @@
<!DOCTYPE html>
<html lang="en-US">
<head>
<script>
var refreshIntervalMsecs = 1000;
var timeoutMsecs = 2000;
function createXHR() {
var xhr = new XMLHttpRequest();
xhr.timeout = timeoutMsecs;
xhr.ontimeout = function () {
console.log("Timed out!");
createXHR().send();
};
xhr.open('GET', '/status');
xhr.onload = function () {
if (xhr.readyState === xhr.DONE) {
if (xhr.status == 200) {
document.getElementById("status").innerText = xhr.response;
}
window.setTimeout(function () { createXHR().send(); }, refreshIntervalMsecs);
}
};
return xhr;
}
createXHR().send();
</script>
</head>
<body>
<pre><code id="status"></code></div>
</body>
</html>

250
static/old/style.css Normal file
View File

@ -0,0 +1,250 @@
body {
background-color: #eee;
border: 0;
margin: 0;
font: 1.1em tahoma, arial, sans-serif;
}
a {
color: darkblue;
transition: color .2s ease-out;
text-decoration: none
}
a:hover {
color: red;
}
input {
display: none;
font: 1.1em tahoma, arial, sans-serif;
}
input:focus,
select:focus,
textarea:focus,
button:focus {
outline: none;
}
input[type="button"] {
width: 100px;
padding: 5px;
text-align: center;
display: block;
}
p {
padding: 10px;
}
#credits {
display: none;
}
#app {} #app-wrap {} #disconnect {
width: 150px;
}
.diag-box {
position: absolute;
top: 0;
left: 0;
bottom: 0;
right: 0;
height: 100%;
width: 100%;
display: none;
}
.diag-box-win {
position: absolute;
left: 10%;
width: 80%;
text-align: center;
border: 2px outset #888;
background-color: #fff;
border-radius: 10px;
top: 20%;
}
.blur {
-webkit-filter: blur(2px);
-moz-filter: blur(2px);
-ms-filter: blur(2px);
-o-filter: blur(2px);
filter: blur(2px);
}
.ape {
margin-left: 20px;
padding: 10px 0px 10px 10px;
}
.ape:hover {
cursor: pointer;
}
.brdb {
border-bottom: 1px solid #888;
}
header {
background-color: #fff;
border-bottom: 1px solid #888;
}
section {
background-color: #fff;
border-bottom: 1px solid #888;
border-top: 1px solid #888;
}
h1 {
display: block;
text-align: center;
margin: 0;
padding: 15px;
font-size: 1.4em
}
h2 {
margin: 0;
margin-top: 20px;
padding: 10px;
text-transform: uppercase;
color: #888;
font-size: 1.0em
}
h3 {
margin: 0;
text-align: center;
padding: 20px 0px 20px 0px;
}
.gr {
color: green;
}
.rd {
color: red;
}
#wifi-status {
display: none;
}
#connect {
display: none;
}
#connect_manual {
display: none;
}
#manual_ssid {
border: none;
width: 80%;
margin-left: 35px;
padding: 10px 0px 10px 10px;
display: block
}
#manual_pwd {
border: none;
width: 80%;
margin-left: 35px;
padding: 10px 0px 10px 10px;
display: block
}
#pwd {
border: none;
width: 80%;
margin-left: 35px;
padding: 10px 0px 10px 10px;
display: block
}
.buttons {
padding: 15px;
}
#join {
float: right;
}
#manual_join {
float: right;
}
#yes-disconnect {
display: inline-block;
margin-left: 20px;
}
#no-disconnect {
display: inline-block;
}
.ctr {
margin: 0 auto;
}
.tctr {
text-align: center;
}
#connect-wait {
display: none;
}
#connect-success {
display: none;
}
#connect-fail {
display: none;
}
#connect-details {
display: none;
}
.fr {
float: right;
margin-right: 20px;
}
.w0 {
background: url('') no-repeat right top;
height: 24px;
margin-right: 20px;
}
.w1 {
background: url('') no-repeat right top;
height: 24px;
margin-right: 20px;
}
.w2 {
background: url('') no-repeat right top;
height: 24px;
margin-right: 20px;
}
.w3 {
background: url('') no-repeat right top;
height: 24px;
margin-right: 20px;
}
.pw {
background: url('') no-repeat right top;
height: 24px;
margin-right: 20px;
height: 24px;
margin-right: 30px;
}
/* SpinKit is licensed under the MIT License. Copyright (c) 2015 Tobias Ahlin */
.spinner {
width: 40px;
height: 40px;
position: relative;
margin: 100px auto;
}
.double-bounce1,
.double-bounce2 {
width: 100%;
height: 100%;
border-radius: 50%;
background-color: #333;
opacity: 0.6;
position: absolute;
top: 0;
left: 0;
-webkit-animation: sk-bounce 2.0s infinite ease-in-out;
animation: sk-bounce 2.0s infinite ease-in-out;
}
.double-bounce2 {
-webkit-animation-delay: -1.0s;
animation-delay: -1.0s;
}
@-webkit-keyframes sk-bounce {
0%, 100% {
-webkit-transform: scale(0.0)
}
50% {
-webkit-transform: scale(1.0)
}
}
@keyframes sk-bounce {
0%, 100% {
transform: scale(0.0);
-webkit-transform: scale(0.0);
}
50% {
transform: scale(1.0);
-webkit-transform: scale(1.0);
}
}
/* end of SpinKit */

137
static/old/wifi.html Normal file
View File

@ -0,0 +1,137 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8"/>
<meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no">
<meta name="apple-mobile-web-app-capable" content="yes" />
<script src="jquery.js"></script>
<link rel="stylesheet" href="style.css">
<script src="code.js"></script>
<title>esp32-wifi-manager</title>
</head>
<body>
<div id="app">
<div id="app-wrap">
<div id="wifi">
<header>
<h1>Wi-Fi</h1>
</header>
<div id="wifi-status">
<h2>Connected to:</h2>
<section id="connected-to">
<div class="ape"><div class="w0"><div class="pw"><span></span></div></div></div>
</section>
</div>
<h2>Manual connect</h2>
<section id="manual_add">
<div class="ape">ADD (HIDDEN) SSID<div>
</section>
<h2>or choose a network...</h2>
<section id="wifi-list">
</section>
<div id="pwrdby"><em>Powered by </em><a id="acredits" href="#"><strong>esp32-wifi-manager</strong></a>.</div>
</div>
<div id="connect_manual">
<header>
<h1>Enter Details</h1>
</header>
<h2>Manual Connection</span></h2>
<section>
<input id="manual_ssid" type="text" placeholder="SSID" value="">
<input id="manual_pwd" type="password" placeholder="Password" value="">
</section>
<div class="buttons">
<input id="manual_join" type="button" value="Join" data-connect="manual" />
<input id="manual_cancel" type="button" value="Cancel"/>
</div>
</div>
<div id="connect">
<header>
<h1>Enter Password</h1>
</header>
<h2>Password for <span id="ssid-pwd"></span></h2>
<section>
<input id="pwd" type="password" placeholder="Password" value="">
</section>
<div class="buttons">
<input id="join" type="button" value="Join" />
<input id="cancel" type="button" value="Cancel"/>
</div>
</div>
<div id="connect-wait">
<header>
<h1>Please wait...</h1>
</header>
<h2>Connecting to <span id="ssid-wait"></span></h2>
<section>
<div id="loading">
<div class="spinner"><div class="double-bounce1"></div><div class="double-bounce2"></div></div>
<p class="tctr">You may lose wifi access while the esp32 recalibrates its radio. Please wait until your device automatically reconnects. This can take up to 30s.</p>
</div>
<div id="connect-success">
<h3 class="gr">Success!</h3>
</div>
<div id="connect-fail">
<h3 class="rd">Connection failed</h3>
<p class="tctr">Please double-check wifi password if any and make sure the access point has good signal.</p>
</div>
</section>
<div class="buttons">
<input id="ok-connect" type="button" value="OK" class="ctr" />
</div>
</div>
<div id="connect-details">
<div id="connect-details-wrap">
<header>
<h1></h1>
</header>
<h2></h2>
<section>
<div class="buttons">
<input id="disconnect" type="button" value="Disconnect" class="ctr"/>
</div>
</section>
<h2>IP Address</h2>
<section>
<div class="ape brdb">IP Address:<div id="ip" class="fr"></div></div>
<div class="ape brdb">Subnet Mask:<div id="netmask" class="fr"></div></div>
<div class="ape">Default Gateway:<div id="gw" class="fr"></div></div>
</section>
<div class="buttons">
<input id="ok-details" type="button" value="OK" class="ctr" />
</div>
</div>
<div id="diag-disconnect" class="diag-box">
<div class="diag-box-win">
<p>Are you sure you would like to disconnect from this wifi?</p>
<div class="buttons">
<input id="no-disconnect" type="button" value="No" />
<input id="yes-disconnect" type="button" value="Yes" />
</div>
</div>
</div>
</div>
</div>
</div>
<div id="credits">
<header>
<h1>About this app...</h1>
</header>
<h2></h2>
<section>
<p><strong>esp32-wifi-manager</strong>, &copy; 2017-2019, Tony Pottier<br />Licender under the MIT License.</p>
<p>
This app would not be possible without the following libraries:
</p>
<ul>
<li>SpinKit, &copy; 2015, Tobias Ahlin. Licensed under the MIT License.</li>
<li>jQuery, The jQuery Foundation. Licensed under the MIT License.</li>
<li>cJSON, &copy; 2009-2017, Dave Gamble and cJSON contributors. Licensed under the MIT License.</li>
</ul>
</section>
<div class="buttons">
<input id="ok-credits" type="button" value="OK" class="ctr" />
</div>
</div>
</body>
<html>

View File

@ -0,0 +1,2 @@
!function(e,t){"object"==typeof exports&&"object"==typeof module?module.exports=t():"function"==typeof define&&define.amd?define([],t):"object"==typeof exports?exports.FitAddon=t():e.FitAddon=t()}(self,(function(){return(()=>{"use strict";var e={775:(e,t)=>{Object.defineProperty(t,"__esModule",{value:!0}),t.FitAddon=void 0;var r=function(){function e(){}return e.prototype.activate=function(e){this._terminal=e},e.prototype.dispose=function(){},e.prototype.fit=function(){var e=this.proposeDimensions();if(e&&this._terminal){var t=this._terminal._core;this._terminal.rows===e.rows&&this._terminal.cols===e.cols||(t._renderService.clear(),this._terminal.resize(e.cols,e.rows))}},e.prototype.proposeDimensions=function(){if(this._terminal&&this._terminal.element&&this._terminal.element.parentElement){var e=this._terminal._core;if(0!==e._renderService.dimensions.actualCellWidth&&0!==e._renderService.dimensions.actualCellHeight){var t=window.getComputedStyle(this._terminal.element.parentElement),r=parseInt(t.getPropertyValue("height")),i=Math.max(0,parseInt(t.getPropertyValue("width"))),n=window.getComputedStyle(this._terminal.element),o=r-(parseInt(n.getPropertyValue("padding-top"))+parseInt(n.getPropertyValue("padding-bottom"))),a=i-(parseInt(n.getPropertyValue("padding-right"))+parseInt(n.getPropertyValue("padding-left")))-e.viewport.scrollBarWidth;return{cols:Math.max(2,Math.floor(a/e._renderService.dimensions.actualCellWidth)),rows:Math.max(1,Math.floor(o/e._renderService.dimensions.actualCellHeight))}}}},e}();t.FitAddon=r}},t={};return function r(i){if(t[i])return t[i].exports;var n=t[i]={exports:{}};return e[i](n,n.exports,r),n.exports}(775)})()}));
//# sourceMappingURL=xterm-addon-fit.js.map

180
static/old/xterm.css Normal file
View File

@ -0,0 +1,180 @@
/**
* Copyright (c) 2014 The xterm.js authors. All rights reserved.
* Copyright (c) 2012-2013, Christopher Jeffrey (MIT License)
* https://github.com/chjj/term.js
* @license MIT
*
* Permission is hereby granted, free of charge, to any person obtaining a copy
* of this software and associated documentation files (the "Software"), to deal
* in the Software without restriction, including without limitation the rights
* to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
* copies of the Software, and to permit persons to whom the Software is
* furnished to do so, subject to the following conditions:
*
* The above copyright notice and this permission notice shall be included in
* all copies or substantial portions of the Software.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
* FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
* AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
* LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
* OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
* THE SOFTWARE.
*
* Originally forked from (with the author's permission):
* Fabrice Bellard's javascript vt100 for jslinux:
* http://bellard.org/jslinux/
* Copyright (c) 2011 Fabrice Bellard
* The original design remains. The terminal itself
* has been extended to include xterm CSI codes, among
* other features.
*/
/**
* Default styles for xterm.js
*/
.xterm {
position: relative;
user-select: none;
-ms-user-select: none;
-webkit-user-select: none;
}
.xterm.focus,
.xterm:focus {
outline: none;
}
.xterm .xterm-helpers {
position: absolute;
top: 0;
/**
* The z-index of the helpers must be higher than the canvases in order for
* IMEs to appear on top.
*/
z-index: 5;
}
.xterm .xterm-helper-textarea {
padding: 0;
border: 0;
margin: 0;
/* Move textarea out of the screen to the far left, so that the cursor is not visible */
position: absolute;
opacity: 0;
left: -9999em;
top: 0;
width: 0;
height: 0;
z-index: -5;
/** Prevent wrapping so the IME appears against the textarea at the correct position */
white-space: nowrap;
overflow: hidden;
resize: none;
}
.xterm .composition-view {
/* TODO: Composition position got messed up somewhere */
background: #000;
color: #FFF;
display: none;
position: absolute;
white-space: nowrap;
z-index: 1;
}
.xterm .composition-view.active {
display: block;
}
.xterm .xterm-viewport {
/* On OS X this is required in order for the scroll bar to appear fully opaque */
background-color: #000;
overflow-y: scroll;
cursor: default;
position: absolute;
right: 0;
left: 0;
top: 0;
bottom: 0;
}
.xterm .xterm-screen {
position: relative;
}
.xterm .xterm-screen canvas {
position: absolute;
left: 0;
top: 0;
}
.xterm .xterm-scroll-area {
visibility: hidden;
}
.xterm-char-measure-element {
display: inline-block;
visibility: hidden;
position: absolute;
top: 0;
left: -9999em;
line-height: normal;
}
.xterm {
cursor: text;
}
.xterm.enable-mouse-events {
/* When mouse events are enabled (eg. tmux), revert to the standard pointer cursor */
cursor: default;
}
.xterm.xterm-cursor-pointer,
.xterm .xterm-cursor-pointer {
cursor: pointer;
}
.xterm.column-select.focus {
/* Column selection mode */
cursor: crosshair;
}
.xterm .xterm-accessibility,
.xterm .xterm-message {
position: absolute;
left: 0;
top: 0;
bottom: 0;
right: 0;
z-index: 10;
color: transparent;
}
.xterm .live-region {
position: absolute;
left: -9999px;
width: 1px;
height: 1px;
overflow: hidden;
}
.xterm-dim {
opacity: 0.5;
}
.xterm-underline {
text-decoration: underline;
}
.xterm-strikethrough {
text-decoration: line-through;
}
.xterm-screen .xterm-decoration-container .xterm-decoration {
z-index: 6;
position: absolute;
}

2
static/old/xterm.js Normal file

File diff suppressed because one or more lines are too long