test: manualChunks
This commit is contained in:
parent
c5b46e291a
commit
11b8f18033
1
package/component/.gitignore
vendored
1
package/component/.gitignore
vendored
@ -5,6 +5,7 @@ example/dist/
|
|||||||
lib/
|
lib/
|
||||||
es/
|
es/
|
||||||
umd/
|
umd/
|
||||||
|
esm/
|
||||||
/types/
|
/types/
|
||||||
npm-debug.log*
|
npm-debug.log*
|
||||||
yarn-debug.log*
|
yarn-debug.log*
|
||||||
|
@ -5,7 +5,7 @@
|
|||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"description": "a component library for Vue 3 base on layui-vue",
|
"description": "a component library for Vue 3 base on layui-vue",
|
||||||
"homepage": "http://www.layui-vue.com",
|
"homepage": "http://www.layui-vue.com",
|
||||||
"main": "es/index.js",
|
"main": "esm/index.js",
|
||||||
"unpkg": "umd/index.js",
|
"unpkg": "umd/index.js",
|
||||||
"jsdelivr": "umd/index.js",
|
"jsdelivr": "umd/index.js",
|
||||||
"types": "types/index.d.ts",
|
"types": "types/index.d.ts",
|
||||||
@ -17,14 +17,15 @@
|
|||||||
],
|
],
|
||||||
"exports": {
|
"exports": {
|
||||||
".": {
|
".": {
|
||||||
"import": "./es/index.js"
|
"import": "./esm/index.js"
|
||||||
},
|
},
|
||||||
"./lib/": "./lib/",
|
"./lib/": "./lib/",
|
||||||
"./es/": "./es/"
|
"./es/": "./es/"
|
||||||
},
|
},
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"build": "npm run build:all && npm run build:es && npm run build:umd && npm run build:types",
|
"build": "npm run build:all && npm run build:es && npm run build:esm && npm run build:umd && npm run build:types",
|
||||||
"build:es": "vite build --emptyOutDir --config ./script/build.es.ts",
|
"build:es": "vite build --emptyOutDir --config ./script/build.es.ts",
|
||||||
|
"build:esm": "vite build --emptyOutDir --config ./script/build.esm.ts",
|
||||||
"build:all": "vite build --emptyOutDir --config ./script/build.all.ts",
|
"build:all": "vite build --emptyOutDir --config ./script/build.all.ts",
|
||||||
"build:umd": "vite build --emptyOutDir --config ./script/build.umd.ts",
|
"build:umd": "vite build --emptyOutDir --config ./script/build.umd.ts",
|
||||||
"build:types": "rimraf types && tsc -d"
|
"build:types": "rimraf types && tsc -d"
|
||||||
|
84
package/component/script/build.esm.ts
Normal file
84
package/component/script/build.esm.ts
Normal file
@ -0,0 +1,84 @@
|
|||||||
|
import { UserConfigExport } from "vite";
|
||||||
|
import vue from "@vitejs/plugin-vue";
|
||||||
|
import { resolve } from "path";
|
||||||
|
import * as fs from "fs";
|
||||||
|
|
||||||
|
const inputDir = resolve(process.cwd(), "./src/component");
|
||||||
|
|
||||||
|
const inputsArray = fs.readdirSync(inputDir).filter((name) => {
|
||||||
|
const componentDir = resolve(inputDir, name);
|
||||||
|
const isDir = fs.lstatSync(componentDir).isDirectory();
|
||||||
|
return isDir && fs.readdirSync(componentDir).includes("index.ts");
|
||||||
|
});
|
||||||
|
|
||||||
|
const inputs = inputsArray.reduce((backObj, pkgName) => {
|
||||||
|
backObj[pkgName] = resolve(
|
||||||
|
process.cwd(),
|
||||||
|
`./src/component/${pkgName}/index.ts`
|
||||||
|
);
|
||||||
|
return backObj;
|
||||||
|
}, {});
|
||||||
|
|
||||||
|
inputs["index"] = resolve(process.cwd(), "./src/index.ts");
|
||||||
|
const matchModule: string[] = [
|
||||||
|
'input', 'dropdown', 'carousel', 'transition', 'datePicker', 'header',
|
||||||
|
'selectOption', 'skeletonItem', 'tabItem', 'upload'
|
||||||
|
];
|
||||||
|
|
||||||
|
export default (): UserConfigExport => {
|
||||||
|
return {
|
||||||
|
publicDir: false,
|
||||||
|
resolve: {
|
||||||
|
alias: [
|
||||||
|
{
|
||||||
|
find: "@",
|
||||||
|
replacement: resolve(process.cwd(), "./"),
|
||||||
|
},
|
||||||
|
],
|
||||||
|
},
|
||||||
|
css: {
|
||||||
|
preprocessorOptions: {
|
||||||
|
less: {
|
||||||
|
javascriptEnabled: true,
|
||||||
|
},
|
||||||
|
},
|
||||||
|
postcss: {},
|
||||||
|
},
|
||||||
|
plugins: [vue()],
|
||||||
|
build: {
|
||||||
|
cssCodeSplit: true,
|
||||||
|
emptyOutDir: true,
|
||||||
|
outDir: "esm",
|
||||||
|
lib: {
|
||||||
|
entry: resolve(process.cwd(), "./src/index.ts"),
|
||||||
|
formats: ["es"],
|
||||||
|
},
|
||||||
|
rollupOptions: {
|
||||||
|
input: inputs,
|
||||||
|
output: {
|
||||||
|
globals: {
|
||||||
|
vue: "Vue",
|
||||||
|
},
|
||||||
|
manualChunks(id) {
|
||||||
|
let arr = id.toString().split('/');
|
||||||
|
if (arr.length >= 2) {
|
||||||
|
//if (arr.length >= 2 && arr[arr.length - 1].split('.')[1] != 'ts'){
|
||||||
|
let entryPoint = arr[arr.length - 2].toString()
|
||||||
|
if (matchModule.includes(entryPoint)) {
|
||||||
|
return entryPoint;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
chunkFileNames: ({ name }) => {
|
||||||
|
return name === "index" ? "index.js" : "[name]/index.js";
|
||||||
|
},
|
||||||
|
entryFileNames: ({ name }) => {
|
||||||
|
return name === "index" ? "index.js" : "[name]/index.js";
|
||||||
|
},
|
||||||
|
assetFileNames: "[name]/index.css",
|
||||||
|
},
|
||||||
|
external: ["vue", "vue-router"],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
};
|
||||||
|
};
|
Loading…
Reference in New Issue
Block a user