统一构建多包发布
This commit is contained in:
@@ -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"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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();
|
||||||
Reference in New Issue
Block a user