1
0
mirror of https://github.com/laurent22/joplin.git synced 2024-11-27 08:21:03 +02:00
joplin/Clipper/joplin-webclipper/background.js

90 lines
2.4 KiB
JavaScript
Raw Normal View History

let browser_ = null;
2018-06-01 16:50:11 +02:00
let browserName_ = null;
if (typeof browser !== 'undefined') {
browser_ = browser;
browserSupportsPromises_ = true;
2018-06-01 16:50:11 +02:00
browserName_ = 'firefox';
} else if (typeof chrome !== 'undefined') {
browser_ = chrome;
browserSupportsPromises_ = false;
2018-06-01 16:50:11 +02:00
browserName_ = 'chrome';
}
2018-06-01 16:50:11 +02:00
let env_ = null;
// Make this function global so that it can be accessed
// from the popup too.
// https://stackoverflow.com/questions/6323184/communication-between-background-page-and-popup-page-in-a-chrome-extension
window.joplinEnv = function() {
if (env_) return env_;
env_ = !('update_url' in browser_.runtime.getManifest()) ? 'dev' : 'prod';
return env_;
}
async function browserCaptureVisibleTabs(windowId, options) {
2018-05-25 09:51:54 +02:00
if (browserSupportsPromises_) return browser_.tabs.captureVisibleTab(windowId, { format: 'jpeg' });
2018-05-25 09:51:54 +02:00
return new Promise((resolve, reject) => {
browser_.tabs.captureVisibleTab(windowId, { format: 'jpeg' }, (image) => {
resolve(image);
});
});
}
async function browserGetZoom(tabId) {
if (browserSupportsPromises_) return browser_.tabs.getZoom(tabId);
return new Promise((resolve, reject) => {
browser_.tabs.getZoom(tabId, (zoom) => {
resolve(zoom);
});
});
}
2018-06-01 16:50:11 +02:00
browser_.runtime.onInstalled.addListener(function(details) {
if (details && details.temporary) {
// In Firefox - https://developer.mozilla.org/en-US/Add-ons/WebExtensions/API/runtime/onInstalled
env_ = 'dev';
} else if (browserName_ === 'chrome') {
// In Chrome
env_ = !('update_url' in browser_.runtime.getManifest()) ? 'dev' : 'prod';
} else {
// If we don't know, be safe and default to prod
env_ = 'prod';
}
if (window.joplinEnv() === 'dev') {
browser_.browserAction.setIcon({
path: 'icons/32-dev.png',
});
}
});
browser_.runtime.onMessage.addListener(async (command) => {
if (command.name === 'screenshotArea') {
const zoom = await browserGetZoom();
const imageDataUrl = await browserCaptureVisibleTabs(null, { format: 'jpeg' });
content = Object.assign({}, command.content);
content.image_data_url = imageDataUrl;
const newArea = Object.assign({}, command.content.crop_rect);
newArea.x *= zoom;
newArea.y *= zoom;
newArea.width *= zoom;
newArea.height *= zoom;
content.crop_rect = newArea;
fetch(command.api_base_url + "/notes", {
method: "POST",
headers: {
'Accept': 'application/json',
'Content-Type': 'application/json'
},
body: JSON.stringify(content)
});
}
});