| 
									
										
										
										
											2020-08-27 07:31:51 -07:00
										 |  |  | // Modules to control application life and create native browser window
 | 
					
						
							| 
									
										
										
										
											2023-08-28 13:23:10 +02:00
										 |  |  | const { app, BrowserWindow, ipcMain, dialog, shell } = require('electron/main') | 
					
						
							| 
									
										
										
										
											2023-08-29 21:52:16 +02:00
										 |  |  | const path = require('node:path') | 
					
						
							| 
									
										
										
										
											2020-08-27 07:31:51 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  | // Keep a global reference of the window object, if you don't, the window will
 | 
					
						
							|  |  |  | // be closed automatically when the JavaScript object is garbage collected.
 | 
					
						
							|  |  |  | let mainWindow | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function createWindow () { | 
					
						
							|  |  |  |   // Create the browser window.
 | 
					
						
							|  |  |  |   mainWindow = new BrowserWindow({ | 
					
						
							|  |  |  |     width: 800, | 
					
						
							|  |  |  |     height: 600, | 
					
						
							|  |  |  |     webPreferences: { | 
					
						
							| 
									
										
										
										
											2023-08-29 21:52:16 +02:00
										 |  |  |       preload: path.join(__dirname, 'preload.js') | 
					
						
							| 
									
										
										
										
											2020-08-27 07:31:51 -07:00
										 |  |  |     } | 
					
						
							|  |  |  |   }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // and load the index.html of the app.
 | 
					
						
							|  |  |  |   mainWindow.loadFile('index.html') | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Open the DevTools.
 | 
					
						
							|  |  |  |   // mainWindow.webContents.openDevTools()
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   // Emitted when the window is closed.
 | 
					
						
							|  |  |  |   mainWindow.on('closed', function () { | 
					
						
							|  |  |  |     // Dereference the window object, usually you would store windows
 | 
					
						
							|  |  |  |     // in an array if your app supports multi windows, this is the time
 | 
					
						
							|  |  |  |     // when you should delete the corresponding element.
 | 
					
						
							|  |  |  |     mainWindow = null | 
					
						
							|  |  |  |   }) | 
					
						
							| 
									
										
										
										
											2023-08-08 12:35:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // Open external links in the default browser
 | 
					
						
							|  |  |  |   mainWindow.webContents.on('will-navigate', (event, url) => { | 
					
						
							|  |  |  |     event.preventDefault() | 
					
						
							|  |  |  |     shell.openExternal(url) | 
					
						
							|  |  |  |   }) | 
					
						
							| 
									
										
										
										
											2020-08-27 07:31:51 -07:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // This method will be called when Electron has finished
 | 
					
						
							|  |  |  | // initialization and is ready to create browser windows.
 | 
					
						
							|  |  |  | // Some APIs can only be used after this event occurs.
 | 
					
						
							|  |  |  | app.whenReady().then(createWindow) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Quit when all windows are closed.
 | 
					
						
							|  |  |  | app.on('window-all-closed', function () { | 
					
						
							|  |  |  |   // On macOS it is common for applications and their menu bar
 | 
					
						
							|  |  |  |   // to stay active until the user quits explicitly with Cmd + Q
 | 
					
						
							|  |  |  |   if (process.platform !== 'darwin') { | 
					
						
							|  |  |  |     app.quit() | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | app.on('activate', function () { | 
					
						
							|  |  |  |   // On macOS it is common to re-create a window in the app when the
 | 
					
						
							|  |  |  |   // dock icon is clicked and there are no other windows open.
 | 
					
						
							|  |  |  |   if (mainWindow === null) { | 
					
						
							|  |  |  |     createWindow() | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-08-29 21:52:16 +02:00
										 |  |  | ipcMain.handle('save-dialog', async () => { | 
					
						
							| 
									
										
										
										
											2020-08-27 07:31:51 -07:00
										 |  |  |   const options = { | 
					
						
							|  |  |  |     title: 'Save an Image', | 
					
						
							|  |  |  |     filters: [{ name: 'Images', extensions: ['jpg', 'png', 'gif'] }] | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2023-08-29 21:52:16 +02:00
										 |  |  |   return (await dialog.showSaveDialog(options)).filePath | 
					
						
							| 
									
										
										
										
											2020-08-27 07:31:51 -07:00
										 |  |  | }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // In this file you can include the rest of your app's specific main process
 | 
					
						
							|  |  |  | // code. You can also put them in separate files and require them here.
 |