调整同步仓库的策略
This commit is contained in:
24
bin/serve.js
24
bin/serve.js
@@ -1,5 +1,5 @@
|
|||||||
const {chalkTag, findPages, fs, fsExtra} = require("./tools");
|
const {chalkTag, findPages, fs, fsExtra} = require("./tools");
|
||||||
const axios = require("axios");
|
|
||||||
let apps = {list: [], desc: "用于产品库主页面获取应用使用", type: 'wxwork'}
|
let apps = {list: [], desc: "用于产品库主页面获取应用使用", type: 'wxwork'}
|
||||||
const getFileInfo = (app, file) => {
|
const getFileInfo = (app, file) => {
|
||||||
let vue = fs.readFileSync(file).toString()
|
let vue = fs.readFileSync(file).toString()
|
||||||
@@ -11,27 +11,9 @@ const getFileInfo = (app, file) => {
|
|||||||
} else
|
} else
|
||||||
app.style = {navigationBarTitleText: app.label}
|
app.style = {navigationBarTitleText: app.label}
|
||||||
}
|
}
|
||||||
if (/^App/.test(app.name) && app.label) {
|
|
||||||
let {name, label} = app,
|
|
||||||
path = app.path.replace(/.+[\\\/]([^\\\/]+)[\\\/]([^\\\/]+)$/g, `/apps/$1/$2`)
|
|
||||||
apps.list.push({
|
|
||||||
id: file.replace(/\.\/?(vue)?/g, '').replace(/[\\\/]/g, '_'),
|
|
||||||
name,
|
|
||||||
label,
|
|
||||||
path,
|
|
||||||
libPath: file.replace(/\\/g, '/').replace(/^src(\/.+)\.vue/, '$1'),
|
|
||||||
type: 'wxwork'
|
|
||||||
})
|
|
||||||
}
|
|
||||||
}
|
|
||||||
const saveApps = app => {
|
|
||||||
if (app.list.length > 0) {
|
|
||||||
axios.post("http://192.168.1.87:12525/node/wechatapps/addOrUpdate", app, {timeout: 1000}).then(res => {
|
|
||||||
if (res.data.code == 0) chalkTag.done("产品库目录已同步至后台数据库...")
|
|
||||||
}).catch(err => 0).finally(() => fsExtra.outputJson('src/config.json', {apps: app.list}))
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
const start = () => {
|
const start = () => {
|
||||||
chalkTag.info('开始生成pages.json...')
|
chalkTag.info('开始生成pages.json...')
|
||||||
let json = {
|
let json = {
|
||||||
@@ -79,7 +61,7 @@ const start = () => {
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
]).then(() => {
|
]).then(() => {
|
||||||
saveApps(apps)
|
fsExtra.outputJson('src/config.json', {apps: apps.list})
|
||||||
fsExtra.outputJson('src/pages.json', json, () => {
|
fsExtra.outputJson('src/pages.json', json, () => {
|
||||||
chalkTag.done('生成pages.json')
|
chalkTag.done('生成pages.json')
|
||||||
})
|
})
|
||||||
|
|||||||
68
bin/sync.js
Normal file
68
bin/sync.js
Normal file
@@ -0,0 +1,68 @@
|
|||||||
|
const {chalkTag, fs, findPages} = require("./tools");
|
||||||
|
const axios = require("axios");
|
||||||
|
|
||||||
|
let apps = {list: [], desc: "用于产品库主页面获取应用使用", type: 'wxwork'}
|
||||||
|
const saveApps = app => {
|
||||||
|
if (app.list.length > 0) {
|
||||||
|
return axios.post("http://192.168.1.87:12525/node/wechatapps/addOrUpdate", app, {timeout: 1000}).then(res => {
|
||||||
|
if (res.data.code == 0) chalkTag.done("产品库目录已同步至后台数据库...")
|
||||||
|
}).catch(err => {
|
||||||
|
console.log(err)
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const getFileInfo = (app, file) => {
|
||||||
|
let vue = fs.readFileSync(file).toString()
|
||||||
|
if (/appName/.test(vue)) {
|
||||||
|
let appName = vue.replace(/[\s\S]*(appName:.+),[\s\S]*/gm, '$1')
|
||||||
|
app.label = appName.replace(/(appName:|["'])/g, '').trim()
|
||||||
|
if (/customNavigation/.test(vue)) {
|
||||||
|
app.style = {navigationStyle: "custom"}
|
||||||
|
} else
|
||||||
|
app.style = {navigationBarTitleText: app.label}
|
||||||
|
}
|
||||||
|
if (/^App/.test(app.name) && app.label) {
|
||||||
|
let {name, label} = app,
|
||||||
|
path = app.path.replace(/.+[\\\/]([^\\\/]+)[\\\/]([^\\\/]+)$/g, `/apps/$1/$2`)
|
||||||
|
apps.list.push({
|
||||||
|
id: file.replace(/\.\/?(vue)?/g, '').replace(/[\\\/]/g, '_'),
|
||||||
|
name,
|
||||||
|
label,
|
||||||
|
path,
|
||||||
|
libPath: file.replace(/\\/g, '/').replace(/^src(\/.+)\.vue/, '$1'),
|
||||||
|
type: 'wxwork'
|
||||||
|
})
|
||||||
|
}
|
||||||
|
}
|
||||||
|
const start = () => {
|
||||||
|
chalkTag.info('开始同步数据到数据库')
|
||||||
|
Promise.all([
|
||||||
|
findPages('src/components/pages', file => {
|
||||||
|
if (/.+\\[^\\]+\\[^\\]+\.vue/g.test(file)) {
|
||||||
|
let app = {
|
||||||
|
path: file.replace(/^src\\(.*).vue/g, '$1').replace(/\\/g, '/')
|
||||||
|
}
|
||||||
|
return getFileInfo(app, file)
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
findPages('src/apps', file => {
|
||||||
|
if (/.+\\App[^\\]+\\[^\\]+\.vue/g.test(file)) {
|
||||||
|
let app = {
|
||||||
|
name: file.replace(/.*\\([^\\]+).vue/g, '$1'),
|
||||||
|
path: file.replace(/^src\\(.*).vue/g, '$1').replace(/\\/g, '/')
|
||||||
|
}
|
||||||
|
return getFileInfo(app, file)
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
findPages('src/project', file => {
|
||||||
|
if (/.+\\App[^\\]+\\[^\\]+\.vue/g.test(file)) {
|
||||||
|
let app = {
|
||||||
|
name: file.replace(/.*\\([^\\]+).vue/g, '$1'),
|
||||||
|
path: file.replace(/^src\\(.*).vue/g, '$1').replace(/\\/g, '/')
|
||||||
|
}
|
||||||
|
return getFileInfo(app, file)
|
||||||
|
}
|
||||||
|
})
|
||||||
|
]).then(() => saveApps(apps)).finally(() => chalkTag.done('同步完成'))
|
||||||
|
}
|
||||||
|
start()
|
||||||
@@ -7,7 +7,8 @@
|
|||||||
"dev": "node bin/serve.js&&cross-env NODE_ENV=development UNI_PLATFORM=h5 vue-cli-service uni-serve --minimize",
|
"dev": "node bin/serve.js&&cross-env NODE_ENV=development UNI_PLATFORM=h5 vue-cli-service uni-serve --minimize",
|
||||||
"lib": "npm unpublish --force&&npm publish",
|
"lib": "npm unpublish --force&&npm publish",
|
||||||
"lib:projects": "npm unpublish --workspaces --force&&npm publish --workspaces",
|
"lib:projects": "npm unpublish --workspaces --force&&npm publish --workspaces",
|
||||||
"pages": "node bin/serve.js"
|
"pages": "node bin/serve.js",
|
||||||
|
"sync": "node bin/sync.js"
|
||||||
},
|
},
|
||||||
"main": "src/apps/index.js",
|
"main": "src/apps/index.js",
|
||||||
"files": [
|
"files": [
|
||||||
|
|||||||
Reference in New Issue
Block a user