Revision: 24519
Updated Code
at March 4, 2010 10:13 by peterwooley
Updated Code
// ==UserScript== // @name Gmail Favicon Alerts 3 // @description Alerts you to the status of your Gmail Inbox through distinct Favicons. // @version 3.1.1a // @date 2010-03-04 // @author Peter Wooley // @namespace http://peterwooley.com // @include https://mail.google.com/mail* // @include http://mail.google.com/mail* // @include https://mail.google.com/mail* // @include http://mail.google.com/a* // @include https://mail.google.com/a* // ==/UserScript== if(!GM_getValue) { function GM_getValue(name, fallback) { return fallback; } } // Register GM Commands and Methods if(!GM_registerMenuCommand) { GM_registerMenuCommand( "Gmail Favicon Alerts > Chat Alerts On", function() { setChat(true) } ); GM_registerMenuCommand( "Gmail Favicon Alerts > Chat Alerts Off", function() { setChat(false) } ); GM_registerMenuCommand( "Gmail Favicon Alerts > Unread Count On", function() { setUnreadCountDisplay(true) } ); GM_registerMenuCommand( "Gmail Favicon Alerts > Unread Count Off", function() { setUnreadCountDisplay(false) } ); function setChat(val) { GM_setValue('chatEnabled', val) }; function setUnreadCountDisplay(val) { GM_setValue('unreadCountDisplay', val) }; } var gfia_instance; var gfia_chat = GM_getValue('chatEnabled', true); if(window.frameElement && window.frameElement.id == "canvas_frame") { new GmailFavIconAlerts(); } function GmailFavIconAlerts() { var self = this; this.construct = function() { this.chat = this.getChat(); this.chatting = false; this.head = window.frameElement.parentNode.parentNode.getElementsByTagName('head')[0]; this.title = this.head.getElementsByTagName('title')[0]; this.inboxText = 'Inbox'; this.chatText = [ {value:'\u2026', chars: 1}, {value:'...', chars: 3} ]; this.timer; this.icons = { chat: '', read: '', unread: '', }; this.pixelMaps = { icons: { 'unread': [ ['','','','','','','','','','','','','','','',''], ['','','','','','','','','','','','','','','',''], ['','','','','','','','','','','','','','','',''], ['#4f7fe8','#4f7fe8','#4f7fe8','#7e9ce0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#7e9ce0','#4f7fe8','#4f7fe8','#4f7fe8'], ['#497ce9','#497ce9','#497ce9','$497ce9','#c0d4ff','#ffffff','#ffffff','#ffffff','#ffffff','#ffffff','#ffffff','#c0d4ff','#497ce9','#497ce9','#497ce9','$497ce9'], ['#4074e5','#4074e5','#5d8cef','#4579e8','#4277e7','#bdd2ff','#ffffff','#ffffff','#ffffff','#ffffff','#bdd2ff','#4277e7','#4f80ec','#5d8cef','#4074e5','#4074e5'], ['#3268de','#3268de','#ffffff','#5585ee','#4076e8','#396fe6','#bad0ff','#ffffff','#ffffff','#bad0ff','#396fe6','#4076e8','#5585ee','#ffffff','#3268de','#3268de'], ['#2359d9','#2359d9','#ffffff','#ffffff','#4e80ee','#336ce6','#3069e5','#b7ceff','#b7ceff','#3069e5','#376ee8','#4e80ee','#ffffff','#ffffff','#2359d9','#2359d9'], ['#144cd2','#144cd2','#fbfbfb','#fbfbfb','#a3b4da','#467ae9','#2f68e4','#2762e1','#2762e1','#2f68e4','#467ae9','#a3b4da','#fbfbfb','#fbfbfb','#144cd2','#144cd2'], ['#0941cc','#0941cc','#f5f5f5','#cfd6e7','#879ac4','#9cadd3','#4073e3','#2962dc','#2962dc','#4073e3','#9cadd3','#879ac4','#cfd6e7','#f5f5f5','#0941cc','#0941cc'], ['#033ac6','#033ac6','#c8d0e0','#8396be','#c8d0e0','#ededed','#ededed','#5a85e3','#5a85e3','#ededed','#ededed','#c8d0e0','#8396be','#c8d0e0','#033ac6','#033ac6'], ['#0031c1','#0031c1','#8092b9','#c3c9d8','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#c3c9d8','#8092b9','#0031c1','#0031c1'], ['#002cbd','#002cbd','#bdc3d2','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#bdc3d2','#002cbd','#002cbd'], ['#0029ba','#0029ba','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#0029ba','#0029ba'], ['','','','','','','','','','','','','','','',''], ['','','','','','','','','','','','','','','',''] ] }, numbers: [ [ [0,1,1,0], [1,0,0,1], [1,0,0,1], [1,0,0,1], [0,1,1,0] ], [ [0,1,0], [1,1,0], [0,1,0], [0,1,0], [1,1,1] ], [ [1,1,1,0], [0,0,0,1], [0,1,1,0], [1,0,0,0], [1,1,1,1] ], [ [1,1,1,0], [0,0,0,1], [0,1,1,0], [0,0,0,1], [1,1,1,0] ], [ [0,0,1,0], [0,1,1,0], [1,0,1,0], [1,1,1,1], [0,0,1,0] ], [ [1,1,1,1], [1,0,0,0], [1,1,1,0], [0,0,0,1], [1,1,1,0] ], [ [0,1,1,0], [1,0,0,0], [1,1,1,0], [1,0,0,1], [0,1,1,0] ], [ [1,1,1,1], [0,0,0,1], [0,0,1,0], [0,1,0,0], [0,1,0,0] ], [ [0,1,1,0], [1,0,0,1], [0,1,1,0], [1,0,0,1], [0,1,1,0] ], [ [0,1,1,0], [1,0,0,1], [0,1,1,1], [0,0,0,1], [0,1,1,0] ], ] }; this.timer = setInterval(this.poll, 500); this.poll(); return true; } this.drawUnreadCount = function(unread) { if(!self.textedCanvas) { self.textedCanvas = []; } if(!self.textedCanvas[unread]) { var iconCanvas = self.getUnreadCanvas(); var textedCanvas = document.createElement('canvas'); textedCanvas.height = textedCanvas.width = iconCanvas.width; var ctx = textedCanvas.getContext('2d'); ctx.drawImage(iconCanvas, 0, 0); ctx.fillStyle = "#fef4ac"; ctx.strokeStyle = "#dabc5c"; ctx.strokeWidth = 1; var count = unread.length; var bgHeight = self.pixelMaps.numbers[0].length; var bgWidth = 0; var padding = count > 2 ? 0 : 1; for(var index = 0; index < count; index++) { bgWidth += self.pixelMaps.numbers[unread[index]][0].length; if(index < count-1) { bgWidth += padding; } } bgWidth = bgWidth > textedCanvas.width-4 ? textedCanvas.width-4 : bgWidth; ctx.fillRect(textedCanvas.width-bgWidth-4,2,bgWidth+4,bgHeight+4); var digit; var digitsWidth = bgWidth; for(var index = 0; index < count; index++) { digit = unread[index]; if (self.pixelMaps.numbers[digit]) { var map = self.pixelMaps.numbers[digit]; var height = map.length; var width = map[0].length; ctx.fillStyle = "#2c3323"; for (var y = 0; y < height; y++) { for (var x = 0; x < width; x++) { if(map[y][x]) { ctx.fillRect(14- digitsWidth + x, y+4, 1, 1); } } } digitsWidth -= width + padding; } } ctx.strokeRect(textedCanvas.width-bgWidth-3.5,2.5,bgWidth+3,bgHeight+3); self.textedCanvas[unread] = textedCanvas; } return self.textedCanvas[unread]; } this.getUnreadCanvas = function() { if(!self.unreadCanvas) { self.unreadCanvas = document.createElement('canvas'); self.unreadCanvas.height = self.unreadCanvas.width = 16; var ctx = self.unreadCanvas.getContext('2d'); for (var y = 0; y < self.unreadCanvas.width; y++) { for (var x = 0; x < self.unreadCanvas.height; x++) { if (self.pixelMaps.icons.unread[y][x]) { ctx.fillStyle = self.pixelMaps.icons.unread[y][x]; ctx.fillRect(x, y, 1, 1); } } } } return self.unreadCanvas; } this.getChat = function() { return false || GM_getValue('chatEnabled', true); } this.getDebugging = function() { return false || GM_getValue('debuggingEnabled', false); } this.getSearchElement = function() { var element; var nav = document.body.getElementsByClassName('n0'); if(nav) { var potential = nav[0]; if(potential.className.indexOf('n0') !== -1) { element = potential; } } return element ? element: null; } this.newChat = function() { var title = self.title.innerHTML; for(var index in self.chatText) { var location = title.indexOf(self.chatText[index].value); if(self.chatText[index].chars + location == title.length) { return true; } } return false; } this.newMail = function() { return self.searchElement.textContent.match(/\((\d*)\)/); } this.getUnreadCountDisplay = function() { return GM_getValue('unreadCountDisplay', true); } this.getUnreadCount = function() { if(this.newMail()) { matches = self.searchElement.textContent.match(/\((\d*)\)/); return matches ? matches[1] : false; } } this.getUnreadCountIcon = function() { var unread = self.getUnreadCount(); if(this.getUnreadCountDisplay()) { return self.drawUnreadCount(unread).toDataURL('image/png'); } else { return self.icons.unread; } } this.poll = function() { if(!self.searchElement) return self.searchElement = self.getSearchElement(); if(self.getChat() && self.newChat()) { return self.setIcon(self.icons.chat); } if(self.newMail()) self.setIcon(self.getUnreadCountIcon()); else self.setIcon(self.icons.read); } this.setIcon = function(icon) { var links = self.head.getElementsByTagName("link"); for (var i = 0; i < links.length; i++) if ((links[i].rel == "shortcut icon" || links[i].rel=="icon") && links[i].href != icon) self.head.removeChild(links[i]); else if(links[i].href == icon) return; var newIcon = document.createElement("link"); newIcon.type = "image/png"; newIcon.rel = "shortcut icon"; newIcon.href = icon; self.head.appendChild(newIcon); var shim = document.createElement('iframe'); shim.width = shim.height = 0; document.body.appendChild(shim); shim.src = "icon"; document.body.removeChild(shim); } this.toString = function() { return '[object GmailFavIconAlerts]'; } return this.construct(); }
Revision: 24518
Updated Code
at March 3, 2010 03:53 by peterwooley
Updated Code
// ==UserScript== // @name Gmail Favicon Alerts 3 // @description Alerts you to the status of your Gmail Inbox through distinct Favicons. // @version 3.1a // @date 2009-11-17 // @author Peter Wooley // @namespace http://peterwooley.com // @include https://mail.google.com/mail* // @include http://mail.google.com/mail* // @include https://mail.google.com/mail* // @include http://mail.google.com/a* // @include https://mail.google.com/a* // ==/UserScript== if(!GM_getValue) { function GM_getValue(name, fallback) { return fallback; } } // Register GM Commands and Methods if(!GM_registerMenuCommand) { GM_registerMenuCommand( "Gmail Favicon Alerts > Chat Alerts On", function() { setChat(true) } ); GM_registerMenuCommand( "Gmail Favicon Alerts > Chat Alerts Off", function() { setChat(false) } ); GM_registerMenuCommand( "Gmail Favicon Alerts > Unread Count On", function() { setUnreadCountDisplay(true) } ); GM_registerMenuCommand( "Gmail Favicon Alerts > Unread Count Off", function() { setUnreadCountDisplay(false) } ); function setChat(val) { GM_setValue('chatEnabled', val) }; function setUnreadCountDisplay(val) { GM_setValue('unreadCountDisplay', val) }; } var gfia_instance; var gfia_chat = GM_getValue('chatEnabled', true); if(window.frameElement && window.frameElement.id == "canvas_frame") { new GmailFavIconAlerts(); } function GmailFavIconAlerts() { var self = this; this.construct = function() { this.chat = this.getChat(); this.chatting = false; this.head = window.frameElement.parentNode.parentNode.firstChild; this.title = this.head.getElementsByTagName('title')[0]; this.inboxText = 'Inbox'; this.chatText = [ {value:'\u2026', chars: 1}, {value:'...', chars: 3} ]; this.timer; this.icons = { chat: '', read: '', unread: '', }; this.pixelMaps = { icons: { 'unread': [ ['','','','','','','','','','','','','','','',''], ['','','','','','','','','','','','','','','',''], ['','','','','','','','','','','','','','','',''], ['#4f7fe8','#4f7fe8','#4f7fe8','#7e9ce0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#7e9ce0','#4f7fe8','#4f7fe8','#4f7fe8'], ['#497ce9','#497ce9','#497ce9','$497ce9','#c0d4ff','#ffffff','#ffffff','#ffffff','#ffffff','#ffffff','#ffffff','#c0d4ff','#497ce9','#497ce9','#497ce9','$497ce9'], ['#4074e5','#4074e5','#5d8cef','#4579e8','#4277e7','#bdd2ff','#ffffff','#ffffff','#ffffff','#ffffff','#bdd2ff','#4277e7','#4f80ec','#5d8cef','#4074e5','#4074e5'], ['#3268de','#3268de','#ffffff','#5585ee','#4076e8','#396fe6','#bad0ff','#ffffff','#ffffff','#bad0ff','#396fe6','#4076e8','#5585ee','#ffffff','#3268de','#3268de'], ['#2359d9','#2359d9','#ffffff','#ffffff','#4e80ee','#336ce6','#3069e5','#b7ceff','#b7ceff','#3069e5','#376ee8','#4e80ee','#ffffff','#ffffff','#2359d9','#2359d9'], ['#144cd2','#144cd2','#fbfbfb','#fbfbfb','#a3b4da','#467ae9','#2f68e4','#2762e1','#2762e1','#2f68e4','#467ae9','#a3b4da','#fbfbfb','#fbfbfb','#144cd2','#144cd2'], ['#0941cc','#0941cc','#f5f5f5','#cfd6e7','#879ac4','#9cadd3','#4073e3','#2962dc','#2962dc','#4073e3','#9cadd3','#879ac4','#cfd6e7','#f5f5f5','#0941cc','#0941cc'], ['#033ac6','#033ac6','#c8d0e0','#8396be','#c8d0e0','#ededed','#ededed','#5a85e3','#5a85e3','#ededed','#ededed','#c8d0e0','#8396be','#c8d0e0','#033ac6','#033ac6'], ['#0031c1','#0031c1','#8092b9','#c3c9d8','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#c3c9d8','#8092b9','#0031c1','#0031c1'], ['#002cbd','#002cbd','#bdc3d2','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#bdc3d2','#002cbd','#002cbd'], ['#0029ba','#0029ba','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#0029ba','#0029ba'], ['','','','','','','','','','','','','','','',''], ['','','','','','','','','','','','','','','',''] ] }, numbers: [ [ [0,1,1,0], [1,0,0,1], [1,0,0,1], [1,0,0,1], [0,1,1,0] ], [ [0,1,0], [1,1,0], [0,1,0], [0,1,0], [1,1,1] ], [ [1,1,1,0], [0,0,0,1], [0,1,1,0], [1,0,0,0], [1,1,1,1] ], [ [1,1,1,0], [0,0,0,1], [0,1,1,0], [0,0,0,1], [1,1,1,0] ], [ [0,0,1,0], [0,1,1,0], [1,0,1,0], [1,1,1,1], [0,0,1,0] ], [ [1,1,1,1], [1,0,0,0], [1,1,1,0], [0,0,0,1], [1,1,1,0] ], [ [0,1,1,0], [1,0,0,0], [1,1,1,0], [1,0,0,1], [0,1,1,0] ], [ [1,1,1,1], [0,0,0,1], [0,0,1,0], [0,1,0,0], [0,1,0,0] ], [ [0,1,1,0], [1,0,0,1], [0,1,1,0], [1,0,0,1], [0,1,1,0] ], [ [0,1,1,0], [1,0,0,1], [0,1,1,1], [0,0,0,1], [0,1,1,0] ], ] }; this.timer = setInterval(this.poll, 500); this.poll(); return true; } this.drawUnreadCount = function(unread) { if(!self.textedCanvas) { self.textedCanvas = []; } if(!self.textedCanvas[unread]) { var iconCanvas = self.getUnreadCanvas(); var textedCanvas = document.createElement('canvas'); textedCanvas.height = textedCanvas.width = iconCanvas.width; var ctx = textedCanvas.getContext('2d'); ctx.drawImage(iconCanvas, 0, 0); ctx.fillStyle = "#fef4ac"; ctx.strokeStyle = "#dabc5c"; ctx.strokeWidth = 1; var count = unread.length; var bgHeight = self.pixelMaps.numbers[0].length; var bgWidth = 0; var padding = count > 2 ? 0 : 1; for(var index = 0; index < count; index++) { bgWidth += self.pixelMaps.numbers[unread[index]][0].length; if(index < count-1) { bgWidth += padding; } } bgWidth = bgWidth > textedCanvas.width-4 ? textedCanvas.width-4 : bgWidth; ctx.fillRect(textedCanvas.width-bgWidth-4,2,bgWidth+4,bgHeight+4); var digit; var digitsWidth = bgWidth; for(var index = 0; index < count; index++) { digit = unread[index]; if (self.pixelMaps.numbers[digit]) { var map = self.pixelMaps.numbers[digit]; var height = map.length; var width = map[0].length; ctx.fillStyle = "#2c3323"; for (var y = 0; y < height; y++) { for (var x = 0; x < width; x++) { if(map[y][x]) { ctx.fillRect(14- digitsWidth + x, y+4, 1, 1); } } } digitsWidth -= width + padding; } } ctx.strokeRect(textedCanvas.width-bgWidth-3.5,2.5,bgWidth+3,bgHeight+3); self.textedCanvas[unread] = textedCanvas; } return self.textedCanvas[unread]; } this.getUnreadCanvas = function() { if(!self.unreadCanvas) { self.unreadCanvas = document.createElement('canvas'); self.unreadCanvas.height = self.unreadCanvas.width = 16; var ctx = self.unreadCanvas.getContext('2d'); for (var y = 0; y < self.unreadCanvas.width; y++) { for (var x = 0; x < self.unreadCanvas.height; x++) { if (self.pixelMaps.icons.unread[y][x]) { ctx.fillStyle = self.pixelMaps.icons.unread[y][x]; ctx.fillRect(x, y, 1, 1); } } } } return self.unreadCanvas; } this.getChat = function() { return false || GM_getValue('chatEnabled', true); } this.getDebugging = function() { return false || GM_getValue('debuggingEnabled', false); } this.getSearchElement = function() { var element; var nav = document.body.getElementsByClassName('n0'); if(nav) { var potential = nav[0]; if(potential.className.indexOf('n0') !== -1) { element = potential; } } return element ? element: null; } this.newChat = function() { var title = self.title.innerHTML; for(var index in self.chatText) { var location = title.indexOf(self.chatText[index].value); if(self.chatText[index].chars + location == title.length) { return true; } } return false; } this.newMail = function() { return self.searchElement.textContent.match(/\((\d*)\)/); } this.getUnreadCountDisplay = function() { return GM_getValue('unreadCountDisplay', true); } this.getUnreadCount = function() { if(this.newMail()) { matches = self.searchElement.textContent.match(/\((\d*)\)/); return matches ? matches[1] : false; } } this.getUnreadCountIcon = function() { var unread = self.getUnreadCount(); if(this.getUnreadCountDisplay()) { return self.drawUnreadCount(unread).toDataURL('image/png'); } else { return self.icons.unread; } } this.poll = function() { if(!self.searchElement) return self.searchElement = self.getSearchElement(); if(self.getChat() && self.newChat()) { return self.setIcon(self.icons.chat); } if(self.newMail()) self.setIcon(self.getUnreadCountIcon()); else self.setIcon(self.icons.read); } this.setIcon = function(icon) { var links = self.head.getElementsByTagName("link"); for (var i = 0; i < links.length; i++) if ((links[i].rel == "shortcut icon" || links[i].rel=="icon") && links[i].href != icon) self.head.removeChild(links[i]); else if(links[i].href == icon) return; var newIcon = document.createElement("link"); newIcon.type = "image/png"; newIcon.rel = "shortcut icon"; newIcon.href = icon; self.head.appendChild(newIcon); var shim = document.createElement('iframe'); shim.width = shim.height = 0; document.body.appendChild(shim); shim.src = "icon"; document.body.removeChild(shim); } this.toString = function() { return '[object GmailFavIconAlerts]'; } return this.construct(); }
Revision: 24517
Initial Code
Initial URL
Initial Description
Initial Title
Initial Tags
Initial Language
at March 3, 2010 03:52 by peterwooley
Initial Code
// ==UserScript== // @name Gmail Favicon Alerts 3 // @description Alerts you to the status of your Gmail Inbox through distinct Favicons. // @version 3.1a // @date 2009-11-17 // @author Peter Wooley // @author Tyler Sticka // @namespace http://peterwooley.com // @include https://mail.google.com/mail* // @include http://mail.google.com/mail* // @include https://mail.google.com/mail* // @include http://mail.google.com/a* // @include https://mail.google.com/a* // ==/UserScript== if(!GM_getValue) { function GM_getValue(name, fallback) { return fallback; } } // Register GM Commands and Methods if(!GM_registerMenuCommand) { GM_registerMenuCommand( "Gmail Favicon Alerts > Chat Alerts On", function() { setChat(true) } ); GM_registerMenuCommand( "Gmail Favicon Alerts > Chat Alerts Off", function() { setChat(false) } ); GM_registerMenuCommand( "Gmail Favicon Alerts > Unread Count On", function() { setUnreadCountDisplay(true) } ); GM_registerMenuCommand( "Gmail Favicon Alerts > Unread Count Off", function() { setUnreadCountDisplay(false) } ); function setChat(val) { GM_setValue('chatEnabled', val) }; function setUnreadCountDisplay(val) { GM_setValue('unreadCountDisplay', val) }; } var gfia_instance; var gfia_chat = GM_getValue('chatEnabled', true); if(window.frameElement && window.frameElement.id == "canvas_frame") { new GmailFavIconAlerts(); } function GmailFavIconAlerts() { var self = this; this.construct = function() { this.chat = this.getChat(); this.chatting = false; this.head = window.frameElement.parentNode.parentNode.firstChild; this.title = this.head.getElementsByTagName('title')[0]; this.inboxText = 'Inbox'; this.chatText = [ {value:'\u2026', chars: 1}, {value:'...', chars: 3} ]; this.timer; this.icons = { chat: '', read: '', unread: '', }; this.pixelMaps = { icons: { 'unread': [ ['','','','','','','','','','','','','','','',''], ['','','','','','','','','','','','','','','',''], ['','','','','','','','','','','','','','','',''], ['#4f7fe8','#4f7fe8','#4f7fe8','#7e9ce0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#95a8d0','#7e9ce0','#4f7fe8','#4f7fe8','#4f7fe8'], ['#497ce9','#497ce9','#497ce9','$497ce9','#c0d4ff','#ffffff','#ffffff','#ffffff','#ffffff','#ffffff','#ffffff','#c0d4ff','#497ce9','#497ce9','#497ce9','$497ce9'], ['#4074e5','#4074e5','#5d8cef','#4579e8','#4277e7','#bdd2ff','#ffffff','#ffffff','#ffffff','#ffffff','#bdd2ff','#4277e7','#4f80ec','#5d8cef','#4074e5','#4074e5'], ['#3268de','#3268de','#ffffff','#5585ee','#4076e8','#396fe6','#bad0ff','#ffffff','#ffffff','#bad0ff','#396fe6','#4076e8','#5585ee','#ffffff','#3268de','#3268de'], ['#2359d9','#2359d9','#ffffff','#ffffff','#4e80ee','#336ce6','#3069e5','#b7ceff','#b7ceff','#3069e5','#376ee8','#4e80ee','#ffffff','#ffffff','#2359d9','#2359d9'], ['#144cd2','#144cd2','#fbfbfb','#fbfbfb','#a3b4da','#467ae9','#2f68e4','#2762e1','#2762e1','#2f68e4','#467ae9','#a3b4da','#fbfbfb','#fbfbfb','#144cd2','#144cd2'], ['#0941cc','#0941cc','#f5f5f5','#cfd6e7','#879ac4','#9cadd3','#4073e3','#2962dc','#2962dc','#4073e3','#9cadd3','#879ac4','#cfd6e7','#f5f5f5','#0941cc','#0941cc'], ['#033ac6','#033ac6','#c8d0e0','#8396be','#c8d0e0','#ededed','#ededed','#5a85e3','#5a85e3','#ededed','#ededed','#c8d0e0','#8396be','#c8d0e0','#033ac6','#033ac6'], ['#0031c1','#0031c1','#8092b9','#c3c9d8','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#e6e6e6','#c3c9d8','#8092b9','#0031c1','#0031c1'], ['#002cbd','#002cbd','#bdc3d2','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#dedede','#bdc3d2','#002cbd','#002cbd'], ['#0029ba','#0029ba','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#7888ad','#0029ba','#0029ba'], ['','','','','','','','','','','','','','','',''], ['','','','','','','','','','','','','','','',''] ] }, numbers: [ [ [0,1,1,0], [1,0,0,1], [1,0,0,1], [1,0,0,1], [0,1,1,0] ], [ [0,1,0], [1,1,0], [0,1,0], [0,1,0], [1,1,1] ], [ [1,1,1,0], [0,0,0,1], [0,1,1,0], [1,0,0,0], [1,1,1,1] ], [ [1,1,1,0], [0,0,0,1], [0,1,1,0], [0,0,0,1], [1,1,1,0] ], [ [0,0,1,0], [0,1,1,0], [1,0,1,0], [1,1,1,1], [0,0,1,0] ], [ [1,1,1,1], [1,0,0,0], [1,1,1,0], [0,0,0,1], [1,1,1,0] ], [ [0,1,1,0], [1,0,0,0], [1,1,1,0], [1,0,0,1], [0,1,1,0] ], [ [1,1,1,1], [0,0,0,1], [0,0,1,0], [0,1,0,0], [0,1,0,0] ], [ [0,1,1,0], [1,0,0,1], [0,1,1,0], [1,0,0,1], [0,1,1,0] ], [ [0,1,1,0], [1,0,0,1], [0,1,1,1], [0,0,0,1], [0,1,1,0] ], ] }; this.timer = setInterval(this.poll, 500); this.poll(); return true; } this.drawUnreadCount = function(unread) { if(!self.textedCanvas) { self.textedCanvas = []; } if(!self.textedCanvas[unread]) { var iconCanvas = self.getUnreadCanvas(); var textedCanvas = document.createElement('canvas'); textedCanvas.height = textedCanvas.width = iconCanvas.width; var ctx = textedCanvas.getContext('2d'); ctx.drawImage(iconCanvas, 0, 0); ctx.fillStyle = "#fef4ac"; ctx.strokeStyle = "#dabc5c"; ctx.strokeWidth = 1; var count = unread.length; var bgHeight = self.pixelMaps.numbers[0].length; var bgWidth = 0; var padding = count > 2 ? 0 : 1; for(var index = 0; index < count; index++) { bgWidth += self.pixelMaps.numbers[unread[index]][0].length; if(index < count-1) { bgWidth += padding; } } bgWidth = bgWidth > textedCanvas.width-4 ? textedCanvas.width-4 : bgWidth; ctx.fillRect(textedCanvas.width-bgWidth-4,2,bgWidth+4,bgHeight+4); var digit; var digitsWidth = bgWidth; for(var index = 0; index < count; index++) { digit = unread[index]; if (self.pixelMaps.numbers[digit]) { var map = self.pixelMaps.numbers[digit]; var height = map.length; var width = map[0].length; ctx.fillStyle = "#2c3323"; for (var y = 0; y < height; y++) { for (var x = 0; x < width; x++) { if(map[y][x]) { ctx.fillRect(14- digitsWidth + x, y+4, 1, 1); } } } digitsWidth -= width + padding; } } ctx.strokeRect(textedCanvas.width-bgWidth-3.5,2.5,bgWidth+3,bgHeight+3); self.textedCanvas[unread] = textedCanvas; } return self.textedCanvas[unread]; } this.getUnreadCanvas = function() { if(!self.unreadCanvas) { self.unreadCanvas = document.createElement('canvas'); self.unreadCanvas.height = self.unreadCanvas.width = 16; var ctx = self.unreadCanvas.getContext('2d'); for (var y = 0; y < self.unreadCanvas.width; y++) { for (var x = 0; x < self.unreadCanvas.height; x++) { if (self.pixelMaps.icons.unread[y][x]) { ctx.fillStyle = self.pixelMaps.icons.unread[y][x]; ctx.fillRect(x, y, 1, 1); } } } } return self.unreadCanvas; } this.getChat = function() { return false || GM_getValue('chatEnabled', true); } this.getDebugging = function() { return false || GM_getValue('debuggingEnabled', false); } this.getSearchElement = function() { var element; var nav = document.body.getElementsByClassName('n0'); if(nav) { var potential = nav[0]; if(potential.className.indexOf('n0') !== -1) { element = potential; } } return element ? element: null; } this.newChat = function() { var title = self.title.innerHTML; for(var index in self.chatText) { var location = title.indexOf(self.chatText[index].value); if(self.chatText[index].chars + location == title.length) { return true; } } return false; } this.newMail = function() { return self.searchElement.textContent.match(/\((\d*)\)/); } this.getUnreadCountDisplay = function() { return GM_getValue('unreadCountDisplay', true); } this.getUnreadCount = function() { if(this.newMail()) { matches = self.searchElement.textContent.match(/\((\d*)\)/); return matches ? matches[1] : false; } } this.getUnreadCountIcon = function() { var unread = self.getUnreadCount(); if(this.getUnreadCountDisplay()) { return self.drawUnreadCount(unread).toDataURL('image/png'); } else { return self.icons.unread; } } this.poll = function() { if(!self.searchElement) return self.searchElement = self.getSearchElement(); if(self.getChat() && self.newChat()) { return self.setIcon(self.icons.chat); } if(self.newMail()) self.setIcon(self.getUnreadCountIcon()); else self.setIcon(self.icons.read); } this.setIcon = function(icon) { var links = self.head.getElementsByTagName("link"); for (var i = 0; i < links.length; i++) if ((links[i].rel == "shortcut icon" || links[i].rel=="icon") && links[i].href != icon) self.head.removeChild(links[i]); else if(links[i].href == icon) return; var newIcon = document.createElement("link"); newIcon.type = "image/png"; newIcon.rel = "shortcut icon"; newIcon.href = icon; self.head.appendChild(newIcon); var shim = document.createElement('iframe'); shim.width = shim.height = 0; document.body.appendChild(shim); shim.src = "icon"; document.body.removeChild(shim); } this.toString = function() { return '[object GmailFavIconAlerts]'; } return this.construct(); }
Initial URL
Initial Description
This is an alpha build of Gmail Favicon Alerts with support for Chrome. It's not perfect, but it's working for me, so I'd love it if you'd give it a try and let me know how it goes.
Initial Title
Gmail Favicon Alerts 3.1a — Chrome Support
Initial Tags
Initial Language
JavaScript