Double click multiple windows fixes (#3777)
* better way of doing on file open Signed-off-by: Jess Frazelle <github@jessfraz.com> * fixes Signed-off-by: Jess Frazelle <github@jessfraz.com> * updates Signed-off-by: Jess Frazelle <github@jessfraz.com> * cleanuer Signed-off-by: Jess Frazelle <github@jessfraz.com> * updates Signed-off-by: Jess Frazelle <github@jessfraz.com> --------- Signed-off-by: Jess Frazelle <github@jessfraz.com>
This commit is contained in:
1
interface.d.ts
vendored
1
interface.d.ts
vendored
@ -31,7 +31,6 @@ export interface IElectronAPI {
|
|||||||
sep: typeof path.sep
|
sep: typeof path.sep
|
||||||
rename: (prev: string, next: string) => typeof fs.rename
|
rename: (prev: string, next: string) => typeof fs.rename
|
||||||
setBaseUrl: (value: string) => void
|
setBaseUrl: (value: string) => void
|
||||||
loadProjectAtStartup: () => Promise<ProjectState | null>
|
|
||||||
packageJson: {
|
packageJson: {
|
||||||
name: string
|
name: string
|
||||||
}
|
}
|
||||||
|
|||||||
@ -69,19 +69,6 @@ const router = createRouter([
|
|||||||
path: PATHS.INDEX,
|
path: PATHS.INDEX,
|
||||||
loader: async () => {
|
loader: async () => {
|
||||||
const onDesktop = isDesktop()
|
const onDesktop = isDesktop()
|
||||||
if (onDesktop) {
|
|
||||||
const projectStartupFile =
|
|
||||||
await window.electron.loadProjectAtStartup()
|
|
||||||
if (projectStartupFile !== null) {
|
|
||||||
// Redirect to the file if we have a file path.
|
|
||||||
if (projectStartupFile.length > 0) {
|
|
||||||
return redirect(
|
|
||||||
PATHS.FILE + '/' + encodeURIComponent(projectStartupFile)
|
|
||||||
)
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return onDesktop
|
return onDesktop
|
||||||
? redirect(PATHS.HOME)
|
? redirect(PATHS.HOME)
|
||||||
: redirect(PATHS.FILE + '/%2F' + BROWSER_PROJECT_NAME)
|
: redirect(PATHS.FILE + '/%2F' + BROWSER_PROJECT_NAME)
|
||||||
|
|||||||
107
src/main.ts
107
src/main.ts
@ -60,7 +60,7 @@ if (process.defaultApp) {
|
|||||||
// Must be done before ready event.
|
// Must be done before ready event.
|
||||||
registerStartupListeners()
|
registerStartupListeners()
|
||||||
|
|
||||||
const createWindow = (): BrowserWindow => {
|
const createWindow = (filePath?: string): BrowserWindow => {
|
||||||
const newWindow = new BrowserWindow({
|
const newWindow = new BrowserWindow({
|
||||||
autoHideMenuBar: true,
|
autoHideMenuBar: true,
|
||||||
show: false,
|
show: false,
|
||||||
@ -81,9 +81,26 @@ const createWindow = (): BrowserWindow => {
|
|||||||
if (MAIN_WINDOW_VITE_DEV_SERVER_URL) {
|
if (MAIN_WINDOW_VITE_DEV_SERVER_URL) {
|
||||||
newWindow.loadURL(MAIN_WINDOW_VITE_DEV_SERVER_URL)
|
newWindow.loadURL(MAIN_WINDOW_VITE_DEV_SERVER_URL)
|
||||||
} else {
|
} else {
|
||||||
newWindow.loadFile(
|
getProjectPathAtStartup(filePath).then((projectPath) => {
|
||||||
path.join(__dirname, `../renderer/${MAIN_WINDOW_VITE_NAME}/index.html`)
|
const startIndex = path.join(
|
||||||
)
|
__dirname,
|
||||||
|
`../renderer/${MAIN_WINDOW_VITE_NAME}/index.html`
|
||||||
|
)
|
||||||
|
|
||||||
|
if (projectPath === null) {
|
||||||
|
newWindow.loadFile(startIndex)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
console.log('Loading file', projectPath)
|
||||||
|
|
||||||
|
const fullUrl = `/file/${encodeURIComponent(projectPath)}`
|
||||||
|
console.log('Full URL', fullUrl)
|
||||||
|
|
||||||
|
newWindow.loadFile(startIndex, {
|
||||||
|
hash: fullUrl,
|
||||||
|
})
|
||||||
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
// Open the DevTools.
|
// Open the DevTools.
|
||||||
@ -233,7 +250,9 @@ app.on('ready', async () => {
|
|||||||
})
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
ipcMain.handle('loadProjectAtStartup', async () => {
|
const getProjectPathAtStartup = async (
|
||||||
|
filePath?: string
|
||||||
|
): Promise<string | null> => {
|
||||||
// If we are in development mode, we don't want to load a project at
|
// If we are in development mode, we don't want to load a project at
|
||||||
// startup.
|
// startup.
|
||||||
// Since the args passed are always '.'
|
// Since the args passed are always '.'
|
||||||
@ -241,52 +260,54 @@ ipcMain.handle('loadProjectAtStartup', async () => {
|
|||||||
return null
|
return null
|
||||||
}
|
}
|
||||||
|
|
||||||
let projectPath: string | null = null
|
let projectPath: string | null = filePath || null
|
||||||
// macOS: open-file events that were received before the app is ready
|
if (projectPath === null) {
|
||||||
const macOpenFiles: string[] = (global as any).macOpenFiles
|
// macOS: open-file events that were received before the app is ready
|
||||||
if (macOpenFiles && macOpenFiles && macOpenFiles.length > 0) {
|
const macOpenFiles: string[] = (global as any).macOpenFiles
|
||||||
projectPath = macOpenFiles[0] // We only do one project at a time
|
if (macOpenFiles && macOpenFiles && macOpenFiles.length > 0) {
|
||||||
}
|
projectPath = macOpenFiles[0] // We only do one project at a time
|
||||||
// Reset this so we don't accidentally use it again.
|
}
|
||||||
const macOpenFilesEmpty: string[] = []
|
// Reset this so we don't accidentally use it again.
|
||||||
// @ts-ignore
|
const macOpenFilesEmpty: string[] = []
|
||||||
global['macOpenFiles'] = macOpenFilesEmpty
|
// @ts-ignore
|
||||||
|
global['macOpenFiles'] = macOpenFilesEmpty
|
||||||
|
|
||||||
// macOS: open-url events that were received before the app is ready
|
// macOS: open-url events that were received before the app is ready
|
||||||
const getOpenUrls: string[] = (global as any).getOpenUrls
|
const getOpenUrls: string[] = (global as any).getOpenUrls
|
||||||
if (getOpenUrls && getOpenUrls.length > 0) {
|
if (getOpenUrls && getOpenUrls.length > 0) {
|
||||||
projectPath = getOpenUrls[0] // We only do one project at a
|
projectPath = getOpenUrls[0] // We only do one project at a
|
||||||
}
|
}
|
||||||
// Reset this so we don't accidentally use it again.
|
// Reset this so we don't accidentally use it again.
|
||||||
// @ts-ignore
|
// @ts-ignore
|
||||||
global['getOpenUrls'] = []
|
global['getOpenUrls'] = []
|
||||||
|
|
||||||
// Check if we have a project path in the command line arguments
|
// Check if we have a project path in the command line arguments
|
||||||
// If we do, we will load the project at that path
|
// If we do, we will load the project at that path
|
||||||
if (args._.length > 1) {
|
if (args._.length > 1) {
|
||||||
if (args._[1].length > 0) {
|
if (args._[1].length > 0) {
|
||||||
projectPath = args._[1]
|
projectPath = args._[1]
|
||||||
// Reset all this value so we don't accidentally use it again.
|
// Reset all this value so we don't accidentally use it again.
|
||||||
args._[1] = ''
|
args._[1] = ''
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (projectPath) {
|
if (projectPath) {
|
||||||
// We have a project path, load the project information.
|
// We have a project path, load the project information.
|
||||||
console.log(`Loading project at startup: ${projectPath}`)
|
console.log(`Loading project at startup: ${projectPath}`)
|
||||||
try {
|
const currentFile = await getCurrentProjectFile(projectPath)
|
||||||
const currentFile = await getCurrentProjectFile(projectPath)
|
|
||||||
console.log(`Project loaded: ${currentFile}`)
|
if (currentFile instanceof Error) {
|
||||||
return currentFile
|
console.error(currentFile)
|
||||||
} catch (e) {
|
return null
|
||||||
console.error(e)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return null
|
console.log(`Project loaded: ${currentFile}`)
|
||||||
|
return currentFile
|
||||||
}
|
}
|
||||||
|
|
||||||
return null
|
return null
|
||||||
})
|
}
|
||||||
|
|
||||||
function parseCLIArgs(): minimist.ParsedArgs {
|
function parseCLIArgs(): minimist.ParsedArgs {
|
||||||
return minimist(process.argv, {})
|
return minimist(process.argv, {})
|
||||||
@ -303,10 +324,11 @@ function registerStartupListeners() {
|
|||||||
app.on('open-file', function (event, path) {
|
app.on('open-file', function (event, path) {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
|
|
||||||
macOpenFiles.push(path)
|
|
||||||
// If we have a mainWindow, lets open another window.
|
// If we have a mainWindow, lets open another window.
|
||||||
if (mainWindow) {
|
if (mainWindow) {
|
||||||
createWindow()
|
createWindow(path)
|
||||||
|
} else {
|
||||||
|
macOpenFiles.push(path)
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -322,10 +344,11 @@ function registerStartupListeners() {
|
|||||||
) {
|
) {
|
||||||
event.preventDefault()
|
event.preventDefault()
|
||||||
|
|
||||||
openUrls.push(url)
|
|
||||||
// If we have a mainWindow, lets open another window.
|
// If we have a mainWindow, lets open another window.
|
||||||
if (mainWindow) {
|
if (mainWindow) {
|
||||||
createWindow()
|
createWindow(url)
|
||||||
|
} else {
|
||||||
|
openUrls.push(url)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -60,9 +60,6 @@ const listMachines = async (): Promise<MachinesListing> => {
|
|||||||
const getMachineApiIp = async (): Promise<String | null> =>
|
const getMachineApiIp = async (): Promise<String | null> =>
|
||||||
ipcRenderer.invoke('find_machine_api')
|
ipcRenderer.invoke('find_machine_api')
|
||||||
|
|
||||||
const loadProjectAtStartup = async (): Promise<string | null> =>
|
|
||||||
ipcRenderer.invoke('loadProjectAtStartup')
|
|
||||||
|
|
||||||
contextBridge.exposeInMainWorld('electron', {
|
contextBridge.exposeInMainWorld('electron', {
|
||||||
login,
|
login,
|
||||||
// Passing fs directly is not recommended since it gives a lot of power
|
// Passing fs directly is not recommended since it gives a lot of power
|
||||||
@ -96,7 +93,6 @@ contextBridge.exposeInMainWorld('electron', {
|
|||||||
isWindows,
|
isWindows,
|
||||||
isLinux,
|
isLinux,
|
||||||
},
|
},
|
||||||
loadProjectAtStartup,
|
|
||||||
// IMPORTANT NOTE: kittycad.ts reads process.env.BASE_URL. But there is
|
// IMPORTANT NOTE: kittycad.ts reads process.env.BASE_URL. But there is
|
||||||
// no way to set it across the bridge boundary. We need to make it a command.
|
// no way to set it across the bridge boundary. We need to make it a command.
|
||||||
setBaseUrl: (value: string) => (process.env.BASE_URL = value),
|
setBaseUrl: (value: string) => (process.env.BASE_URL = value),
|
||||||
|
|||||||
Reference in New Issue
Block a user