form2.html 9.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303
  1. <div class="news-form mt-5">
  2. <div class="text-center title">
  3. <h4>線上諮詢</h4>
  4. <p>與我們合作,馬上展開全新的創作里程碑</p>
  5. </div>
  6. <form>
  7. <div class="row mb-4">
  8. <label for="nameValue" class="col-md-2 col-lg-3 col-xl-2 col-form-label">
  9. <div class="d-flex flex-nowrap">
  10. 聯絡人 <span class="text-danger">*</span>
  11. </div>
  12. </label>
  13. <div class="col-md-10 col-lg-9 col-xl-10">
  14. <input type="text" class="form-control" id="nameValue" placeholder="請留下聯絡人姓名" required>
  15. </div>
  16. </div>
  17. <div class="row mb-4">
  18. <label for="phoneValue" class="col-md-2 col-lg-3 col-xl-2 col-form-label">
  19. <div class="d-flex flex-nowrap">
  20. 聯絡電話 <span class="text-danger">*</span>
  21. </div>
  22. </label>
  23. <div class="col-sm-4 col-md-3 col-lg-4 col-xl-3">
  24. <select id="countryCode" class="form-select">
  25. <option selected>選擇國碼</option>
  26. </select>
  27. </div>
  28. <div class="col-sm-8 col-md-7 col-lg-5 col-xl-7 mt-3 mt-sm-0">
  29. <input type="tel" class="form-control" id="phoneCode" placeholder="e.g., 988 888 888" required>
  30. </div>
  31. </div>
  32. <div class="row mb-4">
  33. <label for="companyValue" class="col-md-2 col-lg-3 col-xl-2 col-form-label">
  34. <div class="d-flex flex-nowrap">
  35. 公司名稱 <span class="text-danger">*</span>
  36. </div>
  37. </label>
  38. <div class="col-md-10 col-lg-9 col-xl-10">
  39. <input type="text" class="form-control" id="companyValue" placeholder="請留下公司名稱" required>
  40. </div>
  41. </div>
  42. <div class="row mb-4">
  43. <label for="companyValue" class="col-md-2 col-lg-3 col-xl-2 col-form-label">
  44. <div class="d-flex flex-nowrap">
  45. LINE ID
  46. </div>
  47. </label>
  48. <div class="col-md-10 col-lg-9 col-xl-10">
  49. <input type="text" class="form-control" id="lineidValue" placeholder="請留下 LINE ID">
  50. </div>
  51. </div>
  52. <div class="row mb-3">
  53. <label for="emailValue" class="col-md-2 col-lg-3 col-xl-2 col-form-label">
  54. <div class="d-flex flex-nowrap">
  55. 電子信箱 <span class="text-danger">*</span>
  56. </div>
  57. </label>
  58. <div class="col-md-10 col-lg-9 col-xl-10">
  59. <input type="email" class="form-control" id="emailValue" placeholder="請留下 E-mail" required>
  60. </div>
  61. <div class="invalid-feedback">
  62. Please choose a username.
  63. </div>
  64. </div>
  65. <div class="row mb-3">
  66. <label for="dateValue" class="col-md-2 col-lg-3 col-xl-2 col-form-label">
  67. <div class="d-flex flex-nowrap">
  68. 預計執行日期 <span class="text-danger">*</span>
  69. </div>
  70. </label>
  71. <div class="col-md-10 col-lg-9 col-xl-10 d-flex align-items-center">
  72. <input type="date" id="dateValue" name="dateValue" class="px-2"
  73. style="border:1px solid #ced4da; border-radius: 3px;" required />
  74. </div>
  75. </div>
  76. <div class="row mb-4">
  77. <label for="captionValue" class="col-md-2 col-lg-3 col-xl-2 col-form-label">
  78. <div class="d-flex flex-nowrap">
  79. 需求說明 <span class="text-danger">*</span>
  80. </div>
  81. </label>
  82. <div class="col-md-10 col-lg-9 col-xl-10">
  83. <textarea class="form-control" id="captionValue" rows="3" placeholder="請簡述說明" required></textarea>
  84. </div>
  85. </div>
  86. <div class="row">
  87. <div class="col-md-10 col-lg-9 col-xl-10 offset-sm-2">
  88. <div class="form-check">
  89. <input class="form-check-input mt-2" type="checkbox" id="agreeValue">
  90. <label class="form-check-label w-100" for="agreeValue">
  91. 本人同意集仕多搜集資料
  92. </label>
  93. </div>
  94. </div>
  95. </div>
  96. <div style="height: 15px;">
  97. <span class="errorText text-danger">尚有欄位未填寫</span>
  98. </div>
  99. <div class="d-flex justify-content-center mt-5">
  100. <button type="submit" class="submit-btn" id="submitBtn">
  101. <span class="spinner-border spinner-border-sm me-2 loading-btn" role="status" aria-hidden="true"></span>
  102. 提交
  103. </button>
  104. </div>
  105. </form>
  106. </div>
  107. <script src="//code.jquery.com/jquery-3.1.1.min.js" integrity="sha256-hVVnYaiADRTO2PzUGmuLJr8BLUSjGIZsDYGmIJLv2b8="
  108. crossorigin="anonymous"></script>
  109. <script src="https://cdn.jsdelivr.net/npm/@supabase/supabase-js@2"></script>
  110. <script type="module">
  111. import { createClient } from 'https://esm.sh/@supabase/supabase-js@2'
  112. const supabase = createClient('http://172.105.241.163:8000', 'eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyAgCiAgICAicm9sZSI6ICJzZXJ2aWNlX3JvbGUiLAogICAgImlzcyI6ICJzdXBhYmFzZS1kZW1vIiwKICAgICJpYXQiOiAxNjQxNzY5MjAwLAogICAgImV4cCI6IDE3OTk1MzU2MDAKfQ.DaYlNEoUrrEn2Ig7tqibS-PHK5vgusbcbo7X36XVt4Q');
  113. // 電話國碼
  114. const countryCodes = [
  115. '+1', // 美國
  116. '+7', // 俄羅斯
  117. '+33', // 法國
  118. '+39', // 義大利
  119. '+44', // 英國
  120. '+46', // 瑞典
  121. '+47', // 挪威
  122. '+49', // 德國
  123. '+52', // 墨西哥
  124. '+60', // 馬來西亞
  125. '+61', // 澳大利亞
  126. '+62', // 印尼
  127. '+64', // 紐西蘭
  128. '+65', // 新加坡
  129. '+66', // 泰國
  130. '+81', // 日本
  131. '+82', // 南韓
  132. '+86', // 中國大陸
  133. '+91', // 印度
  134. '+353', // 愛爾蘭
  135. '+852', // 香港
  136. '+853', // 澳門
  137. '+886', // 台灣
  138. ];
  139. console.log(countryCodes);
  140. const countryCode = document.getElementById('countryCode');
  141. countryCodes.forEach(code => {
  142. const option = document.createElement('option');
  143. option.value = code;
  144. option.text = code;
  145. countryCode.appendChild(option);
  146. });
  147. $('.errorText').hide();
  148. $('.loading-btn').hide();
  149. const scriptURL = 'https://script.google.com/macros/s/AKfycbzuwioqhnP2oL0AdHaYgEBvf0t0yWi2OTxZYlPYSoLuPyHhQFJKMm5mgOCoZEx-cIckbA/exec';
  150. async function send() {
  151. console.log('addEventListener');
  152. let name = document.querySelector('#nameValue').value; // 聯絡人
  153. let phone; // 聯絡電話
  154. let company = document.querySelector('#companyValue').value; // 公司名稱
  155. let email = document.querySelector('#emailValue').value; // 電子信箱
  156. // let demand; // 需求目的
  157. let caption = document.querySelector('#captionValue').value; // 需求說明
  158. let lineid = document.querySelector('#lineidValue').value; // 需求說明
  159. let date = document.querySelector('#dateValue').value; // 預計活動需求日
  160. let agree; // 搜集資料
  161. let time; // 填單時間
  162. // 取得當下時間
  163. const now = new Date();
  164. const options = { year: 'numeric', month: '2-digit', day: '2-digit', hour: '2-digit', minute: '2-digit' };
  165. time = now.toLocaleString('zh-TW', options);
  166. console.log('time', time);
  167. if (document.querySelector('input[id="agreeValue"]:checked')) {
  168. agree = "同意";
  169. } else {
  170. agree = "不同意";
  171. }
  172. // if (document.querySelector('input[name="demandValue"]:checked')) {
  173. // demand = document.querySelector('input[name="demandValue"]:checked').value;
  174. // }
  175. // if (demand === "其他") {
  176. // demand = document.querySelector('#otherText').value;
  177. // }
  178. let countryCode = document.querySelector('#countryCode').value; // 國碼
  179. let phoneCode = document.querySelector('#phoneCode').value; // 電話號碼
  180. phone = `${countryCode} ${phoneCode}`;
  181. const insertdata = {
  182. "name": name,
  183. "phone": phone,
  184. "company": company,
  185. "email": email,
  186. "lineid": lineid,
  187. "caption": caption,
  188. "date": date,
  189. "agree": agree,
  190. "time": time
  191. }
  192. console.log(insertdata);
  193. // const { data, error } = await supabase
  194. // .from('ai_news')
  195. // .insert([insertdata])
  196. // .then(({ data, error }) => {
  197. // if (error) {
  198. // console.error('插入数据时发生错误:', error);
  199. // } else {
  200. // $('.loading-btn').hide();
  201. // alert("成功提交!");
  202. // }
  203. // })
  204. // .catch(e => {
  205. // });
  206. // .select()
  207. $.ajax({
  208. url: scriptURL,
  209. method: "post",
  210. data: {
  211. "name": name,
  212. "phone": phone,
  213. "company": company,
  214. "email": email,
  215. "lineid": lineid,
  216. "caption": caption,
  217. "date": date,
  218. "agree": agree,
  219. "time": time
  220. },
  221. success: function (response) {
  222. if (response == "成功") {
  223. $('.loading-btn').hide();
  224. alert("成功提交!");
  225. }
  226. },
  227. });
  228. };
  229. $('button').on('click', function (e) {
  230. e.preventDefault();
  231. let countryCode = document.querySelector('#countryCode').value;
  232. // let demand = ""; // 需求目的
  233. // if (document.querySelector('input[name="demandValue"]:checked')) {
  234. // demand = document.querySelector('input[name="demandValue"]:checked').value;
  235. // }
  236. // if (demand === "其他") {
  237. // demand = document.querySelector('#otherText').value;
  238. // }
  239. // 手動觸發表單提交
  240. let form = $(this).closest('form');
  241. form[0].reportValidity(); // 顯示瀏覽器內建錯誤提示
  242. if (countryCode === "選擇國碼") {
  243. console.log('表單未通過驗證');
  244. $('.errorText').show();
  245. return;
  246. }
  247. if (form[0].reportValidity()) {
  248. $('.loading-btn').show();
  249. $('.errorText').hide();
  250. send();
  251. }
  252. });
  253. </script>