2016-10-15 13:08:46 +02:00
|
|
|
Module.register("updatenotification", {
|
|
|
|
|
|
|
|
defaults: {
|
|
|
|
updateInterval: 10 * 60 * 1000, // every 10 minutes
|
2019-06-29 15:59:03 -05:00
|
|
|
refreshInterval: 24 * 60 * 60 * 1000, // one day
|
2016-10-15 13:08:46 +02:00
|
|
|
},
|
|
|
|
|
2019-06-29 15:59:03 -05:00
|
|
|
suspended: false,
|
|
|
|
moduleList: {},
|
2016-10-15 13:08:46 +02:00
|
|
|
|
|
|
|
start: function () {
|
2019-06-29 15:59:03 -05:00
|
|
|
var self = this
|
2016-10-15 13:08:46 +02:00
|
|
|
Log.log("Start updatenotification");
|
2019-06-29 15:59:03 -05:00
|
|
|
setInterval( () => { self.moduleList = {};self.updateDom(2) } , self.config.refreshInterval)
|
2016-10-15 13:08:46 +02:00
|
|
|
},
|
|
|
|
|
2017-07-17 14:23:24 +02:00
|
|
|
notificationReceived: function (notification, payload, sender) {
|
2016-10-15 13:08:46 +02:00
|
|
|
if (notification === "DOM_OBJECTS_CREATED") {
|
|
|
|
this.sendSocketNotification("CONFIG", this.config);
|
2016-11-18 12:53:49 +01:00
|
|
|
this.sendSocketNotification("MODULES", Module.definitions);
|
2019-06-29 15:59:03 -05:00
|
|
|
//this.hide(0, { lockString: self.identifier });
|
2016-10-15 13:08:46 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
socketNotificationReceived: function (notification, payload) {
|
|
|
|
if (notification === "STATUS") {
|
2019-06-29 15:59:03 -05:00
|
|
|
this.updateUI(payload);
|
2016-10-15 17:06:52 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2019-06-29 15:59:03 -05:00
|
|
|
updateUI: function (payload) {
|
2016-10-15 17:06:52 +02:00
|
|
|
var self = this;
|
2019-06-29 15:59:03 -05:00
|
|
|
if (payload && payload.behind > 0) {
|
|
|
|
// if we haven't seen info for this module
|
|
|
|
if(this.moduleList[payload.module] == undefined){
|
|
|
|
// save it
|
|
|
|
this.moduleList[payload.module]=payload;
|
|
|
|
self.updateDom(2);
|
|
|
|
}
|
|
|
|
//self.show(1000, { lockString: self.identifier });
|
|
|
|
|
|
|
|
} else if (payload && payload.behind == 0){
|
|
|
|
// if the module WAS in the list, but shouldn't be
|
|
|
|
if(this.moduleList[payload.module] != undefined){
|
|
|
|
// remove it
|
|
|
|
delete this.moduleList[payload.module]
|
|
|
|
self.updateDom(2);
|
|
|
|
}
|
|
|
|
}
|
2016-10-15 13:08:46 +02:00
|
|
|
},
|
|
|
|
|
2019-06-29 15:59:03 -05:00
|
|
|
diffLink: function(module, text) {
|
|
|
|
var localRef = module.hash;
|
|
|
|
var remoteRef = module.tracking.replace(/.*\//, "");
|
2017-10-16 09:35:25 +02:00
|
|
|
return "<a href=\"https://github.com/MichMich/MagicMirror/compare/"+localRef+"..."+remoteRef+"\" "+
|
|
|
|
"class=\"xsmall dimmed\" "+
|
|
|
|
"style=\"text-decoration: none;\" "+
|
|
|
|
"target=\"_blank\" >" +
|
|
|
|
text +
|
|
|
|
"</a>";
|
|
|
|
},
|
|
|
|
|
2016-10-15 13:08:46 +02:00
|
|
|
// Override dom generator.
|
|
|
|
getDom: function () {
|
2019-06-29 15:59:03 -05:00
|
|
|
wrapper = document.createElement("div");
|
|
|
|
if(this.suspended==false){
|
|
|
|
// process the hash of module info found
|
|
|
|
for(key of Object.keys(this.moduleList)){
|
|
|
|
let m= this.moduleList[key]
|
2016-10-15 13:08:46 +02:00
|
|
|
|
2019-06-29 15:59:03 -05:00
|
|
|
var message = document.createElement("div");
|
|
|
|
message.className = "small bright";
|
2016-10-15 13:08:46 +02:00
|
|
|
|
2019-06-29 15:59:03 -05:00
|
|
|
var icon = document.createElement("i");
|
|
|
|
icon.className = "fa fa-exclamation-circle";
|
|
|
|
icon.innerHTML = " ";
|
|
|
|
message.appendChild(icon);
|
|
|
|
|
|
|
|
var updateInfoKeyName = m.behind == 1 ? "UPDATE_INFO_SINGLE" : "UPDATE_INFO_MULTIPLE";
|
2016-10-15 13:08:46 +02:00
|
|
|
|
2019-06-29 15:59:03 -05:00
|
|
|
var subtextHtml = this.translate(updateInfoKeyName, {
|
|
|
|
COMMIT_COUNT: m.behind,
|
|
|
|
BRANCH_NAME: m.current
|
|
|
|
});
|
|
|
|
|
|
|
|
var text = document.createElement("span");
|
|
|
|
if (m.module == "default") {
|
|
|
|
text.innerHTML = this.translate("UPDATE_NOTIFICATION");
|
|
|
|
subtextHtml = this.diffLink(m,subtextHtml);
|
|
|
|
} else {
|
|
|
|
text.innerHTML = this.translate("UPDATE_NOTIFICATION_MODULE", {
|
|
|
|
MODULE_NAME: m.module
|
|
|
|
});
|
|
|
|
}
|
|
|
|
message.appendChild(text);
|
|
|
|
|
|
|
|
wrapper.appendChild(message);
|
|
|
|
|
|
|
|
var subtext = document.createElement("div");
|
|
|
|
subtext.innerHTML = subtextHtml;
|
|
|
|
subtext.className = "xsmall dimmed";
|
|
|
|
wrapper.appendChild(subtext);
|
|
|
|
}
|
|
|
|
}
|
2016-10-15 13:08:46 +02:00
|
|
|
return wrapper;
|
2019-06-29 15:59:03 -05:00
|
|
|
},
|
|
|
|
|
|
|
|
suspend: function() {
|
|
|
|
this.suspended=true;
|
|
|
|
},
|
|
|
|
resume: function() {
|
|
|
|
this.suspended=false;
|
|
|
|
this.updateDom(2);
|
2016-10-15 13:08:46 +02:00
|
|
|
}
|
|
|
|
});
|