-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpopup.js
138 lines (125 loc) · 4.31 KB
/
popup.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
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
/*
* This file is part of Adblock Plus <http://adblockplus.org/>,
* Copyright (C) 2006-2014 Eyeo GmbH
*
* Adblock Plus is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* Adblock Plus is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with Adblock Plus. If not, see <http://www.gnu.org/licenses/>.
*/
var backgroundPage = ext.backgroundPage.getWindow();
var imports = ["require", "extractHostFromURL", "openOptions"];
for (var i = 0; i < imports.length; i++)
window[imports[i]] = backgroundPage[imports[i]];
var Filter = require("filterClasses").Filter;
var FilterStorage = require("filterStorage").FilterStorage;
var Prefs = require("prefs").Prefs;
var isWhitelisted = require("whitelisting").isWhitelisted;
var tab = null;
function init()
{
// Mark page as local to hide non-relevant elements
ext.windows.getLastFocused(function(win)
{
win.getActiveTab(function(tab)
{
if (!/^https?:\/\//.exec(tab.url))
document.body.classList.add("local");
});
});
// Attach event listeners
document.getElementById("enabled").addEventListener("click", toggleEnabled, false);
document.getElementById("clickhide").addEventListener("click", activateClickHide, false);
document.getElementById("clickhide-cancel").addEventListener("click", cancelClickHide, false);
document.getElementById("options").addEventListener("click", function()
{
openOptions();
}, false);
// Set up collapsing of menu items
var collapsers = document.getElementsByClassName("collapse");
for (var i = 0; i < collapsers.length; i++)
{
var collapser = collapsers[i];
collapser.addEventListener("click", toggleCollapse, false);
if (!Prefs[collapser.dataset.option])
document.getElementById(collapser.dataset.collapsable).classList.add("collapsed");
}
// Ask content script whether clickhide is active. If so, show cancel button.
// If that isn't the case, ask background.html whether it has cached filters. If so,
// ask the user whether she wants those filters.
// Otherwise, we are in default state.
ext.windows.getLastFocused(function(win)
{
win.getActiveTab(function(t)
{
tab = t;
if (isWhitelisted(tab.url))
document.getElementById("enabled").classList.add("off");
tab.sendMessage({type: "get-clickhide-state"}, function(response)
{
if (response && response.active)
document.body.classList.add("clickhide-active");
});
});
});
}
window.addEventListener("DOMContentLoaded", init, false);
function toggleEnabled()
{
var enabledButton = document.getElementById("enabled")
var disabled = enabledButton.classList.toggle("off");
if (disabled)
{
var host = extractHostFromURL(tab.url).replace(/^www\./, "");
var filter = Filter.fromText("@@||" + host + "^$document");
if (filter.subscriptions.length && filter.disabled)
filter.disabled = false;
else
{
filter.disabled = false;
FilterStorage.addFilter(filter);
}
}
else
{
// Remove any exception rules applying to this URL
var filter = isWhitelisted(tab.url);
while (filter)
{
FilterStorage.removeFilter(filter);
if (filter.subscriptions.length)
filter.disabled = true;
filter = isWhitelisted(tab.url);
}
}
}
function activateClickHide()
{
document.body.classList.add("clickhide-active");
tab.sendMessage({type: "clickhide-activate"});
// Close the popup after a few seconds, so user doesn't have to
activateClickHide.timeout = window.setTimeout(ext.closePopup, 5000);
}
function cancelClickHide()
{
if (activateClickHide.timeout)
{
window.clearTimeout(activateClickHide.timeout);
activateClickHide.timeout = null;
}
document.body.classList.remove("clickhide-active");
tab.sendMessage({type: "clickhide-deactivate"});
}
function toggleCollapse(event)
{
var collapser = event.currentTarget;
Prefs[collapser.dataset.option] = !Prefs[collapser.dataset.option];
collapser.parentNode.classList.toggle("collapsed");
}