build-entry.js 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  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(Loading.directive);
  25. Vue.prototype.$ELEMENT = {
  26. size: opts.size || '',
  27. zIndex: opts.zIndex || 2000
  28. };
  29. Vue.prototype.$loading = Loading.service;
  30. Vue.prototype.$msgbox = MessageBox;
  31. Vue.prototype.$alert = MessageBox.alert;
  32. Vue.prototype.$confirm = MessageBox.confirm;
  33. Vue.prototype.$prompt = MessageBox.prompt;
  34. Vue.prototype.$notify = Notification;
  35. Vue.prototype.$message = Message;
  36. };
  37. /* istanbul ignore if */
  38. if (typeof window !== 'undefined' && window.Vue) {
  39. install(window.Vue);
  40. }
  41. export default {
  42. version: '{{version}}',
  43. locale: locale.use,
  44. i18n: locale.i18n,
  45. install,
  46. CollapseTransition,
  47. Loading,
  48. {{list}}
  49. };
  50. `;
  51. delete Components.font;
  52. var ComponentNames = Object.keys(Components);
  53. var includeComponentTemplate = [];
  54. var installTemplate = [];
  55. var listTemplate = [];
  56. ComponentNames.forEach(name => {
  57. var componentName = uppercamelcase(name);
  58. includeComponentTemplate.push(render(IMPORT_TEMPLATE, {
  59. name: componentName,
  60. package: name
  61. }));
  62. if (['Loading', 'MessageBox', 'Notification', 'Message'].indexOf(componentName) === -1) {
  63. installTemplate.push(render(INSTALL_COMPONENT_TEMPLATE, {
  64. name: componentName,
  65. component: name
  66. }));
  67. }
  68. if (componentName !== 'Loading') listTemplate.push(` ${componentName}`);
  69. });
  70. var template = render(MAIN_TEMPLATE, {
  71. include: includeComponentTemplate.join(endOfLine),
  72. install: installTemplate.join(',' + endOfLine),
  73. version: process.env.VERSION || require('../../package.json').version,
  74. list: listTemplate.join(',' + endOfLine)
  75. });
  76. fs.writeFileSync(OUTPUT_PATH, template);
  77. console.log('[build entry] DONE:', OUTPUT_PATH);