halo/ui/packages/editor/vite.lib.config.ts

65 lines
1.6 KiB
TypeScript

import { fileURLToPath, URL } from "url";
import VueI18nPlugin from "@intlify/unplugin-vue-i18n/vite";
import Vue from "@vitejs/plugin-vue";
import path from "path";
import Icons from "unplugin-icons/vite";
import { defineConfig } from "vite";
import dts from "vite-plugin-dts";
export default ({ mode }: { mode: string }) => {
const isProduction = mode === "production";
return defineConfig({
experimental: {
enableNativePlugin: true,
},
plugins: [
Vue(),
Icons({
compiler: "vue3",
}),
isProduction &&
dts({
tsconfigPath: "./tsconfig.app.json",
entryRoot: "./src",
outDir: "./dist",
insertTypesEntry: true,
}),
VueI18nPlugin({
include: [path.resolve(__dirname, "./src/locales/*.yaml")],
}),
],
define: {
"process.env.NODE_ENV": '"production"',
},
resolve: {
alias: {
"@": fileURLToPath(new URL("./src", import.meta.url)),
},
},
build: {
outDir: path.resolve(__dirname, "dist"),
lib: {
entry: path.resolve(__dirname, "src/index.ts"),
name: "RichTextEditor",
formats: ["es", "iife"],
fileName: (format) => `rich-text-editor.${format}.js`,
cssFileName: "style",
},
minify: isProduction,
rollupOptions: {
external: ["vue", "vue-demi"],
output: {
globals: {
vue: "Vue",
"vue-demi": "VueDemi",
},
exports: "named",
},
},
sourcemap: false,
},
});
};