-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmail-unread-button.js
81 lines (60 loc) · 5.15 KB
/
mail-unread-button.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
// ==UserScript==
// @name Google extension: add unread button
// @version 0.1
// @description Show a counter by project by week
// @author Yann Roseau (https://github.com/yroseau)
// @copyright 2019, Yann Roseau (https://github.com/yroseau)
// @license MIT; https://github.com/yroseau/google-extension/blob/master/LICENSE
// @include https://mail.google.com/*
// @grant none
// @run-at document-end
// @downloadURL https://raw.githubusercontent.com/yroseau/google-extension/master/mail-unread-button.js
// @updateURL https://raw.githubusercontent.com/yroseau/google-extension/master/mail-unread-button.js
// ==/UserScript==
var checkExist = setInterval(function() {
// get search form
var searchForm = document.getElementById('aso_search_form_anchor');
// if exists
if (searchForm != null) {
// stop search "search form"
clearInterval(checkExist);
// add button on right of search bar
// @todo extract style in separate css
buttonHtmlString = '<span style="top: 0; margin-top: 12px; position: absolute; left: 100%; margin-left: 1em;"><img title="Click to see unread messages" src="" height="24px" id="readSwitch" style="cursor: pointer;"></span>';
searchForm.insertAdjacentHTML('beforeend', buttonHtmlString);
// get button that we insert above
var readSwitch = document.getElementById('readSwitch');
// on click on "unread message" button
var unreadLabel = 'label:unread';
readSwitch.addEventListener('click', function() {
// get search input
var searchInput = searchForm.querySelector('input')
// if search text contains unready only
if (readSwitch.classList.contains("unreadOnly")) {
// change image source and title of button
readSwitch.src = "";
readSwitch.title = "Click to see unread messages";
// remove unread label
var reg = new RegExp(unreadLabel, "g");
searchInput.value = searchInput.value.replace(reg, '').trim();
// if empty, add label inbox to display inbox content
// because if the search input is empty, google mail do not fetch anything
if (searchInput.value === "") {
searchInput.value = "label:inbox"
}
} else {
// change image source and title of button
readSwitch.src = "";
readSwitch.title = "Click to see all messages";
// add unread label in the search input
searchInput.value = searchInput.value.concat(' ', unreadLabel).trim();
}
// toogle unread class to know in which state we are
readSwitch.classList.toggle('unreadOnly');
// click on search button
// @todo change with a better way to start the search
var buttons = searchForm.querySelectorAll('button')
buttons[buttons.length-1].click()
})
}
}, 100);