1
0
mirror of https://github.com/kkapsner/CanvasBlocker synced 2025-01-05 11:32:20 +01:00
CanvasBlocker/lib/askForPermission.js

142 lines
3.5 KiB
JavaScript
Raw Permalink Normal View History

2015-09-08 11:41:33 +02:00
/* jslint moz: true */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
(function(){
"use strict";
var scope;
if ((typeof exports) !== "undefined"){
scope = exports;
}
else {
window.scope.askForPermission = {};
scope = window.scope.askForPermission;
}
2016-02-13 12:28:36 +01:00
const {parseErrorStack} = require("./callingStack");
2015-09-08 11:41:33 +02:00
// Check canvas appearance
function canvasAppearance(window, context){
var oldBorder = false;
var canvas = false;
var inDOM = null;
if (context){
var nodeName;
try {
2016-08-06 19:17:36 +02:00
nodeName = context.nodeName;
}
catch (e){}
if (nodeName === "CANVAS"){
2015-09-08 11:41:33 +02:00
canvas = context;
}
else if (
context instanceof window.CanvasRenderingContext2D ||
context instanceof window.WebGLRenderingContext
){
canvas = context.canvas;
}
}
if (canvas){
oldBorder = canvas.style.border;
canvas.style.border = "2px solid red";
inDOM = canvas.ownerDocument.contains(canvas);
}
return {
canvas: canvas,
askCategory: canvas? (inDOM? "visible": "invisible"): "nocanvas",
get text(){
var text = canvas? (this.visible? "visible": "invisible"): "nocanvas";
Object.defineProperty(this, "text", {value: text});
return text;
},
inDom: inDOM,
get visible(){
var visible = inDOM;
if (inDOM){
canvas.scrollIntoView();
var rect = canvas.getBoundingClientRect();
var foundEl = window.document.elementFromPoint(rect.left + rect.width / 2, rect.top + rect.height / 2);
visible = (foundEl === canvas);
}
Object.defineProperty(this, "visible", {value: visible});
return visible;
},
reset: function(){
if (canvas){
canvas.style.border = oldBorder;
}
}
};
}
var modes = new WeakMap();
2016-02-13 12:28:36 +01:00
function getAskMode(window, type, _){
2015-09-08 11:41:33 +02:00
var mode = modes.get(window);
if (mode){
return mode[type];
}
else {
mode = {
context: {
askText: {
visible: _("askForVisiblePermission"),
invisible: _("askForInvisiblePermission"),
nocanvas: _("askForPermission")
},
askStatus: {
alreadyAsked: {},
answer: {}
}
},
2017-06-25 21:14:13 +02:00
input: {
askText: {
visible: _("askForVisibleInputPermission"),
invisible: _("askForInvisibleInputPermission"),
nocanvas: _("askForInputPermission")
},
askStatus: {
alreadyAsked: {},
answer: {}
}
},
2015-09-08 11:41:33 +02:00
readout: {
askText: {
visible: _("askForVisibleReadoutPermission"),
invisible: _("askForInvisibleReadoutPermission"),
nocanvas: _("askForReadoutPermission")
},
askStatus: {
alreadyAsked: {},
answer: {}
}
}
};
modes.set(window, mode);
return mode[type];
}
}
scope.ask = function({window, type, canvas, errorStack}, {_, prefs}){
2015-09-08 11:41:33 +02:00
var answer;
2016-02-13 12:28:36 +01:00
var askMode = getAskMode(window, type, _);
2015-09-08 11:41:33 +02:00
var askStatus = askMode.askStatus;
var appearance = canvasAppearance(window, canvas);
2016-02-13 12:28:36 +01:00
if (prefs("askOnlyOnce") && askStatus.alreadyAsked[appearance.askCategory]){
2015-09-08 11:41:33 +02:00
// already asked
appearance.reset();
return askStatus.answer[appearance.askCategory];
}
else {
// asking
2017-06-25 21:14:13 +02:00
var msg = askMode.askText[appearance.text];
2016-02-13 12:28:36 +01:00
if (prefs("showCallingFile")){
msg += parseErrorStack(errorStack).toString(_);
2015-09-08 11:41:33 +02:00
}
answer = window.confirm(msg)? "allow": "block";
askStatus.alreadyAsked[appearance.text] = true;
askStatus.answer[appearance.text] = answer;
appearance.reset();
return answer;
}
};
}());