summaryrefslogtreecommitdiff
path: root/web-ui/app/js/page
diff options
context:
space:
mode:
authorGiovane <giovaneliberato@gmail.com>2015-12-29 15:08:54 -0200
committerGiovane <giovaneliberato@gmail.com>2015-12-29 15:13:53 -0200
commit32e625a9389bc7352c911ebc5db289647db3ba66 (patch)
treed24e92685756eaf655e92e4b16a8751c9b8b0e8b /web-ui/app/js/page
parent14f0e57ccbda82206cd8149018b306c6f17032d9 (diff)
Listens to mails available events and count unread #564
- Considering unread all the mails that doesn't have the 'read' status - Remove initial templates because title doesn't support html tags inside
Diffstat (limited to 'web-ui/app/js/page')
-rw-r--r--web-ui/app/js/page/default.js2
-rw-r--r--web-ui/app/js/page/unread_count_title.js25
2 files changed, 19 insertions, 8 deletions
diff --git a/web-ui/app/js/page/default.js b/web-ui/app/js/page/default.js
index 1ca10b50..e33ec723 100644
--- a/web-ui/app/js/page/default.js
+++ b/web-ui/app/js/page/default.js
@@ -128,7 +128,7 @@ define(
feedback.attachTo('#feedback');
feedbackSender.attachTo(document);
- unreadCountTitle.attachTo('#unread-count-title');
+ unreadCountTitle.attachTo(document);
}
return initialize;
diff --git a/web-ui/app/js/page/unread_count_title.js b/web-ui/app/js/page/unread_count_title.js
index f60f5668..26daabec 100644
--- a/web-ui/app/js/page/unread_count_title.js
+++ b/web-ui/app/js/page/unread_count_title.js
@@ -19,21 +19,32 @@
define(
[
'flight/lib/component',
- 'views/templates',
'page/events',
],
- function (defineComponent, templates, events) {
+ function (defineComponent, events) {
'use strict';
-
+
return defineComponent(function () {
- this.render = function () {
- var unreadCountTitleHTML = templates.page.unreadCountTitle();
- this.$node.html(unreadCountTitleHTML);
+ this.getTitleText = function () {
+ return document.title;
+ };
+
+ this.updateCount = function (ev, data) {
+ var unread = data.mails.filter(function (mail) {
+ return mail.status.indexOf('read') === -1;
+ }).length;
+
+ if (unread > 0) {
+ document.title = '(' + unread + ') - ' + this.rawTitle;
+ } else {
+ document.title = this.rawTitle;
+ }
};
this.after('initialize', function () {
- this.render();
+ this.rawTitle = document.title;
+ this.on(document, events.mails.available, this.updateCount);
});
});