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