single.html 5.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <meta http-equiv="X-UA-Compatible" content="ie=edge, Chrome=1">
  7. <meta http-equiv="Cache-Control" content="no-cache">
  8. <title>ChoozMo 全球 YT 推廣服務 | 集仕多</title>
  9. <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet"
  10. integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous">
  11. <link rel="stylesheet" href="//use.fontawesome.com/releases/v5.11.2/css/all.css">
  12. <link rel="stylesheet" href="/css/style.css">
  13. <!-- Start of HubSpot Embed Code -->
  14. <!-- <script type="text/javascript" id="hs-script-loader" async defer src="//js-na1.hs-scripts.com/20485755.js"></script> -->
  15. <!-- End of HubSpot Embed Code -->
  16. <!-- Google Tag Manager -->
  17. <script>(function (w, d, s, l, i) {
  18. w[l] = w[l] || []; w[l].push({
  19. 'gtm.start':
  20. new Date().getTime(), event: 'gtm.js'
  21. }); var f = d.getElementsByTagName(s)[0],
  22. j = d.createElement(s), dl = l != 'dataLayer' ? '&l=' + l : ''; j.async = true; j.src =
  23. 'https://www.googletagmanager.com/gtm.js?id=' + i + dl; f.parentNode.insertBefore(j, f);
  24. })(window, document, 'script', 'dataLayer', 'GTM-MTWWP3G');</script>
  25. <!-- End Google Tag Manager -->
  26. <!-- Google tag (gtag.js) -->
  27. <script async src="https://www.googletagmanager.com/gtag/js?id=G-G5H9MMGQFM"></script>
  28. <script>
  29. window.dataLayer = window.dataLayer || [];
  30. function gtag() { dataLayer.push(arguments); }
  31. gtag('js', new Date());
  32. gtag('config', 'G-G5H9MMGQFM');
  33. </script>
  34. <!-- Global site tag (gtag.js) - Google Ads: 474336061 -->
  35. <script async src="https://www.googletagmanager.com/gtag/js?id=AW-474336061"></script>
  36. <script>
  37. window.dataLayer = window.dataLayer || [];
  38. function gtag() { dataLayer.push(arguments); }
  39. gtag('js', new Date());
  40. gtag('config', 'AW-474336061');
  41. </script>
  42. </head>
  43. <body>
  44. {{ partial "navbar.html" . }}
  45. <main id="global-yt">
  46. <img src="/imgs/dm/ai-video/SaaS-08.webp" alt="" class="img-fluid bg-img">
  47. <div class="container my-5 py-5 position-relative">
  48. <form id="ytForm" class="row g-3 justify-content-center">
  49. <p class="text-center">
  50. 請留下您的資訊
  51. </p>
  52. <div class="col-md-7 mb-3">
  53. <label for="email" class="form-label">
  54. 電子郵件:
  55. </label>
  56. <input type="email" class="form-control" id="email" placeholder="請輸入您的電子郵件地址" required>
  57. </div>
  58. <div class="col-md-7 mb-3">
  59. <label for="youtubeLink" class="form-label">
  60. YouTube 連結:
  61. </label>
  62. <input type="url" class="form-control" id="youtubeLink" placeholder="請貼上您的 YouTube 影片連結" required>
  63. </div>
  64. <div class="col-md-7 mt-4">
  65. <button onclick="sendYTData()" id="submitYTData" type="submit" class="btn btn-primary w-100">送出</button>
  66. </div>
  67. </form>
  68. <hr>
  69. <div class="content">
  70. {{ .Content }}
  71. </div>
  72. <div id="form">
  73. {{ partial "form-main.html" . }}
  74. </div>
  75. </div>
  76. </main>
  77. {{ partial "footer.html" . }}
  78. <script type="application/javascript">
  79. var doNotTrack = false;
  80. if (!doNotTrack) {
  81. (function (i, s, o, g, r, a, m) {
  82. i['GoogleAnalyticsObject'] = r; i[r] = i[r] || function () {
  83. (i[r].q = i[r].q || []).push(arguments)
  84. }, i[r].l = 1 * new Date(); a = s.createElement(o),
  85. m = s.getElementsByTagName(o)[0]; a.async = 1; a.src = g; m.parentNode.insertBefore(a, m)
  86. })(window, document, 'script', 'https://www.google-analytics.com/analytics.js', 'ga');
  87. ga('create', 'UA-153100602-5', 'auto');
  88. ga('send', 'pageview');
  89. }
  90. </script>
  91. <script src="https://cdn.jsdelivr.net/npm/@popperjs/core@2.9.2/dist/umd/popper.min.js"
  92. integrity="sha384-IQsoLXl5PILFhosVNubq5LC7Qb9DXgDA9i+tQ8Zj3iwWAwPtgFTxbJ8NT4GN1R8p"
  93. crossorigin="anonymous"></script>
  94. <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/js/bootstrap.min.js"
  95. integrity="sha384-cVKIPhGWiC2Al4u+LWgxfKTRIcfu0JTxR+EQDz/bgldoEyl4H0zUF0QKbrJ0EcQF"
  96. crossorigin="anonymous"></script>
  97. <script>
  98. function sendYTData() {
  99. event.preventDefault(); // 阻止表單自動送出
  100. const email = document.getElementById("email").value.trim();
  101. const ytLink = document.getElementById("youtubeLink").value.trim();
  102. const submitBtn = document.querySelector("#submitYTData");
  103. if (!email || !ytLink) {
  104. alert("請完整填寫電子郵件與 YouTube 連結");
  105. return;
  106. }
  107. // 顯示 Loading 狀態
  108. submitBtn.disabled = true;
  109. submitBtn.innerHTML = `<span class="spinner-border spinner-border-sm" role="status" aria-hidden="true"></span> 送出中...`;
  110. const data = {
  111. yt_link: ytLink,
  112. email: email
  113. };
  114. fetch("https://cmm.ai:10001/auth/add_yt_record", {
  115. method: "POST",
  116. headers: {
  117. "Content-Type": "application/json"
  118. },
  119. body: JSON.stringify(data)
  120. })
  121. .then(response => response.json())
  122. .then(result => {
  123. console.log("成功送出:", result);
  124. alert("您的資料已送出!");
  125. // 清空輸入框
  126. document.getElementById("email").value = "";
  127. document.getElementById("youtubeLink").value = "";
  128. })
  129. .catch(error => {
  130. console.error("送出失敗:", error);
  131. alert("送出失敗,請稍後再試!");
  132. })
  133. .finally(() => {
  134. // 恢復按鈕狀態
  135. submitBtn.disabled = false;
  136. submitBtn.innerHTML = "送出";
  137. });
  138. }
  139. </script>
  140. </body>
  141. </html>