代码拉取完成,页面将自动刷新
同步操作将从 京东零售/nutui-react 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
import { defineConfig } from 'vite'
import dts from 'vite-plugin-dts'
import fse from 'fs-extra'
import path from 'path'
import config from './package.json'
import componentsConfig from './src/config.json'
const banner = `/*!
* ${config.name} v${config.version} ${new Date()}
* (c) 2023 @jdf2e.
* Released under the MIT License.
*/`
const { resolve } = path
let fileStr = `@import "@/styles/variables.scss";`
const projectID = process.env.VITE_APP_PROJECT_ID
if (projectID) {
fileStr = `@import '@/styles/variables-${projectID}.scss';`
}
// https://vitejs.dev/config/
export default defineConfig({
resolve: {
alias: [{ find: '@', replacement: resolve(__dirname, './src') }],
},
plugins: [
dts({
outDir: 'dist/types',
clearPureImport: false,
exclude: [
'node_modules/**',
'src/sites/**',
'src/**/demo.tsx',
'src/**/demo.taro.tsx',
'src/**/*.spec.tsx',
],
beforeWriteFile(filePath, content) {
return { filePath: filePath.replace('src/', ''), content }
},
afterBuild: () => {
fse
.readFile(
'./dist/types/packages/nutui.taro.react.build.d.ts',
'utf-8'
)
.then((data: string) => {
fse.remove('./dist/types/packages/nutui.taro.react.build.d.ts')
const types: string[] = []
componentsConfig.nav.forEach((item: any) => {
item.packages.forEach((element: any) => {
const { name, show, exportEmpty } = element
if (show || exportEmpty) {
const lowerName = name.toLowerCase()
if (lowerName === 'icon') return
types.push(
`export { ${name}Props } from './packages/${lowerName}/${lowerName}.taro'`
)
}
})
})
fse.outputFile(
'./dist/types/index.d.ts',
`${types.join('\n')}\n${data.replace(/\.\.\//g, './')}`
)
})
},
}),
],
build: {
minify: false,
emptyOutDir: true,
rollupOptions: {
// 请确保外部化那些你的库中不需要的依赖
external: ['react', 'react-dom', '@tarojs/taro', '@tarojs/components'],
output: [
{
banner,
// 在 UMD 构建模式下为这些外部化的依赖提供一个全局变量
globals: {
react: 'React',
'react-dom': 'ReactDOM',
},
format: 'es',
entryFileNames: 'nutui.react.es.js',
},
{
banner,
// 在 UMD 构建模式下为这些外部化的依赖提供一个全局变量
globals: {
react: 'React',
'react-dom': 'ReactDOM',
},
name: 'nutui.react',
format: 'umd',
entryFileNames: 'nutui.react.umd.js',
},
],
},
lib: {
entry: 'src/packages/nutui.taro.react.build.ts',
},
},
})
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。