forked from FOSS/BangleApps
Update app.js
added an if statement to display an alert message if the tv config file is not present.master
parent
1a1d8cf1dd
commit
ca004b2700
|
@ -9,13 +9,15 @@ let devicefile = require("Storage").readJSON(deviceFileName, true);
|
|||
//console.log(devicefile);
|
||||
|
||||
|
||||
let serverDns = serverData.webServerDns;
|
||||
let serverPort = serverData.port;
|
||||
let tvIp = serverData.tvIp;
|
||||
let username = serverData.username;
|
||||
let password = serverData.password;
|
||||
let serverDns = "webServerDns" in serverData ? serverData.webServerDns : 'undefined';
|
||||
|
||||
let panaIp = "tvIp" in serverData ? serverData.tvIp : 'undefined';
|
||||
let serverPort = "port" in serverData ? serverData.port : 'undefined';
|
||||
let tvIp = "tvIp" in serverData ? serverData.tvIp : 'undefined';
|
||||
let username = "username" in serverData ? serverData.username : 'undefined';
|
||||
let password = "password" in serverData ? serverData.password : 'undefined';
|
||||
|
||||
let panaIp = tvIp;
|
||||
//"tvIp" in serverData ? serverData.tvIp : 'undefined';
|
||||
let settingsPort = "port" in serverData ? serverData.port : 'undefined';
|
||||
|
||||
let counter;
|
||||
|
@ -31,7 +33,12 @@ let RIGHT_MARGIN = 15;
|
|||
let midpoint = (g.getWidth() / 2);
|
||||
let IP_AREA = [0, RESULT_HEIGHT, g.getWidth(), g.getHeight()]; // values used for key buttons
|
||||
let KEY_AREA = [0, 24, g.getWidth(), g.getHeight()];
|
||||
let COLORS = {DEFAULT: ['#FF0000'], BLACK: ['#000000'], WHITE: ['#FFFFFF'], GREY: ['#808080', '#222222']}; // background
|
||||
let COLORS = {
|
||||
DEFAULT: ['#FF0000'],
|
||||
BLACK: ['#000000'],
|
||||
WHITE: ['#FFFFFF'],
|
||||
GREY: ['#808080', '#222222']
|
||||
}; // background
|
||||
|
||||
let sourceApps = {
|
||||
"selection": {
|
||||
|
@ -178,7 +185,7 @@ let volume = sourceApps.volume;
|
|||
let selection = sourceApps.selection;
|
||||
let numbers = sourceApps.numbers;
|
||||
|
||||
function assignScreen (screen) {
|
||||
function assignScreen(screen) {
|
||||
currentScreen = screen;
|
||||
console.log(currentScreen);
|
||||
}
|
||||
|
@ -195,8 +202,7 @@ function sendPost(keyPress) {
|
|||
};
|
||||
|
||||
Bangle.http(
|
||||
serverUrl,
|
||||
{
|
||||
serverUrl, {
|
||||
method: 'POST',
|
||||
headers: {
|
||||
'Authorization': `Basic ${credentials}`,
|
||||
|
@ -211,12 +217,11 @@ function sendPost(keyPress) {
|
|||
}
|
||||
|
||||
function receiveDevices() {
|
||||
serverPort = settingsPort;
|
||||
let serverPort = settingsPort;
|
||||
let credentials = btoa(`${username}:${password}`);
|
||||
let serverUrl = `https://${serverDns}:${serverPort}/ssdp-devices.json`;
|
||||
return Bangle.http(
|
||||
serverUrl,
|
||||
{
|
||||
serverUrl, {
|
||||
method: 'GET',
|
||||
headers: {
|
||||
'Authorization': `Basic ${credentials}`
|
||||
|
@ -288,12 +293,12 @@ function displayOutput(num, screenValue) { // top block
|
|||
function buttonPress(val, screenValue) {
|
||||
|
||||
if (screenValue === "ip") {
|
||||
if (val === "<") currNumber = currNumber.slice(0,-1);
|
||||
if (val === "<") currNumber = currNumber.slice(0, -1);
|
||||
else if (val === ".") currNumber = currNumber + ".";
|
||||
else currNumber = currNumber == null ? val : currNumber + val; // currNumber is null if no value pressed
|
||||
|
||||
let ipcount = (currNumber.match(/\./g) || []).length;
|
||||
if (ipcount > 3 || currNumber.length > 15) currNumber = currNumber.slice(0,-1);
|
||||
if (ipcount > 3 || currNumber.length > 15) currNumber = currNumber.slice(0, -1);
|
||||
|
||||
displayOutput(currNumber, screenValue);
|
||||
}
|
||||
|
@ -305,10 +310,8 @@ function buttonPress(val, screenValue) {
|
|||
if (screenValue === "numbers") {
|
||||
if (val === '<') sendPost('back');
|
||||
else if (val === 'ok') sendPost('enter');
|
||||
else sendPost("num_"+val);
|
||||
}
|
||||
|
||||
else if (screenValue === "selection") sendPost(selection[val].key);
|
||||
else sendPost("num_" + val);
|
||||
} else if (screenValue === "selection") sendPost(selection[val].key);
|
||||
else if (screenValue === "volume") sendPost(volume[val].key);
|
||||
}
|
||||
|
||||
|
@ -367,7 +370,7 @@ let tvSelector = {
|
|||
"": {
|
||||
title: "TV Selector",
|
||||
back: function() {
|
||||
load();//E.showMenu(tvSelector);
|
||||
load(); //E.showMenu(tvSelector);
|
||||
}
|
||||
},
|
||||
"Panasonic": function() {
|
||||
|
@ -453,9 +456,15 @@ function subMenu() {
|
|||
|
||||
if (typeof settingsPort !== 'undefined' && settingsPort !== 'undefined') {
|
||||
let portHeader = `Port: ${settingsPort}`;
|
||||
settingssub[portHeader] = function() { IPASSIGN = "port"; ipScreen();};
|
||||
settingssub[portHeader] = function() {
|
||||
IPASSIGN = "port";
|
||||
ipScreen();
|
||||
};
|
||||
} else {
|
||||
settingssub["Set DNS Port"] = function() { IPASSIGN = "port"; ipScreen();};
|
||||
settingssub["Set DNS Port"] = function() {
|
||||
IPASSIGN = "port";
|
||||
ipScreen();
|
||||
};
|
||||
}
|
||||
|
||||
if (typeof panaIp !== 'undefined' && panaIp !== 'undefined') {
|
||||
|
@ -464,24 +473,33 @@ function subMenu() {
|
|||
IPASSIGN = "pana";
|
||||
E.showMenu(deviceSelect);
|
||||
devicefile = require("Storage").readJSON("tvdevicelist.json", true);
|
||||
console.log(devicefile);
|
||||
console.log(devicefile);
|
||||
};
|
||||
} else {
|
||||
settingssub["Set Pana IP"] = function() { IPASSIGN = "pana"; ipScreen();};
|
||||
settingssub["Set Pana IP"] = function() {
|
||||
IPASSIGN = "pana";
|
||||
ipScreen();
|
||||
};
|
||||
}
|
||||
|
||||
if (typeof samsIp !== 'undefined' && panaIp !== 'undefined') {
|
||||
let samsheader = `Sams IP: ${samsIp}`;
|
||||
settingssub[samsheader] = function() { IPASSIGN = "sams"; ipScreen();};
|
||||
settingssub[samsheader] = function() {
|
||||
IPASSIGN = "sams";
|
||||
ipScreen();
|
||||
};
|
||||
} else {
|
||||
settingssub["Set Sams IP"] = function() { IPASSIGN = "sams"; ipScreen();};
|
||||
settingssub["Set Sams IP"] = function() {
|
||||
IPASSIGN = "sams";
|
||||
ipScreen();
|
||||
};
|
||||
}
|
||||
|
||||
E.showMenu(settingssub);
|
||||
}
|
||||
|
||||
const deviceMenu = () => {
|
||||
let parsedResp = JSON.parse(devicefile.resp);
|
||||
let parsedResp = JSON.parse(devicefile.resp);
|
||||
E.showScroller({
|
||||
h: 54,
|
||||
c: parsedResp.length,
|
||||
|
@ -515,13 +533,16 @@ let parsedResp = JSON.parse(devicefile.resp);
|
|||
|
||||
|
||||
let deviceSelect = {
|
||||
"" : { title : "Device Select",
|
||||
back : function() { subMenu(); }
|
||||
"": {
|
||||
title: "Device Select",
|
||||
back: function() {
|
||||
subMenu();
|
||||
}
|
||||
},
|
||||
"Manual IP Assign" : function() {
|
||||
"Manual IP Assign": function() {
|
||||
ipScreen();
|
||||
},
|
||||
"Device Select" : function() {
|
||||
"Device Select": function() {
|
||||
receiveDevices();
|
||||
counter = 5;
|
||||
countDown(deviceMenu);
|
||||
|
@ -624,4 +645,11 @@ Bangle.on('touch', touchHandler);
|
|||
|
||||
Bangle.loadWidgets();
|
||||
Bangle.drawWidgets();
|
||||
mainMenu();
|
||||
|
||||
if (serverData === undefined) {
|
||||
E.showAlert(`${serverDataFile}.json missing.\nSee READ.me`, "Config Error").then(function() {
|
||||
mainMenu();
|
||||
});
|
||||
} else {
|
||||
mainMenu();
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue