* feat: desktop revamp * feat: refactor system monitor * fix linter CI * remove unused import component * added responsive and resizeable component * responsive and resizeable local server page * finalize responsive and resizeable component * fix scroll custom ui * remove react scroll to bottom from modal troubleshoot * fix modal troubleshoot ui * fix setting gpu list * text area custom scroll bar * fix padding message input * cleanup classname * update inference engine model dropdown * update loader style * update quick ask ui * prepare theme provider * update dark theme * remove update hotkey list model and navigation * fix: cleanup hardcode classname * fix: update feedback * Set native theme electron * update destop ui revamp from feedback * update button icon component insider icon chat input message * update model dropdown ui * update tranaparent baclground * update logo model provider * fix: set background material acrylic support to blur background windows * fix: update tranparent left and right panel * fix: linter CI * update app using frameless window * styling custom style minimize, maximize and close app * temporary hidden maximize window * fix: responsive left and right panel * fix: enable click outside when leftpanel responsive * fix: remove unused import * update transparent variable css windows * fix: ui import model * feat: Support Theme system (#2946) * feat: update support theme system * update select component * feat: add theme folder in root project * fix: padding left and right center panel * fix: update padding left and right * chore: migrate themes * fix: rmdirsync error * chore: update gitignore * fix: cp recursive * fix: files electron package json * fix: migration * fix: update fgit ignore --------- Co-authored-by: Louis <louis@jan.ai> * fix: update feedback missing state when refrash app * fix: error test CI * chore: refactor useLoadThemes * chore: cleanup unused vars * fix: revert back menubar windows * fix minor ui * fix: minor ui --------- Co-authored-by: Louis <louis@jan.ai>
120 lines
3.0 KiB
TypeScript
120 lines
3.0 KiB
TypeScript
// @ts-nocheck
|
|
import { app, Menu, shell, dialog } from 'electron'
|
|
import { autoUpdater } from 'electron-updater'
|
|
import { log } from '@janhq/core/node'
|
|
const isMac = process.platform === 'darwin'
|
|
|
|
const template: (Electron.MenuItemConstructorOptions | Electron.MenuItem)[] = [
|
|
{
|
|
label: app.name,
|
|
submenu: [
|
|
{
|
|
label: `About ${app.name}`,
|
|
click: () =>
|
|
dialog.showMessageBox({
|
|
title: `Jan`,
|
|
message: `Jan Version v${app.getVersion()}\n\nCopyright © 2024 Jan`,
|
|
}),
|
|
},
|
|
{
|
|
label: 'Check for Updates...',
|
|
click: () =>
|
|
// Check for updates and notify user if there are any
|
|
autoUpdater
|
|
.checkForUpdatesAndNotify()
|
|
.then((updateCheckResult) => {
|
|
if (
|
|
!updateCheckResult?.updateInfo ||
|
|
updateCheckResult?.updateInfo.version === app.getVersion()
|
|
) {
|
|
dialog.showMessageBox({
|
|
message: `No updates available.`,
|
|
})
|
|
return
|
|
}
|
|
})
|
|
.catch((error) => {
|
|
log('Error checking for updates:' + JSON.stringify(error))
|
|
}),
|
|
},
|
|
{ type: 'separator' },
|
|
{ role: 'services' },
|
|
{ type: 'separator' },
|
|
{ role: 'hide' },
|
|
{ role: 'hideOthers' },
|
|
{ role: 'unhide' },
|
|
{ type: 'separator' },
|
|
{ role: 'quit' },
|
|
],
|
|
},
|
|
{
|
|
label: 'Edit',
|
|
submenu: [
|
|
{ role: 'undo' },
|
|
{ role: 'redo' },
|
|
{ type: 'separator' },
|
|
{ role: 'cut' },
|
|
{ role: 'copy' },
|
|
{ role: 'paste' },
|
|
...(isMac
|
|
? [
|
|
{ role: 'pasteAndMatchStyle' },
|
|
{ role: 'delete' },
|
|
{ role: 'selectAll' },
|
|
{ type: 'separator' },
|
|
{
|
|
label: 'Speech',
|
|
submenu: [{ role: 'startSpeaking' }, { role: 'stopSpeaking' }],
|
|
},
|
|
]
|
|
: [{ role: 'delete' }, { type: 'separator' }, { role: 'selectAll' }]),
|
|
],
|
|
},
|
|
{
|
|
label: 'View',
|
|
submenu: [
|
|
{ role: 'reload' },
|
|
{ role: 'forceReload' },
|
|
{ role: 'toggleDevTools' },
|
|
{ type: 'separator' },
|
|
{ role: 'resetZoom' },
|
|
{ role: 'zoomIn' },
|
|
{ role: 'zoomOut' },
|
|
{ type: 'separator' },
|
|
{ role: 'togglefullscreen' },
|
|
],
|
|
},
|
|
{
|
|
label: 'Window',
|
|
submenu: [
|
|
{ role: 'minimize' },
|
|
{ role: 'zoom' },
|
|
...(isMac
|
|
? [
|
|
{ type: 'separator' },
|
|
{ role: 'front' },
|
|
{ type: 'separator' },
|
|
{ role: 'window' },
|
|
]
|
|
: [{ role: 'close' }]),
|
|
],
|
|
},
|
|
{
|
|
role: 'help',
|
|
submenu: [
|
|
{
|
|
label: 'Learn More',
|
|
click: async () => {
|
|
await shell.openExternal('https://jan.ai/guides/')
|
|
},
|
|
},
|
|
],
|
|
},
|
|
]
|
|
|
|
export const menu = Menu.buildFromTemplate(template)
|
|
|
|
export const setupMenu = () => {
|
|
Menu.setApplicationMenu(menu)
|
|
}
|