1
0
mirror of https://github.com/laurent22/joplin.git synced 2025-01-08 13:06:15 +02:00
joplin/ElectronClient/app/bridge.js

114 lines
2.4 KiB
JavaScript
Raw Normal View History

2017-11-08 19:51:55 +02:00
const { _ } = require('lib/locale.js');
2017-11-14 12:53:18 +02:00
const { Logger } = require('lib/logger.js');
2017-11-08 19:51:55 +02:00
class Bridge {
constructor(electronWrapper) {
this.electronWrapper_ = electronWrapper;
this.autoUpdateLogger_ = null;
}
2017-11-11 14:00:37 +02:00
electronApp() {
return this.electronWrapper_;
}
processArgv() {
return process.argv;
}
window() {
return this.electronWrapper_.window();
}
windowContentSize() {
if (!this.window()) return { width: 0, height: 0 };
const s = this.window().getContentSize();
return { width: s[0], height: s[1] };
}
2017-11-14 20:02:58 +02:00
windowSize() {
if (!this.window()) return { width: 0, height: 0 };
const s = this.window().getSize();
return { width: s[0], height: s[1] };
}
windowSetSize(width, height) {
if (!this.window()) return;
return this.window().setSize(width, height);
}
2017-11-11 00:18:00 +02:00
showOpenDialog(options) {
const {dialog} = require('electron');
return dialog.showOpenDialog(options);
}
showMessageBox(options) {
const {dialog} = require('electron');
return dialog.showMessageBox(options);
}
2017-11-08 19:51:55 +02:00
showErrorMessageBox(message) {
return this.showMessageBox({
type: 'error',
message: message,
});
}
showConfirmMessageBox(message) {
const result = this.showMessageBox({
type: 'question',
message: message,
buttons: [_('OK'), _('Cancel')],
});
return result === 0;
}
get Menu() {
return require('electron').Menu;
}
get MenuItem() {
return require('electron').MenuItem;
}
2017-11-11 14:00:37 +02:00
openExternal(url) {
return require('electron').shell.openExternal(url)
}
openItem(fullPath) {
return require('electron').shell.openItem(fullPath)
}
async checkForUpdatesAndNotify(logFilePath) {
2017-11-14 12:53:18 +02:00
if (!this.autoUpdater_) {
this.autoUpdateLogger_ = new Logger();
this.autoUpdateLogger_.addTarget('file', { path: logFilePath });
this.autoUpdateLogger_.setLevel(Logger.LEVEL_DEBUG);
this.autoUpdateLogger_.info('checkForUpdatesAndNotify: Intializing...');
2017-11-14 12:53:18 +02:00
this.autoUpdater_ = require("electron-updater").autoUpdater;
this.autoUpdater_.logger = this.autoUpdateLogger_;
2017-11-14 12:53:18 +02:00
}
try {
await this.autoUpdater_.checkForUpdatesAndNotify();
} catch (error) {
this.autoUpdateLogger_.error(error);
}
2017-11-14 12:18:18 +02:00
}
2017-11-14 01:04:27 +02:00
}
let bridge_ = null;
function initBridge(wrapper) {
if (bridge_) throw new Error('Bridge already initialized');
bridge_ = new Bridge(wrapper);
return bridge_;
}
function bridge() {
if (!bridge_) throw new Error('Bridge not initialized');
return bridge_;
}
module.exports = { bridge, initBridge }