mirror of https://github.com/espruino/BangleApps
Update app.js
parent
4f604a949d
commit
d2b2b75f2e
|
@ -1,9 +1,6 @@
|
||||||
var Layout = require("Layout");
|
var Layout = require("Layout");
|
||||||
var key = "";
|
|
||||||
var myTimeout;
|
var myTimeout;
|
||||||
var pins = Object.assign(require('Storage').readJSON("pinsafe.json", true) || {});
|
var pins = Object.assign(require('Storage').readJSON("pinsafe.json", true) || {});
|
||||||
print (pins);
|
|
||||||
|
|
||||||
function mainMenu() {
|
function mainMenu() {
|
||||||
if (myTimeout) clearTimeout(myTimeout);
|
if (myTimeout) clearTimeout(myTimeout);
|
||||||
var menu = {
|
var menu = {
|
||||||
|
@ -11,12 +8,13 @@ function mainMenu() {
|
||||||
"< Back" : Bangle.load
|
"< Back" : Bangle.load
|
||||||
};
|
};
|
||||||
if (Object.keys(pins).length==0) Object.assign(menu, {"NO CARDS":""});
|
if (Object.keys(pins).length==0) Object.assign(menu, {"NO CARDS":""});
|
||||||
else for (let c in pins) {
|
else for (let id in pins) {
|
||||||
let pin=pins[c];
|
let p=pins[id];
|
||||||
menu[c]=()=>{decode(pin);};
|
menu[id]=()=>{decode(p);};
|
||||||
}
|
}
|
||||||
Object.assign(menu, {"Add Card": addCard});
|
menu["Add Card"]=addCard;
|
||||||
Object.assign(menu, {"Remove Card":removeCard});
|
menu["Remove Card"]=removeCard;
|
||||||
|
g.clear();
|
||||||
E.showMenu(menu);
|
E.showMenu(menu);
|
||||||
}
|
}
|
||||||
function decode(pin) {
|
function decode(pin) {
|
||||||
|
@ -48,40 +46,41 @@ function showNumpad(text, callback) {
|
||||||
update();
|
update();
|
||||||
}
|
}
|
||||||
function update() {
|
function update() {
|
||||||
numPad.clear(numPad.output);
|
g.reset();
|
||||||
numPad.output.label="Key:"+key;
|
g.clearRect(0,0,g.getWidth(),23);
|
||||||
numPad.render(numPad.output);
|
g.setFont("Vector:24").setFontAlign(1,0).drawString(text+key,g.getWidth(),12);
|
||||||
}
|
}
|
||||||
|
ds="12%";
|
||||||
var numPad = new Layout ({
|
var numPad = new Layout ({
|
||||||
type:"v", c: [{
|
type:"v", c: [{
|
||||||
type:"v", width:180, c: [
|
type:"v", c: [
|
||||||
{type:"txt", font:"15%", pad:1, fillx:1, filly:1, id: "output", label:text+key},
|
{type:"", height:24},
|
||||||
{type:"h", c: [
|
{type:"h",filly:1, c: [
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:"7", cb:l=>{addDigit("7");}},
|
{type:"btn", font:ds, width:58, label:"7", cb:l=>{addDigit("7");}},
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:"8", cb:l=>{addDigit("8");}},
|
{type:"btn", font:ds, width:58, label:"8", cb:l=>{addDigit("8");}},
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:"9", cb:l=>{addDigit("9");}}
|
{type:"btn", font:ds, width:58, label:"9", cb:l=>{addDigit("9");}}
|
||||||
]},
|
]},
|
||||||
{type:"h", c: [
|
{type:"h",filly:1, c: [
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:"4", cb:l=>{addDigit("4");}},
|
{type:"btn", font:ds, width:58, label:"4", cb:l=>{addDigit("4");}},
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:"5", cb:l=>{addDigit("5");}},
|
{type:"btn", font:ds, width:58, label:"5", cb:l=>{addDigit("5");}},
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:"6", cb:l=>{addDigit("6");}}
|
{type:"btn", font:ds, width:58, label:"6", cb:l=>{addDigit("6");}}
|
||||||
]},
|
]},
|
||||||
{type:"h", c: [
|
{type:"h",filly:1, c: [
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:"1", cb:l=>{addDigit("1");}},
|
{type:"btn", font:ds, width:58, label:"1", cb:l=>{addDigit("1");}},
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:"2", cb:l=>{addDigit("2");}},
|
{type:"btn", font:ds, width:58, label:"2", cb:l=>{addDigit("2");}},
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:"3", cb:l=>{addDigit("3");}}
|
{type:"btn", font:ds, width:58, label:"3", cb:l=>{addDigit("3");}}
|
||||||
]},
|
]},
|
||||||
{type:"h", c: [
|
{type:"h",filly:1, c: [
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:" 0 ", cb:l=>{addDigit("0");}},
|
{type:"btn", font:ds, width:58, label:"0", cb:l=>{addDigit("0");}},
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label:" C ", cb:l=>{key=key.slice(0,-1); update();}},
|
{type:"btn", font:ds, width:58, label:"C", cb:l=>{key=key.slice(0,-1); update();}},
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, id:"OK", label:" OK", cb:callback}
|
{type:"btn", font:ds, width:58, id:"OK", label:"OK", cb:callback}
|
||||||
]}
|
]}
|
||||||
]}
|
]}
|
||||||
], lazy:true});
|
], lazy:true});
|
||||||
g.clear();
|
g.clear();
|
||||||
numPad.render();
|
numPad.render();
|
||||||
|
update();
|
||||||
}
|
}
|
||||||
|
|
||||||
function removeCard() {
|
function removeCard() {
|
||||||
var menu = {
|
var menu = {
|
||||||
"" : {title : "select card"},
|
"" : {title : "select card"},
|
||||||
|
@ -97,8 +96,12 @@ function removeCard() {
|
||||||
{type:"txt", font:"15%", pad:1, fillx:1, filly:1, label:"Delete"},
|
{type:"txt", font:"15%", pad:1, fillx:1, filly:1, label:"Delete"},
|
||||||
{type:"txt", font:"15%", pad:1, fillx:1, filly:1, label:card+"?"},
|
{type:"txt", font:"15%", pad:1, fillx:1, filly:1, label:card+"?"},
|
||||||
{type:"h", c: [
|
{type:"h", c: [
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label: "YES", cb:l=>{delete pins[card];mainMenu();}},
|
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label: "YES", cb:l=>{
|
||||||
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label: "NO", cb:l=>{mainMenu();}}
|
delete pins[card];
|
||||||
|
require('Storage').writeJSON("pinsafe.json", pins);
|
||||||
|
mainMenu();
|
||||||
|
}},
|
||||||
|
{type:"btn", font:"15%", pad:1, fillx:1, filly:1, label: " NO", cb:l=>{mainMenu();}}
|
||||||
]}
|
]}
|
||||||
], lazy:true});
|
], lazy:true});
|
||||||
g.clear();
|
g.clear();
|
||||||
|
@ -108,9 +111,9 @@ function removeCard() {
|
||||||
E.showMenu(menu);
|
E.showMenu(menu);
|
||||||
}
|
}
|
||||||
function addCard() {
|
function addCard() {
|
||||||
var help = new Layout({
|
var infoScreen = new Layout({
|
||||||
type:"v", c: [
|
type:"v", c: [
|
||||||
{type:"btn", font:"8%", label:"Enter a name, PIN\nand key for your\ncard. The pin will\nbe stored on your\ndevice in encrypted\nform.", cb:l=>{
|
{type:"txt", font:"10%", label:"Enter a name, PIN\nand key for your\ncard. The PIN will\nbe stored on your\ndevice in encrypted\nform.\nTap to continue!", cb:l=>{
|
||||||
require("textinput").input({text:""}).then(result => {
|
require("textinput").input({text:""}).then(result => {
|
||||||
if (pins[result]!=undefined) {
|
if (pins[result]!=undefined) {
|
||||||
E.showMenu();
|
E.showMenu();
|
||||||
|
@ -132,9 +135,8 @@ function addCard() {
|
||||||
]
|
]
|
||||||
});
|
});
|
||||||
g.clear();
|
g.clear();
|
||||||
help.render();
|
infoScreen.render();
|
||||||
}
|
}
|
||||||
|
|
||||||
function encodeCard(name) {
|
function encodeCard(name) {
|
||||||
showNumpad("PIN:", function() {
|
showNumpad("PIN:", function() {
|
||||||
if (key.length==0) mainMenu();
|
if (key.length==0) mainMenu();
|
||||||
|
@ -157,6 +159,5 @@ function encodeCard(name) {
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
g.reset();
|
g.reset();
|
||||||
g.clear();
|
|
||||||
Bangle.setUI();
|
Bangle.setUI();
|
||||||
mainMenu();
|
mainMenu();
|
||||||
|
|
Loading…
Reference in New Issue