-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathoptions.js
executable file
·102 lines (91 loc) · 3.41 KB
/
options.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
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
// Saves settings to chrome.storage
function save_options() {
const paused = document.getElementById('pauseStatus').checked;
const alwaysOn = document.getElementById('alwaysOn').checked;
const specificSitesOnly = document.getElementById('specificSitesOnly').checked;
let sites = [];
Array.from(document.getElementsByClassName('siteInput')).forEach(v => {
if (v.value != "") {
sites.push(v.value);
}
});
set_pause_badge(paused);
chrome.storage.sync.set({
'alwaysOn': alwaysOn,
'sites': sites,
'specificSitesOnly': specificSitesOnly,
'paused': paused
},
function() {
// Update status to let user know options were saved.
let status = document.getElementById('status');
create_site_list(sites);
status.innerHTML = '<p>Saved. Refresh any open tabs for changes to take effect.</p>';
setTimeout(function() {
status.innerHTML = '';
}, 3000);
})
}
function create_site_list(sites) {
html_to_add = "";
sites.forEach(function(site) {
html_to_add += `<div class="siteInputDiv"><input class="siteInput" type="text" value=${site}><button tabindex="0" aria-label="remove" class="removeSite">✖</button></div>`;
});
html_to_add += `<div class="siteInputDiv"><input class="siteInput" type="text" placeholder="Add site">`;
document.getElementById('siteList').innerHTML = html_to_add
// Allows users to remove sites by clicking the x
Array.from(document.getElementsByClassName('removeSite')).forEach(function(element) {
element.addEventListener('click', function() {
element.parentNode.parentNode.removeChild(element.parentNode);
})
})
}
// Restores select box and checkbox state using the preferences
function restore_options() {
getSettings(function(items) {
if (items.paused === true) {
document.getElementById('pauseStatus').checked = true;
} else {
document.getElementById('pauseStatus').checked = false;
}
document.getElementById('alwaysOn').checked = items.alwaysOn;
document.getElementById('specificSitesOnly').checked = items.specificSitesOnly;
set_pause_badge(items.paused);
create_site_list(items.sites);
})
}
function set_pause_badge(paused) {
if (paused === true) {
chrome.browserAction.setBadgeText({
"text": "ll"
});
} else {
chrome.browserAction.setBadgeText({
"text": ""
});
}
}
document.addEventListener('DOMContentLoaded', restore_options);
document.getElementById('save').addEventListener('click', function() {
document.getElementById('status').innerHTML = '';
save_options();
})
// Ensures either 'alwaysOn' or 'specificSitesOnly' is always set to true
document.getElementById('alwaysOn').addEventListener('click',
function() {
if (this.checked) {
document.getElementById('specificSitesOnly').checked = false;
} else {
document.getElementById('specificSitesOnly').checked = true;
}
}
)
document.getElementById('specificSitesOnly').addEventListener('click',
function() {
if (this.checked) {
document.getElementById('alwaysOn').checked = false;
} else {
document.getElementById('alwaysOn').checked = true;
}
}
)