ollama/app/src/index.ts

107 lines
3.2 KiB
TypeScript
Raw Normal View History

2023-06-28 00:31:02 +00:00
import { app, BrowserWindow, autoUpdater, dialog } from 'electron'
2023-06-23 22:38:22 +00:00
import { spawn } from 'child_process'
import * as path from 'path'
2023-06-27 16:35:51 +00:00
require('@electron/remote/main').initialize()
2023-06-23 19:04:38 +00:00
// This allows TypeScript to pick up the magic constants that's auto-generated by Forge's Webpack
// plugin that tells the Electron app where to look for the Webpack-bundled app code (depending on
// whether you're running in development or production).
declare const MAIN_WINDOW_WEBPACK_ENTRY: string
declare const MAIN_WINDOW_PRELOAD_WEBPACK_ENTRY: string
2023-06-22 16:45:31 +00:00
// Handle creating/removing shortcuts on Windows when installing/uninstalling.
if (require('electron-squirrel-startup')) {
app.quit()
}
2023-06-23 19:04:38 +00:00
const createWindow = (): void => {
// Create the browser window.
2023-06-22 16:45:31 +00:00
// Create the browser window.
const mainWindow = new BrowserWindow({
width: 800,
height: 600,
2023-06-23 18:04:39 +00:00
minWidth: 400,
minHeight: 300,
titleBarStyle: 'hiddenInset',
2023-06-27 16:35:51 +00:00
webPreferences: {
preload: MAIN_WINDOW_PRELOAD_WEBPACK_ENTRY,
nodeIntegration: true,
contextIsolation: false,
},
2023-06-22 16:45:31 +00:00
})
2023-06-27 16:35:51 +00:00
require('@electron/remote/main').enable(mainWindow.webContents)
2023-06-25 04:30:02 +00:00
// and load the index.html of the app.
mainWindow.loadURL(MAIN_WINDOW_WEBPACK_ENTRY)
}
// if the app is packaged then run the server
if (app.isPackaged) {
const resources = process.resourcesPath
console.log(resources)
2023-06-23 22:38:22 +00:00
// Start the executable
2023-06-27 18:33:49 +00:00
const exec = path.join(resources, 'ollama', 'ollama')
2023-06-25 04:30:02 +00:00
console.log(`Starting ${exec}`)
2023-06-27 18:33:49 +00:00
const proc = spawn(exec, ['serve', '--port', '7734'])
2023-06-25 04:30:02 +00:00
proc.stdout.on('data', data => {
2023-06-23 22:38:22 +00:00
console.log(`server: ${data}`)
})
2023-06-25 04:30:02 +00:00
proc.stderr.on('data', data => {
2023-06-23 22:38:22 +00:00
console.error(`server: ${data}`)
})
2023-06-25 04:30:02 +00:00
process.on('exit', () => {
proc.kill()
})
2023-06-22 16:45:31 +00: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.on('ready', createWindow)
// Quit when all windows are closed, except on macOS. There, it's common
// for applications and their menu bar to stay active until the user quits
// explicitly with Cmd + Q.
app.on('window-all-closed', () => {
if (process.platform !== 'darwin') {
app.quit()
}
})
app.on('activate', () => {
// On OS X it's common to re-create a window in the app when the
// dock icon is clicked and there are no other windows open.
if (BrowserWindow.getAllWindows().length === 0) {
createWindow()
}
})
// 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 import them here.
2023-07-06 04:04:06 +00:00
autoUpdater.setFeedURL({
url: `https://ollama.ai/api/update?os=${process.platform}&arch=${process.arch}&version=${app.getVersion()}`,
})
2023-06-27 21:50:50 +00:00
autoUpdater.checkForUpdates()
2023-06-27 21:50:50 +00:00
setInterval(() => {
autoUpdater.checkForUpdates()
}, 60000)
2023-06-28 00:31:02 +00:00
autoUpdater.on('update-downloaded', (event, releaseNotes, releaseName) => {
dialog
.showMessageBox({
type: 'info',
buttons: ['Restart Now', 'Later'],
title: 'New update available',
message: process.platform === 'win32' ? releaseNotes : releaseName,
detail: 'A new version of Ollama is available. Restart to apply the update.',
})
.then(returnValue => {
if (returnValue.response === 0) autoUpdater.quitAndInstall()
})
})