goto.js 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349
  1. // $('.sec05-moblie-container').slick({
  2. // arrows: false,
  3. // slidesToShow: 1,
  4. // slidesToScroll: 1,
  5. // infinite: false,
  6. // centerMode: true,
  7. // });
  8. $(".sendbox").hide();
  9. $(document).on("click", ".collectcontent", function (event) {
  10. $(".sendbox").show(500);
  11. $(this).addClass("select");
  12. $(".select").siblings().removeClass('select');
  13. });
  14. $(document).on("click", ".close", function (event) {
  15. // $(this).siblings('.collectcard').removeClass('select');
  16. $(".sendbox").hide(500);
  17. $(".collectcontent").removeClass("select");
  18. });
  19. // 收藏頁面
  20. $(document).ready(function () {
  21. collecturl = location.search;
  22. getcollect = collecturl.split("?")
  23. var collectuserid = getcollect[1];
  24. $.ajax({
  25. method: "GET",
  26. url: "https://ark.cards:8228/collection/" + collectuserid + "",
  27. // url: "https://api.ptt.cx:8228/collection/Uf161c92b16f84357987a78c2b4b47719",
  28. dataType: "json",
  29. })
  30. .done(function (msg) {
  31. console.log(msg);
  32. // console.log(Object.keys(msg).length);
  33. let msgLen = Object.keys(msg).length;
  34. console.log(msgLen)
  35. var collectcontent = '';
  36. for (var i = 0; i < msgLen; i++) {
  37. collectcontent += '\
  38. <div class="collectcontent col">\
  39. <input style="display: none;" type="checkbox" value="'+ msg[i].id + '" name="nftid" id="' + msg[i].id + '">\
  40. <label for="'+ msg[i].id + '">\
  41. <div class="collectcard card h-100">\
  42. <a target="_blank">\
  43. <img src="'+ msg[i].imgurl + '"class="card-img-top" alt="...">\
  44. </a>\
  45. <div class="card-body p-2">\
  46. <a target="_blank">\
  47. <h5 class="card-title pt-3">'+ msg[i].title + '</h5>\
  48. </a>\
  49. <p class="card-text">\
  50. '+ msg[i].context + ' \
  51. </p>\
  52. <p class="card-text row">\
  53. <small class="text-muted col-6 px-1">\
  54. <img class="mb-1 mx-1 d-inline" style="width: 10px; object-fit: cover; "\
  55. src="./img/sec05/Icon awesome-ethereum.png" alt=""><span>'+ msg[i].cost + '</span>\
  56. </small>\
  57. <small class="price col-6 px-0 text-center">\
  58. <img class="mb-1 mx-1 d-inline" style="width: 12px; object-fit: cover; " src="./img/sec05/like.png" alt=""><span>'+ msg[i].likes + '</span></small>\
  59. </p>\
  60. </div>\
  61. </div>\
  62. </label>\
  63. </div>';
  64. }
  65. $('.sec05-moblie-container').html(collectcontent);
  66. });
  67. });
  68. $(".buybox").hide();
  69. $(document).on("click", ".nftmall", function (event) {
  70. $(".buybox").show(500);
  71. $(this).addClass("select");
  72. $(".select").siblings().removeClass('select');
  73. });
  74. $(document).on("click", ".close", function (event) {
  75. // $(this).siblings('.collectcard').removeClass('select');
  76. $(".buybox").hide(500);
  77. $(".nftmall").removeClass("select");
  78. $(".nftname").prop( "checked", false );
  79. });
  80. $.fn.serializeObject = function () {
  81. var o = {};
  82. var a = this.serializeArray();
  83. // o["id"] = 0;
  84. // o["time_stamp"] = "";
  85. $.each(a, function () {
  86. if (o[this.name]) {
  87. if (!o[this.name].push) {
  88. o[this.name] = [o[this.name]];
  89. }
  90. o[this.name].push(this.value || '');
  91. } else {
  92. o[this.name] = this.value || '';
  93. }
  94. });
  95. return o;
  96. };
  97. $(".collect-send").submit(function (e) {
  98. /* var formRef = $('#form1').serializeArray();
  99. var jsonString = JSON.stringify(formRef);*/
  100. var jsonInfo = $('.collect-send').serializeObject();
  101. var jsonString = JSON.stringify(jsonInfo);
  102. console.log(jsonString),
  103. $.ajax({
  104. type: 'POST',
  105. url: 'https://ark.cards:8228/send',
  106. data: jsonString,
  107. dataType: 'json',
  108. success: function (data) {
  109. console.log('送出成功: ' + data);
  110. alert("送出成功");
  111. // location.reload();
  112. },
  113. beforeSend: function () {
  114. console.log('beforeSend');
  115. },
  116. complete: function () {
  117. console.log('complete');
  118. },
  119. error: function (jqXHR, textStatus, errorThrown) {
  120. console.log(JSON.stringify(jqXHR));
  121. console.log("AJAX errr: " + textStatus + ' : ' + errorThrown);
  122. console.log('送出失敗: ' + jqXHR.responseText);
  123. }
  124. });
  125. return false;
  126. });
  127. $(".nft-buy").submit(function (e) {
  128. /* var formRef = $('#form1').serializeArray();
  129. var jsonString = JSON.stringify(formRef);*/
  130. var jsonInfo = $('.nft-buy').serializeObject();
  131. var jsonString = JSON.stringify(jsonInfo);
  132. console.log(jsonString),
  133. $.ajax({
  134. type: 'POST',
  135. url: 'https://ark.cards:8228/buy',
  136. data: jsonString,
  137. dataType: 'json',
  138. success: function (data) {
  139. console.log('購買成功: ' + data);
  140. alert("購買成功");
  141. location.reload();
  142. },
  143. beforeSend: function () {
  144. console.log('beforeSend');
  145. },
  146. complete: function () {
  147. console.log('complete');
  148. },
  149. error: function (jqXHR, textStatus, errorThrown) {
  150. console.log(JSON.stringify(jqXHR));
  151. console.log("AJAX errr: " + textStatus + ' : ' + errorThrown);
  152. console.log('送出失敗: ' + jqXHR.responseText);
  153. }
  154. });
  155. return false;
  156. });
  157. // 購買頁面
  158. $(document).ready(function () {
  159. collecturl = location.search;
  160. getcollect = collecturl.split("?")
  161. var collectuserid = getcollect[1];
  162. $.ajax({
  163. method: "GET",
  164. url: "https://ark.cards:8228/shop/" + collectuserid + "",
  165. // url: "https://ark.cards:8228/shop/Uf161c92b16f84357987a78c2b4b47719",
  166. dataType: "json",
  167. })
  168. .done(function (msg) {
  169. console.log(msg);
  170. // console.log(Object.keys(msg).length);
  171. let msgLen = Object.keys(msg).length;
  172. console.log(msgLen);
  173. var nftmall = '';
  174. var buybox="";
  175. for (var i = 0; i < msgLen; i++) {
  176. nftmall += '\
  177. <div class="nftmall col">\
  178. <input style="display:none" type="checkbox" value="'+ msg[i].id + '" name="nftid" class="nftname" id="' + msg[i].id + '">\
  179. <label for="'+ msg[i].id + '">\
  180. <div class="collectcard card h-100">\
  181. <a target="_blank">\
  182. <img src="'+ msg[i].imgurl + '"class="card-img-top" alt="...">\
  183. </a>\
  184. <div class="card-body p-2">\
  185. <a target="_blank">\
  186. <h5 class="card-title pt-3">'+ msg[i].title + '</h5>\
  187. </a>\
  188. <p class="card-text">\
  189. '+ msg[i].context + ' \
  190. </p>\
  191. <p class="card-text row">\
  192. <small class="text-muted col-6 px-1">\
  193. <img class="mb-1 mx-1 d-inline" style="width: 10px; object-fit: cover; "\
  194. src="./img/sec05/Icon awesome-ethereum.png" alt=""><span>'+ msg[i].cost + '</span>\
  195. </small>\
  196. <small class="price col-6 px-0 text-center">\
  197. <img class="mb-1 mx-1 d-inline" style="width: 12px; object-fit: cover; " src="./img/sec05/like.png" alt=""><span>'+ msg[i].likes + '</span></small>\
  198. </p>\
  199. </div>\
  200. </div>\
  201. </label>\
  202. </div>';
  203. }
  204. buybox+='\
  205. <div class="p-2">\
  206. <input style="border-radius: 10px; border:none; display: none;" class="p-2 w-100 mb-3" type="text" name="userid" value="' + collectuserid + '" placeholder="請輸入您的userid" required>\
  207. <div class="text-end px-2">\
  208. <p class="text-start text-white mb-2">※一次只能購買一則NFT收藏品</p>\
  209. <button type="button" style="border:1px solid #fff; border-radius: 30px;" class="close btn text-white px-3">取消</button>\
  210. <input style="border-radius: 30px; background:#fff; border: none;" class="send-btn px-3 ms-1 py-2" type="submit" value="購買">\
  211. </div>\
  212. </div>\
  213. </div>';
  214. $('.sec06-nft-mall').html(nftmall);
  215. $('.buybox').html(buybox);
  216. });
  217. });
  218. // 購買建
  219. // $(".nft-buy").submit(function (e) {
  220. // /* var formRef = $('#form1').serializeArray();
  221. // var jsonString = JSON.stringify(formRef);*/
  222. // var jsonInfo = $('.nft-buy').serializeObject();
  223. // var jsonString = JSON.stringify(jsonInfo);
  224. // console.log(jsonString);
  225. // let k = jsonInfo;
  226. // let nftproduct = k.nftidval;
  227. // console.log(nftproduct);
  228. // $.ajax({
  229. // type: 'GET',
  230. // url: "https://api.ptt.cx:8228/buy/" + collectuserid + "/" + nftproduct + "",
  231. // data: jsonString,
  232. // dataType: 'json',
  233. // success: function (data) {
  234. // console.log('購買成功: ' + data);
  235. // alert("購買成功");
  236. // location.reload();
  237. // },
  238. // beforeSend: function () {
  239. // console.log('beforeSend');
  240. // },
  241. // complete: function () {
  242. // console.log('complete');
  243. // },
  244. // error: function (jqXHR, textStatus, errorThrown) {
  245. // console.log(JSON.stringify(jqXHR));
  246. // console.log("AJAX errr: " + textStatus + ' : ' + errorThrown);
  247. // console.log('送出失敗: ' + jqXHR.responseText);
  248. // }
  249. // });
  250. // return false;
  251. // });
  252. // $(document).ready(function () {
  253. // function get_data(){
  254. // $.ajax({
  255. // method: "GET",
  256. // // url:"https://api.ptt.cx:8228/collection/""+userid+",
  257. // url:"https://api.ptt.cx:8228/collection/U176663ce100ebb1f4c404d48749decb1_test_000_000_000",
  258. // dataType: "json",
  259. // })
  260. // .done(function (msg) {
  261. // console.log(msg);
  262. // });
  263. // }
  264. // get_data();
  265. // });
  266. // console.log(location.href);
  267. // Qrcode頁面
  268. $(document).ready(function () {
  269. url = location.search;
  270. getSearch = url.split("?")
  271. var userid = getSearch[1];
  272. function get_data() {
  273. $.ajax({
  274. method: "GET",
  275. url: "https://ark.cards:8228/receive/" + userid + "",
  276. // url:"https://api.ptt.cx:8228/receive/Uf161c92b16f84357987a78c2b4b47719",
  277. dataType: "json",
  278. })
  279. .done(function (msg) {
  280. console.log(msg);
  281. console.log(msg.base)
  282. var Qrcodeimg = '';
  283. var useraddress = '';
  284. Qrcodeimg += '\
  285. <img src="'+ msg.base + '" alt="">\
  286. ';
  287. useraddress += '\
  288. '+ msg.useraddress + '\
  289. ';
  290. $('#Qrcode').html(Qrcodeimg);
  291. $('#copy').html(useraddress);
  292. });
  293. }
  294. get_data();
  295. });
  296. function copyEvent(id) {
  297. var str = document.getElementById(id);
  298. window.getSelection().selectAllChildren(str);
  299. document.execCommand("Copy")
  300. toastr.options = {
  301. // 參數設定[註1]
  302. "closeButton": false, // 顯示關閉按鈕
  303. "debug": false, // 除錯
  304. "newestOnTop": false, // 最新一筆顯示在最上面
  305. "progressBar": false, // 顯示隱藏時間進度條
  306. "positionClass": "toast-top-center", // 位置的類別
  307. "preventDuplicates": false, // 隱藏重覆訊息
  308. "onclick": null, // 當點選提示訊息時,則執行此函式
  309. "showDuration": "300", // 顯示時間(單位: 毫秒)
  310. "hideDuration": "1000", // 隱藏時間(單位: 毫秒)
  311. "timeOut": "1000", // 當超過此設定時間時,則隱藏提示訊息(單位: 毫秒)
  312. "extendedTimeOut": "1000", // 當使用者觸碰到提示訊息時,離開後超過此設定時間則隱藏提示訊息(單位: 毫秒)
  313. "showEasing": "swing", // 顯示動畫時間曲線
  314. "hideEasing": "linear", // 隱藏動畫時間曲線
  315. "showMethod": "fadeIn", // 顯示動畫效果
  316. "hideMethod": "fadeOut" // 隱藏動畫效果
  317. }
  318. toastr.success("複製成功");
  319. }