mirror of
https://github.com/kkapsner/CanvasBlocker
synced 2025-01-08 20:54:49 +01:00
173 lines
4.9 KiB
JavaScript
173 lines
4.9 KiB
JavaScript
// console.log(window, browser, browser.runtime);
|
|
function modalPrompt(message, defaultValue){
|
|
return new Promise(function(resolve, reject){
|
|
document.body.innerHTML = "";
|
|
document.body.appendChild(document.createTextNode(message));
|
|
var input = document.createElement("input");
|
|
input.value = defaultValue;
|
|
document.body.appendChild(input);
|
|
var button = document.createElement("button");
|
|
button.textContent = "OK";
|
|
button.addEventListener("click", function(){
|
|
resolve(input.value);
|
|
});
|
|
document.body.appendChild(button);
|
|
});
|
|
}
|
|
|
|
function log(...args){
|
|
function leftPad(str, char, pad){
|
|
str = "" + str;
|
|
return char.repeat(pad - str.length) + str;
|
|
}
|
|
args.unshift("page action script:");
|
|
var now = new Date();
|
|
args.unshift(
|
|
now.getFullYear() + "-" +
|
|
leftPad(now.getMonth() + 1, "0", 2) + "-" +
|
|
leftPad(now.getDate(), "0", 2) + " " +
|
|
leftPad(now.getHours(), "0", 2) + ":" +
|
|
leftPad(now.getMinutes(), "0", 2) + ":" +
|
|
leftPad(now.getSeconds(), "0", 2) + "." +
|
|
leftPad(now.getMilliseconds(), "0", 3)
|
|
);
|
|
console.log.apply(console, args);
|
|
}
|
|
|
|
Promise.all([
|
|
browser.tabs.query({active: true, currentWindow: true}),
|
|
browser.storage.local.get().then(function(data){
|
|
Object.keys(data).forEach(function(key){
|
|
settings[key] = data[key];
|
|
});
|
|
return settings;
|
|
})
|
|
]).then(function([tabs, settings]){
|
|
if (!tabs.length){
|
|
throw new Error("noTabsFound");
|
|
}
|
|
else if (tabs.length > 1){
|
|
console.error(tabs);
|
|
throw new Error("tooManyTabsFound");
|
|
}
|
|
|
|
const lists = require("./lists");
|
|
lists.updateAll();
|
|
const {parseErrorStack} = require("./callingStack");
|
|
var actionsCallbacks = {
|
|
displayFullURL: function({url}){
|
|
alert(url.href);
|
|
},
|
|
displayCallingStack: function({errorStack}){
|
|
alert(parseErrorStack(errorStack));
|
|
},
|
|
inspectImage: function({dataURL}){
|
|
document.body.innerHTML = "<img src=" + dataURL + ">";
|
|
},
|
|
ignorelistDomain: function({url}){
|
|
var domain = url.host;
|
|
modalPrompt(
|
|
browser.i18n.getMessage("inputIgnoreDomain"),
|
|
url.host
|
|
).then(function(domain){
|
|
if (domain){
|
|
lists.appendTo("ignore", domain);
|
|
}
|
|
window.close();
|
|
});
|
|
},
|
|
whitelistURL: function({url}){
|
|
modalPrompt(
|
|
browser.i18n.getMessage("inputWhitelistDomain"),
|
|
"^" + url.href.replace(/([\\\+\*\?\[\^\]\$\(\)\{\}\=\!\|\.])/g, "\\$1") + "$"
|
|
).then(function(url){
|
|
if (url){
|
|
lists.appendTo("white", url);
|
|
}
|
|
window.close();
|
|
});
|
|
},
|
|
whitelistDomain: function({url}){
|
|
modalPrompt(
|
|
browser.i18n.getMessage("inputWhitelistURL"),
|
|
url.host
|
|
).then(function(domain){
|
|
if (domain){
|
|
lists.appendTo("white", domain);
|
|
}
|
|
window.close();
|
|
});
|
|
},
|
|
disableNotifications: function(notification){
|
|
browser.storage.local.set({showNotifications: false});
|
|
window.close();
|
|
},
|
|
|
|
};
|
|
|
|
var tab = tabs[0];
|
|
browser.runtime.onMessage.addListener(function(data){
|
|
if (Array.isArray(data["canvasBlocker-notifications"])){
|
|
log("got notifications", data);
|
|
var ul = document.getElementById("prints");
|
|
data["canvasBlocker-notifications"].forEach(function(notification){
|
|
console.log(notification);
|
|
|
|
var url = new URL(notification.url);
|
|
var li = document.createElement("li");
|
|
li.className = "print";
|
|
|
|
|
|
li.appendChild(document.createTextNode(" "));
|
|
|
|
var messageSpan = document.createElement("span");
|
|
var messageParts = browser.i18n.getMessage(notification.messageId).split(/\{url\}/g);
|
|
messageSpan.appendChild(document.createTextNode(messageParts.shift()));
|
|
while (messageParts.length){
|
|
var urlSpan = document.createElement("span");
|
|
urlSpan.textContent = url.hostname;
|
|
urlSpan.title = url.href;
|
|
messageSpan.appendChild(urlSpan);
|
|
messageSpan.appendChild(document.createTextNode(messageParts.shift()));
|
|
}
|
|
messageSpan.title = notification.timestamp + ": " + notification.functionName;
|
|
li.appendChild(messageSpan);
|
|
|
|
li.appendChild(document.createTextNode(" "));
|
|
|
|
var actions = document.createElement("span");
|
|
actions.className = "actions";
|
|
var data = {url, errorStack: notification.errorStack, notification, dataURL: notification.dataURL};
|
|
Object.keys(actionsCallbacks).forEach(function(key, i){
|
|
var button = document.createElement("button");
|
|
button.className = key;
|
|
button.textContent = browser.i18n.getMessage(key);
|
|
button.addEventListener("click", function(){actionsCallbacks[key](data);});
|
|
actions.appendChild(button);
|
|
if (i % 3 === 2){
|
|
actions.appendChild(document.createElement("br"));
|
|
}
|
|
});
|
|
if (notification.dataURL){
|
|
actions.classList.add("imageAvailable");
|
|
}
|
|
li.appendChild(actions);
|
|
|
|
ul.appendChild(li);
|
|
});
|
|
}
|
|
});
|
|
log("clearing the display");
|
|
var ul = document.getElementById("prints");
|
|
ul.innerHTML = "";
|
|
log("request notifications from tab", tab.id);
|
|
browser.tabs.sendMessage(
|
|
tab.id,
|
|
{
|
|
"canvasBlocker-sendNotifications": tab.id
|
|
}
|
|
);
|
|
log("waiting for notifications");
|
|
}).catch(function(e){
|
|
console.error(e);
|
|
}); |