35 lines
1.1 KiB
JavaScript
35 lines
1.1 KiB
JavaScript
import vue from '@vitejs/plugin-vue'
|
|
import { toSass } from './src/renderer/src/libs/sass-utils'
|
|
import theme from './src/renderer/src/libs/theme'
|
|
|
|
export const sharedConfig = {
|
|
plugins: [vue()],
|
|
css: {
|
|
preprocessorOptions: {
|
|
scss: {
|
|
api: 'modern-compiler',
|
|
additionalData:
|
|
'@use "/src/styles/_functions.scss" as *; @use "/src/styles/_font-style.scss" as *;',
|
|
functions: {
|
|
'get($keys)': function (keys) {
|
|
keys = keys.toString().replace(/['"]+/g, '').split('.')
|
|
|
|
let result = theme
|
|
for (let i = 0; i < keys.length; i++) {
|
|
result = result[keys[i]]
|
|
}
|
|
|
|
return toSass(result)
|
|
},
|
|
'getColors()': function () {
|
|
return toSass(theme.colors)
|
|
},
|
|
'getThemes()': function () {
|
|
return toSass(theme.themes)
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}
|