diff options
author | Giovane <giovaneliberato@gmail.com> | 2015-12-29 15:08:54 -0200 |
---|---|---|
committer | Giovane <giovaneliberato@gmail.com> | 2015-12-29 15:13:53 -0200 |
commit | 32e625a9389bc7352c911ebc5db289647db3ba66 (patch) | |
tree | d24e92685756eaf655e92e4b16a8751c9b8b0e8b /web-ui/app/js/page | |
parent | 14f0e57ccbda82206cd8149018b306c6f17032d9 (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.js | 2 | ||||
-rw-r--r-- | web-ui/app/js/page/unread_count_title.js | 25 |
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); }); }); |