goto.js 11 KB

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