393 lines
14 KiB
JavaScript
393 lines
14 KiB
JavaScript
// Set setting toggle values on-load:
|
|
extensionAPI.storage.sync.get({ 'notifications': 'on' }, (item) => {
|
|
setNotifications(item.notifications, false);
|
|
});
|
|
extensionAPI.storage.sync.get({ 'hiddenResultsBanner': 'on' }, (item) => {
|
|
setHiddenResultsBanner(item.hiddenResultsBanner, false);
|
|
});
|
|
extensionAPI.storage.sync.get({ 'crossLanguage': 'off' }, (item) => {
|
|
setCrossLanguage(item.crossLanguage, false);
|
|
});
|
|
extensionAPI.storage.sync.get({ 'reorderResults': 'on' }, (item) => {
|
|
setReorder(item.reorderResults, false);
|
|
});
|
|
extensionAPI.storage.sync.get({ 'openChangelog': 'off' }, (item) => {
|
|
setOpenChangelog(item.openChangelog, false);
|
|
});
|
|
extensionAPI.storage.sync.get({ 'breezewiki': 'off' }, (item) => {
|
|
// Account for legacy 'on' setting for BreezeWiki
|
|
if (item.breezewiki === 'on') {
|
|
setBreezeWiki('redirect');
|
|
} else {
|
|
setBreezeWiki(item.breezewiki, false);
|
|
}
|
|
|
|
// Load BreezeWiki options if BreezeWiki is enabled
|
|
if (item.breezewiki !== 'off') {
|
|
loadBreezewikiOptions();
|
|
}
|
|
});
|
|
|
|
// Event listeners for toggling search engines
|
|
const searchEngineToggles = document.querySelectorAll('.searchEngineToggles label');
|
|
searchEngineToggles.forEach((engine) => {
|
|
let engineInput = engine.querySelector('input');
|
|
let engineName = engineInput.getAttribute('data-search-engine');
|
|
engine.addEventListener('change', () => {
|
|
if (engineInput.checked) {
|
|
extensionAPI.storage.sync.get({'searchEngineToggles': {}}, (settings) => {
|
|
settings.searchEngineToggles[engineName] = 'on';
|
|
extensionAPI.storage.sync.set({
|
|
'searchEngineToggles': settings.searchEngineToggles
|
|
});
|
|
});
|
|
engineInput.checked = true;
|
|
} else {
|
|
extensionAPI.storage.sync.get( { 'searchEngineToggles': {} }, (settings) => {
|
|
settings.searchEngineToggles[engineName] = 'off';
|
|
extensionAPI.storage.sync.set({
|
|
'searchEngineToggles': settings.searchEngineToggles
|
|
});
|
|
});
|
|
engineInput.checked = false;
|
|
}
|
|
});
|
|
});
|
|
document.querySelectorAll('.searchEngineToggles input').forEach((el) => {
|
|
const searchEngineName = el.getAttribute('data-search-engine');
|
|
extensionAPI.storage.sync.get({
|
|
'searchEngineToggles': {}
|
|
}, (settings) => {
|
|
if (settings.searchEngineToggles[searchEngineName] === 'on' || !settings.searchEngineToggles.hasOwnProperty(searchEngineName)) {
|
|
el.checked = true;
|
|
} else {
|
|
el.checked = false;
|
|
}
|
|
});
|
|
});
|
|
|
|
|
|
// Set notifications setting
|
|
function setNotifications(setting, storeSetting = true) {
|
|
if (storeSetting) {
|
|
extensionAPI.storage.sync.set({ 'notifications': setting });
|
|
}
|
|
const notificationsIcon = document.getElementById('notificationsIcon');
|
|
if (setting === 'on') {
|
|
document.getElementById('notificationsCheckbox').checked = true;
|
|
notificationsIcon.innerText = '🔔';
|
|
} else {
|
|
document.getElementById('notificationsCheckbox').checked = false;
|
|
notificationsIcon.innerText = '🔕';
|
|
}
|
|
}
|
|
|
|
// Set search results hidden banner setting
|
|
function setHiddenResultsBanner(setting, storeSetting = true) {
|
|
if (storeSetting) {
|
|
extensionAPI.storage.sync.set({ 'hiddenResultsBanner': setting });
|
|
}
|
|
if (setting === 'on') {
|
|
document.getElementById('hiddenResultsBannerCheckbox').checked = true;
|
|
} else {
|
|
document.getElementById('hiddenResultsBannerCheckbox').checked = false;
|
|
}
|
|
}
|
|
|
|
// Set cross-language setting
|
|
function setCrossLanguage(setting, storeSetting = true) {
|
|
if (storeSetting) {
|
|
extensionAPI.storage.sync.set({ 'crossLanguage': setting });
|
|
}
|
|
|
|
const crossLanguageIcon = document.getElementById('crossLanguageIcon');
|
|
if (setting === 'on') {
|
|
document.getElementById('crossLanguageCheckbox').checked = true;
|
|
crossLanguageIcon.innerText = '🌐';
|
|
} else {
|
|
document.getElementById('crossLanguageCheckbox').checked = false;
|
|
crossLanguageIcon.innerText = '⚪️';
|
|
}
|
|
}
|
|
|
|
// Set re-order setting
|
|
function setReorder(setting, storeSetting = true) {
|
|
if (storeSetting) {
|
|
extensionAPI.storage.sync.set({ 'reorderResults': setting });
|
|
}
|
|
|
|
if (setting === 'on') {
|
|
document.getElementById('reorderResultsCheckbox').checked = true;
|
|
} else {
|
|
document.getElementById('reorderResultsCheckbox').checked = false;
|
|
}
|
|
}
|
|
|
|
// Set open changelog setting
|
|
function setOpenChangelog(setting, storeSetting = true) {
|
|
if (storeSetting) {
|
|
extensionAPI.storage.sync.set({ 'openChangelog': setting });
|
|
}
|
|
|
|
const openChangelogIcon = document.getElementById('openChangelogIcon');
|
|
if (setting === 'on') {
|
|
document.getElementById('openChangelogCheckbox').checked = true;
|
|
openChangelogIcon.innerText = '📂';
|
|
} else {
|
|
document.getElementById('openChangelogCheckbox').checked = false;
|
|
openChangelogIcon.innerText = '📁';
|
|
}
|
|
}
|
|
|
|
// Event listeners for general setting toggles
|
|
document.getElementById('notificationsCheckbox').addEventListener('change', () => {
|
|
extensionAPI.storage.sync.get({ 'notifications': 'on' }, (item) => {
|
|
if (item.notifications === 'on') {
|
|
setNotifications('off');
|
|
} else {
|
|
setNotifications('on');
|
|
}
|
|
});
|
|
});
|
|
document.getElementById('hiddenResultsBannerCheckbox').addEventListener('change', () => {
|
|
extensionAPI.storage.sync.get({ 'hiddenResultsBanner': 'on' }, (item) => {
|
|
if (item.hiddenResultsBanner === 'on') {
|
|
setHiddenResultsBanner('off');
|
|
} else {
|
|
setHiddenResultsBanner('on');
|
|
}
|
|
});
|
|
});
|
|
document.getElementById('crossLanguageCheckbox').addEventListener('change', () => {
|
|
extensionAPI.storage.sync.get({ 'crossLanguage': 'off' }, (item) => {
|
|
if (item.crossLanguage === 'on') {
|
|
setCrossLanguage('off');
|
|
} else {
|
|
setCrossLanguage('on');
|
|
}
|
|
});
|
|
});
|
|
document.getElementById('reorderResultsCheckbox').addEventListener('change', () => {
|
|
extensionAPI.storage.sync.get({ 'reorderResults': 'on' }, (item) => {
|
|
if (item.reorderResults === 'on') {
|
|
setReorder('off');
|
|
} else {
|
|
setReorder('on');
|
|
}
|
|
});
|
|
});
|
|
document.getElementById('openChangelogCheckbox').addEventListener('change', () => {
|
|
extensionAPI.storage.sync.get({ 'openChangelog': 'off' }, (item) => {
|
|
if (item.openChangelog === 'on') {
|
|
setOpenChangelog('off');
|
|
} else {
|
|
setOpenChangelog('on');
|
|
}
|
|
});
|
|
});
|
|
document.querySelectorAll('[name="breezewikiSetting"]').forEach((el) => {
|
|
el.addEventListener('change', async () => {
|
|
const settingValue = document.options.breezewikiSetting.value;
|
|
extensionAPI.storage.sync.set({ 'breezewiki': settingValue });
|
|
setBreezeWiki(settingValue);
|
|
if (settingValue !== 'off') {
|
|
loadBreezewikiOptions();
|
|
}
|
|
});
|
|
});
|
|
|
|
// Set BreezeWiki settings
|
|
function setBreezeWiki(setting, storeSetting = true) {
|
|
// Account for legacy BreezeWiki sestting ('on' is now 'redirect')
|
|
if (setting === 'on') {
|
|
setting = 'redirect';
|
|
}
|
|
|
|
// Store BreezeWiki setting
|
|
if (storeSetting) {
|
|
extensionAPI.storage.sync.set({ 'breezewiki': setting });
|
|
}
|
|
|
|
// Set BreezeWiki value on radio group
|
|
document.options.breezewikiSetting.value = setting;
|
|
|
|
// Toggle/update host display
|
|
const breezewikiHost = document.getElementById('breezewikiHost');
|
|
if (setting !== 'off') {
|
|
breezewikiHost.style.display = 'block';
|
|
extensionAPI.storage.sync.get({ 'breezewikiHost': null }, (host) => {
|
|
if (!host.breezewikiHost) {
|
|
fetch('https://bw.getindie.wiki/instances.json')
|
|
.then((response) => {
|
|
if (response.ok) {
|
|
return response.json();
|
|
}
|
|
throw new Error('Indie Wiki Buddy failed to get BreezeWiki data.');
|
|
}).then((breezewikiHosts) => {
|
|
breezewikiHosts = breezewikiHosts.filter(host =>
|
|
extensionAPI.runtime.getManifest().version.localeCompare(host.iwb_version,
|
|
undefined,
|
|
{ numeric: true, sensitivity: 'base' }
|
|
) >= 0
|
|
);
|
|
// Check if BreezeWiki's main site is available
|
|
let breezewikiMain = breezewikiHosts.filter(host => host.instance === 'https://breezewiki.com');
|
|
if (breezewikiMain.length > 0) {
|
|
host.breezewikiHost = breezewikiMain[0].instance;
|
|
} else {
|
|
// If BreezeWiki.com is not available, set to a random mirror
|
|
try {
|
|
host.breezewikiHost = breezewikiHosts[Math.floor(Math.random() * breezewikiHosts.length)].instance;
|
|
} catch (e) {
|
|
console.log('Indie Wiki Buddy failed to get BreezeWiki data: ' + e);
|
|
}
|
|
}
|
|
extensionAPI.storage.sync.set({ 'breezewikiHost': host.breezewikiHost });
|
|
extensionAPI.storage.sync.set({ 'breezewikiHostOptions': breezewikiHosts });
|
|
extensionAPI.storage.sync.set({ 'breezewikiHostFetchTimestamp': Date.now() });
|
|
document.getElementById('breezewikiHostSelect').value = host.breezewikiHost;
|
|
}).catch((e) => {
|
|
console.log('Indie Wiki Buddy failed to get BreezeWiki data: ' + e);
|
|
|
|
// If fetch fails and no host is set, default to breezewiki.com:
|
|
if (!host) {
|
|
extensionAPI.storage.sync.set({ 'breezewikiHost': 'https://breezewiki.com' });
|
|
}
|
|
});
|
|
} else {
|
|
document.getElementById('breezewikiHostSelect').value = host.breezewikiHost;
|
|
}
|
|
});
|
|
} else {
|
|
breezewikiHost.style.display = 'none';
|
|
}
|
|
}
|
|
|
|
function populateBreezewikiHosts(breezewikiHosts, selectedHost, customHostName) {
|
|
// Populate dropdown selection of hosts
|
|
const breezewikiHostSelect = document.getElementById('breezewikiHostSelect');
|
|
while (breezewikiHostSelect.firstChild) {
|
|
// Remove any existing options
|
|
breezewikiHostSelect.removeChild(breezewikiHostSelect.firstChild);
|
|
}
|
|
|
|
// Add known BreezeWiki domains:
|
|
for (var i = 0; i < breezewikiHosts.length; i++) {
|
|
let option = document.createElement('option');
|
|
option.value = breezewikiHosts[i].instance;
|
|
let textContent = breezewikiHosts[i].instance.replace('https://', '');
|
|
const numberOfPeriods = (textContent.match(/\./g) || []).length;
|
|
if (numberOfPeriods > 1) {
|
|
textContent = textContent.substring(textContent.indexOf('.') + 1);
|
|
}
|
|
option.textContent = textContent;
|
|
breezewikiHostSelect.appendChild(option);
|
|
}
|
|
|
|
// Add custom BreezeWiki host option:
|
|
let customOption = document.createElement('option');
|
|
customOption.value = 'CUSTOM';
|
|
customOption.textContent = extensionAPI.i18n.getMessage('settingsBreezeWikiCustomHostOption');
|
|
breezewikiHostSelect.appendChild(customOption);
|
|
breezewikiHostSelect.value = selectedHost;
|
|
|
|
// Set up custom domain input:
|
|
if (breezewikiHostSelect.value === 'CUSTOM') {
|
|
document.getElementById('breezewikiCustomHost').style.display = 'block';
|
|
} else {
|
|
document.getElementById('breezewikiCustomHost').style.display = 'none';
|
|
}
|
|
document.getElementById('customBreezewikiHost').value = customHostName.replace(/^https?:\/\//i, '');
|
|
}
|
|
|
|
// Populate BreezeWiki dropdown when enabled
|
|
async function loadBreezewikiOptions() {
|
|
// Load BreezeWiki options:
|
|
extensionAPI.storage.sync.get(['breezewikiHostOptions', 'breezewikiHostFetchTimestamp', 'breezewikiHost', 'breezewikiCustomHost'], (item) => {
|
|
let hostOptions = item.breezewikiHostOptions;
|
|
let hostFetchTimestamp = item.breezewikiHostFetchTimestamp;
|
|
let host = item.breezewikiHost;
|
|
let customHost = item.breezewikiCustomHost || '';
|
|
|
|
// Fetch and cache list of BreezeWiki hosts if first time,
|
|
// or if it has been 24 hrs since last refresh
|
|
if (!host || !hostOptions || !hostFetchTimestamp || (Date.now() - 86400000 > hostFetchTimestamp)) {
|
|
fetch('https://bw.getindie.wiki/instances.json')
|
|
.then((response) => {
|
|
if (response.ok) {
|
|
return response.json();
|
|
}
|
|
throw new Error('Indie Wiki Buddy failed to get BreezeWiki data.');
|
|
}).then((breezewikiHosts) => {
|
|
breezewikiHosts = breezewikiHosts.filter(host =>
|
|
extensionAPI.runtime.getManifest().version.localeCompare(host.iwb_version,
|
|
undefined,
|
|
{ numeric: true, sensitivity: 'base' }
|
|
) >= 0
|
|
);
|
|
// If host isn't set, or currently selected host is no longer available, select random host:
|
|
if (!host || !breezewikiHosts.some(item => item.instance === host)) {
|
|
// Check if BreezeWiki's main site is available
|
|
let breezewikiMain = breezewikiHosts.filter(host => host.instance === 'https://breezewiki.com');
|
|
if (breezewikiMain.length > 0) {
|
|
host = breezewikiMain[0].instance;
|
|
} else {
|
|
// If BreezeWiki.com is not available, set to a random mirror
|
|
try {
|
|
host = breezewikiHosts[Math.floor(Math.random() * breezewikiHosts.length)].instance;
|
|
} catch (e) {
|
|
console.log('Indie Wiki Buddy failed to get BreezeWiki data: ' + e);
|
|
}
|
|
}
|
|
}
|
|
populateBreezewikiHosts(breezewikiHosts, host, customHost);
|
|
|
|
// Store BreezeWiki host details
|
|
extensionAPI.storage.sync.set({ 'breezewikiHost': host });
|
|
extensionAPI.storage.sync.set({ 'breezewikiHostOptions': breezewikiHosts });
|
|
extensionAPI.storage.sync.set({ 'breezewikiHostFetchTimestamp': Date.now() });
|
|
}).catch((e) => {
|
|
console.log('Indie Wiki Buddy failed to get BreezeWiki data: ' + e);
|
|
|
|
// If fetch fails and no host is set, default to breezewiki.com:
|
|
if (!host) {
|
|
extensionAPI.storage.sync.set({ 'breezewikiHost': 'https://breezewiki.com' });
|
|
}
|
|
});
|
|
} else {
|
|
// If currently selected host is no longer available, select random host:
|
|
if (host !== 'CUSTOM' && !hostOptions.some(item => item.instance === host)) {
|
|
host = hostOptions[Math.floor(Math.random() * hostOptions.length)].instance;
|
|
}
|
|
|
|
populateBreezewikiHosts(hostOptions, host, customHost);
|
|
|
|
// Store BreezeWiki host details
|
|
extensionAPI.storage.sync.set({ 'breezewikiHost': host });
|
|
}
|
|
});
|
|
}
|
|
|
|
// Somehow this has to be done manually
|
|
document.querySelectorAll('[data-msg]').forEach(element => {
|
|
// Check data-msg-ph-* attributes for placeholder text
|
|
// iterate
|
|
const placeholders = [];
|
|
for (let i = 1; i <= 9; i++) {
|
|
let ph = element.getAttribute(`data-msg-ph-${i}`);
|
|
if (ph) {
|
|
placeholders.push(ph);
|
|
}
|
|
}
|
|
|
|
element.innerHTML = extensionAPI.i18n.getMessage(element.dataset.msg, placeholders);
|
|
});
|
|
|
|
document.querySelectorAll('[data-msg-attr]').forEach(element => {
|
|
const attrs = element.dataset.msgAttr.split(',');
|
|
attrs.forEach(attr => {
|
|
const [key, value] = attr.split('=');
|
|
element.setAttribute(key, extensionAPI.i18n.getMessage(value));
|
|
});
|
|
});
|