mirror of
https://github.com/laurent22/joplin.git
synced 2025-01-11 18:24:43 +02:00
3917e3469d
* add button to About box to copy Joplin's information to the clipboard On certain OS it is not possible to copy the text in the About window. This change allows to copy that info to the Clipboard. Due to some shortfalls in Electron, it is not possible to set `defaultId` and `cancelId` to 0. (Actually one can set them to 0, but the result is not what one would expect.) Thus I had to move the default `OK` button to the left. I also added a hack to position the `OK` button approximately in the middle of the dialog box (if the copyLabel is not longer than 14 characters). * remove hack to position button * add a new bridge function showMessageBox The function returns the index of the clicked button. * we don't need the first 3 lines (product name and copyright)
180 lines
4.1 KiB
JavaScript
180 lines
4.1 KiB
JavaScript
const { _, setLocale } = require('lib/locale.js');
|
|
const { dirname } = require('lib/path-utils.js');
|
|
const { BrowserWindow } = require('electron');
|
|
|
|
class Bridge {
|
|
|
|
constructor(electronWrapper) {
|
|
this.electronWrapper_ = electronWrapper;
|
|
this.autoUpdateLogger_ = null;
|
|
this.lastSelectedPath_ = null;
|
|
}
|
|
|
|
electronApp() {
|
|
return this.electronWrapper_;
|
|
}
|
|
|
|
env() {
|
|
return this.electronWrapper_.env();
|
|
}
|
|
|
|
processArgv() {
|
|
return process.argv;
|
|
}
|
|
|
|
window() {
|
|
return this.electronWrapper_.window();
|
|
}
|
|
|
|
newBrowserWindow(options) {
|
|
return new BrowserWindow(options);
|
|
}
|
|
|
|
windowContentSize() {
|
|
if (!this.window()) return { width: 0, height: 0 };
|
|
const s = this.window().getContentSize();
|
|
return { width: s[0], height: s[1] };
|
|
}
|
|
|
|
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);
|
|
}
|
|
|
|
openDevTools() {
|
|
return this.window().webContents.openDevTools();
|
|
}
|
|
|
|
closeDevTools() {
|
|
return this.window().webContents.closeDevTools();
|
|
}
|
|
|
|
showSaveDialog(options) {
|
|
const { dialog } = require('electron');
|
|
if (!options) options = {};
|
|
if (!('defaultPath' in options) && this.lastSelectedPath_) options.defaultPath = this.lastSelectedPath_;
|
|
const filePath = dialog.showSaveDialogSync(this.window(), options);
|
|
if (filePath) {
|
|
this.lastSelectedPath_ = filePath;
|
|
}
|
|
return filePath;
|
|
}
|
|
|
|
showOpenDialog(options) {
|
|
const { dialog } = require('electron');
|
|
if (!options) options = {};
|
|
if (!('defaultPath' in options) && this.lastSelectedPath_) options.defaultPath = this.lastSelectedPath_;
|
|
if (!('createDirectory' in options)) options.createDirectory = true;
|
|
const filePaths = dialog.showOpenDialogSync(this.window(), options);
|
|
if (filePaths && filePaths.length) {
|
|
this.lastSelectedPath_ = dirname(filePaths[0]);
|
|
}
|
|
return filePaths;
|
|
}
|
|
|
|
// Don't use this directly - call one of the showXxxxxxxMessageBox() instead
|
|
showMessageBox_(window, options) {
|
|
const { dialog } = require('electron');
|
|
if (!window) window = this.window();
|
|
return dialog.showMessageBoxSync(window, options);
|
|
}
|
|
|
|
showErrorMessageBox(message) {
|
|
return this.showMessageBox_(this.window(), {
|
|
type: 'error',
|
|
message: message,
|
|
buttons: [_('OK')],
|
|
});
|
|
}
|
|
|
|
showConfirmMessageBox(message, options = null) {
|
|
if (options === null) options = {};
|
|
|
|
const result = this.showMessageBox_(this.window(), Object.assign({}, {
|
|
type: 'question',
|
|
message: message,
|
|
cancelId: 1,
|
|
buttons: [_('OK'), _('Cancel')],
|
|
}, options));
|
|
|
|
return result === 0;
|
|
}
|
|
|
|
/* returns the index of the clicked button */
|
|
showMessageBox(message, options = null) {
|
|
if (options === null) options = {};
|
|
|
|
const result = this.showMessageBox_(this.window(), Object.assign({}, {
|
|
type: 'question',
|
|
message: message,
|
|
buttons: [_('OK'), _('Cancel')],
|
|
}, options));
|
|
|
|
return result;
|
|
}
|
|
|
|
showInfoMessageBox(message, options = {}) {
|
|
const result = this.showMessageBox_(this.window(), Object.assign({}, {
|
|
type: 'info',
|
|
message: message,
|
|
buttons: [_('OK')],
|
|
}, options));
|
|
return result === 0;
|
|
}
|
|
|
|
setLocale(locale) {
|
|
setLocale(locale);
|
|
}
|
|
|
|
get Menu() {
|
|
return require('electron').Menu;
|
|
}
|
|
|
|
get MenuItem() {
|
|
return require('electron').MenuItem;
|
|
}
|
|
|
|
openExternal(url) {
|
|
return require('electron').shell.openExternal(url);
|
|
}
|
|
|
|
openItem(fullPath) {
|
|
return require('electron').shell.openItem(fullPath);
|
|
}
|
|
|
|
checkForUpdates(inBackground, window, logFilePath, options) {
|
|
const { checkForUpdates } = require('./checkForUpdates.js');
|
|
checkForUpdates(inBackground, window, logFilePath, options);
|
|
}
|
|
|
|
buildDir() {
|
|
return this.electronApp().buildDir();
|
|
}
|
|
|
|
screen() {
|
|
return require('electron').screen;
|
|
}
|
|
|
|
}
|
|
|
|
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 };
|