personal_information.html 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>绑定机器</title>
  6. <meta name="viewport" content="width=device-width, initial-scale=1,maximum-scale=1, user-scalable=no">
  7. <meta name="apple-mobile-web-app-capable" content="yes">
  8. <meta name="apple-mobile-web-app-status-bar-style" content="black">
  9. <link rel="stylesheet" type="text/css" href="//css.iamberry.com/wateroPF/css/mui.min.css?v=2017072401" />
  10. <link rel="stylesheet" type="text/css" href="//css.iamberry.com/wateroPF/css/mui.picker.min.css?v=2017072401" />
  11. <link rel="stylesheet" type="text/css" href="//css.iamberry.com/wateroPF/new/css/iconfont.css?v=2017072401" />
  12. <link rel="stylesheet" type="text/css" href="//css.iamberry.com/wateroPF/css/style.css?v=2017072401" />
  13. <link rel="stylesheet" type="text/css" href="//css.iamberry.com/wateroPF/new/css/personal_information.css?v=2017072401" />
  14. <style>
  15. h4{margin-top:5px;margin-bottom: 5px;font-size: 20px;}
  16. .btn-pull-code{position: absolute;right: 10px;top:7px;height:34px;padding:0 6px;border-radius: 5px; line-height: 34px;font-size: 12px; color: #fff; background: #24cae9;}
  17. .btn-pull-code .active{background: #c8c8c8;}
  18. .icon-fuxuankuang a{color: #24cae9;}
  19. .icon-yanse,.icon-youhui,.icon-fuxuankuang,.icon-jiage,.icon-songhuo{font-size: 15px;padding-left: 22px;}
  20. .icon-yanse:before,.icon-fuxuankuang:before,.icon-youhui:before,.icon-jiage:before,.icon-songhuo:before{font-size: 18px;color: #24cae9;position: absolute;left: 0;width: 20px;height: 18px;}
  21. .try_price{color: #f1436c;}
  22. .ul_radio{width: 100%;}
  23. .ul_radio li{width:21%;height: 55px;margin: 0 1%;border: 1px solid rgba(0,0,0,.1);border-radius: 5px; display: inline-block;position: relative;font-family:"iconfont" !important;font-style:normal;-webkit-font-smoothing: antialiased;}
  24. .ul_radio .active:after{position: absolute;right: 0;bottom: 0;content: "\e66f";color: #f1436c;line-height: 1;font-size: 20px;}
  25. .head-img {position: absolute;bottom: 15px;right: 13px;width: 60px;height: 60px;border-radius: 30px;border: 3px solid #E5E5E5;}
  26. .mui-table-view .mui-media .mui-media-body{height: 41px;line-height: 41px;color: #333;}
  27. .mui-table-view .mui-media .mui-media-body>span{color: #f1436c;}
  28. .my-table-view-try{border-top: .6em solid #f0f0f0;border-bottom: .6em solid #f0f0f0;padding-bottom: 10px;}
  29. .my-table-view-try .mui-table-view-cell{padding:10px 13px 10px 30px !important;font-size: 12px;}
  30. .mui-table-view-cell:after,.mui-table-view:before,.mui-table-view:after,.mui-input-group .mui-input-row:after,.mui-input-group:before,.mui-input-group:after{display: none;}
  31. .mui-table-view-cell>a:not(.mui-btn){color: #666;margin: -15px -15px;}
  32. .mui-table-view-cell>a .mui-pull-right{color: #999;font-size: 14px;}
  33. #btn_submit{color: #fff;padding: 10px 0;font-size: 18px;background: #24cae9;width: 70%;margin:40px auto 0 auto;}
  34. .mui-btn-block.mui-active,.btn-pull-code.mui-active{background-color: #c8c8c8 !important;}
  35. .icon-fuxuankuang.mui-active:before{color: #c8c8c8;}
  36. .mui-content-padded{margin: 10px 13px;}
  37. .tips{padding: 25px 10px;background: #36a4c6;text-align: center;color: #fff;}
  38. .mui-input-group .mui-input-row {height: 50px;padding: 5px 0;border: 1px solid rgba(0,0,0,.1); margin:10px 0;}
  39. .mui-input-row label{color: #666;width:27%;font-size: 15px;}
  40. .mui-input-row label~input{width:73%;}
  41. .mui-input-row label~input::-webkit-input-placeholder{font-size: 15px;}
  42. .triangle-down {width:0;height:0;border-left:7px solid transparent;border-right:7px solid transparent;border-top:7px solid #ccc;}
  43. .my-arrowright{position: absolute;right: 18px;top: 28px;color: #666;pointer-events:none;}
  44. .mui-btn-red{background-color: #e9004c;}
  45. .icon-saoma{position: absolute;right: 0;top:0;padding: 12px;color: #55c0dc;}
  46. .mui-icon-arrowdown{position: absolute;right: 0;top:0;padding: 12px;color: #999;pointer-events: none;}
  47. </style>
  48. </head>
  49. <body style="background: #fff;">
  50. <div class="loading-bg">
  51. <div class="mui-loading">
  52. <div class="mui-spinner">
  53. </div>
  54. &nbsp;&nbsp;加载中...
  55. </div>
  56. </div>
  57. <div class="mui-content" style="background: #fff;">
  58. <div class="tips more">
  59. <h4>现在完善机器信息!</h4>
  60. <span>即赠送美国WaterO滤芯2个</span>
  61. <div>T1+T2</div>
  62. </div>
  63. <div class="mui-content-padded">
  64. <form class="mui-input-group">
  65. <!--<div class="mui-input-row">
  66. <label>产品编码</label>
  67. <input type="text" class="mui-input-clear" placeholder="请扫描机身上的产品编码" id="ipt-number">
  68. <span class="iconfont icon-saoma"></span>
  69. </div>-->
  70. <input type="hidden" class="mui-input-clear" placeholder="请扫描机身上的产品编码" id="ipt-number">
  71. <div class="mui-input-row">
  72. <label>购买日期</label>
  73. <input type="text" placeholder="请选择购买机器日期" id="ipt-date" readonly="readonly">
  74. <span class="mui-icon mui-icon-arrowdown"></span>
  75. </div>
  76. <div class="mui-input-row">
  77. <label>您的姓名</label>
  78. <input type="text" maxlength="12" class="mui-input-clear" placeholder="请填写您的姓名" id="ipt-name">
  79. </div>
  80. <div class="mui-input-row">
  81. <label>您的邮箱</label>
  82. <input type="text" maxlength="32" class="mui-input-clear" placeholder="请填写您的邮箱" id="ipt-email">
  83. </div>
  84. <div class="mui-input-row">
  85. <label>手机号码</label>
  86. <input type="tel" maxlength="11" class="mui-input-clear" placeholder="请填写手机号码" id="ipt-phone">
  87. </div>
  88. <div class="mui-input-row">
  89. <label>验&nbsp;&nbsp;证&nbsp;&nbsp;码</label>
  90. <input type="text" maxlength="4" placeholder="请输入验证码" id="ipt-code">
  91. <span class="btn-pull-code" id="pull-code">获取验证码</span>
  92. </div>
  93. </form>
  94. </div>
  95. <div class="mui-content-padded">
  96. <button type="button" data-loading-icon="mui-spinner mui-spinner-custom" data-loading-text="提交中" class="mui-btn mui-btn-block mui-btn-outlined mui-active" id="btn_submit" disabled="disabled" >提交</button>
  97. </div>
  98. </div>
  99. <script src="//s.iamberry.com/wateroPF/js/mui.min.js?v=2016101701"></script>
  100. <script src="//s.iamberry.com/wateroPF/js/mui.picker.min.js"></script>
  101. <script src="//s.iamberry.com/wateroPF/js/jquery-2.1.1.min.js"></script>
  102. <script src="//s.iamberry.com/wateroPF/js/shop/main.js?v=2016101701"></script>
  103. <script src="//s.iamberry.com/wateroPF/js/shop/wechat-utils-1.0.js"></script>
  104. <script type="text/javascript">
  105. var check = false,alert_msg='';
  106. var mobile=/^(13|14|15|18)[0-9]{9}$/; //手机号码
  107. var uname = /^[\u4e00-\u9fa5]{1,12}$/; //中文英文
  108. var email=/^\w[-\w.+]*@([A-Za-z0-9][-A-Za-z0-9]+\.)+[A-Za-z]{2,18}$/;
  109. var code = /^[0-9]{4}$/; //数字
  110. mui.ready(function(){
  111. console.log("页面加载完毕")
  112. document.querySelector('.loading-bg').style.display='none';
  113. var shareId = getParam("shareId");
  114. if (shareId != null && shareId != '') {
  115. $('#ipt-number').val(shareId);
  116. }
  117. });
  118. //扫码
  119. mui('body').on('tap', '.icon-saoma', function() {
  120. wx.scanQRCode({
  121. needResult: 1, // 默认为0,扫描结果由微信处理,1则直接返回扫描结果,
  122. scanType: ["barCode"], // 可以指定扫二维码还是一维码,默认二者都有
  123. success: function (res) {
  124. var result = res.resultStr; // 当needResult 为 1 时,扫码返回的结果
  125. if (result.indexOf("weixin.qq.com") > 0) {
  126. mui.alert("请扫描条形码!");
  127. } else {
  128. $('#ipt-number').val(result);
  129. }
  130. }
  131. });
  132. });
  133. mui('body').on('tap', '#btn_submit', function() {
  134. change_input();
  135. if(check){
  136. console.log("提交");
  137. mui(this).button('loading');
  138. setTimeout(function() {
  139. mui(this).button('reset');
  140. }.bind(this), 2000);
  141. //mui.alert("本批watero试用机为新机,请您在试用过程中足够爱惜,切勿刮划机身及损坏包装,感谢您的配合!");
  142. var data_array = {
  143. "numberBarcode":$('#ipt-number').val(),
  144. "numberSalesTime":$('#ipt-date').val(),
  145. "phoneCode":$('#ipt-code').val(),
  146. "userName":$('#ipt-name').val(),
  147. "userTel":$('#ipt-phone').val(),
  148. "userEmail":$('#ipt-email').val()
  149. };
  150. $.ajax({
  151. type: 'post',
  152. url: base_path + '/qrcode/update_user_info',
  153. data:data_array,
  154. dataType: 'json',
  155. timeout: 15000,
  156. success: function(dt) {
  157. if (dt.status) {
  158. mui.openWindow({
  159. url: '/wateroPF/view/my_equipment1.html'
  160. })
  161. } else {
  162. mui.alert(dt.message);
  163. }
  164. },
  165. error: function(xhr, type, errorThrown) {
  166. mui.alert("请检查网络或刷新页面重试!");
  167. }
  168. });
  169. }else{
  170. console.log("未通过");
  171. mui.alert(alert_msg);
  172. }
  173. });
  174. mui('body').on('tap', '#xieyi-dalog', function() {
  175. mui.openWindow({
  176. url: 'try_xieyi.html'
  177. });
  178. });
  179. $(".ul_radio li").each(function() {
  180. $(this).on("click", function() {
  181. $(this).addClass("active");
  182. $(this).siblings().removeClass("active");
  183. });
  184. });
  185. $(document).on('tap', '#btn-tongyi', function() {
  186. var btn_submit=$("#btn_submit");
  187. console.log($(this).hasClass("mui-active"));
  188. if($(this).hasClass("mui-active")){
  189. $(this).removeClass("mui-active");
  190. btn_submit.removeClass("mui-active");
  191. }else{
  192. $(this).addClass("mui-active");
  193. btn_submit.addClass("mui-active");
  194. }
  195. });
  196. $(document).on('tap', '#pull-code', function() {
  197. if($("#ipt-phone").val().trim()=="" &&(!$("#pull-code").hasClass("mui-active"))){
  198. mui.alert("请填写手机号码");
  199. return;
  200. }else{
  201. if(!mobile.test($("#ipt-phone").val().trim())){
  202. mui.alert("手机号码不正确,请重新填写");
  203. return;
  204. }else{
  205. if($(this).hasClass("mui-active")){
  206. mui.alert();
  207. return;
  208. }else{
  209. $(this).addClass("mui-active");
  210. $('#btn_submit').removeClass("mui-active");
  211. $('#btn_submit').removeAttr("disabled");
  212. settime("pull-code");
  213. $.ajax({
  214. type: 'post',
  215. url: base_path + '/qrcode/send_phone_code',
  216. data:{
  217. "phone" : $("#ipt-phone").val()
  218. },
  219. dataType: 'json',
  220. timeout: 15000,
  221. success: function(dt) {
  222. },
  223. error: function(xhr, type, errorThrown) {
  224. mui.alert("请检查网络或刷新页面重试!");
  225. }
  226. });
  227. }
  228. }
  229. }
  230. });
  231. var countdown=60;
  232. function settime(val) {
  233. pullid=dc(val);
  234. if (countdown == 0) {
  235. pullid.removeAttribute("disabled");
  236. pullid.className='btn-pull-code';
  237. pullid.innerText="获取验证码";
  238. countdown = 60;
  239. return false;
  240. } else {
  241. pullid.setAttribute("disabled", true);
  242. pullid.className='btn-pull-code mui-active';
  243. pullid.innerText="重新发送(" + countdown + ")";
  244. countdown--;
  245. }
  246. setTimeout(function() {
  247. settime(val)
  248. },1000)
  249. }
  250. function change_input() {
  251. //活动暂时结束 下次开启时注释这段代码就好了
  252. alert_msg="活动已暂停,开始时间请联系客服";
  253. check=false;
  254. return false;
  255. $(".mui-input-group input").each(function(index) {
  256. switch ($(this).attr("id")){
  257. /*case "ipt-number":
  258. if($(this).val().trim()==""){
  259. alert_msg="请填写产品编码";
  260. check=false;
  261. return false;
  262. }
  263. break;*/
  264. case "ipt-date":
  265. if($(this).val().trim()==""){
  266. alert_msg="请选择购买日期";
  267. check=false;
  268. return false;
  269. }
  270. break;
  271. case "ipt-name":
  272. if($(this).val().trim()==""){
  273. alert_msg="请填写姓名";
  274. check=false;
  275. return false;
  276. }else{
  277. if(uname.test($(this).val())) {
  278. check=true;
  279. }else{
  280. alert_msg="姓名格式不正确,请重新填写";
  281. check=false;
  282. return false;
  283. }
  284. }
  285. break;
  286. case "ipt-email":
  287. if($(this).val().trim()==""){
  288. alert_msg="请填写您的邮箱";
  289. check=false;
  290. return false;
  291. }else{
  292. if(email.test($(this).val())) {
  293. check=true;
  294. }else{
  295. alert_msg="邮箱格式不正确,请重新填写";
  296. check=false;
  297. return false;
  298. }
  299. }
  300. break;
  301. case "ipt-phone":
  302. if($(this).val().trim()==""){
  303. alert_msg="请填写手机号";
  304. check=false;
  305. return false;
  306. }else{
  307. if(mobile.test($(this).val().trim())) {
  308. check=true;
  309. }else{
  310. alert_msg="手机号码不正确,请重新填写";
  311. check=false;
  312. return false;
  313. }
  314. }
  315. break;
  316. case "ipt-code":
  317. if($(this).val().trim()==""){
  318. alert_msg="请填写验证码";
  319. check=false;
  320. return false;
  321. }else{
  322. if(code.test($(this).val().trim())) {
  323. check=true;
  324. }else{
  325. alert_msg="验证码格式不正确,请重新填写";
  326. check=false;
  327. return false;
  328. }
  329. }
  330. break;
  331. default:
  332. break;
  333. }
  334. });
  335. var btn_submit = dc('btn_submit');
  336. if(check) {
  337. console.log("通过")
  338. } else {
  339. console.log(alert_msg);
  340. }
  341. }
  342. var flag = false;
  343. var mask = mui.createMask(function() {
  344. return flag;
  345. }); //callback为用户点击蒙版时自动执行的回调;
  346. mui('body').on('tap', '#ipt-date', function() {
  347. var th = this;
  348. var picker = new mui.DtPicker({
  349. type: "date", //设置日历初始视图模式
  350. beginDate: new Date(2016, 7, 1), //设置开始日期
  351. endDate: new Date() //设置结束日期
  352. });
  353. console.log(picker)
  354. picker.show(function(rs) {
  355. th.value = rs.text;
  356. picker.dispose();
  357. });
  358. });
  359. </script>
  360. </body>
  361. </html>