diff --git a/apps/jsonclock/README.md b/apps/jsonclock/README.md index d449daad7..96a1cdd71 100644 --- a/apps/jsonclock/README.md +++ b/apps/jsonclock/README.md @@ -17,3 +17,4 @@ inspired by [This FitBit face](https://github.com/Sharkgrammer/clockface.json) ![](white.png) ![](no_steps.png) ![](no_location.png) +![](dark-emulator.png) \ No newline at end of file diff --git a/apps/jsonclock/app-icon.js b/apps/jsonclock/app-icon.js index 8c2888b97..dcac31aa3 100644 --- a/apps/jsonclock/app-icon.js +++ b/apps/jsonclock/app-icon.js @@ -1 +1 @@ -require("heatshrink").decompress(atob("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")) +require("heatshrink").decompress(atob("mEwwcCBhEcuPHAQsDwE48AQDnEDx048YCEDQ/AEZAxEnADCEZAKBg5HQCIxiJuARPAEZHBgEBwQGBwE04VNmBHHXYXDhlAg0YsIbBEY8AZQmDhBHcFwcg4AOE4YpCI4swI4NgAQUAAQRHDg0IkAdDkGSAoRBNiBZWjgDCI4UBLAqPHKQMgCJQWFQIIROI6BzD4DXBw0YI5EAhEhwwIBoEwdQwAEWYIDBEYJIYa4REBSQKBBI5kJkmCgECpkwQIprEgcMmOAEZCPVJQYANhwRQaiIjRABqPCgLPEkilBNYxoCmHDa4L+BDAqzFgUIkGCjEgHhwxGAA4uEGYxHImPAahBHDgxEByEAAIIAqI4T+DABXgEaICEADoA=")) diff --git a/apps/jsonclock/app.js b/apps/jsonclock/app.js index 2bfd549b5..1e22615ea 100644 --- a/apps/jsonclock/app.js +++ b/apps/jsonclock/app.js @@ -1,4 +1,5 @@ -var SunCalc = require("suncalc"); // from modules folder +{ +const SunCalc = require("suncalc"); // from modules folder const storage = require('Storage'); const widget_utils = require('widget_utils'); const global_settings = storage.readJSON("setting.json", true) || {}; @@ -42,14 +43,14 @@ const maxLines = Math.floor(usableHeight / lineHeight); var numWidth = 0; // requires the myLocation app -function loadLocation() { +let loadLocation = function() { location = require("Storage").readJSON(LOCATION_FILE, 1) || {}; location.lat = location.lat || 0; location.lon = location.lon || 0; location.location = location.location || null; -} +}; -function getHr(h) { +let getHr = function(h) { var amPm = ""; if (settings.hr_12) { amPm = h < 12 ? "AM" : "PM"; @@ -57,17 +58,17 @@ function getHr(h) { if (h == 0) h = 12; } return [h, amPm]; -} +}; -function extractTime(d) { +let extractTime = function(d) { const out = getHr(d.getHours()); const h = out[0]; const amPm = out[1]; const m = d.getMinutes(); return `${h}:${("0"+m).substr(-2)}${amPm}`; -} +}; -function extractDate(d) { +let extractDate = function(d) { const weekdays = ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"]; const months = ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec" @@ -78,9 +79,9 @@ function extractDate(d) { const day = d.getDate(); return `${weekday} ${month} ${day}`; -} +}; -function getSteps() { +let getSteps = function() { try { return Bangle.getHealthStatus("day").steps; } catch (e) { @@ -89,9 +90,9 @@ function getSteps() { else return null; } -} +}; -function getVal(now, loc) { +let getVal = function(now, loc) { const vals = {}; const currentDateStr = extractDate(now); if (loc.location) { @@ -107,10 +108,9 @@ function getVal(now, loc) { vals.batt_pct = E.getBattery(); vals.steps = getSteps(); return vals; -} +}; - -function loadJson() { +let loadJson = function() { const now = new Date(); vals = getVal(now, location); //vals.steps = null; // For testing; uncomment to see the steps not appear @@ -142,9 +142,9 @@ function loadJson() { jsonText = JSON.stringify(raw, null, 2); // just stringify the object lines = jsonText.split("\n"); -} +}; -function draw() { +let draw = function() { g.clear(); g.setFontAlign(-1, -1); g.setFont("Vector", 10); @@ -169,9 +169,9 @@ function draw() { } redraw(); -} +}; -function redraw() { +let redraw = function() { for (let i = 0; i < maxLines; i++) { const lineIndex = i; const line = lines[lineIndex]; @@ -217,19 +217,18 @@ function redraw() { g.drawString(line, numWidth, y); } } - Bangle.drawWidgets(); -} +}; -function clearVals() { +let clearVals = function() { g.setFont("Vector", fontSize); g.setFontAlign(-1, -1); valuePositions.forEach(pos => { g.setColor(clrs.bg); g.fillRect(pos.x, pos.y, w, pos.y + lineHeight); }); -} +}; -function redrawValues() { +let redrawValues = function() { loadJson(); clearVals(); redraw(); @@ -238,12 +237,12 @@ function redrawValues() { drawTimeout = undefined; redrawValues(); }, 60000 - (Date.now() % 60000)); -} +}; Bangle.on('touch', (zone, e) => { if (e.x >= (buttonY - buttonHeight) && e.x <= (buttonX + buttonHeight) && (e.y >= (buttonY - buttonHeight) && e.y <= (buttonY + buttonHeight))) { - load(); // Exit app + Bangle.showLauncher(); // Exit app } }); @@ -253,16 +252,9 @@ Bangle.on('backlight', function(on) { } }); -Bangle.setUI({ - mode: "clock", - remove: function() { - if (drawTimeout) clearTimeout(drawTimeout); - drawTimeout = undefined; - } -}); - +Bangle.setUI("clock"); loadLocation(); Bangle.loadWidgets(); widget_utils.hide(); draw(); -setTimeout(Bangle.drawWidgets, 0); \ No newline at end of file +} \ No newline at end of file diff --git a/apps/jsonclock/app.png b/apps/jsonclock/app.png index 88e06c4ef..ab6c821f4 100644 Binary files a/apps/jsonclock/app.png and b/apps/jsonclock/app.png differ diff --git a/apps/jsonclock/dark-emulator.png b/apps/jsonclock/dark-emulator.png new file mode 100644 index 000000000..88e06c4ef Binary files /dev/null and b/apps/jsonclock/dark-emulator.png differ diff --git a/apps/jsonclock/metadata.json b/apps/jsonclock/metadata.json index 643c25613..7e6c4d9eb 100644 --- a/apps/jsonclock/metadata.json +++ b/apps/jsonclock/metadata.json @@ -1,19 +1,14 @@ { "id": "jsonclock", - "name": "jsonclock", + "name": "JsonClock", "version": "0.01", - "dependencies": {"mylocation":"app"}, "description": "JSON view of the time, date, steps, battery, and sunrise and sunset times", "icon": "app.png", + "screenshots": [{"url":"app.png"}], "type": "clock", "tags": "clock", - "supports" : ["BANGLEJS2"], - "screenshots": [{"url":"app.png"}], - "readme": "README.md", + "supports": ["BANGLEJS","BANGLEJS2"], "storage": [ {"name":"jsonclock.app.js","url":"app.js"}, - {"name":"jsonclock.img","url":"app-icon.js","evaluate":true}, - {"name":"jsonclock.settings.js","url":"settings.js"} - ], - "data": [{"name":"jsonclock.json"}], - "sortorder": -9 + {"name":"jsonclock.img","url":"app-icon.js","evaluate":true} + ] }