step2.js 6.2KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247
  1. var form = {
  2. databaseUrl: '127.0.0.1',
  3. databasePort: '3306',
  4. databaseTable: '5kcrm_',
  5. databasePwd: '',
  6. databaseUser: 'root'
  7. };
  8. var rules = {
  9. databaseUrl: {
  10. required: true,
  11. regexp: /[^\u4e00-\u9fa5]+$/,
  12. label: '数据库主机地址'
  13. },
  14. databaseName: {
  15. required: true,
  16. regexp: /[^\u4e00-\u9fa5]+$/,
  17. label: '数据库名'
  18. },
  19. databasePort: {
  20. required: true,
  21. regexp: /^[0-9]*$/,
  22. label: '数据库端口号'
  23. },
  24. databaseUser: {
  25. required: true,
  26. regexp: /[^\u4e00-\u9fa5]+$/,
  27. label: '数据库用户名'
  28. },
  29. databasePwd: {
  30. required: false,
  31. regexp: null,
  32. label: '数据库密码'
  33. },
  34. databaseTable: {
  35. required: true,
  36. regexp: /[^\u4e00-\u9fa5]+$/,
  37. label: '数据库表前缀'
  38. },
  39. root: {
  40. required: true,
  41. regexp: /^[1][3-9][0-9]{9}$/,
  42. label: '管理员账号'
  43. },
  44. pwd: {
  45. required: true,
  46. regexp: /^(?=.*[a-zA-Z])(?=.*\d).{6,20}$/,
  47. label: '管理员密码(6~20位字母加数字组合)'
  48. },
  49. wkcode: {
  50. required: false,
  51. regexp: null,
  52. label: '序列号'
  53. },
  54. };
  55. var timer = null;
  56. var flag = true;
  57. _initFormValue();
  58. // 上一步
  59. $('.prev').click(function () {
  60. window.location = 'step1.html'
  61. });
  62. // 下一步
  63. $('.next').click(function () {
  64. // 获取form数据
  65. // 校验form数据 true 校验通过 false 校验失败
  66. var forms = getFormData();
  67. var result = checkForm();
  68. // console.log('result---', result, forms);
  69. if (result) {
  70. $('#cover').css('display', 'block');//显示遮罩层
  71. setTimeout(()=>{
  72. $.ajax({
  73. cache: true,
  74. type: "POST",
  75. dataType: 'json',
  76. url: "./step4",
  77. data: {
  78. form: forms
  79. },
  80. async: true,
  81. timeout: 20000,
  82. success: function (result) {
  83. if (result.code == '200') {
  84. localStorage.clear();
  85. window.location = 'step5.html';
  86. } else if (result.code == '400') {
  87. window.location.href = '/admin/install/step6';
  88. // $('#cover').css('display', 'none');
  89. // alert(result.error); //失败
  90. // return false;
  91. // window.location = 'step3.html'
  92. } else {
  93. window.location.href = '/admin/install/step6';
  94. // window.location = 'step3.html';
  95. // alert('安装失败');
  96. }
  97. },
  98. error: function (xhr) {
  99. window.location.href = '/admin/install/step6';
  100. }
  101. });
  102. })
  103. }
  104. });
  105. function getRes() {
  106. if (timer) {
  107. clearTimeout(timer);
  108. timer = null;
  109. }
  110. // $.post("/admin/install/progress",function(result){
  111. // $(".install_progress_a").show();
  112. // $(".install_progress_a").empty();
  113. // $(".form").hide();
  114. // $(".control").hide();
  115. // if(result.data.now < result.data.length ){
  116. // $(".install_progress_a").append("<progress class='install_progress' max='"+ result.data.length+"' value='"+ result.data.now +"''></progress>");
  117. // html ="<div class='install_pro'> 正在安装中,请稍后...</div>";
  118. // $(".install_progress_a").append(html);
  119. // timer = setTimeout(getRes, 1000)
  120. // } else {
  121. // $(".install_progress_a").append("<progress class='install_progress' max='100' value='100'></progress>");
  122. // html ="<div class='install_pro'> 安装成功 </div>";
  123. // $(".install_progress_a").append(html);
  124. // clearTimeout(timer);
  125. // timer = null;
  126. // }
  127. // });
  128. $.ajax({
  129. cache: true,
  130. type: "POST",
  131. dataType: 'json',
  132. url: './progress',
  133. data: '',
  134. async: false,
  135. success: function (result) {
  136. $(".install_progress_a").show();
  137. $(".install_progress_a").empty();
  138. $(".form").hide();
  139. $(".control").hide();
  140. if (result.data.now < result.data.length) {
  141. $(".install_progress_a").append("<progress class='install_progress' max='" + result.data.length + "' value='" + result.data.now + "''></progress>");
  142. html = "<div class='install_pro'> 正在安装中,请稍后...</div>";
  143. $(".install_progress_a").append(html);
  144. timer = setTimeout(getRes, 1000)
  145. } else {
  146. $(".install_progress_a").append("<progress class='install_progress' max='100' value='100'></progress>");
  147. html = "<div class='install_pro'> 安装成功 </div>";
  148. $(".install_progress_a").append(html);
  149. clearTimeout(timer);
  150. timer = null;
  151. }
  152. }
  153. });
  154. }
  155. /**
  156. * 给 form 输入框赋初值
  157. * @private
  158. */
  159. function _initFormValue() {
  160. $('input').each(function (index, item) {
  161. item.value = form[item.name] || null
  162. $(item).change(function () {
  163. $(this).removeClass('input-error');
  164. var borther = $(this).siblings('.error');
  165. borther.remove();
  166. if (borther.filter('.remind')[0]) {
  167. borther.filter('.remind').show()
  168. }
  169. })
  170. });
  171. }
  172. /**
  173. * 获取 form 输入的值
  174. * @return {form}
  175. */
  176. function getFormData() {
  177. $('.wkform').each(function (index, item) {
  178. form[item.name] = item.value;
  179. // 重置表单状态
  180. $(item).removeClass('input-error');
  181. var borther = $(item).siblings();
  182. borther.remove('.error');
  183. if (borther.filter('.remind')[0]) {
  184. borther.filter('.remind').show()
  185. }
  186. });
  187. return form
  188. }
  189. /**
  190. * 校验表单
  191. * @return {boolean}
  192. */
  193. function checkForm() {
  194. var result = {};
  195. for (var key in rules) {
  196. var rule = rules[key];
  197. if (rule.required) {
  198. if (!form[key] || form[key] == '') {
  199. result[key] = rule.label + '不能为空!';
  200. }
  201. }
  202. if (rule.regexp && !result[key]) {
  203. var flag = rule.regexp.test(form[key]);
  204. if (!flag) {
  205. let msg = rule.label === '管理员账号' ? '手机号码' : rule.label
  206. result[key] = '请输入正确的' + msg + '!';
  207. }
  208. }
  209. }
  210. var flag = true;
  211. if (JSON.stringify(result) !== '{}' && typeof result === 'object') {
  212. for (var key in result) {
  213. renderErrorMsg(key, result[key])
  214. flag = false;
  215. }
  216. }
  217. return flag
  218. }
  219. /**
  220. * 渲染错误信息
  221. * @param key
  222. * @param msg
  223. */
  224. function renderErrorMsg(key, msg) {
  225. $('input').each(function (index, item) {
  226. if (item.name === key) {
  227. var remindDom = $(item).next()[0] || null;
  228. if (remindDom) {
  229. $(remindDom).hide()
  230. }
  231. $(item).parent().append('<div class="error">' + msg + '</div>');
  232. $(item).addClass('input-error')
  233. }
  234. })
  235. }