element/bin/build-entry.js

73 lines
1.7 KiB
JavaScript
Raw Normal View History

2016-07-27 14:15:02 +08:00
var Components = require('../components.json')
var fs = require('fs')
var render = require('json-templater/string')
var uppercamelcase = require('uppercamelcase')
var path = require('path')
var OUTPUT_PATH = path.join(__dirname, '../src/index.js')
var IMPORT_TEMPLATE = `import {{name}} from '../packages/{{package}}/index.js';`
var ISNTALL_COMPONENT_TEMPLATE = ` Vue.component({{name}}.name, {{name}});`
var MAIN_TEMPLATE = `{{include}}
const install = function(Vue) {
2016-07-27 17:05:28 +08:00
if (install.installed) return;
2016-07-27 14:15:02 +08:00
{{install}}
2016-07-29 16:41:14 +08:00
// Vue.use(Loading);
2016-07-27 14:15:02 +08:00
2016-07-29 16:41:14 +08:00
// Vue.prototype.$msgbox = MessageBox;
// Vue.prototype.$alert = MessageBox.alert;
// Vue.prototype.$confirm = MessageBox.confirm;
// Vue.prototype.$prompt = MessageBox.prompt;
// Vue.prototype.$notify = Notification;
2016-07-27 14:15:02 +08:00
};
// auto install
if (typeof window !== 'undefined' && window.Vue) {
install(window.Vue);
};
module.exports = {
install,
{{list}}
};
`
delete Components.font
var ComponentNames = Object.keys(Components)
var includeComponentTemplate = []
var installTemplate = []
var listTemplate = []
ComponentNames.forEach(name => {
var componentName = uppercamelcase(name)
includeComponentTemplate.push(render(IMPORT_TEMPLATE, {
name: componentName,
package: name
}))
if (['Loading', 'MessageBox', 'Notification'].indexOf(componentName) === -1) {
installTemplate.push(render(ISNTALL_COMPONENT_TEMPLATE, {
name: componentName,
component: name
}))
}
listTemplate.push(` ${componentName}`)
})
var template = render(MAIN_TEMPLATE, {
include: includeComponentTemplate.join('\n'),
install: installTemplate.join('\n'),
list: listTemplate.join(',\n')
})
fs.writeFileSync(OUTPUT_PATH, template)
console.log('[build entry] DONE:', OUTPUT_PATH)