Files
afilmory/apps/web/plugins/vite/deps.ts
2025-10-31 02:07:13 +08:00

40 lines
1.3 KiB
TypeScript

import type { Plugin, UserConfig } from 'vite'
export function createDependencyChunksPlugin(dependencies: string[][]): Plugin {
return {
name: 'dependency-chunks',
config(config: UserConfig) {
config.build = config.build || {}
config.build.rollupOptions = config.build.rollupOptions || {}
config.build.rollupOptions.output = config.build.rollupOptions.output || {}
const { output } = config.build.rollupOptions
const outputConfig = Array.isArray(output) ? output[0] : output
outputConfig.assetFileNames = 'assets/[name].[hash:6][extname]'
outputConfig.chunkFileNames = (chunkInfo) => {
return chunkInfo.name.startsWith('vendor/') ? '[name]-[hash].js' : 'assets/[name]-[hash].js'
}
outputConfig.manualChunks = (id: string, { getModuleInfo }) => {
const moduleInfo = getModuleInfo(id)
if (moduleInfo?.dynamicImporters?.length && moduleInfo?.importers?.length) {
return null
}
const matchedDep = dependencies.findIndex((dep) => {
return dep.some((d) => {
const pattern = `/node_modules/${d}/`
return id.includes(pattern) && !id.includes(`${pattern}node_modules/`)
})
})
if (matchedDep !== -1) {
return `vendor/${matchedDep}`
}
return null
}
},
}
}