springFestivalActivity.html 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779
  1. <!DOCTYPE html>
  2. <html lang="zh-CN">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
  6. <title>春节活动</title>
  7. <link rel="icon" href="../static/img/favicon2.ico" type="img/x-ico">
  8. <link rel="stylesheet" href="../static/js/vender/toastr/toastr.min.css">
  9. <link rel="stylesheet" href="../static/css/springFestivalActivity.css">
  10. <script src="../static/js/vender/jquery-3.4.1.min.js"></script>
  11. <script src="../static/js/vender/toastr/toastr.min.js"></script>
  12. <script src="../static/js/vender/config.js"></script>
  13. </head>
  14. <body>
  15. <div class="code-container">
  16. <div class="award-tip">购买星曜月卡获得1次抽奖资格 星曜年卡获得10次抽奖资格</div>
  17. <div class="rule-wrap">
  18. <div class="rule">活动规则</div>
  19. <div class="award">奖励一览</div>
  20. </div>
  21. <div class="gift-box">
  22. <img class="gift-img" src="../static/img/springFestivalActivity/gift.png" />
  23. </div>
  24. </div>
  25. <div class="next-container">
  26. <div class="lottery-tip">抽奖10次必中年卡</div>
  27. <div class="lottery-wrap">
  28. <div class="once">抽奖1次</div>
  29. <div class="five-times">抽奖5次</div>
  30. </div>
  31. <div class="rest-times">
  32. <div class="rest-times-text">剩余次数 <span class="rest-times-number">0</span>次</div>
  33. <div class="get-times">获取次数 >></div>
  34. </div>
  35. <div class="no-join-activity">使用激活码,星币支付及PC端不参与活动</div>
  36. <div class="share-wrap">分享至朋友圈、QQ获得“幸运BUFF”</div>
  37. <div class="get-award">
  38. <div class="award-text">已获取奖励</div>
  39. <div class="award-number"></div>
  40. </div>
  41. <div class="activity-time">活动时间 :2021年1月25日-2月15日</div>
  42. <div class="activity-tip">仅购买星曜月卡,星曜年卡才可参与此活动哦</div>
  43. </div>
  44. <div class="award-record-mask">
  45. <div class="dialog">
  46. <div class="tab-wrap">
  47. <div class="award-change-btn active" data-index="0">领取</div>
  48. <div class="award-change-btn" data-index="1">已使用</div>
  49. </div>
  50. <div class="record-wrap">
  51. <div class="title-row">
  52. <div class="title-award">奖品</div>
  53. <div class="title-Title">时间</div>
  54. <div class="title-operat">操作</div>
  55. </div>
  56. <div class="line"></div>
  57. <div class="data-list"></div>
  58. </div>
  59. <div class="sure-btn">确定</div>
  60. <img class="close" src="../static/img/springFestivalActivity/close.png" />
  61. </div>
  62. </div>
  63. <div class="rule-mask">
  64. <div class="rule-dialog">
  65. <img class="rule-text" src="../static/img/springFestivalActivity/ruleText.png" />
  66. <div class="rule-list">
  67. <div class="rule-point">1、活动期间,购买获得的抽取资格不限次数, 活动期间可用,活动结束后未使用的做过期处理。</div>
  68. <div class="rule-point">2、参与活动的套餐是星曜月卡与年卡套餐,其他套餐不参与活动。</div>
  69. <div class="rule-point">3、星币、激活码购买的订单不参与本次活动。</div>
  70. <div class="rule-point">4、抽取的奖励只能新增云机,请去云手机首页查看。</div>
  71. <div class="rule-point">5、活动结束后3天保留奖励分配入口,但不能再参与活动。</div>
  72. <div class="rule-point">6、双子星官方对活动具有最终解释权。</div>
  73. </div>
  74. <img class="rule-close" src="../static/img/springFestivalActivity/close.png" />
  75. </div>
  76. </div>
  77. <div class="award-mask">
  78. <div class="award-dialog">
  79. <div class="award-result-row">
  80. <img class="icon" src="../static/img/springFestivalActivity/left-icon.png" />
  81. <span class="award-result">参与抽奖有几率获得以下奖励</span>
  82. <img class="icon" src="../static/img/springFestivalActivity/right-icon.png" />
  83. </div>
  84. <div class="card-wrap"></div>
  85. <img class="award-close" src="../static/img/springFestivalActivity/close.png" />
  86. </div>
  87. </div>
  88. <div class="award-result-mask">
  89. <div class="award-result-dialog">
  90. <div class="have-times-wrap">
  91. <div class="result-tip-row">
  92. <div class="award-result-tip">善良的人,好运气最终是会眷顾你</div>
  93. <div class="join-result-tip">抽取奖励仅为新增云手机,请去云手机首页查看</div>
  94. </div>
  95. <div class="card-wrap award-result-wrap"></div>
  96. <div class="btn-row">
  97. <div class="left-btn">再抽<span class="report-times"></span>次</div>
  98. <div class="look-btn">查看</div>
  99. </div>
  100. <div class="times-text">还剩次数:<span class="times-text-number"></span>次</div>
  101. </div>
  102. <div class="no-times-wrap">
  103. <div class="no-times-tip">
  104. <div>意不意外,惊不惊喜!</div>
  105. <div>当前抽奖次数不足哦</div>
  106. </div>
  107. <div class="no-times-btn">购买星曜云手机获取次数</div>
  108. </div>
  109. <img class="award-result-close" src="../static/img/springFestivalActivity/close.png" />
  110. </div>
  111. </div>
  112. <div class="distribution-mask">
  113. <div class="distribution-dialog">
  114. <div class="distribution-wrap">
  115. <div class="limit-tip">
  116. <div>云手机数量已达上限</div>
  117. <div>请分配云机时长</div>
  118. </div>
  119. <div class="distribution-btn">分配奖励</div>
  120. </div>
  121. </div>
  122. </div>
  123. <script>
  124. toastr.options.positionClass = 'toast-center-center';
  125. toastr.options.timeOut = '1500';
  126. </script>
  127. <script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.3.2.js"></script>
  128. <script type="text/javascript">
  129. // var baseUrl = 'https://test.androidscloud.com'
  130. let timer,flag = true;
  131. var url = window.location.href;
  132. url = url.split('/')
  133. var loc = window.location.search,
  134. n1 = loc.length,//地址的总长度
  135. n2 = loc.indexOf("="),//取得=号的位置
  136. id = loc.substr(n2 + 1, n1 - n2),//从=号后面的内容
  137. u = navigator.userAgent,
  138. ua = navigator.userAgent.toLowerCase(),
  139. isiOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/),
  140. isMiniprogram = false,
  141. isAndroid = u.indexOf('Android') > -1 || u.indexOf('Adr') > -1; //android终端
  142. let activityState = 0,
  143. luckDraw = 0,
  144. surplus = 0, //剩余未抽奖次数
  145. receive = 1,
  146. pages = 0,
  147. phoneRemainQuantity = 0,
  148. pageNum = 0,
  149. notReceive = 0;
  150. recordFlag = false;
  151. if(id !== ''){
  152. operate(3);
  153. }
  154. if (ua.match(/MicroMessenger/i) == "micromessenger") {
  155. //ios的ua中无miniProgram,但都有MicroMessenger(表示是微信浏览器)
  156. wx.miniProgram.getEnv((res) => {
  157. if (res.miniprogram) {
  158. isMiniprogram = true;
  159. } else {
  160. isMiniprogram = false;
  161. }
  162. })
  163. } else {
  164. isMiniprogram = false;
  165. }
  166. init();
  167. getPhoneNumber();
  168. setInterval(() => {
  169. init();
  170. },30000);
  171. //初始化数据
  172. function init(times) {
  173. $.ajax({
  174. url: baseUrl + '/api/user/v1/activity/getSpringFestivalConfig',
  175. type: 'get',
  176. headers: {
  177. 'Authorization': id //id
  178. },
  179. contentType: "application/json",
  180. dataType: 'json',
  181. cache: false,
  182. success: function (res) {
  183. if(res.status === 0){
  184. $('.card-wrap').eq(0).text('');
  185. let time = `活动时间 :${res.data.startTime.substr(0,4)}年${res.data.startTime.substring(5,7)}月${res.data.startTime.substring(8,10)}日-${res.data.endTime.substring(5,7)}月${res.data.endTime.substring(8,10)}日`;
  186. $('.activity-time').eq(0).text(time);
  187. let str = '',
  188. cardData = [{name: '天',imgName: 'day'},{name: '周',imgName: 'week'},{name: '月',imgName: 'mouth'},
  189. {name: '季',imgName: 'season'},{name: '年',imgName: 'year'}],
  190. jackpot = res.data.jackpot;
  191. cardData = cardData.filter((item) => jackpot.includes(item.name));
  192. for (var i = 0; i < cardData.length; i++) {
  193. str += `<div class="card-item">
  194. <img class="card" src="../static/img/springFestivalActivity/${cardData[i].imgName}.png" />
  195. <div class="card-text">星曜${cardData[i].name}卡</div>
  196. </div>`
  197. }
  198. activityState = res.data.activityState;
  199. if(activityState === 2){
  200. $('.share-wrap').eq(0).css('display', 'none');
  201. }
  202. luckDraw = res.data.luckDraw;
  203. surplus = res.data.surplus;
  204. notReceive = res.data.notReceive;
  205. $('.rest-times-number').eq(0).text(surplus);
  206. $('.times-text-number').eq(0).text(surplus);
  207. if(res.data.addition === 1){
  208. $('.gift-box')[0].className = 'gift-box have-buff'
  209. } else {
  210. $('.gift-box')[0].className = 'gift-box'
  211. }
  212. if(notReceive > 0){
  213. receive = 0;
  214. notReceive = notReceive > 99 ? '99+' : notReceive;
  215. $('.tab-wrap').eq(0).css('display', 'flex');
  216. $('.record-wrap').eq(0).css('marginTop', '0.2rem');
  217. $('.record-wrap').eq(0).css('height', '5.38rem');
  218. $('.data-list').eq(0).css('height', '4.38rem');
  219. $('.award-number').eq(0).css('display', 'block');
  220. $('.award-number').eq(0).text(notReceive);
  221. }else{
  222. $('.award-number').eq(0).css('display', 'none');
  223. $('.tab-wrap').eq(0).css('display', 'none');
  224. $('.record-wrap').eq(0).css('marginTop', '1.6rem');
  225. $('.record-wrap').eq(0).css('height', '5.86rem');
  226. }
  227. $('.card-wrap').eq(0).append(str)
  228. }else{
  229. stopManyClick(() =>{
  230. toastr.error(res.msg)
  231. })
  232. }
  233. },
  234. })
  235. }
  236. //点击获奖记录
  237. $('.get-award')[0].addEventListener('click',() => {
  238. if(activityState === 2 && luckDraw === 0){
  239. stopManyClick(() =>{
  240. toastr.error('活动已结束,期待下次的见面');
  241. })
  242. return
  243. }
  244. $('.dialog').animate({top: '2.24rem'},"fast");
  245. $('.award-record-mask').show();
  246. document.documentElement.style.overflow='hidden';
  247. $('.data-list').eq(0).text('');
  248. pageNum = 1;
  249. pages = 0;
  250. recordFlag = true;
  251. getAward();
  252. },false);
  253. //点击获奖记录关闭按钮
  254. $('.close')[0].addEventListener('click',handleClose,false);
  255. function handleClose() {
  256. $('.dialog').animate({top: '-10.96rem'},"fast");
  257. $('.award-record-mask').hide();
  258. document.documentElement.style.overflow='auto';
  259. }
  260. //点击确定
  261. $('.sure-btn')[0].addEventListener('click',handleClose,false);
  262. //点击规则
  263. $('.rule')[0].addEventListener('click',() => {
  264. $('.rule-dialog').animate({top: '2.24rem'},"fast");
  265. $('.rule-mask').show();
  266. document.documentElement.style.overflow='hidden';
  267. },false);
  268. //点击规则关闭按钮
  269. $('.rule-close')[0].addEventListener('click',() => {
  270. $('.rule-dialog').animate({top: '-10.96rem'},"fast");
  271. $('.rule-mask').hide();
  272. document.documentElement.style.overflow='auto';
  273. },false);
  274. //点击奖励一览
  275. $('.award')[0].addEventListener('click',() => {
  276. if(activityState === 0){
  277. stopManyClick(() =>{
  278. toastr.error('该活动暂未开启,请稍安勿躁');
  279. })
  280. }else if(activityState === 2 && luckDraw === 0){
  281. stopManyClick(() =>{
  282. toastr.error('活动已结束,期待下次的见面');
  283. })
  284. }else{
  285. $('.award-dialog').animate({top: '2.24rem'},"fast");
  286. $('.award-mask').show();
  287. document.documentElement.style.overflow='hidden';
  288. }
  289. },false);
  290. //点击奖励一览关闭按钮
  291. $('.award-close')[0].addEventListener('click',() => {
  292. $('.award-dialog').animate({top: '-10.96rem'},"fast");
  293. $('.award-mask').hide();
  294. document.documentElement.style.overflow='auto';
  295. },false);
  296. //点击领取按钮
  297. $('.tab-wrap')[0].addEventListener('click',(e) => {
  298. if(e.target.className === 'tab-wrap'){
  299. return
  300. }
  301. receive = e.target.dataset.index;
  302. if(receive == 1){
  303. $('.award-change-btn')[0].className = 'award-change-btn'
  304. }else{
  305. $('.award-change-btn')[1].className = 'award-change-btn'
  306. }
  307. $('.data-list').eq(0).text('');
  308. pageNum = 1;
  309. pages = 0;
  310. recordFlag = true;
  311. getAward();
  312. $('.award-change-btn')[receive].className = 'award-change-btn active'
  313. },false);
  314. //点击抽奖
  315. $('.once')[0].addEventListener('click',() => {
  316. if(activityState === 0){
  317. stopManyClick(() =>{
  318. toastr.error('该活动暂未开启,请稍安勿躁');
  319. })
  320. }else if(activityState === 2 && luckDraw === 0){
  321. stopManyClick(() =>{
  322. toastr.error('活动已结束,期待下次的见面');
  323. })
  324. }else{
  325. handleAward(1)
  326. }
  327. },false);
  328. $('.five-times')[0].addEventListener('click',() => {
  329. if(activityState === 0){
  330. stopManyClick(() =>{
  331. toastr.error('该活动暂未开启,请稍安勿躁');
  332. })
  333. }else if(activityState === 2 && luckDraw === 0){
  334. stopManyClick(() =>{
  335. toastr.error('活动已结束,期待下次的见面');
  336. })
  337. }else{
  338. handleAward(5)
  339. }
  340. },false);
  341. //点击再抽
  342. $('.left-btn')[0].addEventListener('click',() => {
  343. let val = $('.report-times').eq(0).text();
  344. handleAward(val,'report')
  345. },false);
  346. function handleAward(times,type) {
  347. if(surplus === 0 || (times == 5 && surplus < 5)){
  348. $('.have-times-wrap').eq(0).css('display', 'none');
  349. $('.no-times-wrap').eq(0).css('display', 'block');
  350. $('.award-result-dialog').animate({top: '1.86rem'},"fast");
  351. $('.award-result-mask').show();
  352. document.documentElement.style.overflow='hidden';
  353. return
  354. }
  355. $.ajax({
  356. url: baseUrl + '/api/user/v1/activity/obtainRewards',
  357. type: 'post',
  358. headers: {
  359. 'Authorization': id //id
  360. },
  361. data:JSON.stringify({
  362. frequency: times
  363. }),
  364. contentType: "application/json",
  365. dataType: 'json',
  366. cache: false,
  367. success: function (res) {
  368. if(res.status === 0){
  369. $('.have-times-wrap').eq(0).css('display', 'block');
  370. $('.no-times-wrap').eq(0).css('display', 'none');
  371. if(type !== 'report'){
  372. $('.award-result-dialog').animate({top: '1.86rem'},"fast");
  373. $('.award-result-mask').show();
  374. document.documentElement.style.overflow='hidden';
  375. }
  376. $('.award-result-wrap').eq(0).text('');
  377. let str = '',
  378. cardObj = {
  379. '天': 'day',
  380. '周': 'week',
  381. '月': 'month',
  382. '季': 'season',
  383. '年': 'year'
  384. },
  385. imgNumber = 1,
  386. imgNumberArr = [0,0,0,0,0,0],
  387. list = res.data.list;
  388. if(list.length === 1){
  389. $('.award-result-wrap')[0].className = 'card-wrap award-result-wrap one-result';
  390. str = `<div class="card-item">
  391. <img class="one-card" src="../static/img/springFestivalActivity/one-award/common${imgNumber}.png" />
  392. </div> `
  393. let imgTimer = setInterval(() => {
  394. imgNumber++;
  395. if(imgNumber < 7){
  396. $('.one-card')[0].src = `../static/img/springFestivalActivity/one-award/common${imgNumber}.png`;
  397. }else{
  398. $('.one-card')[0].src = `../static/img/springFestivalActivity/one-award/${cardObj[list[0].duration]}${imgNumber}.png`;
  399. }
  400. if(imgNumber === 11){
  401. clearInterval(imgTimer);
  402. }
  403. },80)
  404. }else{
  405. $('.award-result-wrap')[0].className = 'card-wrap award-result-wrap'
  406. for (let i = 0; i < list.length; i++) {
  407. str += `<div class="card-item">
  408. <img class="many-card card" src="../static/img/springFestivalActivity/many-award/common${imgNumber}.png" />
  409. </div>`
  410. setTimeout(() => {
  411. $('.many-card')[i].className = `many-card card many-card${i+1}`;
  412. })
  413. let imgTimer2 = setInterval(() => {
  414. imgNumberArr[i]++;
  415. if(imgNumberArr[i] < 6){
  416. $('.many-card')[i].src = `../static/img/springFestivalActivity/many-award/common${imgNumberArr[i]}.png`;
  417. }else{
  418. $('.many-card')[i].src = `../static/img/springFestivalActivity/many-award/${cardObj[list[i].duration]}${imgNumberArr[i]}.png`;
  419. }
  420. if(imgNumberArr[i] === 11){
  421. clearInterval(imgTimer2);
  422. }
  423. },80)
  424. }
  425. }
  426. $('.report-times').eq(0).text(times);
  427. if(notReceive > 0){
  428. $('.join-result-tip').eq(0).css('opacity', '0');
  429. }
  430. let text = notReceive > 0?'确定':'查看';
  431. $('.look-btn').eq(0).text(text);
  432. $('.award-result-wrap').eq(0).append(str);
  433. init();
  434. getPhoneNumber();
  435. }else{
  436. stopManyClick(() =>{
  437. toastr.error(res.msg)
  438. })
  439. }
  440. },
  441. })
  442. }
  443. //点击抽奖关闭按钮
  444. $('.award-result-close')[0].addEventListener('click',() => {
  445. $('.award-result-dialog').animate({top: '-10.96rem'},"fast");
  446. $('.award-result-mask').hide();
  447. document.documentElement.style.overflow='auto';
  448. },false);
  449. //点击分享按钮
  450. $('.share-wrap')[0].addEventListener('click',() => {
  451. if(activityState === 0){
  452. stopManyClick(() =>{
  453. toastr.error('该活动暂未开启,请稍安勿躁');
  454. })
  455. return
  456. }
  457. $.ajax({
  458. url: baseUrl + '/api/public/v4/actFissionAward/getActDetail',
  459. type: 'get',
  460. headers: {
  461. 'Authorization': id //id
  462. },
  463. contentType: "application/json",
  464. dataType: 'json',
  465. cache: false,
  466. success: (res) => {
  467. if (res.status === 0) {
  468. init();
  469. var shareInfo = res.data;
  470. if (isMiniprogram) { // 小程序
  471. copyUrl(shareInfo.gotoUrl);
  472. } else if (isAndroid) {
  473. window.native.share(shareInfo.title, shareInfo.content, shareInfo.gotoUrl, shareInfo.shareImg);
  474. } else if (isiOS) {
  475. window.webkit.messageHandlers.share.postMessage({
  476. title: shareInfo.title,
  477. content: shareInfo.content,
  478. gotoUrl: shareInfo.gotoUrl,
  479. shareImg: shareInfo.shareImg
  480. });
  481. }
  482. } else {
  483. stopManyClick(() =>{
  484. toastr.error(res.msg)
  485. })
  486. }
  487. },
  488. })
  489. $.ajax({
  490. url: baseUrl + '/api/user/v1/activity/addBuff',
  491. type: 'get',
  492. headers: {
  493. 'Authorization': id //id
  494. },
  495. contentType: "application/json",
  496. dataType: 'json',
  497. cache: false,
  498. success: function (res) {
  499. console.log(res)
  500. },
  501. })
  502. },false);
  503. //点击购买星耀获取云机按钮
  504. $('.no-times-btn')[0].addEventListener('click',() => {
  505. if(activityState === 2){
  506. stopManyClick(() =>{
  507. toastr.error('活动已结束,期待下次的见面');
  508. })
  509. return
  510. }
  511. if (isMiniprogram) { // 小程序
  512. if(phoneRemainQuantity > 0){
  513. wx.miniProgram.navigateTo({
  514. url: '/packageA/order/buy/index?type=activity'
  515. })
  516. } else {
  517. wx.miniProgram.navigateTo({
  518. url: '/packageA/order/renew/index?type=activity'
  519. })
  520. }
  521. } else if (isAndroid) { // 安卓
  522. if(phoneRemainQuantity > 0){
  523. window.native.startPurchase(1, 365);
  524. } else {
  525. window.native.startRenew();
  526. }
  527. } else if (isiOS) {
  528. if(phoneRemainQuantity > 0){
  529. window.webkit.messageHandlers.startPurchase.postMessage({ type: 1, day: 365 });
  530. } else {
  531. window.webkit.messageHandlers.startRenew.postMessage({ type: 1, day: 365 });
  532. }
  533. }
  534. },false);
  535. //点击获取次数
  536. $('.get-times')[0].addEventListener('click',() => {
  537. if(activityState === 1){
  538. stopManyClick(() =>{
  539. if (isMiniprogram) { // 小程序
  540. if(phoneRemainQuantity > 0){
  541. wx.miniProgram.navigateTo({
  542. url: '/packageA/order/buy/index?type=activity'
  543. })
  544. } else {
  545. wx.miniProgram.navigateTo({
  546. url: '/packageA/order/renew/index?type=activity'
  547. })
  548. }
  549. } else if (isAndroid) { // 安卓
  550. if(phoneRemainQuantity > 0){
  551. window.native.startPurchase(1, 365);
  552. } else {
  553. window.native.startRenew();
  554. }
  555. } else if (isiOS) {
  556. if(phoneRemainQuantity > 0){
  557. window.webkit.messageHandlers.startPurchase.postMessage({ type: 1, day: 365 });
  558. } else {
  559. window.webkit.messageHandlers.startRenew.postMessage({ type: 1, day: 365 });
  560. }
  561. }
  562. })
  563. }else if(activityState === 0) {
  564. stopManyClick(() =>{
  565. toastr.error('该活动暂未开启,请稍安勿躁');
  566. })
  567. } else {
  568. stopManyClick(() =>{
  569. toastr.error('活动已结束,期待下次的见面');
  570. })
  571. }
  572. },false);
  573. // 点击查看
  574. $('.look-btn')[0].addEventListener('click',() => {
  575. if(notReceive > 0){
  576. $('.distribution-dialog').animate({top: '5.24rem'},"fast");
  577. $('.distribution-mask').show();
  578. document.documentElement.style.overflow='hidden';
  579. return
  580. }
  581. if (isMiniprogram) { // 小程序
  582. wx.miniProgram.switchTab({
  583. url: '/pages/home/home'
  584. })
  585. } else if (isAndroid) { // 安卓
  586. window.native.startMain();
  587. } else if (isiOS) {
  588. window.webkit.messageHandlers.startMain.postMessage({ type: 2});
  589. }
  590. },false);
  591. //点击分配奖励按钮
  592. $('.distribution-btn')[0].addEventListener('click',() => {
  593. $('.award-result-dialog').animate({top: '-10.96rem'},"fast");
  594. $('.award-result-mask').hide();
  595. $('.distribution-dialog').animate({top: '-10.96rem'},"fast");
  596. $('.distribution-mask').hide();
  597. $('.dialog').animate({top: '2.24rem'},"fast");
  598. $('.award-record-mask').show();
  599. document.documentElement.style.overflow='hidden';
  600. $('.award-change-btn')[1].className = 'award-change-btn'
  601. $('.award-change-btn')[0].className = 'award-change-btn active'
  602. receive = 0;
  603. pageNum = 1;
  604. pages = 0;
  605. recordFlag = true;
  606. $('.data-list').eq(0).text('');
  607. getAward()
  608. },false);
  609. //点击使用按钮
  610. $('.data-list')[0].addEventListener('click',(e) => {
  611. if (e.target.className === 'record-operate operate-btn') {
  612. let awardId = parseInt(e.target.dataset.awardid);
  613. let awardName = e.target.dataset.awardname;
  614. if (isMiniprogram) { // 小程序
  615. wx.miniProgram.navigateTo({
  616. url: `/packageA/activityCloudPhone/index?id=${awardId}&awardName=${awardName}`
  617. })
  618. } else if (isAndroid) { // 安卓
  619. window.native.activatePhone(2, awardId, awardName);
  620. } else if (isiOS) {
  621. window.webkit.messageHandlers.activatePhone.postMessage({ type: 2, awardId: awardId, awardName: awardName });
  622. }
  623. }
  624. },false);
  625. //获取抽奖记录
  626. function getAward(){
  627. $.ajax({
  628. url: baseUrl + '/api/user/v1/activity/platformGetRewardsH5',
  629. type: 'post',
  630. headers: {
  631. 'Authorization': id //id
  632. },
  633. data:JSON.stringify({
  634. pageNum: pageNum,
  635. pageSize: 10,
  636. receive: receive
  637. }),
  638. contentType: "application/json",
  639. dataType: 'json',
  640. cache: false,
  641. success: function (res) {
  642. if(res.status === 0){
  643. recordFlag = true;
  644. let str = '',
  645. records = res.data.records;
  646. pages = res.data.pages;
  647. if(records.length === 0){
  648. $('.title-row').eq(0).css('display', 'none');
  649. if(receive == 1 && notReceive > 0){
  650. str = '<div class="no-award">暂无已分配云手机</div>'
  651. }else{
  652. str = '<div class="no-award">没有抽奖记录,我都替你着急</div>'
  653. }
  654. }else{
  655. $('.title-row').eq(0).css('display', 'flex');
  656. }
  657. for (var i = 0; i < records.length; i++) {
  658. str += `<div class="data-row">
  659. <div class="award-card">星曜${records[i].effectiveTimeStr}卡</div>
  660. <div class="record-time">${records[i].createTime.substring(5,7)}月${records[i].createTime.substring(8,10)}日${records[i].createTime.substr(11)}</div>
  661. <div class="${records[i].receive === 1?'record-operate':'record-operate operate-btn'}"
  662. data-awardId="${records[i].id}" data-awardName="星曜${records[i].effectiveTimeStr}卡">
  663. ${records[i].receive === 1?'已使用':'领取'}</div>
  664. </div>`
  665. }
  666. $('.data-list').eq(0).append(str)
  667. }else{
  668. stopManyClick(() =>{
  669. toastr.error(res.msg)
  670. })
  671. }
  672. },
  673. })
  674. }
  675. function getPhoneNumber(){
  676. $.ajax({
  677. url: baseUrl + '/api/user/v2/meal/info?phoneType=SVIP',
  678. type: 'get',
  679. headers: {
  680. 'Authorization': id //id
  681. },
  682. contentType: "application/json",
  683. dataType: 'json',
  684. cache: false,
  685. success: function (res) {
  686. if(res.status === 0){
  687. phoneRemainQuantity = res.data.list[0].phoneRemainQuantity;
  688. }else{
  689. stopManyClick(() =>{
  690. toastr.error(res.msg)
  691. })
  692. }
  693. },
  694. })
  695. }
  696. //抽奖记录数据下拉加载
  697. $('.data-list')[0].addEventListener('scroll',function () {
  698. let scrollTop = $('.data-list')[0].scrollTop;
  699. let clientHeight = $('.data-list')[0].clientHeight;
  700. let scrollHeight = $('.data-list')[0].scrollHeight;
  701. if(scrollTop + clientHeight + 100 > scrollHeight){
  702. if(recordFlag && pageNum < pages && pages > 1){
  703. recordFlag = false;
  704. pageNum++;
  705. getAward();
  706. }
  707. }
  708. });
  709. //复制
  710. function copyUrl(url) {
  711. stopManyClick(() => {
  712. var oInput = document.createElement('input'); //创建一个input
  713. oInput.setAttribute("readonly", "readonly");//设置只读,否则移动端使用复制功能时可能会造成软件盘弹出
  714. oInput.value = url;
  715. document.body.appendChild(oInput);//将input插入到body
  716. // oInput.select(); // 选择对象 ios不支持
  717. selectText(oInput, 0, oInput.value.length);
  718. document.execCommand("Copy"); // 执行浏览器复制命令
  719. toastr.error('复制分享链接成功!');
  720. oInput.style.display = 'none'; // 将input隐藏
  721. oInput.blur();
  722. oInput.remove(); // 将input销毁
  723. })
  724. }
  725. // input自带的select()方法在苹果端无法进行选择,所以需要自己去写一个类似的方法
  726. // 选择文本。createTextRange(setSelectionRange)是input方法
  727. function selectText(textbox, startIndex, stopIndex) {
  728. if (textbox.createTextRange) {//ie
  729. const range = textbox.createTextRange();
  730. range.collapse(true);
  731. range.moveStart('character', startIndex);//起始光标
  732. range.moveEnd('character', stopIndex - startIndex);//结束光标
  733. range.select();//不兼容苹果
  734. } else {//firefox/chrome
  735. textbox.setSelectionRange(startIndex, stopIndex);
  736. textbox.focus();
  737. }
  738. }
  739. //埋点
  740. function operate(accessType){
  741. $.ajax({
  742. url: baseUrl + '/api/public/v1/game/user/operate',
  743. type: 'post',
  744. headers: {
  745. 'Authorization': id //id
  746. },
  747. data:JSON.stringify({
  748. accessType: accessType,
  749. entrance: 3,
  750. url: window.location.href
  751. }),
  752. contentType:"application/json",
  753. dataType: 'json',
  754. cache: false,
  755. success: function (res) {
  756. console.log(res)
  757. },
  758. })
  759. }
  760. //防止提示一秒内重复显示
  761. function stopManyClick(fn) {
  762. if (flag) {
  763. fn();
  764. }
  765. flag = false;
  766. if(timer){clearTimeout(timer);}
  767. timer = setTimeout(() => {flag = true}, 1500);
  768. }
  769. </script>
  770. </body>
  771. </html>