createComponentMode.js 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. // 创建模板
  2. const inquirer = require('inquirer');
  3. // import { ROOT_PACKAGE_PATH } from '../util/dic';
  4. //const conf = require(ROOT_PACKAGE_PATH('src/config.json'));
  5. import { nav } from '../src/config.ts';
  6. // const path = require('path');
  7. // const fs = require('fs');
  8. // const copy = require('copy');
  9. //const createPkgDeclare = require('./createPkgDeclare');
  10. // const t = require('@babel/types');
  11. // const { parse } = require('@babel/parser');
  12. // const { default: traverse } = require('@babel/traverse');
  13. // const { default: generate } = require('@babel/generator');
  14. var newCpt = {
  15. version: '1.0.0',
  16. name: '',
  17. type: '',
  18. chnName: '',
  19. desc: '',
  20. sort: '',
  21. showDemo: true,
  22. author: '',
  23. star: undefined
  24. };
  25. function init() {
  26. inquirer
  27. .prompt([
  28. {
  29. type: 'input',
  30. name: 'name',
  31. message: '组件英文名(每个单词的首字母都大写,如TextBox):',
  32. validate(value: any) {
  33. let repeat = false;
  34. for (var i = 0; i < nav.length; i++) {
  35. for (var j = 0; j < nav[i].packages.length; j++) {
  36. if (nav[i].packages[j].name === value) {
  37. repeat = true;
  38. }
  39. }
  40. }
  41. if (repeat) {
  42. return '该组件名已存在!';
  43. }
  44. const pass = value && value.match(/^[A-Z]/);
  45. if (pass) {
  46. return true;
  47. }
  48. return '不能为空,且每个单词的首字母都要大写,如TextBox';
  49. }
  50. },
  51. {
  52. type: 'input',
  53. name: 'chnName',
  54. message: '组件中文名(十个字以内):',
  55. validate(value: any) {
  56. const pass = value && value.length <= 10;
  57. if (pass) {
  58. return true;
  59. }
  60. return '不能为空,且不能超过十个字符';
  61. }
  62. },
  63. {
  64. type: 'input',
  65. name: 'desc',
  66. message: '组件描述(五十个字以内):'
  67. },
  68. {
  69. type: 'rawlist',
  70. name: 'type',
  71. message: '请选择组件类型(输入编号):',
  72. choices: ['component', 'filter', 'directive', 'method'],
  73. validate(value: any) {
  74. const pass = value && /^[1-4]$/.test(value);
  75. if (pass) {
  76. return true;
  77. }
  78. return '输入有误!请输入选项前编号';
  79. }
  80. },
  81. {
  82. type: 'rawlist',
  83. name: 'sort',
  84. message: '请选择组件分类(输入编号):',
  85. choices: sorts,
  86. validate(value: any) {
  87. const pass = /^[1-7]$/.test(value);
  88. if (pass) {
  89. return true;
  90. }
  91. return '输入有误!请输入选项前编号';
  92. }
  93. },
  94. {
  95. type: 'confirm',
  96. name: 'showDemo',
  97. message: '是否需要DEMO页面?',
  98. default: true
  99. },
  100. {
  101. type: 'confirm',
  102. name: 'showTest',
  103. message: '是否需要单元测试页面?',
  104. default: true
  105. },
  106. {
  107. type: 'input',
  108. name: 'author',
  109. message: '组件作者(可署化名):'
  110. }
  111. ])
  112. .then(function(answers: any) {
  113. // answers.sort = String(sorts.indexOf(answers.sort));
  114. // newCpt = Object.assign(newCpt, answers);
  115. console.log(answers);
  116. //createDir();
  117. });
  118. }
  119. export default async function createComponent() {
  120. init();
  121. }