* refactor(GeminiService): migrate to new Google GenAI SDK and update file handling methods - Updated import statements to use the new Google GenAI SDK. - Refactored file upload, retrieval, and deletion methods to align with the new SDK's API. - Adjusted type definitions and response handling for improved type safety and clarity. - Enhanced file listing and processing logic to utilize async iteration for better performance. * refactor(GeminiProvider): update message handling and integrate abort signal support - Refactored message content handling to align with updated type definitions, ensuring consistent use of Content type. - Enhanced abort signal management for chat requests, allowing for better control over ongoing operations. - Improved message processing logic to streamline user message history handling and response generation. - Adjusted type definitions for message contents to enhance type safety and clarity. * refactor(electron.vite.config): replace direct import of Vite React plugin with dynamic import * fix(Gemini): clean up unused methods and improve property access * fix(typecheck): update color properties to use CSS variables * feat: 修改画图逻辑 * fix: import viteReact --------- Co-authored-by: eeee0717 <chentao020717Work@outlook.com>
82 lines
2.1 KiB
TypeScript
82 lines
2.1 KiB
TypeScript
import viteReact from '@vitejs/plugin-react'
|
|
import { defineConfig, externalizeDepsPlugin } from 'electron-vite'
|
|
import { resolve } from 'path'
|
|
import { visualizer } from 'rollup-plugin-visualizer'
|
|
|
|
const visualizerPlugin = (type: 'renderer' | 'main') => {
|
|
return process.env[`VISUALIZER_${type.toUpperCase()}`] ? [visualizer({ open: true })] : []
|
|
}
|
|
// const viteReact = await import('@vitejs/plugin-react')
|
|
export default defineConfig({
|
|
main: {
|
|
plugins: [
|
|
externalizeDepsPlugin({
|
|
exclude: [
|
|
'@cherrystudio/embedjs',
|
|
'@cherrystudio/embedjs-openai',
|
|
'@cherrystudio/embedjs-loader-web',
|
|
'@cherrystudio/embedjs-loader-markdown',
|
|
'@cherrystudio/embedjs-loader-msoffice',
|
|
'@cherrystudio/embedjs-loader-xml',
|
|
'@cherrystudio/embedjs-loader-pdf',
|
|
'@cherrystudio/embedjs-loader-sitemap',
|
|
'@cherrystudio/embedjs-libsql',
|
|
'@cherrystudio/embedjs-loader-image',
|
|
'p-queue',
|
|
'webdav'
|
|
]
|
|
}),
|
|
...visualizerPlugin('main')
|
|
],
|
|
resolve: {
|
|
alias: {
|
|
'@main': resolve('src/main'),
|
|
'@types': resolve('src/renderer/src/types'),
|
|
'@shared': resolve('packages/shared')
|
|
}
|
|
},
|
|
build: {
|
|
rollupOptions: {
|
|
external: ['@libsql/client']
|
|
}
|
|
}
|
|
},
|
|
preload: {
|
|
plugins: [externalizeDepsPlugin()],
|
|
resolve: {
|
|
alias: {
|
|
'@shared': resolve('packages/shared')
|
|
}
|
|
}
|
|
},
|
|
renderer: {
|
|
plugins: [
|
|
viteReact({
|
|
babel: {
|
|
plugins: [
|
|
[
|
|
'styled-components',
|
|
{
|
|
displayName: true, // 开发环境下启用组件名称
|
|
fileName: false, // 不在类名中包含文件名
|
|
pure: true, // 优化性能
|
|
ssr: false // 不需要服务端渲染
|
|
}
|
|
]
|
|
]
|
|
}
|
|
}),
|
|
...visualizerPlugin('renderer')
|
|
],
|
|
resolve: {
|
|
alias: {
|
|
'@renderer': resolve('src/renderer/src'),
|
|
'@shared': resolve('packages/shared')
|
|
}
|
|
},
|
|
optimizeDeps: {
|
|
exclude: []
|
|
}
|
|
}
|
|
})
|