统一构建多包发布

This commit is contained in:
aixianling
2022-02-17 16:15:13 +08:00
parent fe66924093
commit 2491c8e906
2 changed files with 75 additions and 68 deletions

View File

@@ -11,9 +11,12 @@
"lib": "vue-cli-service build --no-clean --target lib --dest lib packages/index.js&&npm unpublish --force&&npm publish", "lib": "vue-cli-service build --no-clean --target lib --dest lib packages/index.js&&npm unpublish --force&&npm publish",
"lib:core": "vue-cli-service build --target lib --dest core/dist core/index.js --name vc-app-core&&npm unpublish --force&&npm publish", "lib:core": "vue-cli-service build --target lib --dest core/dist core/index.js --name vc-app-core&&npm unpublish --force&&npm publish",
"lib:project": "node project/build.js", "lib:project": "node project/build.js",
"lib:sass": "node project/sass.js", "lib:all": "node project/allProject.js&&npm unpublish --workspaces --force&&npm publish --workspaces",
"ui": "npm i dvcp-ui@latest dvcp-dv-ui@latest" "ui": "npm i dvcp-ui@latest dvcp-dv-ui@latest"
}, },
"workspaces": [
"project/*"
],
"dependencies": { "dependencies": {
"@amap/amap-jsapi-loader": "^1.0.1", "@amap/amap-jsapi-loader": "^1.0.1",
"@jiaminghi/data-view": "^2.10.0", "@jiaminghi/data-view": "^2.10.0",
@@ -88,4 +91,4 @@
"last 2 versions", "last 2 versions",
"not ie <= 8" "not ie <= 8"
] ]
} }

View File

