1
0
mirror of https://codeberg.org/nobody/LocalCDN.git synced 2025-01-18 12:39:53 +01:00
LocalCDN-Firefox-Chrome-Brave/pages/popup/popup.js

577 lines
16 KiB
JavaScript
Raw Normal View History

2020-02-27 13:45:29 +01:00
/**
* Main Popup Page
* Belongs to Decentraleyes.
*
* @author Thomas Rientjes
* @author nobody42
2020-02-27 13:45:29 +01:00
* @since 2016-08-09
* @license MPL 2.0
*
* 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/.
*/
'use strict';
/**
* Popup
*/
let counterFrameworks = 0;
2020-05-30 10:04:48 +02:00
let counterCDNs = 0;
let oversized = false;
2020-02-27 13:45:29 +01:00
var popup = {};
/**
* Private Methods
*/
popup._renderContents = function () {
helpers.insertI18nContentIntoDocument(document);
helpers.insertI18nTitlesIntoDocument(document);
if (!helpers.insertI18nContentIntoDocument(document)) {
popup._renderLocaleNotice();
}
2020-02-27 13:45:29 +01:00
popup._renderNonContextualContents();
popup._determineTargetTab()
.then(popup._determineDomainWhitelistStatus)
.then(popup._determineStatusManipulateDOM)
2020-02-27 13:45:29 +01:00
.then(popup._determineResourceInjections)
.then(popup._renderContextualContents);
if(BrowserType.CHROMIUM) {
document.getElementById('div-manipulateDOM').hidden = true;
}
2020-02-27 13:45:29 +01:00
};
popup._renderNonContextualContents = function () {
2020-05-27 06:22:58 +02:00
let versionLabelElement, counterElement, testingUtilityLinkElement, optionsButtonElement, donationButtonElement, infoButtonLabel, infoButtonSVG;
2020-02-27 13:45:29 +01:00
versionLabelElement = document.getElementById('version-label');
counterElement = document.getElementById('injection-counter');
testingUtilityLinkElement = document.getElementById('testing-utility-link');
optionsButtonElement = document.getElementById('options-button');
2020-05-16 17:40:46 +02:00
donationButtonElement = document.getElementById('donate-button');
2020-05-27 06:22:58 +02:00
infoButtonLabel = document.getElementById('manipulateDOM-indicator');
2020-02-27 13:45:29 +01:00
versionLabelElement.innerText = popup._version;
counterElement.innerText = helpers.formatNumber(popup._amountInjected);
testingUtilityLinkElement.addEventListener('mouseup', popup._onTestingUtilityLinkClicked);
optionsButtonElement.addEventListener('mouseup', popup._onOptionsButtonClicked);
2020-05-16 17:40:46 +02:00
donationButtonElement.addEventListener('mouseup', popup._onDonationButtonClicked);
2020-05-27 06:22:58 +02:00
infoButtonLabel.addEventListener('mouseup', popup._onInfoButtonClicked);
2020-02-27 13:45:29 +01:00
};
popup._renderContextualContents = function () {
if (popup._domain !== null) {
popup._renderDomainWhitelistPanel();
}
2020-05-30 10:04:48 +02:00
counterCDNs = Object.keys(popup._resourceInjections).length;
if (counterCDNs > 0) {
2020-02-27 13:45:29 +01:00
popup._renderInjectionPanel(popup._resourceInjections);
}
};
popup._renderDomainWhitelistPanel = function () {
let websiteContextElement, protectionToggleElement, domainIndicatorElement, manipulateDOMToggleElement, manipulateDOMToggleStyle;
2020-02-27 13:45:29 +01:00
websiteContextElement = document.getElementById('website-context');
protectionToggleElement = document.getElementById('protection-toggle-switch');
2020-02-27 13:45:29 +01:00
domainIndicatorElement = document.getElementById('domain-indicator');
protectionToggleElement.setAttribute('dir', popup._scriptDirection);
domainIndicatorElement.innerText = popup._domain;
manipulateDOMToggleElement = document.getElementById('manipulateDOM-toggle-switch');
manipulateDOMToggleStyle = document.getElementById('toggle-switch-manipulateDOM');
2020-02-27 13:45:29 +01:00
if (popup._domainIsWhitelisted === true) {
let enableProtectionTitle = chrome.i18n.getMessage('enableProtectionTitle');
2020-05-26 20:37:26 +02:00
manipulateDOMToggleElement.disabled = true;
protectionToggleElement.checked = false;
2020-05-26 20:37:26 +02:00
manipulateDOMToggleStyle.setAttribute('class', 'slider-disabled');
2020-02-27 13:45:29 +01:00
protectionToggleElement.setAttribute('title', enableProtectionTitle);
2020-05-26 20:37:26 +02:00
protectionToggleElement.addEventListener('click', popup._enableProtection);
2020-02-27 13:45:29 +01:00
} else {
manipulateDOMToggleElement.disabled = false;
manipulateDOMToggleStyle.setAttribute('class', 'slider');
2020-02-27 13:45:29 +01:00
let disableProtectionTitle = chrome.i18n.getMessage('disableProtectionTitle');
protectionToggleElement.checked = true;
2020-02-27 13:45:29 +01:00
protectionToggleElement.addEventListener('click', popup._disableProtection);
protectionToggleElement.setAttribute('title', disableProtectionTitle);
if (popup._domainManipulateDOM === true) {
manipulateDOMToggleElement.checked = true;
manipulateDOMToggleElement.addEventListener('click', popup._disableManipulateDOM);
} else {
manipulateDOMToggleElement.checked = false;
manipulateDOMToggleElement.addEventListener('click', popup._enableManipulateDOM);
}
2020-02-27 13:45:29 +01:00
}
websiteContextElement.setAttribute('class', 'panel');
};
popup._renderInjectionPanel = function (groupedInjections) {
let websiteContextElement, injectionOverviewElement;
websiteContextElement = document.getElementById('website-context');
injectionOverviewElement = popup._createInjectionOverviewElement(groupedInjections);
websiteContextElement.append(injectionOverviewElement);
};
popup._enableProtection = function () {
let message = {
'topic': 'whitelist:remove-domain',
'value': popup._domain
};
chrome.runtime.sendMessage(message, function () {
2020-05-26 06:44:02 +02:00
popup._onToggled();
2020-02-27 13:45:29 +01:00
});
};
popup._disableProtection = function () {
let message = {
'topic': 'whitelist:add-domain',
'value': popup._domain
};
chrome.runtime.sendMessage(message, function () {
2020-05-26 06:44:02 +02:00
popup._onToggled();
2020-02-27 13:45:29 +01:00
});
};
popup._enableManipulateDOM = function () {
let message = {
'topic': 'manipulateDOM:add-domain',
'value': popup._domain
};
chrome.runtime.sendMessage(message, function () {
2020-05-26 06:44:02 +02:00
popup._onToggled();
});
};
popup._disableManipulateDOM = function () {
let message = {
'topic': 'manipulateDOM:remove-domain',
'value': popup._domain
};
chrome.runtime.sendMessage(message, function () {
2020-05-26 06:44:02 +02:00
popup._onToggled();
});
};
2020-02-27 13:45:29 +01:00
popup._determineDomainWhitelistStatus = function () {
return new Promise((resolve) => {
let message = {
'topic': 'domain:fetch-is-whitelisted',
'value': popup._domain
};
chrome.runtime.sendMessage(message, function (response) {
popup._domainIsWhitelisted = response.value;
resolve();
});
});
};
popup._determineStatusManipulateDOM = function () {
return new Promise((resolve) => {
let message = {
'topic': 'domain:fetch-is-manipulateDOM',
'value': popup._domain
};
chrome.runtime.sendMessage(message, function (response) {
popup._domainManipulateDOM = response.value;
resolve();
});
});
};
2020-02-27 13:45:29 +01:00
popup._determineResourceInjections = function () {
return new Promise((resolve) => {
let message = {
'topic': 'tab:fetch-injections',
'value': popup._targetTab.id
};
chrome.runtime.sendMessage(message, function (response) {
let groupedInjections = popup._groupResourceInjections(response.value);
popup._resourceInjections = groupedInjections;
resolve();
});
});
};
popup._determineTargetTab = function () {
return new Promise((resolve) => {
chrome.tabs.query({'active': true, 'currentWindow': true}, function (tabs) {
popup._targetTab = tabs[0];
popup._domain = helpers.extractDomainFromUrl(tabs[0].url, true);
resolve();
});
});
};
popup._determineAmountInjected = function () {
return new Promise((resolve) => {
chrome.storage.local.get(Setting.AMOUNT_INJECTED, function (items) {
popup._amountInjected = items.amountInjected || 0;
resolve();
});
});
};
popup._groupResourceInjections = function (injections) {
let groupedInjections = {};
for (let index in injections) {
let {source} = injections[index];
groupedInjections[source] = groupedInjections[source] || [];
groupedInjections[source].push(injections[index]);
}
return groupedInjections;
};
popup._createInjectionOverviewElement = function (groupedInjections) {
let injectionOverviewElement = document.createElement('ul');
injectionOverviewElement.setAttribute('class', 'list');
2020-05-26 20:37:26 +02:00
statisticData = groupedInjections;
2020-02-27 13:45:29 +01:00
for (let source in groupedInjections) {
let injectionGroupHeaderElement, injectionGroupElement, cdn;
cdn = groupedInjections[source];
if (counterFrameworks < 3) {
injectionGroupHeaderElement = popup._createInjectionGroupHeaderElement(source, cdn);
injectionGroupElement = popup._createInjectionGroupElement(source, cdn);
2020-02-27 13:45:29 +01:00
injectionOverviewElement.appendChild(injectionGroupHeaderElement);
injectionOverviewElement.appendChild(injectionGroupElement);
2020-05-30 10:04:48 +02:00
} else {
oversized = true;
}
2020-02-27 13:45:29 +01:00
}
2020-05-30 10:04:48 +02:00
if (oversized) {
injectionOverviewElement.append(popup._appendMoreButton());
}
2020-02-27 13:45:29 +01:00
return injectionOverviewElement;
};
popup._createInjectionGroupHeaderElement = function (source, cdn) {
let injectionGroupHeaderElement, badgeElement, badgeTextNode, cdnNameTextNode;
injectionGroupHeaderElement = document.createElement('li');
injectionGroupHeaderElement.setAttribute('class', 'list-item');
badgeElement = document.createElement('span');
badgeElement.setAttribute('class', 'badge');
badgeTextNode = document.createTextNode(cdn.length);
badgeElement.appendChild(badgeTextNode);
cdnNameTextNode = document.createTextNode(helpers.determineCdnName(source));
injectionGroupHeaderElement.appendChild(badgeElement);
injectionGroupHeaderElement.appendChild(cdnNameTextNode);
return injectionGroupHeaderElement;
};
popup._createInjectionGroupElement = function (source, cdn) {
2020-05-30 10:04:48 +02:00
let injectionGroupElement;
2020-02-27 13:45:29 +01:00
// Filter duplicates
let bundle = [];
for (let injection of cdn) {
bundle.push(injection);
}
let filtered = popup._filterDuplicates(bundle, 'bundle');
2020-02-27 13:45:29 +01:00
injectionGroupElement = document.createElement('ul');
injectionGroupElement.setAttribute('class', 'sublist');
for (let injection of filtered) {
2020-05-26 20:37:26 +02:00
if(counterFrameworks < 3){
2020-05-26 20:37:26 +02:00
let injectionElement = popup._createInjectionElement(injection);
injectionGroupElement.appendChild(injectionElement);
} else {
oversized = true;
}
counterFrameworks++;
2020-05-26 20:37:26 +02:00
}
2020-05-30 10:04:48 +02:00
2020-02-27 13:45:29 +01:00
return injectionGroupElement;
};
popup._createInjectionElement = function (injection, oversized = false) {
2020-02-27 13:45:29 +01:00
let injectionElement, filename, name, nameTextNode, noteElement, noteTextNode;
2020-05-26 20:37:26 +02:00
if(oversized) {
2020-05-30 10:04:48 +02:00
return popup._appendMoreButton();
2020-05-26 20:37:26 +02:00
}
injectionElement = document.createElement('li');
injectionElement.setAttribute('class', 'sublist-item');
2020-02-27 13:45:29 +01:00
filename = helpers.extractFilenameFromPath(injection.path);
// If bundle empty, use filename
if (injection.bundle === ''){
name = helpers.determineResourceName(filename);
} else {
name = injection.bundle + ' (Bundle)'
}
2020-02-27 13:45:29 +01:00
nameTextNode = document.createTextNode(`- ${name}`);
injectionElement.appendChild(nameTextNode);
if (injection.version !== null) {
noteElement = document.createElement('span');
noteElement.setAttribute('class', 'side-note');
2020-04-05 08:55:04 +02:00
let versionNode = (injection.version === 'beta') ? ` ${injection.version}` : ` v${injection.version}`;
noteTextNode = document.createTextNode(versionNode);
noteElement.appendChild(noteTextNode);
injectionElement.appendChild(noteElement);
}
2020-02-27 13:45:29 +01:00
return injectionElement;
};
2020-05-30 10:04:48 +02:00
popup._appendMoreButton = function() {
let lastElement = document.createElement('p');
let moreInjections = document.createElement('span');
let nameTextNode = document.createTextNode(`... and more`);
moreInjections.setAttribute('id', 'get-more-injections-btn');
moreInjections.addEventListener('mouseup', function() {
popup._onMoreInjectionsButton();
}, false);
moreInjections.appendChild(nameTextNode);
lastElement.appendChild(moreInjections);
return lastElement;
}
2020-05-26 20:37:26 +02:00
popup._filterDuplicates = function(array, key) {
/**
* Function to remove duplicates from an array, depending on 'key'.
* Ignore empty values of the 'key'
*
*/
2020-02-27 13:45:29 +01:00
2020-05-26 20:37:26 +02:00
let filtered = array
.map(e => e[key])
.map((value, index, newArray) => (value != '') ? (newArray.indexOf(value) === index && index) : index )
.filter(e => array[e])
.map(e => array[e]);
2020-02-27 13:45:29 +01:00
2020-05-26 20:37:26 +02:00
return filtered;
2020-02-27 13:45:29 +01:00
};
popup._renderLocaleNotice = function () {
let localeNoticeElement, nameTextNode;
localeNoticeElement = document.getElementById('popup-incomplete-translation');
localeNoticeElement.setAttribute('class', 'notice notice-default');
localeNoticeElement.addEventListener('mouseup', popup._onIncompleteTranslation);
nameTextNode = document.createTextNode('Translation is incomplete. You want to help?');
localeNoticeElement.appendChild(nameTextNode);
localeNoticeElement.addEventListener('mouseup', popup._onIncompleteTranslation);
};
2020-05-26 20:37:26 +02:00
2020-02-27 13:45:29 +01:00
/**
* Event Handlers
*/
popup._onDocumentLoaded = function () {
let manifest, language;
manifest = chrome.runtime.getManifest();
language = navigator.language;
popup._version = helpers.formatVersion(manifest.version);
popup._scriptDirection = helpers.determineScriptDirection(language);
popup._determineAmountInjected()
.then(popup._renderContents);
};
popup._onTestingUtilityLinkClicked = function (event) {
if (event.button === 0 || event.button === 1) {
chrome.tabs.create({
2020-03-18 11:13:08 +01:00
'url': 'https://localcdn.de/test',
2020-02-27 13:45:29 +01:00
'active': (event.button === 0)
});
}
if (event.button === 0) {
window.close();
}
};
popup._onOptionsButtonClicked = function () {
chrome.runtime.openOptionsPage();
return window.close();
};
2020-05-16 17:40:46 +02:00
popup._onDonationButtonClicked = function () {
2020-05-16 17:40:46 +02:00
if (event.button === 0 || event.button === 1) {
chrome.tabs.create({
'url': chrome.extension.getURL('pages/donate/donate.html'),
2020-05-16 17:40:46 +02:00
'active': (event.button === 0)
});
}
if (event.button === 0) {
window.close();
}
};
2020-05-26 06:44:02 +02:00
popup._onToggled = function () {
let bypassCache = (typeof browser === 'undefined');
chrome.tabs.reload(popup._targetTab.id, {bypassCache});
2020-05-29 08:18:05 +02:00
setTimeout(function () {
popup._close();
2020-05-29 18:05:46 +02:00
}, 200);
};
2020-05-26 20:37:26 +02:00
popup._close = function () {
2020-05-26 20:37:26 +02:00
chrome.runtime.getPlatformInfo(function (information) {
2020-05-26 20:37:26 +02:00
if (information.os === chrome.runtime.PlatformOs.ANDROID) {
chrome.tabs.getCurrent(function (tab) {
chrome.tabs.remove(tab.id);
});
} else {
window.close();
}
});
};
2020-05-26 20:37:26 +02:00
popup._onMoreInjectionsButton = function () {
2020-05-26 21:23:26 +02:00
// Store current injections in extension storage.
// Maybe a local statistic/diagram will be implemented later.
2020-05-26 20:37:26 +02:00
chrome.storage.local.set({
[Setting.STATISTIC_DATA]: statisticData
});
chrome.tabs.create({
'url': chrome.extension.getURL('pages/statistics/statistics.html'),
'active': true
});
2020-05-26 21:23:26 +02:00
popup._close();
2020-05-26 20:37:26 +02:00
};
2020-05-27 06:22:58 +02:00
popup._onInfoButtonClicked = function () {
if (event.button === 0 || event.button === 1) {
chrome.tabs.create({
'url': chrome.extension.getURL('pages/help/help.html'),
'active': (event.button === 0)
});
}
if (event.button === 0) {
window.close();
}
};
popup._onIncompleteTranslation = function () {
if (event.button === 0 || event.button === 1) {
chrome.tabs.create({
'url': 'https://localcdn.de/translation/',
'active': (event.button === 0)
});
}
if (event.button === 0) {
window.close();
}
};
2020-05-26 20:37:26 +02:00
2020-02-27 13:45:29 +01:00
/**
* Initializations
*/
2020-05-26 20:37:26 +02:00
let statisticData;
2020-02-27 13:45:29 +01:00
document.addEventListener('DOMContentLoaded', popup._onDocumentLoaded);