代码拉取完成,页面将自动刷新
import { fileURLToPath, URL } from 'node:url'
import { defineConfig } from 'vite'
import Vue from '@vitejs/plugin-vue'
import VueMacros from 'unplugin-vue-macros/vite'
import AutoImport from 'unplugin-auto-import/vite'
import Components from 'unplugin-vue-components/vite'
import { TDesignResolver } from 'unplugin-vue-components/resolvers'
import { createSvgIconsPlugin } from 'vite-plugin-svg-icons'
import pkg from './package.json'
import copyright from './src/utils/copyright'
export default defineConfig({
base: '/umo-editor/',
plugins: [
VueMacros({
plugins: {
vue: Vue(),
},
}),
AutoImport({
dirs: ['./src/composables'],
imports: ['vue', '@vueuse/core'],
resolvers: [
TDesignResolver({
library: 'vue-next',
esm: true,
}),
],
dts: './imports.d.ts',
}),
Components({
directoryAsNamespace: true,
dirs: ['./src/components'],
resolvers: [
TDesignResolver({
library: 'vue-next',
esm: true,
}),
],
}),
createSvgIconsPlugin({
iconDirs: [process.cwd() + '/src/assets/icons'],
}),
],
resolve: {
alias: {
'@': fileURLToPath(new URL('./src', import.meta.url)),
},
},
css: {
preprocessorOptions: {
less: {
modifyVars: {
'@prefix': 'umo',
},
javascriptEnabled: true,
},
},
},
build: {
lib: {
entry: process.cwd() + '/src/components/index.js',
name: pkg.name,
fileName: 'umo-editor',
},
outDir: 'dist',
minify: 'esbuild',
cssMinify: true,
rollupOptions: {
output: [
{
banner: copyright,
intro: `import './style.css'`,
format: 'es',
},
],
external: [
/@vueuse\/.*/,
/@tiptap\/.*/,
/nzh\/.*/,
'vue',
'@eslint/object-schema',
'@imgly/background-removal',
'@vue-monaco/editor',
'dom-to-image-more',
'es-drager',
'file64',
'file-saver',
'hotkeys-js',
'jsbarcode',
'katex',
'mermaid',
'plyr',
'pretty-bytes',
'qrcode-svg',
'svg64',
'vue-i18n',
'vue-esign',
],
},
},
})
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。