@@ -1,6 +1,5 @@
const fsExtra = require('fs-extra') const fsExtra = require('fs-extra')
const path = require('path') const path = require('path')
const {exec} = require('child_process')
const chalk = require('chalk') const chalk = require('chalk')
const fs = require('fs') const fs = require('fs')
/** /**
@@ -22,8 +21,10 @@ const promisify = fn => {
}); });
} }
} }
const readdir = promisify(fs.readdir) const readdir = promisify(fs.readdir)
const stat = promisify(fs.stat) const stat = promisify(fs.stat)
/** /**
* 封装打印工具 * 封装打印工具
*/ */
@@ -34,6 +35,7 @@ const chalkTag = {
warn: msg => log([chalk.bgYellow.black(' WARN '), msg].join(' ')), warn: msg => log([chalk.bgYellow.black(' WARN '), msg].join(' ')),
error: msg => log([chalk.bgRed.black(' ERROR '), msg].join(' ')), error: msg => log([chalk.bgRed.black(' ERROR '), msg].join(' ')),
} }
/** /**
* 遍历应用的方法 * 遍历应用的方法
*/ */
@@ -51,53 +53,73 @@ const findApp = (dir, cb) => {
}) || []) }) || [])
}) })
} }
const start = () => { /**
chalkTag.info("开始运行sass应用打包工具") * 初始化打包配置文件
let cores, apps, PROJECT = "sass" */
new Promise(resolve => { const init = () => {
let install = path.join(__dirname, PROJECT, 'index.js') chalkTag.info('开始运行项目打包工具...')
return new Promise(resolve => fs.readdir('./project', (err, files) => {
resolve(files.filter(e => e.indexOf('.') < 0))
}))
}
/**
* 生成对应的main入口js文件
*/
const generateMain = project => {
let cores, apps
const getCores = new Promise(resolve => {
let install = path.join(__dirname, project, 'index.js')
fsExtra.ensureFile(install) fsExtra.ensureFile(install)
const coreLib = path.join(__dirname, PROJECT, 'core.import.json') const coreLib = path.join(__dirname, project, 'core.import.json')
fsExtra.readJson(coreLib, (err, data) => { fsExtra.readJson(coreLib, (err, data) => {
chalkTag.info("加载核心库配置..") chalkTag.info(project + "加载核心库配置..")
cores = [] cores = []
if (data) { if (data) {
findApp('core/apps', file => { findApp('core/apps', file => {
let fileName = file.replace(/.*(App\w+)\.vue/g, '$1') let fileName = file.replace(/.*\\(.+)\.vue/g, '$1')
if (Object.keys(data).includes(fileName)) { if (Object.keys(data).includes(fileName)) {
cores.push({name: fileName, component: file.replace(/\\/g, "/")}) cores.push({name: fileName, component: file.replace(/\\/g, "/")})
log(">>>正在打包核心库...%s", fileName)
} }
}).then(() => { }).then(() => {
chalkTag.done('核心库打包完毕') chalkTag.done(project + '核心库打包完毕')
resolve(PROJECT) resolve()
}) })
} else { } else {
chalkTag.done('核心库无打包') chalkTag.done(project + '核心库无打包')
resolve(PROJECT) resolve()
} }
}) })
}).then(prj => { })
apps = [] const getApps = new Promise(resolve => {
// return findApp("packages", file => { const appLib = path.join(__dirname, project.toString(), 'apps.import.json')
// if (/.*\\(App[^\\]+)\.vue/g.test(file)) { fsExtra.readJson(appLib, (err, data) => {
// let fileName = file.replace(/.*\\(App[^\\]+)\.vue/g, '$1') chalkTag.info(project + '加载业务应用配置...')
// apps.push({name: fileName, component: file.replace(/\\/g, "/")}) apps = []
// log(">>>正在打包业务应用...%s", fileName) let appDir = "packages"
// } if (data) {
// }).then(() => { findApp(appDir, file => {
// chalkTag.done('业务应用打包完毕') let fileName = file.replace(/.*\\(.+)\.vue/g, '$1')
// return prj if (Object.keys(data).includes(fileName)) {
// }) apps.push({name: fileName, component: file.replace(/\\/g, "/")})
return prj }
}).then(prj => new Promise(resolve => { }).then(() => {
chalkTag.info('正在生成打包文件...') chalkTag.done(project + '业务应用打包完毕')
let bin = path.join(__dirname, prj.toString(), 'index.js'), resolve()
coreApps = cores.map(e => `{name:'${e.name}',component:require('../../${e.component}').default}`), })
bizApps = apps.map(e => `{name:'${e.name}',component:require('../../${e.component}').default}`), } else {
comps = [...coreApps, ...bizApps], chalkTag.done(project + '业务应用无打包')
content = ` resolve()
}
})
})
return new Promise(resolve => {
Promise.all([getCores, getApps]).then(() => {
chalkTag.info(project + '正在生成打包文件...')
let bin = path.join(__dirname, project.toString(), 'index.js'),
coreApps = cores.map(e => `{name:'${e.name}',component:require('../../${e.component}').default}`),
bizApps = apps.map(e => `{name:'${e.name}',component:require('../../${e.component}').default}`),
comps = [...coreApps, ...bizApps],
content = `
const apps = [${comps.toString()}] const apps = [${comps.toString()}]
const install = function (Vue) { const install = function (Vue) {
if (install.installed) return Promise.resolve() if (install.installed) return Promise.resolve()
@@ -129,39 +151,21 @@ const start = () => {
install install
} }
` `
fsExtra.outputFile(bin, content, err => { fsExtra.outputFile(bin, content, err => {
if (err) { if (err) chalkTag.error(err)
chalkTag.error(err) else chalkTag.done(project + '生成打包文件')
} else chalkTag.done('生成打包文件') resolve()
resolve(prj)
})
})).then(project => new Promise(resolve => {
fsExtra.readJson(path.join(__dirname, project.toString(), 'package.json'), (err, json) => {
let cmd = `vue-cli-service build --target lib --dest project/${project}/dist project/${project}/index.js --name ${json.name}`
chalkTag.info('正在压缩文件中...')
exec(cmd, {
cwd: path.join(__dirname, '..')
}, (err, stdout) => {
log(stdout);
if (!err) {
chalkTag.done('打包成功!')
resolve(project)
} else {
chalkTag.error(err)
}
}) })
}) })
})).then(project => { })
chalkTag.info('正在发布中...')
let cmd = `npm unpublish dvcp-sass-apps@1.0.0 --force&&npm publish` }
exec(cmd, { const start = () => {
cwd: path.join(__dirname, project) //询问打包哪个项目
}, (err, stdout) => { init().then(choices => {
log(stdout); return Promise.all(choices.map(prj => generateMain(prj))).then(() => {
if (!err) { chalkTag.done('完成生成打包文件')
chalkTag.done('发布成功!')
} else chalkTag.error(err)
}) })
}) })
} }
start() start();