talkdesk-useragent-switcher/extension/firefox/data/popup/index.js

431 lines
13 KiB
JavaScript
Raw Normal View History

2017-09-13 03:18:12 -07:00
'use strict';
2020-09-26 23:54:02 -07:00
// localization
document.querySelectorAll('[data-localized-value]').forEach(e => {
const ref = e.dataset.localizedValue;
const translated = chrome.i18n.getMessage(ref);
if (translated) {
e.value = translated;
}
});
document.querySelectorAll('[data-localized-title]').forEach(e => {
const ref = e.dataset.localizedTitle;
const translated = chrome.i18n.getMessage(ref);
if (translated) {
e.title = translated;
}
});
document.querySelectorAll('[data-localized-placeholder]').forEach(e => {
const ref = e.dataset.localizedPlaceholder;
const translated = chrome.i18n.getMessage(ref);
if (translated) {
e.placeholder = translated;
}
});
document.querySelectorAll('[data-localized-content]').forEach(e => {
const ref = e.dataset.localizedContent;
const translated = chrome.i18n.getMessage(ref);
if (translated) {
e.dataset.content = translated;
}
});
2020-09-28 07:02:45 -07:00
document.querySelectorAll('[data-localize]').forEach(e => {
const ref = e.dataset.localize;
const translated = chrome.i18n.getMessage(ref);
if (translated) {
e.textContent = translated;
}
});
2020-09-26 23:54:02 -07:00
const DCSI = 'firefox-default';
document.body.dataset.android = navigator.userAgent.indexOf('Android') !== -1;
let tab = {};
chrome.tabs.query({
active: true,
currentWindow: true
}, tbs => {
if (tbs.length) {
tab = tbs[0];
if ('cookieStoreId' in tab) {
const apply = document.querySelector('[data-cmd="apply"]');
2020-09-26 23:54:02 -07:00
apply.value = chrome.i18n.getMessage('applyContainer');
apply.title = chrome.i18n.getMessage('applyContainerTitle');
const w = document.querySelector('[data-cmd="window"]');
2020-09-26 23:54:02 -07:00
w.value = chrome.i18n.getMessage('applyContainerWindow');
w.title = chrome.i18n.getMessage('applyContainerWindowTitle');
const reset = document.querySelector('[data-cmd="reset"]');
2020-09-26 23:54:02 -07:00
reset.value = chrome.i18n.getMessage('resetContainer');
reset.title = chrome.i18n.getMessage('resetContainerTitle');
}
}
});
2019-07-31 22:41:28 -07:00
const map = {};
2017-09-13 03:18:12 -07:00
function sort(arr) {
function sort(a = '', b = '') {
const pa = a.split('.');
const pb = b.split('.');
for (let i = 0; i < 3; i++) {
const na = Number(pa[i]);
const nb = Number(pb[i]);
if (na > nb) {
return 1;
}
if (nb > na) {
return -1;
}
if (!isNaN(na) && isNaN(nb)) {
return 1;
}
if (isNaN(na) && !isNaN(nb)) {
return -1;
}
}
return 0;
}
const list = arr.sort((a, b) => sort(a.browser.version, b.browser.version));
2020-03-15 05:20:18 -07:00
if (document.getElementById('sort').value === 'descending') {
2017-09-13 03:18:12 -07:00
return list.reverse();
}
return list;
}
2020-08-03 22:02:57 -07:00
function get(path) {
const cf = Promise.resolve({
match() {
return Promise.resolve();
},
add() {
return Promise.resolve();
}
});
2020-08-03 22:52:40 -07:00
return (typeof caches !== 'undefined' ? caches : {
open() {
return cf;
2020-08-03 22:52:40 -07:00
}
}).open('agents').catch(() => cf).then(cache => {
2020-08-03 22:02:57 -07:00
const link = 'https://cdn.jsdelivr.net/gh/ray-lothian/UserAgent-Switcher/node/' + path;
2020-08-03 22:52:40 -07:00
// updating agents once per 7 days
chrome.storage.local.get({
['cache.' + path]: 0
}, prefs => {
const now = Date.now();
if (now - prefs['cache.' + path] > 7 * 24 * 60 * 60 * 1000) {
cache.add(link).then(() => chrome.storage.local.set({
['cache.' + path]: now
}));
}
2020-08-03 22:02:57 -07:00
});
2020-08-03 22:52:40 -07:00
return cache.match(link).then(resp => resp || fetch(path));
2020-08-03 22:02:57 -07:00
});
}
2019-07-31 22:41:28 -07:00
function update(ua) {
const browser = document.getElementById('browser').value;
const os = document.getElementById('os').value;
2017-09-13 03:18:12 -07:00
const t = document.querySelector('template');
const parent = document.getElementById('list');
const tbody = parent.querySelector('tbody');
tbody.textContent = '';
2017-09-13 03:18:12 -07:00
parent.dataset.loading = true;
2020-08-03 22:02:57 -07:00
get('browsers/' + browser.toLowerCase() + '-' + os.toLowerCase().replace(/\//g, '-') + '.json')
2020-08-03 21:47:39 -07:00
.then(r => r.json()).catch(e => {
console.error(e);
return [];
}).then(list => {
if (list) {
const fragment = document.createDocumentFragment();
let radio;
2021-05-02 00:37:13 -07:00
list = sort(list);
list.forEach((o, n) => {
2020-08-03 21:47:39 -07:00
const clone = document.importNode(t.content, true);
2021-05-02 00:37:13 -07:00
const num = clone.querySelector('td:nth-child(1)');
num.textContent = n + 1;
const second = clone.querySelector('td:nth-child(3)');
2020-08-04 03:16:03 -07:00
if (o.browser.name && o.browser.version) {
second.title = second.textContent = o.browser.name + ' ' + (o.browser.version || ' ');
}
else {
second.title = second.textContent = '-';
}
2021-05-02 00:37:13 -07:00
const third = clone.querySelector('td:nth-child(4)');
2020-08-04 03:16:03 -07:00
if (o.os.name && o.os.version) {
third.title = third.textContent = o.os.name + ' ' + (o.os.version || ' ');
}
else {
third.title = third.textContent = '-';
}
2021-05-02 00:37:13 -07:00
const forth = clone.querySelector('td:nth-child(5)');
2020-08-03 21:47:39 -07:00
forth.title = forth.textContent = o.ua;
if (o.ua === ua) {
radio = clone.querySelector('input[type=radio]');
}
fragment.appendChild(clone);
2021-05-02 00:37:13 -07:00
});
2020-08-03 21:47:39 -07:00
tbody.appendChild(fragment);
if (radio) {
radio.checked = true;
radio.scrollIntoView({
block: 'center',
inline: 'nearest'
});
}
2020-09-28 07:02:45 -07:00
document.getElementById('custom').placeholder = chrome.i18n.getMessage('filterAmong', [list.length]);
2020-08-03 21:47:39 -07:00
[...document.getElementById('os').querySelectorAll('option')].forEach(option => {
option.disabled = (map.matching[browser.toLowerCase()] || []).indexOf(option.value.toLowerCase()) === -1;
2019-07-31 22:41:28 -07:00
});
}
2020-08-03 21:47:39 -07:00
else {
throw Error('OS is not found');
}
2020-09-06 00:57:47 -07:00
// FF 55.0 does not support finally
}).catch(() => {}).then(() => {
2020-08-03 21:47:39 -07:00
parent.dataset.loading = false;
});
2017-09-13 03:18:12 -07:00
}
2020-03-15 05:20:18 -07:00
document.getElementById('browser').addEventListener('change', e => chrome.storage.local.set({
'popup-browser': e.target.value
}));
document.getElementById('os').addEventListener('change', e => chrome.storage.local.set({
'popup-os': e.target.value
}));
document.getElementById('sort').addEventListener('change', e => chrome.storage.local.set({
'popup-sort': e.target.value
}));
2017-09-13 03:18:12 -07:00
document.addEventListener('change', ({target}) => {
if (target.closest('#filter')) {
2019-07-31 23:53:48 -07:00
chrome.storage.local.get({
ua: ''
}, prefs => update(prefs.ua || navigator.userAgent));
2017-09-13 03:18:12 -07:00
}
2018-04-10 00:50:58 -07:00
if (target.type === 'radio') {
2021-05-02 00:37:13 -07:00
document.getElementById('ua').value = target.closest('tr').querySelector('td:nth-child(5)').textContent;
2018-08-16 03:14:11 -07:00
document.getElementById('ua').dispatchEvent(new Event('input'));
2017-09-13 03:18:12 -07:00
}
});
2019-06-25 03:22:49 -07:00
2020-08-03 22:52:40 -07:00
document.addEventListener('DOMContentLoaded', () => fetch('./map.json').then(r => r.json()).then(o => {
Object.assign(map, o);
2019-06-25 03:22:49 -07:00
2020-08-03 22:52:40 -07:00
const f1 = document.createDocumentFragment();
for (const browser of map.browser) {
const option = document.createElement('option');
option.value = option.textContent = browser;
f1.appendChild(option);
}
const f2 = document.createDocumentFragment();
for (const os of map.os) {
const option = document.createElement('option');
option.value = option.textContent = os;
f2.appendChild(option);
}
2019-06-25 03:22:49 -07:00
2020-08-03 22:52:40 -07:00
document.querySelector('#browser optgroup:last-of-type').appendChild(f1);
document.querySelector('#os optgroup:last-of-type').appendChild(f2);
2020-03-15 05:20:18 -07:00
2020-08-03 22:52:40 -07:00
chrome.storage.local.get({
'popup-browser': 'Chrome',
'popup-os': 'Windows',
'popup-sort': 'descending'
}, prefs => {
document.getElementById('browser').value = prefs['popup-browser'];
document.getElementById('os').value = prefs['popup-os'];
document.getElementById('sort').value = prefs['popup-sort'];
2020-03-15 05:20:18 -07:00
2020-12-28 05:17:45 -08:00
chrome.runtime.sendMessage({
method: 'get-ua'
}, ua => {
update(ua);
document.getElementById('ua').value = ua;
document.getElementById('ua').dispatchEvent(new Event('input'));
});
2020-08-03 22:52:40 -07:00
});
}));
2017-09-13 03:18:12 -07:00
document.getElementById('list').addEventListener('click', ({target}) => {
2019-11-05 03:02:26 -08:00
const tr = target.closest('tbody tr');
2017-09-13 03:18:12 -07:00
if (tr) {
const input = tr.querySelector('input');
if (input && input !== target) {
2019-11-05 03:02:26 -08:00
input.checked = true;
2017-09-13 03:18:12 -07:00
input.dispatchEvent(new Event('change', {
bubbles: true
}));
}
}
});
document.getElementById('custom').addEventListener('keyup', ({target}) => {
const value = target.value;
2019-11-05 03:02:26 -08:00
[...document.querySelectorAll('#list tbody tr')]
2017-09-13 03:18:12 -07:00
.forEach(tr => tr.dataset.matched = tr.textContent.toLowerCase().indexOf(value.toLowerCase()) !== -1);
});
chrome.storage.onChanged.addListener(prefs => {
if (prefs.ua) {
document.getElementById('ua').value = prefs.ua.newValue || navigator.userAgent;
2018-08-16 03:14:11 -07:00
document.getElementById('ua').dispatchEvent(new Event('input'));
2017-09-13 03:18:12 -07:00
}
});
function msg(msg) {
2019-11-05 03:02:26 -08:00
const toast = document.getElementById('toast');
toast.textContent = msg;
window.setTimeout(() => toast.textContent = '', 2000);
}
2017-09-13 03:18:12 -07:00
// commands
document.addEventListener('click', ({target}) => {
const cmd = target.dataset.cmd;
if (cmd) {
if (cmd === 'apply') {
const value = document.getElementById('ua').value;
if (value === navigator.userAgent) {
2020-09-26 23:54:02 -07:00
msg(chrome.i18n.getMessage('msgDefaultUA'));
}
else {
2020-09-26 23:54:02 -07:00
msg(chrome.i18n.getMessage('msgUASet'));
}
if (value !== navigator.userAgent) {
// prevent a container ua string from overwriting the default one
if ('cookieStoreId' in tab && tab.cookieStoreId !== DCSI) {
2020-12-28 05:17:45 -08:00
chrome.runtime.sendMessage({
method: 'request-update',
value,
cookieStoreId: tab.cookieStoreId
});
chrome.storage.local.get({
'container-uas': {}
}, prefs => {
prefs['container-uas'][tab.cookieStoreId] = value;
chrome.storage.local.set(prefs);
});
}
else {
chrome.storage.local.set({
ua: value
});
}
}
2017-09-13 03:18:12 -07:00
}
else if (cmd === 'window') {
2018-08-16 03:14:11 -07:00
const value = document.getElementById('ua').value;
2020-12-28 05:17:45 -08:00
chrome.runtime.sendMessage({
method: 'request-update',
value,
2021-05-02 06:06:20 -07:00
cookieStoreId: tab.cookieStoreId,
windowId: tab.windowId
2020-12-28 05:17:45 -08:00
});
2018-08-16 03:14:11 -07:00
}
2017-09-13 03:18:12 -07:00
else if (cmd === 'reset') {
const input = document.querySelector('#list :checked');
if (input) {
input.checked = false;
}
// prevent a container ua string from overwriting the default one
if ('cookieStoreId' in tab && tab.cookieStoreId !== DCSI) {
2020-12-28 05:17:45 -08:00
chrome.runtime.sendMessage({
method: 'request-update',
value: '',
cookieStoreId: tab.cookieStoreId,
delete: true
});
chrome.storage.local.get({
'container-uas': {}
}, prefs => {
delete prefs['container-uas'][tab.cookieStoreId];
chrome.storage.local.set(prefs);
});
2020-09-26 23:54:02 -07:00
msg(chrome.i18n.getMessage('msgDisabledOnContainer'));
}
else {
chrome.storage.local.set({
ua: ''
});
2020-09-26 23:54:02 -07:00
msg(chrome.i18n.getMessage('msgDisabled'));
}
2017-09-13 03:18:12 -07:00
}
else if (cmd === 'refresh') {
chrome.tabs.query({
active: true,
currentWindow: true
}, ([tab]) => chrome.tabs.reload(tab.id, {
bypassCache: true
}));
}
2018-05-15 00:54:51 -07:00
else if (cmd === 'options') {
chrome.runtime.openOptionsPage();
}
2018-08-16 03:14:11 -07:00
else if (cmd === 'reload') {
chrome.runtime.reload();
}
2019-05-15 22:18:58 -07:00
else if (cmd === 'test') {
chrome.storage.local.get({
2020-08-03 22:52:40 -07:00
'test': 'https://webbrowsertools.com/useragent/?method=normal&verbose=false'
2019-05-15 22:18:58 -07:00
}, prefs => chrome.tabs.create({
url: prefs.test
}));
}
if (cmd) {
target.classList.add('active');
window.setTimeout(() => target.classList.remove('active'), 500);
}
2017-09-13 03:18:12 -07:00
}
});
2018-08-16 03:14:11 -07:00
document.getElementById('ua').addEventListener('input', e => {
2019-11-05 03:02:26 -08:00
const value = e.target.value;
document.querySelector('[data-cmd=apply]').disabled = value === '';
document.querySelector('[data-cmd=window]').disabled = value === '';
if (value) {
2020-12-28 05:17:45 -08:00
chrome.runtime.sendMessage({
method: 'parse-ua',
value
}, o => {
2019-11-05 03:02:26 -08:00
document.getElementById('appVersion').value = o.appVersion;
document.getElementById('platform').value = o.platform;
document.getElementById('vendor').value = o.vendor;
document.getElementById('product').value = o.product;
document.getElementById('oscpu').value = o.oscpu;
});
}
2018-08-16 03:14:11 -07:00
});
document.getElementById('ua').addEventListener('keyup', e => {
if (e.key === 'Enter') {
document.querySelector('[data-cmd="apply"]').click();
}
});
/* container support */
2020-09-26 23:54:02 -07:00
document.querySelector('[data-cmd="container"]').addEventListener('click', () => {
chrome.permissions.request({
permissions: ['cookies']
}, granted => {
if (granted) {
window.close();
}
});
});
2021-02-28 21:17:39 -08:00
if (/Firefox/.test(navigator.userAgent) && chrome.permissions) {
chrome.permissions.contains({
permissions: ['cookies']
}, granted => {
if (granted === false) {
document.querySelector('[data-cmd="container"]').classList.remove('hide');
}
});
}