Fix bitcoin halving countdown and add EUR fetch price

This commit is contained in:
Djuri 2023-11-13 17:14:11 +01:00
parent 3f49b3ef4e
commit 6dfc15832b
9 changed files with 72 additions and 19 deletions

View file

@ -71,7 +71,7 @@
<div> <div>
<p>Uptime: {{#if uptime.h }}{{ uptime.h }}h {{/if}}{{ uptime.m }}m {{ uptime.s }}s</p> <p>Uptime: {{#if uptime.h }}{{ uptime.h }}h {{/if}}{{ uptime.m }}m {{ uptime.s }}s</p>
<p> <p>
Price connection: WS Price connection:
<span> <span>
{{#if connectionStatus.price}} {{#if connectionStatus.price}}
&#9989; &#9989;
@ -80,14 +80,15 @@
{{/if}} {{/if}}
</span> </span>
- -
Mempool.space connection: WS Mempool.space connection:
<span> <span>
{{#if connectionStatus.blocks}} {{#if connectionStatus.blocks}}
&#9989; &#9989;
{{else}} {{else}}
&#10060; &#10060;
{{/if}} {{/if}}
</span> </span><br>
<small>If you use "Fetch &euro; price" the WS Price connection will show &#10060; since it uses another data source.</small>
</p> </p>
</div> </div>
</div> </div>
@ -262,7 +263,16 @@
<label class="form-check-label" for="mdnsEnabled">mDNS (restart required)</label> <label class="form-check-label" for="mdnsEnabled">mDNS (restart required)</label>
</div> </div>
</div> </div>
</div>
<div class="row">
<div class="col-sm-12">
<div class="form-check form-switch">
<input class="form-check-input" type="checkbox" id="fetchEurPrice" name="fetchEurPrice" value="1">
<label class="form-check-label" for="fetchEurPrice">Fetch &euro; price (restart required)</label>
</div>
</div>
</div>
<div>
<script id="screens-template" type="text/x-handlebars-template"> <script id="screens-template" type="text/x-handlebars-template">
<div class="row"> <div class="row">
<div class="col-sm-6"> <div class="col-sm-6">

View file

@ -5,7 +5,7 @@ Handlebars.registerHelper('splitText', function (aString) {
var c = aString.split("/").map((el) => { return "<div class=\"flex-items\">" + el + "</div>"; }).join(''); var c = aString.split("/").map((el) => { return "<div class=\"flex-items\">" + el + "</div>"; }).join('');
return "<div class=\"splitText\">" + c + "</div>"; return "<div class=\"splitText\">" + c + "</div>";
} }
if (aString.length > 1) { if (aString.length > 1 && !aString.startsWith("&")) {
return "<div class=\"mediumText\">" + aString + "</div>"; return "<div class=\"mediumText\">" + aString + "</div>";
} }
if (aString.length == 0 || aString === " ") { if (aString.length == 0 || aString === " ") {

View file

@ -23,6 +23,13 @@ let processStatusData = (jsonData) => {
var source = document.getElementById("entry-template").innerHTML; var source = document.getElementById("entry-template").innerHTML;
var template = Handlebars.compile(source); var template = Handlebars.compile(source);
let index = jsonData.data.findIndex(d => d === '[');
if (index !== -1) {
jsonData.data[index] = '&euro;';
}
var context = { var context = {
timerRunning: jsonData.timerRunning, timerRunning: jsonData.timerRunning,
memFreePercent: Math.round(jsonData.espFreeHeap / jsonData.espHeapSize * 100), memFreePercent: Math.round(jsonData.espFreeHeap / jsonData.espHeapSize * 100),
@ -128,6 +135,9 @@ fetch('/api/settings', {
if (jsonData.ledTestOnPower) if (jsonData.ledTestOnPower)
document.getElementById('ledTestOnPower').checked = true; document.getElementById('ledTestOnPower').checked = true;
if (jsonData.fetchEurPrice)
document.getElementById('fetchEurPrice').checked = true;
// let nodeFields = ["rpcHost", "rpcPort", "rpcUser", "tzOffset"]; // let nodeFields = ["rpcHost", "rpcPort", "rpcUser", "tzOffset"];
// for (let n of nodeFields) { // for (let n of nodeFields) {

View file

@ -11,7 +11,7 @@
data_dir = data/build data_dir = data/build
[env] [env]
platform = espressif32 platform = https://github.com/platformio/platform-espressif32.git
framework = arduino, espidf framework = arduino, espidf
monitor_speed = 115200 monitor_speed = 115200
upload_speed = 921600 upload_speed = 921600
@ -57,3 +57,8 @@ extends = env:lolin_s3_mini
build_flags = build_flags =
${env:lolin_s3_mini.build_flags} ${env:lolin_s3_mini.build_flags}
-D USE_QR -D USE_QR
[env:lolin_s3_mini_qr_ota]
extends = env:lolin_s3_mini_qr
upload_protocol = espota
upload_port = 192.168.23.30

View file

@ -167,8 +167,12 @@ void setupPreferences()
void setupWebsocketClients(void *pvParameters) void setupWebsocketClients(void *pvParameters)
{ {
setupBlockNotify(); setupBlockNotify();
// setupPriceFetchTask();
if (preferences.getBool("fetchEurPrice", false)) {
setupPriceFetchTask();
} else {
setupPriceNotify(); setupPriceNotify();
}
vTaskDelete(NULL); vTaskDelete(NULL);
} }

View file

@ -120,6 +120,8 @@ void setEpdContent(std::array<String, NUM_SCREENS> newEpdContent, bool forceUpda
{ {
std::lock_guard<std::mutex> lock(epdUpdateMutex); std::lock_guard<std::mutex> lock(epdUpdateMutex);
waitUntilNoneBusy();
for (uint i = 0; i < NUM_SCREENS; i++) for (uint i = 0; i < NUM_SCREENS; i++)
{ {
if (newEpdContent[i].compareTo(currentEpdContent[i]) != 0 || forceUpdate) if (newEpdContent[i].compareTo(currentEpdContent[i]) != 0 || forceUpdate)
@ -387,7 +389,7 @@ void waitUntilNoneBusy()
vTaskDelay(10); vTaskDelay(10);
if (count == 200) if (count == 200)
{ {
displays[i].init(0, false); //displays[i].init(0, false);
vTaskDelay(100); vTaskDelay(100);
} }
else if (count > 205) else if (count > 205)

View file

@ -27,17 +27,17 @@ void taskPriceFetch(void *pvParameters)
String payload = http->getString(); String payload = http->getString();
StaticJsonDocument<96> doc; StaticJsonDocument<96> doc;
deserializeJson(doc, payload); deserializeJson(doc, payload);
usdPrice = doc["bitcoin"]["usd"]; // usdPrice = doc["bitcoin"]["usd"];
eurPrice = doc["bitcoin"]["eur"]; eurPrice = doc["bitcoin"]["eur"].as<uint>();
setPrice(usdPrice); setPrice(eurPrice);
if (workQueue != nullptr && (getCurrentScreen() == SCREEN_BTC_TICKER || getCurrentScreen() == SCREEN_MSCW_TIME || getCurrentScreen() == SCREEN_MARKET_CAP)) if (workQueue != nullptr && (getCurrentScreen() == SCREEN_BTC_TICKER || getCurrentScreen() == SCREEN_MSCW_TIME || getCurrentScreen() == SCREEN_MARKET_CAP))
{ {
WorkItem priceUpdate = {TASK_PRICE_UPDATE, 0}; WorkItem priceUpdate = {TASK_PRICE_UPDATE, 0};
xQueueSend(workQueue, &priceUpdate, portMAX_DELAY); xQueueSend(workQueue, &priceUpdate, portMAX_DELAY);
} }
preferences.putUInt("lastPrice", usdPrice); preferences.putUInt("lastPrice", eurPrice);
} }
else else
{ {

View file

@ -48,14 +48,23 @@ void workerTask(void *pvParameters)
{ {
firstIndex = 0; firstIndex = 0;
uint price = getPrice(); uint price = getPrice();
char priceSymbol = '$';
if (getCurrentScreen() == SCREEN_BTC_TICKER) if (getCurrentScreen() == SCREEN_BTC_TICKER)
{ {
priceString = ("$" + String(price)).c_str(); if (preferences.getBool("fetchEurPrice", false)) {
priceSymbol = '[';
}
priceString = (priceSymbol + String(price)).c_str();
if (priceString.length() < (NUM_SCREENS)) if (priceString.length() < (NUM_SCREENS))
{ {
priceString.insert(priceString.begin(), NUM_SCREENS - priceString.length(), ' '); priceString.insert(priceString.begin(), NUM_SCREENS - priceString.length(), ' ');
if (preferences.getBool("fetchEurPrice", false)) {
taskEpdContent[0] = "BTC/EUR";
} else {
taskEpdContent[0] = "BTC/USD"; taskEpdContent[0] = "BTC/USD";
}
firstIndex = 1; firstIndex = 1;
} }
} }
@ -154,7 +163,7 @@ void workerTask(void *pvParameters)
taskEpdContent[1] = "HALV/ING"; taskEpdContent[1] = "HALV/ING";
taskEpdContent[(NUM_SCREENS - 5)] = String(years) + "/YRS"; taskEpdContent[(NUM_SCREENS - 5)] = String(years) + "/YRS";
taskEpdContent[(NUM_SCREENS - 4)] = String(days) + "/DAYS"; taskEpdContent[(NUM_SCREENS - 4)] = String(days) + "/DAYS";
taskEpdContent[(NUM_SCREENS - 3)] = String(days) + "/HRS"; taskEpdContent[(NUM_SCREENS - 3)] = String(hours) + "/HRS";
taskEpdContent[(NUM_SCREENS - 2)] = String(mins) + "/MINS"; taskEpdContent[(NUM_SCREENS - 2)] = String(mins) + "/MINS";
taskEpdContent[(NUM_SCREENS - 1)] = "TO/GO"; taskEpdContent[(NUM_SCREENS - 1)] = "TO/GO";
} }

View file

@ -244,7 +244,7 @@ void onApiSettingsGet(AsyncWebServerRequest *request)
root["mcapBigChar"] = preferences.getBool("mcapBigChar", true); root["mcapBigChar"] = preferences.getBool("mcapBigChar", true);
root["mdnsEnabled"] = preferences.getBool("mdnsEnabled", true); root["mdnsEnabled"] = preferences.getBool("mdnsEnabled", true);
root["otaEnabled"] = preferences.getBool("otaEnabled", true); root["otaEnabled"] = preferences.getBool("otaEnabled", true);
root["fetchEurPrice"] = preferences.getBool("fetchEurPrice", false);
root["hostname"] = getMyHostname(); root["hostname"] = getMyHostname();
root["ip"] = WiFi.localIP(); root["ip"] = WiFi.localIP();
@ -305,6 +305,19 @@ void onApiSettingsPost(AsyncWebServerRequest *request)
settingsChanged = processEpdColorSettings(request); settingsChanged = processEpdColorSettings(request);
if (request->hasParam("fetchEurPrice", true))
{
AsyncWebParameter *fetchEurPrice = request->getParam("fetchEurPrice", true);
preferences.putBool("fetchEurPrice", fetchEurPrice->value().toInt());
settingsChanged = true;
}
else
{
preferences.putBool("fetchEurPrice", 0);
settingsChanged = true;
}
if (request->hasParam("ledTestOnPower", true)) if (request->hasParam("ledTestOnPower", true))
{ {
AsyncWebParameter *ledTestOnPower = request->getParam("ledTestOnPower", true); AsyncWebParameter *ledTestOnPower = request->getParam("ledTestOnPower", true);