passes open url in renderUrl on open
This commit is contained in:
parent
cfc584beaa
commit
77e7cb7401
2 changed files with 23 additions and 24 deletions
|
@ -4,6 +4,7 @@ import isDev from 'electron-is-dev';
|
||||||
import windowStateKeeper from 'electron-window-state';
|
import windowStateKeeper from 'electron-window-state';
|
||||||
|
|
||||||
import setupBarMenu from './menu/setupBarMenu';
|
import setupBarMenu from './menu/setupBarMenu';
|
||||||
|
import * as PAGES from '../../ui/constants/pages';
|
||||||
|
|
||||||
export default appState => {
|
export default appState => {
|
||||||
// Get primary display dimensions from Electron.
|
// Get primary display dimensions from Electron.
|
||||||
|
@ -34,7 +35,8 @@ export default appState => {
|
||||||
plugins: true,
|
plugins: true,
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
const lbryProto = 'lbry://';
|
||||||
|
const lbryProtoQ = 'lbry://?';
|
||||||
const rendererURL = isDev ? `http://localhost:8080` : `file://${__dirname}/index.html`;
|
const rendererURL = isDev ? `http://localhost:8080` : `file://${__dirname}/index.html`;
|
||||||
|
|
||||||
let window = new BrowserWindow(windowConfiguration);
|
let window = new BrowserWindow(windowConfiguration);
|
||||||
|
@ -44,14 +46,13 @@ export default appState => {
|
||||||
// and restore the maximized or full screen state.
|
// and restore the maximized or full screen state.
|
||||||
windowState.manage(window);
|
windowState.manage(window);
|
||||||
|
|
||||||
window.loadURL(rendererURL);
|
|
||||||
|
|
||||||
let deepLinkingURI;
|
let deepLinkingURI;
|
||||||
|
|
||||||
if (
|
if (
|
||||||
(process.platform === 'win32' || process.platform === 'linux') &&
|
(process.platform === 'win32' || process.platform === 'linux') &&
|
||||||
String(process.argv[1]).startsWith('lbry')
|
String(process.argv[1]).startsWith('lbry')
|
||||||
) {
|
) {
|
||||||
[, deepLinkingURI] = process.argv;
|
[, deepLinkingURI] = process.argv || '';
|
||||||
// Keep only command line / deep linked arguments
|
// Keep only command line / deep linked arguments
|
||||||
// Windows normalizes URIs when they're passed in from other apps. On Windows, this tries to
|
// Windows normalizes URIs when they're passed in from other apps. On Windows, this tries to
|
||||||
// restore the original URI that was typed.
|
// restore the original URI that was typed.
|
||||||
|
@ -67,9 +68,24 @@ export default appState => {
|
||||||
.replace('/?', '?');
|
.replace('/?', '?');
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
deepLinkingURI = appState.macDeepLinkingURI;
|
deepLinkingURI = appState.macDeepLinkingURI || '';
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// is it a lbry://? pointing to an app page
|
||||||
|
if (deepLinkingURI.includes(lbryProtoQ)) {
|
||||||
|
if (Object.values(PAGES).includes(deepLinkingURI.substr(lbryProtoQ.length))) {
|
||||||
|
deepLinkingURI = deepLinkingURI.replace(lbryProtoQ, '#/$/');
|
||||||
|
} else {
|
||||||
|
deepLinkingURI = '';
|
||||||
|
}
|
||||||
|
// else is it a claim
|
||||||
|
} else if (deepLinkingURI.includes(lbryProto)) {
|
||||||
|
deepLinkingURI = deepLinkingURI.replace(lbryProto, '#');
|
||||||
|
} else {
|
||||||
|
deepLinkingURI = '';
|
||||||
|
}
|
||||||
|
|
||||||
|
window.loadURL(rendererURL + deepLinkingURI);
|
||||||
setupBarMenu();
|
setupBarMenu();
|
||||||
|
|
||||||
// Windows back/forward mouse navigation
|
// Windows back/forward mouse navigation
|
||||||
|
@ -119,13 +135,11 @@ export default appState => {
|
||||||
}
|
}
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
window.once('ready-to-show', () => {
|
window.once('ready-to-show', () => {
|
||||||
window.show();
|
window.show();
|
||||||
});
|
});
|
||||||
|
|
||||||
window.webContents.on('did-finish-load', () => {
|
window.webContents.on('did-finish-load', () => {
|
||||||
window.webContents.send('open-uri-requested', deepLinkingURI, true);
|
|
||||||
window.webContents.session.setUserAgent(`LBRY/${app.getVersion()}`);
|
window.webContents.session.setUserAgent(`LBRY/${app.getVersion()}`);
|
||||||
if (isDev) {
|
if (isDev) {
|
||||||
window.webContents.openDevTools();
|
window.webContents.openDevTools();
|
||||||
|
|
|
@ -73,7 +73,7 @@ const startDaemon = async () => {
|
||||||
app.quit();
|
app.quit();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
daemon.launch();
|
await daemon.launch();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -115,7 +115,7 @@ if (!gotSingleInstanceLock) {
|
||||||
});
|
});
|
||||||
|
|
||||||
app.on('ready', async () => {
|
app.on('ready', async () => {
|
||||||
startDaemon();
|
await startDaemon();
|
||||||
startSandbox();
|
startSandbox();
|
||||||
|
|
||||||
if (isDev) {
|
if (isDev) {
|
||||||
|
@ -195,21 +195,6 @@ app.on('will-quit', event => {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
// https://electronjs.org/docs/api/app#event-will-finish-launching
|
|
||||||
app.on('will-finish-launching', () => {
|
|
||||||
// Protocol handler for macOS
|
|
||||||
app.on('open-url', (event, URL) => {
|
|
||||||
event.preventDefault();
|
|
||||||
|
|
||||||
if (rendererWindow) {
|
|
||||||
rendererWindow.webContents.send('open-uri-requested', URL);
|
|
||||||
rendererWindow.show();
|
|
||||||
} else {
|
|
||||||
appState.macDeepLinkingURI = URL;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
app.on('before-quit', () => {
|
app.on('before-quit', () => {
|
||||||
appState.isQuitting = true;
|
appState.isQuitting = true;
|
||||||
});
|
});
|
||||||
|
|
Loading…
Add table
Reference in a new issue