优化一下产品库加载
This commit is contained in:
@@ -1,4 +1,5 @@
|
||||
import store from "../store";
|
||||
import {waiting} from "../utils";
|
||||
|
||||
export default {
|
||||
routes: () => store.state.apps.map(e => {
|
||||
@@ -15,47 +16,63 @@ export default {
|
||||
},
|
||||
loadApps() {
|
||||
//新App的自动化格式
|
||||
let files = require.context('../../packages', true, /\.(\/.+)\/App[A-Z][^\/]+\.vue$/)
|
||||
files.keys().map(path => {
|
||||
if (files(path).default) {
|
||||
let {name, label} = files(path).default,
|
||||
addApp = {
|
||||
name, label: label || name,
|
||||
path: path.replace(/\.(\/.+\/App.+)\.vue$/, '/packages$1'),
|
||||
entry: 'appEntry',
|
||||
module: files(path).default
|
||||
}
|
||||
//命名规范入口文件必须以App开头
|
||||
store.commit("addApp", addApp)
|
||||
}
|
||||
})
|
||||
let cores = require.context('../../core', true, /\.(\/.+)\/App[^\/]+\.vue$/)
|
||||
cores.keys().map(path => {
|
||||
if (cores(path).default) {
|
||||
let {name, label} = cores(path).default,
|
||||
addApp = {
|
||||
name, label: label || name,
|
||||
path: path.replace(/\.(\/.+\/App.+)\.vue$/, '/core$1'),
|
||||
entry: 'appEntry',
|
||||
module: cores(path).default
|
||||
}
|
||||
//命名规范入口文件必须以App开头
|
||||
store.commit("addApp", addApp)
|
||||
}
|
||||
})
|
||||
let project = require.context('../../project', true, /\.(\/.+)\/App[^\/]+\.vue$/)
|
||||
project.keys().map(path => {
|
||||
if (project(path).default) {
|
||||
let {name, label} = project(path).default,
|
||||
waiting.init({innerHTML: '应用加载中..'})
|
||||
let apps = require.context('../../', true, /\.(\/.+)\/App[A-Z][^\/]+\.vue$/, "lazy")
|
||||
Promise.all(apps.keys().map(path => apps(path).then(file => {
|
||||
if (file.default) {
|
||||
let {name, label} = file.default,
|
||||
addApp = {
|
||||
name: [path.replace(/\.\/([^\/]+)\/.*/, '$1'), name].join("_"), label: label || name,
|
||||
path: path.replace(/\.(\/.+\/App.+)\.vue$/, '/project$1'),
|
||||
path: path.replace(/\.(\/.+\/App.+)\.vue$/, '/$1'),
|
||||
entry: 'appEntry',
|
||||
module: project(path).default
|
||||
module: file.default
|
||||
}
|
||||
waiting.setContent(`加载${name}...`)
|
||||
//命名规范入口文件必须以App开头
|
||||
store.commit("addApp", addApp)
|
||||
}
|
||||
})
|
||||
return store.commit("addApp", addApp)
|
||||
} else return 0
|
||||
}))).then(() => waiting.close())
|
||||
// let files = require.context('../../packages', true, /\.(\/.+)\/App[A-Z][^\/]+\.vue$/)
|
||||
// files.keys().map(path => {
|
||||
// if (files(path).default) {
|
||||
// let {name, label} = files(path).default,
|
||||
// addApp = {
|
||||
// name, label: label || name,
|
||||
// path: path.replace(/\.(\/.+\/App.+)\.vue$/, '/packages$1'),
|
||||
// entry: 'appEntry',
|
||||
// module: files(path).default
|
||||
// }
|
||||
// //命名规范入口文件必须以App开头
|
||||
// store.commit("addApp", addApp)
|
||||
// }
|
||||
// })
|
||||
// let cores = require.context('../../core', true, /\.(\/.+)\/App[^\/]+\.vue$/)
|
||||
// cores.keys().map(path => {
|
||||
// if (cores(path).default) {
|
||||
// let {name, label} = cores(path).default,
|
||||
// addApp = {
|
||||
// name, label: label || name,
|
||||
// path: path.replace(/\.(\/.+\/App.+)\.vue$/, '/core$1'),
|
||||
// entry: 'appEntry',
|
||||
// module: cores(path).default
|
||||
// }
|
||||
// //命名规范入口文件必须以App开头
|
||||
// store.commit("addApp", addApp)
|
||||
// }
|
||||
// })
|
||||
// let project = require.context('../../project', true, /\.(\/.+)\/App[^\/]+\.vue$/)
|
||||
// project.keys().map(path => {
|
||||
// if (project(path).default) {
|
||||
// let {name, label} = project(path).default,
|
||||
// addApp = {
|
||||
// name: [path.replace(/\.\/([^\/]+)\/.*/, '$1'), name].join("_"), label: label || name,
|
||||
// path: path.replace(/\.(\/.+\/App.+)\.vue$/, '/project$1'),
|
||||
// entry: 'appEntry',
|
||||
// module: project(path).default
|
||||
// }
|
||||
// //命名规范入口文件必须以App开头
|
||||
// store.commit("addApp", addApp)
|
||||
// }
|
||||
// })
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user