index-designer.js 23 KB

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