layui-layer/vite.config.ts
2022-11-15 08:28:03 +08:00

56 lines
1.4 KiB
TypeScript

import { defineConfig } from "vite";
import { name } from "./package.json";
import { babel } from "@rollup/plugin-babel";
import vue from "@vitejs/plugin-vue";
import path from "path";
const camelize = (name: string) =>
name.replace(/(^|-)(\w)/g, (a, b, c) => c.toUpperCase());
export default defineConfig({
resolve: {
alias: {
"/@src": path.resolve(__dirname, "src"),
},
},
plugins: [vue()],
build: {
target: "es2015",
outDir: path.resolve(__dirname, "lib"),
lib: {
entry: path.resolve(__dirname, "src/index.ts"),
name: camelize(name),
},
terserOptions: {
compress: {
drop_console: true,
drop_debugger: true,
pure_funcs: ["console.log"],
},
output: {
comments: true,
},
},
rollupOptions: {
output: {
exports: "named",
globals: (id: string) => {
const name = id.replace(/^@/, "").split("/")[0];
return camelize(name);
},
assetFileNames: "index.css",
},
plugins: [
babel({
babelHelpers: "runtime",
exclude: "node_modules/**",
extensions: [".js", ".jsx", ".ts", ".tsx", ".vue"],
presets: ["@babel/preset-env", "@babel/preset-typescript"],
plugins: [["@babel/plugin-transform-runtime"]],
}),
],
external: ["vue"],
},
},
});