mirror of
https://github.com/mdn/webextensions-examples.git
synced 2026-04-16 14:28:33 +02:00
70 lines
1.9 KiB
JavaScript
70 lines
1.9 KiB
JavaScript
const CSS = "body { border: 20px solid red; }";
|
|
const TITLE_APPLY = "Apply CSS";
|
|
const TITLE_REMOVE = "Remove CSS";
|
|
const APPLICABLE_PROTOCOLS = ["http:", "https:"];
|
|
|
|
/*
|
|
Toggle CSS: based on the current title, insert or remove the CSS.
|
|
Update the page action's title and icon to reflect its state.
|
|
*/
|
|
function toggleCSS(tab) {
|
|
|
|
function gotTitle(title) {
|
|
if (title === TITLE_APPLY) {
|
|
browser.pageAction.setIcon({tabId: tab.id, path: "icons/on.svg"});
|
|
browser.pageAction.setTitle({tabId: tab.id, title: TITLE_REMOVE});
|
|
browser.tabs.insertCSS({code: CSS});
|
|
} else {
|
|
browser.pageAction.setIcon({tabId: tab.id, path: "icons/off.svg"});
|
|
browser.pageAction.setTitle({tabId: tab.id, title: TITLE_APPLY});
|
|
browser.tabs.removeCSS({code: CSS});
|
|
}
|
|
}
|
|
|
|
var gettingTitle = browser.pageAction.getTitle({tabId: tab.id});
|
|
gettingTitle.then(gotTitle);
|
|
}
|
|
|
|
/*
|
|
Returns true only if the URL's protocol is in APPLICABLE_PROTOCOLS.
|
|
*/
|
|
function protocolIsApplicable(url) {
|
|
var anchor = document.createElement('a');
|
|
anchor.href = url;
|
|
return APPLICABLE_PROTOCOLS.includes(anchor.protocol);
|
|
}
|
|
|
|
/*
|
|
Initialize the page action: set icon and title, then show.
|
|
Only operates on tabs whose URL's protocol is applicable.
|
|
*/
|
|
function initializePageAction(tab) {
|
|
if (protocolIsApplicable(tab.url)) {
|
|
browser.pageAction.setIcon({tabId: tab.id, path: "icons/off.svg"});
|
|
browser.pageAction.setTitle({tabId: tab.id, title: TITLE_APPLY});
|
|
browser.pageAction.show(tab.id);
|
|
}
|
|
}
|
|
|
|
/*
|
|
When first loaded, initialize the page action for all tabs.
|
|
*/
|
|
var gettingAllTabs = browser.tabs.query({});
|
|
gettingAllTabs.then((tabs) => {
|
|
for (let tab of tabs) {
|
|
initializePageAction(tab);
|
|
}
|
|
});
|
|
|
|
/*
|
|
Each time a tab is updated, reset the page action for that tab.
|
|
*/
|
|
browser.tabs.onUpdated.addListener((id, changeInfo, tab) => {
|
|
initializePageAction(tab);
|
|
});
|
|
|
|
/*
|
|
Toggle CSS when the page action is clicked.
|
|
*/
|
|
browser.pageAction.onClicked.addListener(toggleCSS);
|