2020-02-25 21:47:05 +00:00
|
|
|
// defaultSites are loaded from sites.js at installation extension (and are saved to local storage)
|
|
|
|
// var defaultSites = {};
|
2020-08-20 17:01:12 +00:00
|
|
|
var ext_api = chrome || browser;
|
2017-07-08 17:40:29 +00:00
|
|
|
|
2020-03-25 18:31:28 +00:00
|
|
|
// Saves options to ext_api.storage
|
2017-07-08 17:40:29 +00:00
|
|
|
function save_options() {
|
|
|
|
var gh_url = document.getElementById('bypass_sites').value;
|
|
|
|
var inputEls = document.querySelectorAll('#bypass_sites input');
|
|
|
|
var sites = {};
|
|
|
|
|
|
|
|
var sites = Array.from(inputEls).reduce(function(memo, inputEl) {
|
|
|
|
if (inputEl.checked) {
|
|
|
|
memo[inputEl.dataset.key] = inputEl.dataset.value;
|
|
|
|
}
|
|
|
|
return memo;
|
|
|
|
}, {});
|
|
|
|
|
2020-10-31 19:06:38 +00:00
|
|
|
ext_api.storage.local.set({
|
2017-07-08 17:40:29 +00:00
|
|
|
sites: sites
|
|
|
|
}, function() {
|
|
|
|
// Update status to let user know options were saved.
|
|
|
|
var status = document.getElementById('status');
|
2020-03-09 20:11:38 +00:00
|
|
|
status.textContent = 'Options saved.';
|
2021-01-05 17:53:59 +00:00
|
|
|
setTimeout(function () {
|
|
|
|
status.textContent = '';
|
|
|
|
}, 800);
|
2020-03-04 17:19:35 +00:00
|
|
|
});
|
2017-07-08 17:40:29 +00:00
|
|
|
}
|
|
|
|
|
2020-03-25 18:31:28 +00:00
|
|
|
// Restores checkbox input states using the preferences stored in ext_api.storage.
|
2020-02-25 21:47:05 +00:00
|
|
|
function renderOptions() {
|
2020-11-24 16:12:47 +00:00
|
|
|
var labelEl;
|
2020-10-31 19:06:38 +00:00
|
|
|
ext_api.storage.local.get({
|
2021-01-05 17:53:59 +00:00
|
|
|
sites: {}, sites_custom: {}, sites_excluded: []
|
2017-07-08 17:40:29 +00:00
|
|
|
}, function(items) {
|
|
|
|
var sites = items.sites;
|
2021-01-05 17:53:59 +00:00
|
|
|
var sites_excluded = items.sites_excluded;
|
2017-07-08 17:40:29 +00:00
|
|
|
var sitesEl = document.getElementById('bypass_sites');
|
2020-07-02 10:43:12 +00:00
|
|
|
var clean_key;
|
2017-07-08 17:40:29 +00:00
|
|
|
for (var key in defaultSites) {
|
|
|
|
if (!defaultSites.hasOwnProperty(key)) {
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
var value = defaultSites[key];
|
2020-11-24 16:12:47 +00:00
|
|
|
labelEl = document.createElement('label');
|
2017-07-08 17:40:29 +00:00
|
|
|
var inputEl = document.createElement('input');
|
|
|
|
inputEl.type = 'checkbox';
|
|
|
|
inputEl.dataset.key = key;
|
|
|
|
inputEl.dataset.value = value;
|
2020-07-02 10:43:12 +00:00
|
|
|
clean_key = key.replace(/\s\(.*\)/, '');
|
2021-01-05 17:53:59 +00:00
|
|
|
inputEl.checked = Object.keys(sites).some(title => (title.replace(/\s\(.*\)/, '') === clean_key)) && !sites_excluded.includes(value);
|
2020-02-29 19:08:32 +00:00
|
|
|
if (value !== '###') {
|
2020-07-02 10:43:12 +00:00
|
|
|
labelEl.appendChild(inputEl);
|
2020-11-24 16:12:47 +00:00
|
|
|
} else {
|
|
|
|
labelEl.appendChild(document.createElement('hr'));
|
|
|
|
labelEl.setAttribute('style', ' font-weight: bold;');
|
2020-01-14 19:02:04 +00:00
|
|
|
}
|
2020-07-02 10:43:12 +00:00
|
|
|
labelEl.appendChild(document.createTextNode(' ' + key));
|
2017-07-08 17:40:29 +00:00
|
|
|
sitesEl.appendChild(labelEl);
|
|
|
|
}
|
2020-07-02 10:43:12 +00:00
|
|
|
// custom
|
2020-11-24 16:12:47 +00:00
|
|
|
labelEl.appendChild(document.createElement('hr'));
|
|
|
|
labelEl = document.createElement('label');
|
|
|
|
labelEl.setAttribute('style', ' font-weight: bold;');
|
|
|
|
labelEl.appendChild(document.createTextNode('* Custom Sites'));
|
2020-02-28 15:23:17 +00:00
|
|
|
sitesEl.appendChild(labelEl);
|
|
|
|
var sites_custom = items.sites_custom;
|
2020-08-20 17:01:12 +00:00
|
|
|
var defaultSites_domains = ext_api.extension.getBackgroundPage().defaultSites_domains;
|
2020-07-02 10:43:12 +00:00
|
|
|
for (var key in sites_custom) {
|
2020-08-20 17:01:12 +00:00
|
|
|
var domain = sites_custom[key]['domain'];
|
|
|
|
if (defaultSites.hasOwnProperty(key) || defaultSites_domains.includes(domain)) {
|
2020-02-28 15:23:17 +00:00
|
|
|
continue;
|
|
|
|
}
|
2020-11-24 16:12:47 +00:00
|
|
|
labelEl = document.createElement('label');
|
2020-02-28 15:23:17 +00:00
|
|
|
var inputEl = document.createElement('input');
|
|
|
|
inputEl.type = 'checkbox';
|
|
|
|
inputEl.dataset.key = key;
|
2020-08-20 17:01:12 +00:00
|
|
|
inputEl.dataset.value = domain;
|
2020-07-02 10:43:12 +00:00
|
|
|
clean_key = key.replace(/\s\(.*\)/, '');
|
2021-01-05 17:53:59 +00:00
|
|
|
inputEl.checked = Object.keys(sites).some(title => (title.replace(/\s\(.*\)/, '') === clean_key)) && !sites_excluded.includes(domain);
|
2020-07-02 10:43:12 +00:00
|
|
|
if (value !== '' && value !== '###') {
|
2020-02-28 15:23:17 +00:00
|
|
|
labelEl.appendChild(inputEl);
|
|
|
|
}
|
|
|
|
labelEl.appendChild(document.createTextNode(' '+key));
|
|
|
|
sitesEl.appendChild(labelEl);
|
2020-07-02 10:43:12 +00:00
|
|
|
}
|
2021-01-05 17:53:59 +00:00
|
|
|
// excluded
|
|
|
|
labelEl.appendChild(document.createElement('hr'));
|
|
|
|
labelEl = document.createElement('label');
|
|
|
|
labelEl.setAttribute('style', ' font-weight: bold;');
|
|
|
|
labelEl.appendChild(document.createTextNode('* Excluded Sites (ignored when checked in list)'));
|
|
|
|
sitesEl.appendChild(labelEl);
|
|
|
|
labelEl = document.createElement('label');
|
|
|
|
labelEl.appendChild(document.createTextNode(sites_excluded.join()));
|
|
|
|
sitesEl.appendChild(labelEl);
|
|
|
|
save_options();
|
2017-07-08 17:40:29 +00:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
function selectAll() {
|
|
|
|
var inputEls = Array.from(document.querySelectorAll('input'));
|
2021-01-05 17:53:59 +00:00
|
|
|
inputEls.forEach(function (inputEl) {
|
2017-07-08 17:40:29 +00:00
|
|
|
inputEl.checked = true;
|
|
|
|
});
|
2021-01-05 17:53:59 +00:00
|
|
|
// Update status to let user know all sites are selected.
|
|
|
|
var status = document.getElementById('status');
|
|
|
|
status.textContent = 'All sites selected.';
|
|
|
|
setTimeout(function () {
|
|
|
|
status.textContent = '';
|
|
|
|
}, 800);
|
2017-07-08 17:40:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
function selectNone() {
|
|
|
|
var inputEls = Array.from(document.querySelectorAll('input'));
|
|
|
|
inputEls.forEach(function(inputEl) {
|
|
|
|
inputEl.checked = false;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-11-10 17:15:18 +00:00
|
|
|
function closeButton() {
|
|
|
|
window.close();
|
|
|
|
}
|
|
|
|
|
2017-07-08 17:40:29 +00:00
|
|
|
document.addEventListener('DOMContentLoaded', renderOptions);
|
|
|
|
document.getElementById('save').addEventListener('click', save_options);
|
|
|
|
document.getElementById('select-all').addEventListener('click', selectAll);
|
|
|
|
document.getElementById('select-none').addEventListener('click', selectNone);
|
2020-11-10 17:15:18 +00:00
|
|
|
document.getElementById("button-close").addEventListener('click', closeButton);
|