-
Notifications
You must be signed in to change notification settings - Fork 1
/
vite.config.ts
100 lines (90 loc) · 3.68 KB
/
vite.config.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
import { defineConfig } from "vite";
import { resolve, basename } from "path";
import { fileURLToPath } from 'url';
import posthtml from '@vituum/vite-plugin-posthtml';
import topLevelAwait from "vite-plugin-top-level-await";
// https://vitejs.dev/config/
export default defineConfig(async () => ({
// Vite options tailored for Tauri development and only applied in `tauri dev` or `tauri build`
// prevent vite from obscuring rust errors
clearScreen: false,
// tauri expects a fixed port, fail if that port is not available
server: {
port: 1420,
strictPort: true,
},
// to make use of `TAURI_DEBUG` and other env variables
// https://tauri.studio/v1/api/config#buildconfig.beforedevcommand
envPrefix: ["VITE_", "TAURI_"],
// PostHTML plugin is used to implement modular HTML components
// across windows.
plugins: [
posthtml(),
topLevelAwait({
// The export name of top-level await promise for each chunk module
promiseExportName: "__tla",
// The function to generate import names of top-level await promise in each chunk module
promiseImportName: i => `__tla_${i}`
})
],
build: {
// Tauri supports es2021
target: process.env.TAURI_PLATFORM == "windows" ? "chrome105" : "safari13",
// don't minify for debug builds
minify: !process.env.TAURI_DEBUG ? "esbuild" : false,
// produce sourcemaps for debug builds
sourcemap: !!process.env.TAURI_DEBUG,
rollupOptions: {
input: {
signpost: resolve(__dirname, 'src/html/signpost.html'),
sketch_editor: resolve(__dirname, 'src/html/sketch-editor.html'),
analysis_workflow: resolve(__dirname, 'src/html/analysis.html'),
state_space_explorer: resolve(__dirname, 'src/html/state-space-explorer.html'),
edit_node_dialog: resolve(__dirname, 'src/html/component-editor/regulations-editor/rename-dialog/rename-dialog.html'),
import_observation_dialog: resolve(__dirname, 'src/html/component-editor/observations-editor/observations-import/observations-import.html'),
edit_observation_dialog: resolve(__dirname, 'src/html/component-editor/observations-editor/edit-observation/edit-observation.html'),
edit_dataset_dialog: resolve(__dirname, 'src/html/component-editor/observations-editor/edit-dataset/edit-dataset.html'),
edit_function_dialog: resolve(__dirname, 'src/html/component-editor/functions-editor/edit-fn-dialog/edit-fn-dialog.html'),
edit_property_dialog: resolve(__dirname, 'src/html/component-editor/properties-editor/edit-property/edit-property.html')
}
}
},
/*
This is a workaround for correctly showing images imported from UIKit.
See https://stackoverflow.com/questions/71519410/how-can-vite-be-configured-to-load-relative-images-in-stylesheets-imported-from
*/
resolve: {
alias: [
{
find: '../../images',
replacement: 'uikit/src/images',
customResolver(updatedId, importer) {
// don't replace if importer is not our my-uikit.less
if (importer === undefined || basename(importer) !== 'uikit-theme.less') {
return '../../images';
}
return fileURLToPath(
new URL(
'./node_modules/uikit/src/images' + updatedId,
import.meta.url
)
);
},
},
],
// alias: {
// '../../images/backgrounds': 'uikit/src/images/backgrounds',
// '../../images/components': 'uikit/src/images/components',
// '../../images/icons': 'uikit/src/images/icons'
// }
},
css: {
preprocessorOptions: {
less: {
math: "always",
relativeUrls: true,
javascriptEnabled: true
},
},
}
}));