2016-10-15 13:08:46 +02:00
|
|
|
Module.register("updatenotification", {
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
defaults: {
|
|
|
|
updateInterval: 10 * 60 * 1000, // every 10 minutes
|
|
|
|
},
|
|
|
|
|
|
|
|
status: false,
|
|
|
|
|
|
|
|
start: function () {
|
|
|
|
Log.log("Start updatenotification");
|
2016-10-15 17:06:52 +02:00
|
|
|
|
2016-10-15 13:08:46 +02:00
|
|
|
},
|
|
|
|
|
|
|
|
notificationReceived: function(notification, payload, sender) {
|
|
|
|
if (notification === "DOM_OBJECTS_CREATED") {
|
|
|
|
this.sendSocketNotification("CONFIG", this.config);
|
2016-10-15 17:06:52 +02:00
|
|
|
this.hide(0,{lockString: self.identifier});
|
2016-10-15 13:08:46 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
socketNotificationReceived: function (notification, payload) {
|
|
|
|
if (notification === "STATUS") {
|
|
|
|
this.status = payload;
|
2016-10-15 17:06:52 +02:00
|
|
|
this.updateUI();
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
updateUI: function() {
|
|
|
|
var self = this;
|
|
|
|
if (this.status && this.status.behind > 0) {
|
|
|
|
self.updateDom(0);
|
|
|
|
self.show(1000, {lockString: self.identifier});
|
2016-10-15 13:08:46 +02:00
|
|
|
}
|
|
|
|
},
|
|
|
|
|
|
|
|
// Override dom generator.
|
|
|
|
getDom: function () {
|
|
|
|
var wrapper = document.createElement("div");
|
|
|
|
|
|
|
|
if (this.status && this.status.behind > 0) {
|
|
|
|
var message = document.createElement("div");
|
|
|
|
message.className = "small bright";
|
|
|
|
|
|
|
|
var icon = document.createElement("i");
|
|
|
|
icon.className = "fa fa-exclamation-circle";
|
|
|
|
icon.innerHTML = " ";
|
|
|
|
message.appendChild(icon);
|
|
|
|
|
|
|
|
var text = document.createElement("span");
|
2016-11-16 18:19:44 +01:00
|
|
|
if (this.status.module == "default") {
|
|
|
|
text.innerHTML = this.translate("UPDATE_NOTIFICATION");
|
|
|
|
} else {
|
|
|
|
text.innerHTML = this.translate("UPDATE_NOTIFICATION_MODULE").replace("MODULE_NAME", this.status.module);
|
|
|
|
}
|
2016-10-15 13:08:46 +02:00
|
|
|
message.appendChild(text);
|
|
|
|
|
|
|
|
wrapper.appendChild(message);
|
|
|
|
|
|
|
|
var subtext = document.createElement("div");
|
|
|
|
subtext.innerHTML = this.translate("UPDATE_INFO")
|
|
|
|
.replace("COMMIT_COUNT", this.status.behind + " " + ((this.status.behind == 1)? 'commit' : 'commits'))
|
|
|
|
.replace("BRANCH_NAME", this.status.current);
|
|
|
|
subtext.className = "xsmall dimmed";
|
|
|
|
wrapper.appendChild(subtext);
|
|
|
|
}
|
|
|
|
|
|
|
|
return wrapper;
|
|
|
|
}
|
|
|
|
});
|