mirror of
https://gitee.com/ElemeFE/element.git
synced 2024-12-02 12:18:46 +08:00
aa9851ee74
* Chore: upgrade webpack@4 * Chore: upgrade to webpack@4 * Chore: add babel-preset-stage-2 * Chore: fix test case * Chore: upgrade webpack@4 * Docs: update docs * Docs: update docs * Chore: fix coveralls * Chore: update yarn.lock
99 lines
2.5 KiB
JavaScript
99 lines
2.5 KiB
JavaScript
var Components = require('../../components.json');
|
|
var fs = require('fs');
|
|
var render = require('json-templater/string');
|
|
var uppercamelcase = require('uppercamelcase');
|
|
var path = require('path');
|
|
var endOfLine = require('os').EOL;
|
|
|
|
var OUTPUT_PATH = path.join(__dirname, '../../src/index.js');
|
|
var IMPORT_TEMPLATE = 'import {{name}} from \'../packages/{{package}}/index.js\';';
|
|
var INSTALL_COMPONENT_TEMPLATE = ' {{name}}';
|
|
var MAIN_TEMPLATE = `/* Automatically generated by './build/bin/build-entry.js' */
|
|
|
|
{{include}}
|
|
import locale from 'element-ui/src/locale';
|
|
import CollapseTransition from 'element-ui/src/transitions/collapse-transition';
|
|
|
|
const components = [
|
|
{{install}},
|
|
CollapseTransition
|
|
];
|
|
|
|
const install = function(Vue, opts = {}) {
|
|
locale.use(opts.locale);
|
|
locale.i18n(opts.i18n);
|
|
|
|
components.forEach(component => {
|
|
Vue.component(component.name, component);
|
|
});
|
|
|
|
Vue.use(Loading.directive);
|
|
|
|
Vue.prototype.$ELEMENT = {
|
|
size: opts.size || '',
|
|
zIndex: opts.zIndex || 2000
|
|
};
|
|
|
|
Vue.prototype.$loading = Loading.service;
|
|
Vue.prototype.$msgbox = MessageBox;
|
|
Vue.prototype.$alert = MessageBox.alert;
|
|
Vue.prototype.$confirm = MessageBox.confirm;
|
|
Vue.prototype.$prompt = MessageBox.prompt;
|
|
Vue.prototype.$notify = Notification;
|
|
Vue.prototype.$message = Message;
|
|
|
|
};
|
|
|
|
/* istanbul ignore if */
|
|
if (typeof window !== 'undefined' && window.Vue) {
|
|
install(window.Vue);
|
|
}
|
|
|
|
export default {
|
|
version: '{{version}}',
|
|
locale: locale.use,
|
|
i18n: locale.i18n,
|
|
install,
|
|
CollapseTransition,
|
|
Loading,
|
|
{{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', 'Message'].indexOf(componentName) === -1) {
|
|
installTemplate.push(render(INSTALL_COMPONENT_TEMPLATE, {
|
|
name: componentName,
|
|
component: name
|
|
}));
|
|
}
|
|
|
|
if (componentName !== 'Loading') listTemplate.push(` ${componentName}`);
|
|
});
|
|
|
|
var template = render(MAIN_TEMPLATE, {
|
|
include: includeComponentTemplate.join(endOfLine),
|
|
install: installTemplate.join(',' + endOfLine),
|
|
version: process.env.VERSION || require('../../package.json').version,
|
|
list: listTemplate.join(',' + endOfLine)
|
|
});
|
|
|
|
fs.writeFileSync(OUTPUT_PATH, template);
|
|
console.log('[build entry] DONE:', OUTPUT_PATH);
|
|
|