Skip to content

Commit

Permalink
I don't understand you Firefox
Browse files Browse the repository at this point in the history
  • Loading branch information
fregante committed Jun 30, 2024
1 parent 82e0e74 commit c231263
Show file tree
Hide file tree
Showing 2 changed files with 32 additions and 22 deletions.
51 changes: 29 additions & 22 deletions source/background.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@ import addDomainPermissionToggle from 'webext-permission-toggle';
import oneEvent from 'one-event';
import optionsStorage from './options-storage.js';

const browserAction = chrome.action ?? chrome.browserAction;
const browser = globalThis.browser ?? globalThis.chrome;

const browserAction = browser.action ?? browser.browserAction;

// Firefox hates iframes on activeTab
// https://bugzilla.mozilla.org/show_bug.cgi?id=1653408
Expand All @@ -17,17 +19,22 @@ if (navigator.userAgent.includes('Firefox/')) {
}

function stopGT(tab) {
chrome.scripting.executeScript({
browser.scripting.executeScript({
target: {tabId: tab.id},
func: () => stopGT(),
});
}

async function handleAction({id}) {
const defaults = {
const defaultTarget = {
target: {tabId: id, allFrames: true},
};
const [topFrame] = await chrome.scripting.executeScript({
const defaults = {
...defaultTarget,
injectImmediately: true,
};

const [topFrame] = await browser.scripting.executeScript({
...defaults,
func: () => typeof window.startGT === 'function',
});
Expand All @@ -37,15 +44,15 @@ async function handleAction({id}) {
if (!alreadyInjected) {
try {
await Promise.all([
chrome.scripting.insertCSS({...defaults, files: ['/ghost-text.css']}),
chrome.scripting.executeScript({...defaults, files: ['/ghost-text.js']}),
browser.scripting.insertCSS({...defaultTarget, files: ['/ghost-text.css']}),
browser.scripting.executeScript({...defaults, files: ['/ghost-text.js']}),
]);
} catch (error) {
console.error(error);
}
}

await chrome.scripting.executeScript({...defaults, func: () => startGT()});
await browser.scripting.executeScript({...defaults, func: () => startGT()});

Check failure on line 55 in source/background.js

View workflow job for this annotation

GitHub Actions / Lint

'startGT' is not defined.

Check failure on line 55 in source/background.js

View workflow job for this annotation

GitHub Actions / Lint

'startGT' is not defined.
}

function handlePortListenerErrors(listener) {
Expand All @@ -69,7 +76,7 @@ function handlePortListenerErrors(listener) {
};
}

chrome.runtime.onConnect.addListener(handlePortListenerErrors(async port => {
browser.runtime.onConnect.addListener(handlePortListenerErrors(async port => {
console.assert(port.name === 'new-field');
const options = await optionsStorage.getAll();
const response = await fetch(`http://localhost:${options.serverPort}`);
Expand Down Expand Up @@ -115,58 +122,58 @@ function handleMessages({code, count}, {tab}) {
tabId: tab.id,
});
} else if (code === 'focus-tab') {
chrome.tabs.update(tab.id, {active: true});
chrome.windows.update(tab.windowId, {focused: true});
browser.tabs.update(tab.id, {active: true});
browser.windows.update(tab.windowId, {focused: true});
}
}

// Temporary code from https://github.com/fregante/GhostText/pull/267
async function saveShortcut() {
const storage = await chrome.storage.local.get('shortcut');
const storage = await browser.storage.local.get('shortcut');
if (storage.shortcut) {
// Already saved
return;
}

const shortcuts = await chrome.commands.getAll();
const shortcuts = await browser.commands.getAll();
for (const item of shortcuts) {
if (item.shortcut) {
// eslint-disable-next-line no-await-in-loop -- Intentional
await chrome.storage.local.set({shortcut: item.shortcut});
await browser.storage.local.set({shortcut: item.shortcut});
return;
}
}
}

async function getActiveTab() {
const [activeTab] = await chrome.tabs.query({active: true, currentWindow: true});
const [activeTab] = await browser.tabs.query({active: true, currentWindow: true});
return activeTab;
}

function init() {
browserAction.onClicked.addListener(handleAction);
chrome.runtime.onMessage.addListener(handleMessages);
chrome.contextMenus.create({
browser.runtime.onMessage.addListener(handleMessages);
browser.contextMenus.create({
id: 'stop-gt',
title: 'Disconnect GhostText on this page',
contexts: ['action'],
});
chrome.contextMenus.onClicked.addListener(({menuItemId}, tab) => {
browser.contextMenus.onClicked.addListener(({menuItemId}, tab) => {
if (menuItemId === 'stop-gt') {
stopGT(tab);
} else if (menuItemId === 'start-gt-editable') {
handleAction(tab);
}
});
chrome.commands.onCommand.addListener(async (command, tab = getActiveTab()) => {
browser.commands.onCommand.addListener(async (command, tab = getActiveTab()) => {
if (command === 'open') {
handleAction(await tab);
} else if (command === 'close') {
stopGT(await tab);
}
});

chrome.contextMenus.create({
browser.contextMenus.create({
id: 'start-gt-editable',
title: 'Activate GhostText on field',
contexts: ['editable'],
Expand All @@ -176,15 +183,15 @@ function init() {
color: '#008040',
});

chrome.runtime.onInstalled.addListener(async ({reason}) => {
browser.runtime.onInstalled.addListener(async ({reason}) => {
// Only notify on install
if (reason === 'install') {
const {installType} = await chrome.management.getSelf();
const {installType} = await browser.management.getSelf();
if (installType === 'development') {
return;
}

await chrome.tabs.create({
await browser.tabs.create({
url: 'https://ghosttext.fregante.com/welcome/',
active: true,
});
Expand Down
3 changes: 3 additions & 0 deletions source/manifest.json
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,9 @@
"128": "icons/icon128.png",
"256": "icons/icon256.png"
},
"content_security_policy": {
"extension_pages": "connect-src 'self' http://localhost:* ws:; script-src 'self';"
},
"permissions": [
"activeTab",
"contextMenus",
Expand Down

0 comments on commit c231263

Please sign in to comment.