-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathfilterList.js
75 lines (69 loc) · 2.3 KB
/
filterList.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
const ENTER_KEY_CODE = 13;
document.addEventListener('DOMContentLoaded', function renderFilterListTable() {
drawFilterListTable(setDeleteButtonsListeners);
setAddButtonListener();
});
function setDeleteButtonsListeners(){
let buttons = document.getElementsByTagName("button");
console.log("button number: " + buttons.length);
for (i = 0; i < buttons.length; i++) {
buttons[i].addEventListener("click", function() {
let url = document.getElementById(this.id[0] + "site").innerHTML;
let id = this.id[0];
chrome.storage.sync.get('blockedSites', function (data){
let blockedSites = data.blockedSites;
blockedSites.splice(id,1);
console.log("selected button index: " + id);
chrome.storage.sync.set({'blockedSites': blockedSites}, function (){
console.log(url + " has been removed from filter list");
drawFilterListTable(setDeleteButtonsListeners);
});
});
});
};
};
function drawFilterListTable(callback){
chrome.storage.sync.get('blockedSites', function (data){
let blockedSites = data.blockedSites;
let tableDiv = document.getElementById('filterList');
let table = "<table>";
let counter = 0;
blockedSites.forEach(function(site){
table += "<tr><td id =\"" + counter + "site\">"
+ site + "</td><td><button id =\""+ counter++
+ "button\">×</button ></td></tr>";
});
table += "</table>";
document.getElementById('filterList').innerHTML = table;
console.log("table drawn");
if (callback === undefined){
callback = function(){};
}
callback();
});
};
function setAddButtonListener(){
document.getElementById('urlInput').addEventListener("keypress", function(event){
if(event.keyCode == ENTER_KEY_CODE){
addUrlToFilterList();
}
});
let addButton = document.getElementById('add');
addButton.addEventListener('click', function() {
addUrlToFilterList();
});
};
function addUrlToFilterList(){
let urlInput = document.getElementById('urlInput');
if(urlInput.value != ""){
chrome.storage.sync.get('blockedSites', function (data){
let blockedSites = data.blockedSites;
blockedSites.push(urlInput.value)
chrome.storage.sync.set({'blockedSites': blockedSites}, function (){
console.log(urlInput + " has been added to filter list");
urlInput.value = "";
drawFilterListTable(setDeleteButtonsListeners);
});
});
}
};