[x] Fixed opening URLs in external browser on MacOS

This commit is contained in:
Greyhoof 2023-10-10 11:54:09 +02:00
parent 877bb9448f
commit bfcbf8573b
1 changed files with 24 additions and 5 deletions

View File

@ -173,11 +173,22 @@ async function addSpellcheckerItems(menu: electron.Menu): Promise<void> {
} }
function openURLExternally(linkUrl: string): void { function openURLExternally(linkUrl: string): void {
// check if user set a path, whether it exists and if it is a file // console.log('openURLExternally()', JSON.stringify(settings));
if(settings.browserPath !== '' && // console.log('openURLExternally() -> path set?', settings.browserPath !== '');
fs.existsSync(settings.browserPath) && // console.log('openURLExternally() -> path exists?', fs.existsSync(settings.browserPath));
fs.lstatSync(settings.browserPath).isFile()) { // console.log('openURLExternally() -> path points to file?', fs.lstatSync(settings.browserPath).isFile());
const os = require('os');
// check if user set a path, whether it exists and if it is a file or an .app path
let isValid = (settings.browserPath !== '' && fs.existsSync(settings.browserPath));
if (os.platform() === "darwin") {
// is there a better way for this on macos?
isValid = (isValid && settings.browserPath.endsWith('.app'));
} else {
isValid = (isValid && fs.lstatSync(settings.browserPath).isFile());
}
if(isValid) {
// check if URL is already encoded // check if URL is already encoded
// (this should work almost all the time, but there might be edge-cases with very unusual URLs) // (this should work almost all the time, but there might be edge-cases with very unusual URLs)
let isEncoded = (linkUrl !== decodeURI(linkUrl)); let isEncoded = (linkUrl !== decodeURI(linkUrl));
@ -197,7 +208,15 @@ function openURLExternally(linkUrl: string): void {
let link = settings.browserArgs.replace('%s', '\"'+linkUrl+'\"'); let link = settings.browserArgs.replace('%s', '\"'+linkUrl+'\"');
const execFile = require('child_process').exec; const execFile = require('child_process').exec;
execFile(`"${settings.browserPath}" ${link}`); if (os.platform() === "darwin") {
// NOTE: This is seemingly bugged on MacOS when setting Safari as the external browser while using a different default browser.
// In that case, this will open the URL in both the selected application AND the default browser.
// Other browsers work fine. (Tested with Chrome with Firefox as the default browser.)
// https://developer.apple.com/forums/thread/685385
execFile(`open -a "${settings.browserPath}" ${link}`);
} else {
execFile(`"${settings.browserPath}" ${link}`);
}
} else { } else {
electron.shell.openExternal(linkUrl); electron.shell.openExternal(linkUrl);
} }