index-designer.js 24 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617
  1. let userAgent;
  2. let isSafari = false;
  3. let browserName;
  4. let filter;
  5. const urlParams = new URLSearchParams(window.location.search);
  6. let getfilter = urlParams.get('q');
  7. let cid = urlParams.get('cid');
  8. console.log(getfilter, cid);
  9. $('.likeSee__views').click(function() {
  10. window.location.href = `./index_designerList.html?q=views&cid=${cid}`
  11. $(this).css('color', '#EE7800');
  12. })
  13. $('.likeSee__sort').click(function() {
  14. window.location.href = `./index_designerList.html?cid=${cid}`
  15. $(this).css('color', '#EE7800');
  16. })
  17. function getQuery() {
  18. let query = getfilter;
  19. if(query == 'views'){
  20. filter = 'views';
  21. $('.likeSee__views').css('color', '#EE7800');
  22. } else {
  23. filter = 'dateSort';
  24. $('.likeSee__sort').css('color', '#EE7800');
  25. }
  26. }
  27. getQuery();
  28. // group data
  29. function group(data) {
  30. var result = [];
  31. var groupItem;
  32. for (var i = 0; i < data.length; i++ ) {
  33. if (i % 18 == 0) {
  34. groupItem != null && result.push(groupItem);
  35. groupItem = [];
  36. }
  37. groupItem.push(data[i]);
  38. }
  39. result.push(groupItem);
  40. return result;
  41. }
  42. // pagination variables
  43. let num_per_page = 9;
  44. let n = 0;
  45. let n_video = 0;
  46. let n_columns = 0;
  47. let totalPages = {
  48. intro: 0,
  49. video: 0,
  50. columns: 0,
  51. vr360: 0,
  52. company: 0,
  53. };
  54. window.onload = function(){
  55. if(screen.width < 600){
  56. window.location.href = `../index_designerList_mb.html?cid=${cid}`;
  57. }
  58. userAgent = navigator.userAgent;
  59. detectBrowser(userAgent);
  60. detectDirection ();
  61. let result;
  62. let designer;
  63. let id = 0;
  64. $.ajax({
  65. method: "GET",
  66. url: "./json/realtime.json",
  67. dataType: "json",
  68. }).done(function (msg) {
  69. result = [...msg];
  70. renderSec00(result);
  71. });
  72. $.ajax({
  73. method: "GET",
  74. url: `./json/designers-${cid}.json`,
  75. dataType: "json",
  76. }).done(function (msg) {
  77. designer = [...msg][0];
  78. console.log(designer)
  79. if(filter == 'views'){
  80. designer['Content'][0]['Carddata'].sort(function (a, b){
  81. return a[filter] > b[filter]? -1:1;
  82. })
  83. } else {
  84. designer['Content'][0]['Carddata'].sort(function (a, b){
  85. return a[filter] > b[filter]? 1:-1;
  86. })
  87. }
  88. for(let i = 0; i < designer['Content'].length; i++){
  89. let testArr = group(designer['Content'][i]['Carddata']);
  90. console.log(testArr);
  91. }
  92. console.log(designer['Content'][0]['Carddata']);
  93. renderinfoCard(designer);
  94. renderTab(designer['Content']);
  95. renderTabContent(designer['Content'], designer);
  96. renderModalTitle(designer['CompanyName']);
  97. $(window).scroll(function() {
  98. loadMore(designer);
  99. })
  100. });
  101. }
  102. function detectDirection () {
  103. let height = (window.screen.width * 5) / 12;
  104. console.log(height);
  105. $('.sec-02 .slide-item').css('height', `${height}px`);
  106. }
  107. function detectBrowser(agent){
  108. if(userAgent.match(/chrome|chromium|crios/i)){
  109. browserName = "chrome";
  110. }else if(userAgent.match(/firefox|fxios/i)){
  111. browserName = "firefox";
  112. } else if(userAgent.match(/safari/i)){
  113. browserName = "safari";
  114. }else if(userAgent.match(/opr\//i)){
  115. browserName = "opera";
  116. } else if(userAgent.match(/edg/i)){
  117. browserName = "edge";
  118. }else{
  119. browserName="No browser detection";
  120. }
  121. if(browserName === 'safari'){
  122. isSafari = true;
  123. }
  124. console.log(isSafari);
  125. }
  126. function renderSec00(data) {
  127. let temp = data[0]['data'];
  128. renderBullet(temp);
  129. renderBannerStr('sec-00__slider', temp);
  130. $(".sec-00__slider").slick({
  131. dots: false,
  132. speed: 500,
  133. autoplay: true,
  134. autoplaySpeed: 4000,
  135. arrows: true,
  136. prevArrow: '<button type="button" class="slick-prev"><i class="fas fa-chevron-left" style="font-size: 32px;color: white;transform: translateY(-10px);"></i></button>',
  137. nextArrow: '<button type="button" class="slick-next"><i class="fas fa-chevron-right" style="font-size: 32px;color: white;transform: translateY(-10px);"></i></button>'
  138. });
  139. $('.sec-00__bullet').removeClass('bullet-active');
  140. $('.sec-00__bullet').eq($('.slick-active').data('slick-index')).addClass('bullet-active');
  141. // $('.sec-00__slider').on('beforeChange', function(event, slick, currentSlide, nextSlide){
  142. // console.log(currentSlide);
  143. // console.log($('.slick-active').data('slick-index'));
  144. // });
  145. $('.sec-00__slider').on('afterChange', function(event, slick, currentSlide){
  146. console.log(currentSlide);
  147. console.log($('.slick-active').data('slick-index'));
  148. $('.sec-00__bullet').removeClass('bullet-active');
  149. $('.sec-00__bullet').eq(currentSlide).addClass('bullet-active');
  150. });
  151. }
  152. function renderBullet(data) {
  153. let str = '';
  154. for(let i = 0; i < data.length; i++){
  155. str += '<div class="sec-00__bullet"></div>'
  156. }
  157. console.log('bullet');
  158. $('.sec-00__bulletList').html(str);
  159. }
  160. // function renderBannerStr(sec, data) {
  161. // let str = '';
  162. // for(let i = 0; i < data.length; i++){
  163. // if(data[i]['Dwebp'] && !isSafari) {
  164. // str+= `<div class="${sec}-${i+1} slide-item" onclick="window.open('${data[i]['link']}');" style="background-image: url('${data[i]['Dwebp']}');" data-bg="${data[i]['Dwebp']}"></div>`
  165. // } else {
  166. // str+= `<div class="${sec}-${i+1} slide-item" onclick="window.open('${data[i]['link']}');" style="background-image: url('${data[i]['DimgUrl']}');" data-bg="${data[i]['DimgUrl']}"></div>`
  167. // }
  168. // }
  169. // $(`.${sec}`).html(str);
  170. // }
  171. function renderBannerStr(sec, data) {
  172. let str = '';
  173. for(let i = 0; i < data.length; i++){
  174. if(data[i]['Dwebp'] && !isSafari) {
  175. str+= `<img class="${sec}-${i+1} slide-item img-fluid" src="${data[i]['Dwebp']}" onclick="window.open('${data[i]['link']}');" data-bg="${data[i]['Dwebp']}">`
  176. } else {
  177. str+= `<img class="${sec}-${i+1} slide-item img-fluid" src="${data[i]['DimgUrl']}" onclick="window.open('${data[i]['link']}');" data-bg="${data[i]['DimgUrl']}">`
  178. }
  179. }
  180. $(`.${sec}`).html(str);
  181. }
  182. function renderinfoCard(designer) {
  183. $('.hero__img').attr('src', designer['BannerImg']);
  184. $('.infoCard__avatar').css('backgroundImage', `url(${designer['Designerimg']})`)
  185. $('.infoCard__name').text(designer['DesignerName']);
  186. $('.infoCard__seo').text(designer['Description']);
  187. $('.infoCard__company').text(designer['CompanyName']);
  188. if(designer['Approve'] !== '') {
  189. $('.infoCard__approve').text(designer['Approve']);
  190. }
  191. // Basics
  192. let str = '';
  193. for(let i = 0;i < designer['Basics'].length; i ++) {
  194. str += `<aside class="d-flex">
  195. <div class="infoCard__detail__l">
  196. <div>${designer['Basics'][i].title}</div>
  197. </div>
  198. <div class="infoCard__detail__r">
  199. <a href="${designer['Basics'][i].link}">${designer['Basics'][i].data}</a>
  200. </div>
  201. </aside>`
  202. }
  203. $('.infoCard__basics').html(str);
  204. // Branches
  205. let otherStr = '';
  206. for(let i = 0;i < designer['Branches'].length; i ++) {
  207. otherStr += `<aside class="d-flex">
  208. <div class="infoCard__detail__l">
  209. <div>${designer['Branches'][i].title}</div>
  210. </div>
  211. <div class="infoCard__detail__r">
  212. <a href="${designer['Branches'][i].link}" >${designer['Branches'][i].data}</a>
  213. </div>
  214. </aside>`
  215. }
  216. $('.infoCard__branches').html(otherStr);
  217. // scMedia
  218. let mediaStr = '';
  219. for(let i = 0;i < designer['scMedia'].length; i ++) {
  220. if(i === 4) {
  221. mediaStr += `<span>
  222. <img src="${designer['scMedia'][i].img}" class="dislike" alt="">
  223. <img src="https://hhh.com.tw/assets/images/rv_web/like.svg" class="like" alt="">
  224. </span>`;
  225. } else if (i === 3) {
  226. mediaStr += `<span class="send" data-bs-toggle="modal" data-bs-target="#emailModal">
  227. <img src="${designer['scMedia'][i].img}" alt="">
  228. </span>`;
  229. }
  230. else {
  231. mediaStr += `<a href="${designer['scMedia'][i].link}">
  232. <img src="${designer['scMedia'][i].img}" alt="">
  233. </a>`;
  234. }
  235. }
  236. $('.scMedia').html(mediaStr);
  237. document.querySelector('.dislike').addEventListener('click', function() {
  238. $('.dislike').css('display', 'none');
  239. $('.like').css('display', 'block');
  240. })
  241. document.querySelector('.like').addEventListener('click', function() {
  242. $('.dislike').css('display', 'block');
  243. $('.like').css('display', 'none');
  244. })
  245. // term condition
  246. let termStr = '';
  247. for(let i = 0;i < designer['Terms'].length; i ++) {
  248. termStr += `<aside class="d-flex">
  249. <div class="infoCard__detail__l">
  250. <div>${designer['Terms'][i].title}</div>
  251. </div>
  252. <div class="infoCard__detail__r">
  253. <div>${designer['Terms'][i].data}</div>
  254. </div>
  255. </aside>`
  256. }
  257. $('.infoCard__terms').html(termStr);
  258. }
  259. function renderTab(content) {
  260. let tabTitleStr = '';
  261. for(let i = 0;i < content.length; i ++) {
  262. if(i == 0) {
  263. tabTitleStr += `<li class="nav-item p-0 " role="presentation">
  264. <a class="nav-item-link nav-item-active bg-transparent active" id="pills-${content[i]['Tabtag']}-tab"
  265. data-bs-toggle="pill" data-bs-target="#pills-${content[i]['Tabtag']}" type="button" role="tab"
  266. aria-controls="pills-${content[i]['Tabtag']}" aria-selected="false" data-link="https://hhh.com.tw/videos/lists/">${content[i]['Title']}</a>
  267. </li>`
  268. } else if (content[i]['isActive']) {
  269. tabTitleStr += `<li class="nav-item p-0" role="presentation">
  270. <a class="nav-item-link nav-item-active bg-transparent" id="pills-${content[i]['Tabtag']}-tab"
  271. data-bs-toggle="pill" data-bs-target="#pills-${content[i]['Tabtag']}" type="button" role="tab"
  272. aria-controls="pills-${content[i]['Tabtag']}" aria-selected="false" data-link="https://hhh.com.tw/videos/lists/">${content[i]['Title']}</a>
  273. </li>`
  274. }
  275. }
  276. $('#pills-tab').html(tabTitleStr);
  277. $('.pill-aside').html(tabTitleStr);
  278. }
  279. function renderCard(content, i = 0){
  280. let cardData = '';
  281. let data = content[i];
  282. for(let j = 0;j < data.length; j ++) {
  283. cardData += `<div class="col-md-4">
  284. <a href="" target="_blank">
  285. <div class="card">
  286. <div class="card__bgImg" style="background-image: url(${data[i]['imgURL']});">
  287. </div>
  288. <div class="card-body">
  289. <h5 class="card-title card__title mt-0">${data[i]['title']}</h5>
  290. <p class="card-text mb-0">
  291. <a href="" class="card__tag" target="_blank">混搭風</a>
  292. <a href="" class="card__tag" target="_blank">混搭風</a>
  293. <a href="" class="card__tag" target="_blank">混搭風</a>
  294. </p>
  295. </div>
  296. </div>
  297. </a>
  298. </div>`
  299. $('#pills-intro .work__row').append(cardData);
  300. }
  301. }
  302. function renderTabContent(content, meta) {
  303. let tabStr = '';
  304. for(let i = 0;i < content.length; i ++) {
  305. let cardData = ''
  306. if(content[i].info) {
  307. for(let j = 0;j < content[i].info.length; j ++) {
  308. cardData += `<div class="company__block">
  309. <h4 class="company__title">${content[i].info[j].title}</h4>
  310. <div class="company__text">
  311. ${content[i].info[j].data}
  312. </div>
  313. </div>`
  314. }
  315. tabStr += `<div class="tab-pane fade " id="pills-${content[i]['Tabtag']}" role="tabpanel"
  316. aria-labelledby="pills-${content[i]['Tabtag']}-tab">
  317. <div class="row justfy-content-between">
  318. <div class="col-md-8">
  319. <article class="company__article">
  320. ${cardData}
  321. </article>
  322. </div>
  323. <div class="col-md-4 fb__block">
  324. <div id="fb-container">
  325. <div class="fb-page" data-href="${meta['FB_link']}" data-tabs="timeline" data-width="320" data-height="700" data-small-header="false" data-adapt-container-width="true" data-hide-cover="false" data-show-facepile="true">
  326. <blockquote cite="${meta['FB_link']}" class="fb-xfbml-parse-ignore">
  327. <a href="${meta['FB_link']}">${meta['CompanyName']}</a>
  328. </blockquote>
  329. </div>
  330. </div>
  331. </div>
  332. </div>
  333. <script async defer crossorigin="anonymous" src="https://connect.facebook.net/zh_TW/sdk.js#xfbml=1&version=v9.0" nonce="7TsDzQN7"></script>
  334. `
  335. } else {
  336. for(let j = 0;j < (content[i].Carddata.length < num_per_page? content[i].Carddata.length: num_per_page); j ++) {
  337. // for(let j = 0;j < content[i].Carddata.length; j ++) {
  338. let tagStr = '';
  339. for(let k = 0;k < content[i].Carddata[j].tags.length; k ++) {
  340. tagStr += `<a href="${content[i].Carddata[j].tags[k]['link']}" class="card__tag" target="_blank">${content[i].Carddata[j].tags[k]['name']}</a>`
  341. }
  342. cardData += `<div class="col-lg-6 col-xl-4">
  343. <a href="" target="_blank">
  344. <div class="card">
  345. <div class="card__bgImg" style="background-image: url(${content[i].Carddata[j]['imgURL']});">
  346. </div>
  347. <div class="card-body">
  348. <h5 class="card-title card__title mt-0">${content[i].Carddata[j]['title']}</h5>
  349. <p class="card-text mb-0">
  350. ${tagStr}
  351. </p>
  352. </div>
  353. </div>
  354. </a>
  355. </div>`
  356. }
  357. tabStr += `<div class="tab-pane fade " id="pills-${content[i]['Tabtag']}" role="tabpanel"
  358. aria-labelledby="pills-${content[i]['Tabtag']}-tab">
  359. <div class="row work__row">
  360. ${cardData}
  361. </div>
  362. </div>`
  363. let key = content[i]['Tabtag'];
  364. totalPages[key] = content[i].Carddata.length;
  365. }
  366. }
  367. console.log(tabStr);
  368. console.log(totalPages);
  369. $('#pills-tabContent').html(tabStr);
  370. $('#pills-tabContent').append('<div style="padding: 40px;"></div>');
  371. $('#pills-intro').addClass('active');
  372. $('#pills-intro').addClass('show');
  373. $('#pills-video .card__bgImg').append('<img src="https://hhh.com.tw/assets/images/rv_web/play.svg" alt="" width="50" height="50">')
  374. $('.infoContent .nav-item-link').click(checkTab);
  375. checkTab();
  376. }
  377. function renderFB(data) {
  378. let str = '';
  379. for(let i = 0; i < data.length; i++){
  380. }
  381. $('.fb__block').html(str);
  382. }
  383. function checkTab() {
  384. if($('#pills-intro-tab').hasClass('active')) {
  385. $('.likeSee').attr('hidden', false)
  386. } else {
  387. $('.likeSee').attr('hidden', true)
  388. }
  389. }
  390. $(document).on("click","#pills-tab .nav-item-link",function() {
  391. console.log($(this));
  392. console.log($(this).attr('id'));
  393. let className = $(this).attr('id');
  394. $(`#pills-tab .nav-item-link`).removeClass('active');
  395. $(`#${className}`).addClass('active');
  396. $(`.pill-aside #${className}`).addClass('active');
  397. });
  398. let sticky = document.querySelector('.sec-00').offsetHeight;
  399. window.addEventListener('scroll', fixedOnScroll);
  400. const navbar = document.querySelector('.navbar-main');
  401. function fixedOnScroll() {
  402. if(window.pageYOffset >= 344){
  403. navbar.classList.add('sticky');
  404. } else {
  405. navbar.classList.remove('sticky');
  406. }
  407. }
  408. $(window).scroll(function() {
  409. if ( $(this).scrollTop() > 800 ){
  410. $('.fixed-btn').fadeIn(222);
  411. } else {
  412. $('.fixed-btn').stop().fadeOut(222);
  413. }
  414. }).scroll();
  415. function loadMore(designer) {
  416. let nowTab = document.querySelector('.infoContent .tab-pane.show');
  417. if(nowTab === document.querySelector('#pills-intro')) {
  418. let last = document.querySelector('#pills-intro .work__row>div:last-child');
  419. let pageNum = Math.ceil(totalPages.intro / 9) - 1;
  420. if ($(this).scrollTop() > last.offsetTop) {
  421. console.log('over');
  422. if(n >= pageNum) {
  423. n = pageNum;
  424. return;
  425. } else {
  426. n ++;
  427. let append = '';
  428. let d = designer['Content'][0].Carddata.slice(9*n, (9*n)+9);
  429. for(let j = 0;j < d.length; j ++) {
  430. append += `<div class="col-lg-6 col-xl-4">
  431. <a href="" target="_blank">
  432. <div class="card">
  433. <div class="card__bgImg" style="background-image: url(${d[j]['imgURL']});">
  434. </div>
  435. <div class="card-body">
  436. <h5 class="card-title card__title mt-0">${d[j]['title']}</h5>
  437. <p class="card-text mb-0">
  438. <a href="" class="card__tag" target="_blank">混搭風</a>
  439. <a href="" class="card__tag" target="_blank">混搭風</a>
  440. <a href="" class="card__tag" target="_blank">混搭風</a>
  441. </p>
  442. </div>
  443. </div>
  444. </a>
  445. </div>`
  446. }
  447. $('#pills-intro .work__row').append(append);
  448. }
  449. }
  450. } else if (nowTab === document.querySelector('#pills-video')) {
  451. let pageNum = Math.ceil(totalPages.video / 9) - 1;
  452. console.log(totalPages.video);
  453. let last = document.querySelector('#pills-video .work__row>div:last-child');
  454. if ($(this).scrollTop() > last.offsetTop) {
  455. if(n_video >= pageNum) {
  456. n_video = pageNum;
  457. console.log('n-video:', n_video);
  458. console.log('pageNum', pageNum);
  459. return;
  460. } else {
  461. console.log('pass-video');
  462. n_video ++;
  463. console.log('test');
  464. let append = '';
  465. let d = designer['Content'][1].Carddata.slice(9*n_video, (9*n_video)+9);
  466. for(let j = 0;j < d.length; j ++) {
  467. append += `<div class="col-lg-6 col-xl-4">
  468. <a href="" target="_blank">
  469. <div class="card">
  470. <div class="card__bgImg" style="background-image: url(${d[j]['imgURL']});">
  471. <img src="https://hhh.com.tw/assets/images/rv_web/play.svg" alt="" width="50" height="50">
  472. </div>
  473. <div class="card-body">
  474. <h5 class="card-title card__title mt-0">${d[j]['title']}</h5>
  475. <p class="card-text mb-0">
  476. <a href="" class="card__tag" target="_blank">混搭風</a>
  477. <a href="" class="card__tag" target="_blank">混搭風</a>
  478. <a href="" class="card__tag" target="_blank">混搭風</a>
  479. </p>
  480. </div>
  481. </div>
  482. </a>
  483. </div>`
  484. }
  485. $('#pills-video .work__row').append(append);
  486. }
  487. }
  488. } else if (nowTab === document.querySelector('#pills-columns')) {
  489. let last = document.querySelector('#pills-columns .work__row>div:last-child');
  490. let pageNum = Math.ceil(totalPages.columns / 9) - 1;
  491. if ($(this).scrollTop() > last) {
  492. if(n_columns >= pageNum) {
  493. n_columns = pageNum;
  494. return;
  495. } else {
  496. n_columns ++;
  497. console.log('test');
  498. let append = '';
  499. let d = designer['Content'][2].Carddata.slice(9*n_columns, (9*n_columns)+9);
  500. for(let j = 0;j < d.length; j ++) {
  501. append += `<div class="col-lg-6 col-xl-4">
  502. <a href="" target="_blank">
  503. <div class="card">
  504. <div class="card__bgImg" style="background-image: url(${d[j]['imgURL']});">
  505. </div>
  506. <div class="card-body">
  507. <h5 class="card-title card__title mt-0">${d[j]['title']}</h5>
  508. <p class="card-text mb-0">
  509. <a href="" class="card__tag" target="_blank">混搭風</a>
  510. <a href="" class="card__tag" target="_blank">混搭風</a>
  511. <a href="" class="card__tag" target="_blank">混搭風</a>
  512. </p>
  513. </div>
  514. </div>
  515. </a>
  516. </div>`
  517. }
  518. $('#pills-columns .work__row').append(append);
  519. }
  520. }
  521. }
  522. }
  523. $('.btn-gotop').click(function () {
  524. $('html, body').animate({
  525. scrollTop: 0
  526. }, 500)
  527. });
  528. $('.sec-00__close').click(function(){
  529. $(this).css('display', 'none');
  530. $('.sec-00').addClass('bannerClose');
  531. //$('.sec-02').css('padding-top', '53px');
  532. sticky = 0;
  533. });
  534. document.addEventListener('lazybeforeunveil', function(e){
  535. var bg = e.target.getAttribute('data-bg');
  536. if(bg){
  537. e.target.style.backgroundImage = 'url(' + bg + ')';
  538. }
  539. });
  540. function renderModalTitle(title) {
  541. $('#emailModal #title').val(title);
  542. }
  543. function putEmail() {
  544. const emailPattern = /^(([^<>()[\]\\.,;:\s@"]+(\.[^<>()[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
  545. if($('#email').val() !== null && emailPattern.test($('#email').val())) {
  546. $('#error').hide();
  547. $('#putEmail_hidden').css('display', 'block');
  548. $('#add_email').text($('#email').val());
  549. $('#email').val('');
  550. } else {
  551. $('#error').show();
  552. $('#error').text('email 格式有誤');
  553. }
  554. }