build-entry.js 2.5 KB

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