build-entry.js 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293
  1. var Components = require('../../components.json');
  2. var fs = require('fs');
  3. var render = require('json-templater/string');
  4. var uppercamelcase = require('uppercamelcase');
  5. var path = require('path');
  6. var OUTPUT_PATH = path.join(__dirname, '../../src/index.js');
  7. var IMPORT_TEMPLATE = 'import {{name}} from \'../packages/{{package}}/index.js\';';
  8. var INSTALL_COMPONENT_TEMPLATE = ' {{name}}';
  9. var MAIN_TEMPLATE = `/* Automatic generated by './build/bin/build-entry.js' */
  10. {{include}}
  11. import locale from 'element-ui/src/locale';
  12. import CollapseTransition from 'element-ui/src/transitions/collapse-transition';
  13. const components = [
  14. {{install}},
  15. CollapseTransition
  16. ];
  17. const install = function(Vue, opts = {}) {
  18. /* istanbul ignore if */
  19. if (install.installed) return;
  20. locale.use(opts.locale);
  21. locale.i18n(opts.i18n);
  22. components.map(component => {
  23. Vue.component(component.name, component);
  24. });
  25. Vue.use(Loading.directive);
  26. Vue.prototype.$loading = Loading.service;
  27. Vue.prototype.$msgbox = MessageBox;
  28. Vue.prototype.$alert = MessageBox.alert;
  29. Vue.prototype.$confirm = MessageBox.confirm;
  30. Vue.prototype.$prompt = MessageBox.prompt;
  31. Vue.prototype.$notify = Notification;
  32. Vue.prototype.$message = Message;
  33. };
  34. /* istanbul ignore if */
  35. if (typeof window !== 'undefined' && window.Vue) {
  36. install(window.Vue);
  37. };
  38. module.exports = {
  39. version: '{{version}}',
  40. locale: locale.use,
  41. i18n: locale.i18n,
  42. install,
  43. CollapseTransition,
  44. Loading,
  45. {{list}}
  46. };
  47. `;
  48. delete Components.font;
  49. var ComponentNames = Object.keys(Components);
  50. var includeComponentTemplate = [];
  51. var installTemplate = [];
  52. var listTemplate = [];
  53. ComponentNames.forEach(name => {
  54. var componentName = uppercamelcase(name);
  55. includeComponentTemplate.push(render(IMPORT_TEMPLATE, {
  56. name: componentName,
  57. package: name
  58. }));
  59. if (['Loading', 'MessageBox', 'Notification', 'Message'].indexOf(componentName) === -1) {
  60. installTemplate.push(render(INSTALL_COMPONENT_TEMPLATE, {
  61. name: componentName,
  62. component: name
  63. }));
  64. }
  65. if (componentName !== 'Loading') listTemplate.push(` ${componentName}`);
  66. });
  67. var template = render(MAIN_TEMPLATE, {
  68. include: includeComponentTemplate.join('\n'),
  69. install: installTemplate.join(',\n'),
  70. version: process.env.VERSION || require('../../package.json').version,
  71. list: listTemplate.join(',\n')
  72. });
  73. fs.writeFileSync(OUTPUT_PATH, template);
  74. console.log('[build entry] DONE:', OUTPUT_PATH);