var reloadTimer = undefined;
var id_user; // ID of the user who is to be accounted for the next coffee
var identifier_registration = false; // true if identifier is supposed to be registered for user
+var eventMsg = undefined; // Feedback message about the last event performed by the user
console.log("hello from flask");
//sendJSON("{\"type\":\"empty\"}");
return;
}
+ if (eventMsg !== undefined) {
+ update("eventMsg", eventMsg);
+ eventMsg = undefined;
+ }
if (id_user !== undefined) {
document.getElementById("nextStep").innerHTML = "Now select a beverage on the coffee machineā¦";
- } else {
+ } else if (flavorChosen !== undefined) {
document.getElementById("nextStep").innerHTML = "Enjoy your " + flavorChosen + "!";
}
document.getElementById("logout_button").innerHTML = '<br>logout<br>(' + timeToLogout + ' s)';
}
catch (err) {
- console.log("Error: ", err);
+ console.log("updateUI error: ", err);
}
}
break;
case "rfid":
if (identifier_registration) {
- ajax("POST", "user/identifier/add", JSON.stringify({ id: msg.uid }), "user");
+ ajax("POST", "user/identifier/add", JSON.stringify({ id: msg.uid }), "content");
addIdentifier_finish();
} else {
var flavor = getFlavor(msg.key);
if (flavor !== "") {
addCoffee(flavor, time);
+ } else if (msg.key == "A") {
+ // When pressing 'Menu' key, logout to not count
+ // subsequent keys as coffee orders.
+ logout();
}
}
break;
replayOfflineQueue();
updateUI();
clearTimeout(reloadTimer);
+ if (id_user)
+ logout();
+ else
+ ajax("GET", "home", "", "content"); // Load home screen on first load or reload
} else {
// Cancel current timer for the case when loadRemote()
// was called multiple times (e.g. multiple ajax()
function login(id) {
- ajax("POST", "login", id, "user");
+ ajax("POST", "login", id, "content");
id_user = id;
countingTimeLogout(120);
}
function logout() {
sendReset();
- ajax("GET", "logout", "", "user");
+ ajax("GET", "logout", "", "content");
id_user = undefined;
timeToLogout = undefined;
identifier_registration = false;
+ window.scrollTo(0, 0); // Scroll up
}
function countingTimeLogout(count_time)
}
function renameUser() {
- ajax("GET", "user/rename?name=" + document.getElementById("username").value, "", "user");
+ ajax("GET", "user/rename?name=" + document.getElementById("username").value, "", "content");
}
function getFlavor(letter) {
flavor: flavor
});
if (id_user) {
- ajax("POST", "coffee/add", data, "user");
+ ajax("POST", "coffee/add", data, "content");
flavorChosen = flavor;
id_user = undefined;
countingTimeLogout(10); //mean 10 seconds
}
}
+
+function addEvent(event_name, action_msg, time = new Date()) {
+ var data = JSON.stringify({
+ time: time.toISOString(),
+ event_name: event_name,
+ uid: id_user
+ });
+ if (id_user) {
+ eventMsg = "You have " + action_msg + ". Thanks!"
+ ajax("POST", "event", data, "content");
+ window.scrollTo(0, 0); // Scroll up
+ }
+}
+
+
function addIdentifier_start() {
identifier_registration = true;
document.getElementById("addIdentifier").disabled = true;
}
function disableIdentifier(id) {
- ajax("POST", "user/identifier/disable", JSON.stringify({ id: id }), "user");
+ ajax("POST", "user/identifier/disable", JSON.stringify({ id: id }), "content");
}
function renameIdentifier(i) {
name: document.getElementById("identifier_name_" + i).value
});
- ajax("POST", "user/identifier/rename", data, "user");
+ ajax("POST", "user/identifier/rename", data, "content");
}
function sendLog(json) {