main.js 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477
  1. import * as compnt from "../../../../public/js/compnt.js";
  2. import * as unicom from "../../../../public/js/unicom.js";
  3. import "../scss/main.scss";
  4. var flowproductid = "2018072301"
  5. var rightsproductid = "2020010201"
  6. // 返回时强制手机刷新
  7. $(function () {
  8. var isPageHide = false;
  9. window.addEventListener('pageshow', function () {
  10. if (isPageHide) {
  11. window.location.reload();
  12. }
  13. });
  14. window.addEventListener('pagehide', function () {
  15. isPageHide = true;
  16. });
  17. if (window.location.href.indexOf('draw.html') >=0) {
  18. var user = JSON.parse(localStorage.getItem('user'));
  19. if (user != null) {
  20. $('.usermob').val(user.usermob);
  21. }
  22. }
  23. })
  24. init();
  25. function init() {
  26. var message = localStorage.getItem('message');
  27. if (message != null && message != '') {
  28. compnt.showAlert(message);
  29. localStorage.removeItem('message');
  30. }
  31. compnt.showLoading();
  32. unicom.init().then(function(response) {
  33. compnt.hideLoading();
  34. unicom.loadUserInfo();
  35. if (location.href.indexOf("/index") >= 0) {
  36. var pid = localStorage.getItem('pid');
  37. var pidtime = localStorage.getItem('pidtime')
  38. var currproduct = flowproductid;
  39. // 设置选择的产品
  40. if (pidtime != null && new Date().getTime() - pidtime < 1000 * 60 * 2
  41. && unicom.products[pid] != null) {
  42. currproduct = pid;
  43. }
  44. orderPageProductChange(currproduct)
  45. showOrderPage();
  46. } else {
  47. openPage();
  48. }
  49. if (location.href.indexOf('/cancel') >= 0) {
  50. unicom.burypointLogId('110002'); // 退订页面pv, pv去重得到uv
  51. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'open', ea: 'cancel_open' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  52. } else if (location.href.indexOf('/draw') >= 0) {
  53. unicom.burypointLogId('110003'); // 领取页面pv, pv去重得到uv
  54. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'open', ea: 'draw_open' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  55. } else if (location.href.indexOf('/flow') >= 0) {
  56. unicom.burypointLogId('110004'); // 流量查询pv, pv去重得到uv
  57. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'open', ea: 'flow_open' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  58. } else if (location.href.indexOf('/active') >= 0) {
  59. unicom.burypointLogId('110005'); // 激活页面pv, pv去重得到uv
  60. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'open', ea: 'active_open' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  61. } else if (location.href.indexOf('/refund') >= 0) {
  62. unicom.burypointLogId('110006'); // 退款
  63. } else {
  64. // location.href.indexOf('/index') >= 0
  65. // location.href.indexOf('/order') >= 0
  66. unicom.burypointLogId('110001'); // 订购页面pv, pv去重得到uv
  67. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'open', ea: 'order_open' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  68. }
  69. })
  70. }
  71. function openPage(pageName) {
  72. if (pageName == null) {
  73. if (location.href.indexOf("/index") >= 0) pageName = "order";
  74. if (location.href.indexOf("cancel.html") >= 0) pageName = "cancel";
  75. if (location.href.indexOf("draw.html") >= 0) pageName = "draw";
  76. if (location.href.indexOf("active.html") >= 0) pageName = "active";
  77. if (location.href.indexOf("flow.html") >= 0) pageName = "flow";
  78. }
  79. switch (pageName) {
  80. case "cancel":
  81. showCancelPage();
  82. break;
  83. case "draw":
  84. showDrawPage();
  85. break;
  86. default:
  87. showOrderPage();
  88. break;
  89. }
  90. orderPageProductChange(unicom.query.pid)
  91. }
  92. // 意外惊喜, 用标签+name 属性,在iphone6,7中会报错
  93. //$('a[name="gotoCancelPage"').each(function(i, item) {
  94. $('.gotoCancelPage').each(function(i, item) {
  95. $(item).unbind('click').on('click', function () {
  96. showCancelPage()
  97. })
  98. })
  99. $('#gotoDrawPage').unbind('click').on('click', function () {
  100. showDrawPage(window.location.href.substring(window.location.href.lastIndexOf('/') + 1, window.location.href.lastIndexOf('.')))
  101. })
  102. function showOrderPage(backPage) {
  103. if (location.href.indexOf('/index') < 0) {
  104. if (backPage == null || backPage == '') {
  105. backPage = 'index.html';
  106. }
  107. window.location.href = backPage + "?fes=" + unicom.query.fes + "&sou=" + unicom.query.sou;
  108. return;
  109. }
  110. $('#btn-order').unbind('click').on('click', function (event) {
  111. if (!compnt.lockClick()) {
  112. return;
  113. }
  114. unicom.showCapPage(null, null, false, false, true).then(function (data) {
  115. compnt.unlockClick();
  116. order(data.userid, data.token, data.usermob);
  117. }).fail(function(response) {
  118. compnt.unlockClick();
  119. })
  120. })
  121. }
  122. function showDrawPage(back) {
  123. if (location.href.indexOf("draw.html") < 0) {
  124. window.location.href = "draw.html?fes=" + unicom.query.fes + "&sou=" + unicom.query.sou + '&back=' + (back == null ? '' : back) + '&pid=' + unicom.product.productid;
  125. return;
  126. }
  127. unicom.product = unicom.products[rightsproductid];
  128. var $container = $('.section-login').find('.form-group');
  129. $container.find('.sendcode').unbind('click').on('click', function () {
  130. unicom.sendSms($container, 'drawlogin', unicom.products[rightsproductid]);
  131. })
  132. $container.find('.login').unbind('click').on('click', function() {
  133. var usermob = $container.find('.usermob').val();
  134. var account = $container.find('.account').val();
  135. var smscode = $container.find('.smscode').val();
  136. if (usermob == null || usermob == "") {
  137. compnt.showAlert('请输入联通手机号');
  138. return;
  139. }
  140. if (account == null || account == "") {
  141. compnt.showAlert('请输入抖音短视频账号');
  142. return;
  143. }
  144. if (smscode == null || smscode == "") {
  145. compnt.showAlert('请输入验证码');
  146. return;
  147. }
  148. var $comfirm = showConfirmDialog(account);
  149. $comfirm.find('.cancel').on('click', function() {
  150. compnt.hideLoading();
  151. });
  152. $comfirm.find('.okay').on('click', function() {
  153. unicom.checkCode($container, true).done(function() {
  154. drawCoin(account);
  155. }).fail(function(data) {
  156. compnt.hideLoading();
  157. })
  158. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'draw_click_send_sms_code_btn' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  159. });
  160. })
  161. }
  162. function drawCoin(account) {
  163. compnt.showLoading();
  164. unicom.drawCoin(account, '').done(function(response) {
  165. compnt.hideLoading();
  166. switch (response.resultCode) {
  167. case "0000":
  168. var $container = $('.section-login').find('.form-group');
  169. $container.find('.usermob').val('');
  170. $container.find('.smscode').val('');
  171. $container.find('.account').val('');
  172. showAlertDialog('抖币充值中,详情结果以短信形式告知').then(function() {
  173. if (unicom.query.back != null && unicom.query.back != '') {
  174. showOrderPage(unicom.query.back + ".html");
  175. }
  176. });
  177. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'draw_success' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  178. break;
  179. case "7605":
  180. showAlertDialog(response.errorInfo);
  181. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'draw_failure' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  182. break;
  183. default:
  184. var prefix = '';
  185. if (response.errorInfo.indexOf('领取失败') < 0) {
  186. prefix = '领取失败,';
  187. }
  188. showAlertDialog(prefix + response.errorInfo);
  189. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'draw_failure' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  190. break;
  191. }
  192. }).fail(function(data) {
  193. compnt.hideLoading();
  194. })
  195. }
  196. function showCancelPage() {
  197. if (location.href.indexOf("cancel.html") < 0) {
  198. window.location.href = "cancel.html?fes=" + unicom.query.fes + "&sou=" + unicom.query.sou + '&pid=' + unicom.product.productid;
  199. return;
  200. }
  201. var $container = $('.section-login').find('.form-group');
  202. $container.find('.sendcode').unbind('click').on('click', function () {
  203. unicom.sendSms($container, 'cancellogin');
  204. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'cancel_click_send_sms_code_btn' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  205. })
  206. $container.find('.login').unbind('click').on('click', function () {
  207. compnt.showLoading();
  208. unicom.checkCode($container).done(function() {
  209. unicom.cancel().done(function(response) {
  210. compnt.hideLoading();
  211. switch (response.resultCode) {
  212. case "0000":
  213. showAlertDialog('退订成功!');
  214. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'cancel_success' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  215. break;
  216. case "7605": //应该是已经退订了吧,因此不需要在重复退订啦
  217. showAlertDialog(response.errorInfo);//.then(function(message) {
  218. //showFlowPage();
  219. //});
  220. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'cancel_failure' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  221. break;
  222. default:
  223. var prefix = '';
  224. if (response.errorInfo.indexOf('退订失败') < 0) {
  225. prefix = '退订失败,';
  226. }
  227. showAlertDialog(prefix + response.errorInfo);
  228. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'cancel_failure' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  229. break;
  230. }
  231. }).fail(function(data) {
  232. compnt.hideLoading();
  233. })
  234. }).fail(function(data) {
  235. compnt.hideLoading();
  236. })
  237. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'cancel_click_confirm_btn' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  238. })
  239. window.scrollTo(0, 0)
  240. }
  241. $(".product-slider").delegate(".item-9", "click",function(){
  242. orderPageProductChange(flowproductid)
  243. });
  244. $(".product-slider").delegate(".item-15", "click",function(){
  245. orderPageProductChange(rightsproductid)
  246. });
  247. function orderPageProductChange(productid) {
  248. if (unicom.products[productid] == null) {
  249. return;
  250. }
  251. unicom.product = unicom.products[productid];
  252. if (productid == flowproductid) {
  253. $('body').addClass('body-9')
  254. $('.banner-text').addClass('banner-text-9')
  255. } else {
  256. $('body').removeClass('body-9')
  257. $('.banner-text').removeClass('banner-text-9')
  258. }
  259. if (window.location.href.indexOf('/index') >= 0) {
  260. // 记录当前选择的是哪个产品,等从退订页面返回到订购页面的时候,还能选择同样的产品
  261. localStorage.setItem('pid', productid);
  262. localStorage.setItem('pidtime', new Date().getTime())
  263. if (productid == flowproductid) {
  264. $('body').addClass('body-9');
  265. $('.banner-text').addClass('banner-text-9');
  266. $('.item-15').addClass('item-15-inactive');
  267. $('.item-9').removeClass('item-9-inactive');
  268. $('.agr-15').css({'display': 'none'});
  269. $('.agr-9').css({'display': 'block'});
  270. } else {
  271. $('body').removeClass('body-9');
  272. $('.banner-text').removeClass('banner-text-9');
  273. $('.item-15').removeClass('item-15-inactive');
  274. $('.item-9').addClass('item-9-inactive');
  275. $('.agr-15').css({'display': 'block'});
  276. $('.agr-9').css({'display': 'none'});
  277. }
  278. } else if (window.location.href.indexOf('cancel.html') >= 0) {
  279. if (productid == flowproductid) {
  280. $('.agr-15').css({'display': 'none'});
  281. $('.agr-9').css({'display': 'block'});
  282. } else {
  283. $('.agr-15').css({'display': 'block'});
  284. $('.agr-9').css({'display': 'none'});
  285. }
  286. }
  287. }
  288. function showConfirmDialog(account) {
  289. var $overlay = $('<div class="overlay"></div>')
  290. var $dialog = $(
  291. '<div class="dialog dialog-confirm">' +
  292. ' <div class="content">请确认是否领取抖音币到' + account + '账号?</div>' +
  293. ' <div class="actions">' +
  294. ' <div class="btn cancel">取消</div>' +
  295. ' <div class="btn okay">确认</div>' +
  296. ' </div>' +
  297. '</div>');
  298. $overlay.appendTo($(document.body))
  299. $dialog.appendTo($(document.body))
  300. $dialog.find('.btn').on('click', function () {
  301. $overlay.remove();
  302. $dialog.remove();
  303. $dialog = null;
  304. })
  305. $dialog.close = function () {
  306. $overlay.remove();
  307. $dialog.remove();
  308. $dialog = null;
  309. }
  310. return $dialog;
  311. }
  312. /**
  313. * 订购
  314. */
  315. function order(userid, token, usermob) {
  316. compnt.showLoading('处理中,请稍后...');
  317. unicom.order(userid, token, usermob).done(function(response) {
  318. compnt.hideLoading();
  319. switch (response.resultCode) {
  320. case "0000": //订购成功!跳转到领取会员页面
  321. unicom.saveUserInfo();
  322. showAlertDialog('订购成功!');
  323. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'order_success' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  324. return;
  325. case "0013":
  326. showAlertDialog('该号码归属省分2/3G暂未开通此产品!');
  327. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'order_failure' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  328. break;
  329. case "6611":
  330. showAlertDialog('错误代码(6611),订购失败,请重试!');
  331. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'order_failure' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  332. break;
  333. case "6615":
  334. showAlertDialog('订购失败,请确定用户套餐!');
  335. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'order_failure' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  336. break;
  337. case "6622": // 用户已订购过此产品!跳转到流量查页面
  338. showAlertDialog('您已经订购了本产品~')
  339. unicom.saveUserInfo();
  340. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'order_failure' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  341. break;
  342. default:
  343. showAlertDialog(response.errorInfo + ',订购失败,请确定用户套餐!');
  344. WoAnalytics.addPoint({ ad: $('#nanyanad').val(), ett: 'click', ea: 'order_failure' + $('#nanyanlabel').val(), ct: 'web', pm: parseInt(unicom.query.sou, 32) })
  345. break;
  346. }
  347. }).fail(function (error) {
  348. compnt.hideLoading();
  349. console.log(error);
  350. });
  351. }
  352. function showAlertDialog(message) {
  353. var $overlay = $('<div class="overlay"></div>');
  354. var $dialog = $(
  355. '<div class="dialog dialog-message">' +
  356. ' <div class="content">' + message + '</div>' +
  357. ' <div class="actions">' +
  358. ' <div class="btn"></div>' +
  359. ' </div>' +
  360. '</div>');
  361. $overlay.appendTo($(document.body))
  362. $dialog.appendTo($(document.body))
  363. $("body").css("overflow", "hidden");
  364. $dialog.find('.btn').unbind('click').on('click', function () {
  365. $dialog.close()
  366. })
  367. var def = $.Deferred();
  368. $dialog.close = function () {
  369. $overlay.remove();
  370. $dialog.remove();
  371. $dialog = null;
  372. $("body").css("overflow", "auto");
  373. def.resolve($dialog);
  374. }
  375. return def;
  376. }
  377. /*$("body").on("touchstart", function(e) {
  378. // 判断默认行为是否可以被禁用
  379. // iphone 6, 7中不能滑动,判断 touchstart 未失效
  380. if (e.cancelable) {
  381. // 判断默认行为是否已经被禁用
  382. if (!e.defaultPrevented) {
  383. e.preventDefault();
  384. }
  385. }
  386. });*/
  387. var startX = 0; var startY = 0; var endX = 0; var endY = 0;
  388. $('.slider').unbind('touchstart').on('touchstart', function(event) {
  389. var touch = event.targetTouches[0];
  390. startX = touch.pageX;
  391. startY = touch.pageY;
  392. })
  393. $('.slider').unbind('touchmove').on('touchmove', function(event) {
  394. var touch = event.targetTouches[0];
  395. endX = touch.pageX;
  396. endY = touch.pageY;
  397. })
  398. $('.slider').unbind('touchend').on('touchend', function(event) {
  399. if (endX - startX >= 100) {
  400. orderPageProductChange(rightsproductid)
  401. } else if (startX - endX >= 100) {
  402. orderPageProductChange(flowproductid)
  403. }
  404. })