step2.js 6.0KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243
  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: 120000,
  82. success: function (result) {
  83. if (result.code == '200') {
  84. localStorage.clear();
  85. window.location = 'step5.html';
  86. } else if (result.code == '400') {
  87. // alert(result.error);
  88. window.location.href = 'step6.html';
  89. } else {
  90. // alert(result.error);
  91. window.location.href = 'step6.html';
  92. }
  93. },
  94. error: function (xhr) {
  95. window.location.href = 'step6.html';
  96. }
  97. });
  98. })
  99. }
  100. });
  101. function getRes() {
  102. if (timer) {
  103. clearTimeout(timer);
  104. timer = null;
  105. }
  106. // $.post("/admin/install/progress",function(result){
  107. // $(".install_progress_a").show();
  108. // $(".install_progress_a").empty();
  109. // $(".form").hide();
  110. // $(".control").hide();
  111. // if(result.data.now < result.data.length ){
  112. // $(".install_progress_a").append("<progress class='install_progress' max='"+ result.data.length+"' value='"+ result.data.now +"''></progress>");
  113. // html ="<div class='install_pro'> 正在安装中,请稍后...</div>";
  114. // $(".install_progress_a").append(html);
  115. // timer = setTimeout(getRes, 1000)
  116. // } else {
  117. // $(".install_progress_a").append("<progress class='install_progress' max='100' value='100'></progress>");
  118. // html ="<div class='install_pro'> 安装成功 </div>";
  119. // $(".install_progress_a").append(html);
  120. // clearTimeout(timer);
  121. // timer = null;
  122. // }
  123. // });
  124. $.ajax({
  125. cache: true,
  126. type: "POST",
  127. dataType: 'json',
  128. url: './progress',
  129. data: '',
  130. async: false,
  131. success: function (result) {
  132. $(".install_progress_a").show();
  133. $(".install_progress_a").empty();
  134. $(".form").hide();
  135. $(".control").hide();
  136. if (result.data.now < result.data.length) {
  137. $(".install_progress_a").append("<progress class='install_progress' max='" + result.data.length + "' value='" + result.data.now + "''></progress>");
  138. html = "<div class='install_pro'> 正在安装中,请稍后...</div>";
  139. $(".install_progress_a").append(html);
  140. timer = setTimeout(getRes, 1000)
  141. } else {
  142. $(".install_progress_a").append("<progress class='install_progress' max='100' value='100'></progress>");
  143. html = "<div class='install_pro'> 安装成功 </div>";
  144. $(".install_progress_a").append(html);
  145. clearTimeout(timer);
  146. timer = null;
  147. }
  148. }
  149. });
  150. }
  151. /**
  152. * 给 form 输入框赋初值
  153. * @private
  154. */
  155. function _initFormValue() {
  156. $('input').each(function (index, item) {
  157. item.value = form[item.name] || null
  158. $(item).change(function () {
  159. $(this).removeClass('input-error');
  160. var borther = $(this).siblings('.error');
  161. borther.remove();
  162. if (borther.filter('.remind')[0]) {
  163. borther.filter('.remind').show()
  164. }
  165. })
  166. });
  167. }
  168. /**
  169. * 获取 form 输入的值
  170. * @return {form}
  171. */
  172. function getFormData() {
  173. $('.wkform').each(function (index, item) {
  174. form[item.name] = item.value;
  175. // 重置表单状态
  176. $(item).removeClass('input-error');
  177. var borther = $(item).siblings();
  178. borther.remove('.error');
  179. if (borther.filter('.remind')[0]) {
  180. borther.filter('.remind').show()
  181. }
  182. });
  183. return form
  184. }
  185. /**
  186. * 校验表单
  187. * @return {boolean}
  188. */
  189. function checkForm() {
  190. var result = {};
  191. for (var key in rules) {
  192. var rule = rules[key];
  193. if (rule.required) {
  194. if (!form[key] || form[key] == '') {
  195. result[key] = rule.label + '不能为空!';
  196. }
  197. }
  198. if (rule.regexp && !result[key]) {
  199. var flag = rule.regexp.test(form[key]);
  200. if (!flag) {
  201. let msg = rule.label === '管理员账号' ? '手机号码' : rule.label
  202. result[key] = '请输入正确的' + msg + '!';
  203. }
  204. }
  205. }
  206. var flag = true;
  207. if (JSON.stringify(result) !== '{}' && typeof result === 'object') {
  208. for (var key in result) {
  209. renderErrorMsg(key, result[key])
  210. flag = false;
  211. }
  212. }
  213. return flag
  214. }
  215. /**
  216. * 渲染错误信息
  217. * @param key
  218. * @param msg
  219. */
  220. function renderErrorMsg(key, msg) {
  221. $('input').each(function (index, item) {
  222. if (item.name === key) {
  223. var remindDom = $(item).next()[0] || null;
  224. if (remindDom) {
  225. $(remindDom).hide()
  226. }
  227. $(item).parent().append('<div class="error">' + msg + '</div>');
  228. $(item).addClass('input-error')
  229. }
  230. })
  231. }