index.js 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460
  1. let userAgent;
  2. let isSafari = false;
  3. let browserName;
  4. let filter;
  5. $('.likeSee__views').click(function() {
  6. window.location.href = './index_designerList.html'
  7. })
  8. $('.likeSee__sort').click(function() {
  9. window.location.href = './index_designerList.html?q=dateSort'
  10. })
  11. function getpathId(){
  12. let query = window.location.search.split('?').pop();
  13. return query.split('=')[1];
  14. }
  15. function getQuery() {
  16. let query = getpathId();
  17. if(query == 'dateSort'){
  18. filter = 'dateSort';
  19. } else {
  20. filter = 'views';
  21. }
  22. }
  23. getQuery();
  24. // pagination variables
  25. let num_per_page = 9;
  26. let n = 0;
  27. let totalPages = {
  28. intro: 0,
  29. video: 0,
  30. columns: 0,
  31. vr360: 0,
  32. company: 0,
  33. };
  34. window.onload = function(){
  35. if(screen.width < 900){
  36. window.location.href = "../index_designerList_mb.html";
  37. }
  38. userAgent = navigator.userAgent;
  39. detectBrowser(userAgent);
  40. detectDirection ();
  41. let result;
  42. let designer;
  43. let id = 0;
  44. $.ajax({
  45. method: "GET",
  46. url: "./json/realtime.json",
  47. dataType: "json",
  48. }).done(function (msg) {
  49. result = [...msg];
  50. renderSec00(result);
  51. });
  52. $.ajax({
  53. method: "GET",
  54. url: "./json/designers.json",
  55. dataType: "json",
  56. }).done(function (msg) {
  57. designer = [...msg][id];
  58. console.log(designer)
  59. designer['Content'][0]['Carddata'].sort(function (a, b){
  60. return a[filter] > b[filter]? -1:1;
  61. })
  62. console.log(designer['Content'][0]['Carddata']);
  63. renderinfoCard(designer)
  64. renderTab(designer['Content'])
  65. renderTabContent(designer['Content'])
  66. $(window).scroll(function() {
  67. loadMore(designer);
  68. })
  69. });
  70. }
  71. function detectDirection () {
  72. let height = (window.screen.width * 5) / 12;
  73. console.log(height);
  74. $('.sec-02 .slide-item').css('height', `${height}px`);
  75. }
  76. function detectBrowser(agent){
  77. if(userAgent.match(/chrome|chromium|crios/i)){
  78. browserName = "chrome";
  79. }else if(userAgent.match(/firefox|fxios/i)){
  80. browserName = "firefox";
  81. } else if(userAgent.match(/safari/i)){
  82. browserName = "safari";
  83. }else if(userAgent.match(/opr\//i)){
  84. browserName = "opera";
  85. } else if(userAgent.match(/edg/i)){
  86. browserName = "edge";
  87. }else{
  88. browserName="No browser detection";
  89. }
  90. if(browserName === 'safari'){
  91. isSafari = true;
  92. }
  93. console.log(isSafari);
  94. }
  95. function renderSec00(data) {
  96. let temp = data[0]['data'];
  97. renderBannerStr('sec-00__slider', temp);
  98. $(".sec-00__slider").slick({
  99. dots: false,
  100. speed: 800,
  101. autoplay: true,
  102. autoplaySpeed: 5000,
  103. arrows: true,
  104. prevArrow: '<button type="button" class="slick-prev"><i class="fas fa-chevron-left" style="font-size: 32px;color: white;transform: translateY(-10px);"></i></button>',
  105. nextArrow: '<button type="button" class="slick-next"><i class="fas fa-chevron-right" style="font-size: 32px;color: white;transform: translateY(-10px);"></i></button>'
  106. });
  107. }
  108. function renderBannerStr(sec, data) {
  109. let str = '';
  110. for(let i = 0; i < data.length; i++){
  111. if(data[i]['Dwebp'] && !isSafari) {
  112. 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>`
  113. } else {
  114. 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>`
  115. }
  116. }
  117. $(`.${sec}`).html(str);
  118. }
  119. function renderinfoCard(designer) {
  120. $('.hero__img').attr('src', designer['BannerImg']);
  121. $('.infoCard__avatar').css('backgroundImage', `url(${designer['Designerimg']})`)
  122. $('.infoCard__name').text(designer['DesignerName']);
  123. $('.infoCard__seo').text(designer['Description']);
  124. $('.infoCard__company').text(designer['CompanyName']);
  125. if(designer['Approve'] !== '') {
  126. $('.infoCard__approve').text(designer['Approve']);
  127. }
  128. // Basics
  129. let str = '';
  130. for(let i = 0;i < designer['Basics'].length; i ++) {
  131. str += `<aside class="d-flex">
  132. <div class="infoCard__detail__l">
  133. <div>${designer['Basics'][i].title}</div>
  134. </div>
  135. <div class="infoCard__detail__r">
  136. <a href="${designer['Basics'][i].link}">${designer['Basics'][i].data}</a>
  137. </div>
  138. </aside>`
  139. }
  140. $('.infoCard__basics').html(str);
  141. // Branches
  142. let otherStr = '';
  143. for(let i = 0;i < designer['Branches'].length; i ++) {
  144. otherStr += `<aside class="d-flex">
  145. <div class="infoCard__detail__l">
  146. <div>${designer['Branches'][i].title}</div>
  147. </div>
  148. <div class="infoCard__detail__r">
  149. <a href="${designer['Branches'][i].link}" >${designer['Branches'][i].data}</a>
  150. </div>
  151. </aside>`
  152. }
  153. $('.infoCard__branches').html(otherStr);
  154. // scMedia
  155. let mediaStr = '';
  156. for(let i = 0;i < designer['scMedia'].length; i ++) {
  157. if(i === 4) {
  158. mediaStr += `<span>
  159. <img src="${designer['scMedia'][i].img}" class="dislike" alt="">
  160. <img src="https://hhh.com.tw/assets/images/rv_web/like.svg" class="like" alt="">
  161. </span>`;
  162. } else {
  163. mediaStr += `<a href="${designer['scMedia'][i].link}">
  164. <img src="${designer['scMedia'][i].img}" alt="">
  165. </a>`;
  166. }
  167. }
  168. $('.scMedia').html(mediaStr);
  169. document.querySelector('.dislike').addEventListener('click', function() {
  170. $('.dislike').css('display', 'none');
  171. $('.like').css('display', 'block');
  172. })
  173. document.querySelector('.like').addEventListener('click', function() {
  174. $('.dislike').css('display', 'block');
  175. $('.like').css('display', 'none');
  176. })
  177. // term condition
  178. let termStr = '';
  179. for(let i = 0;i < designer['Terms'].length; i ++) {
  180. termStr += `<aside class="d-flex">
  181. <div class="infoCard__detail__l">
  182. <div>${designer['Terms'][i].title}</div>
  183. </div>
  184. <div class="infoCard__detail__r">
  185. <div>${designer['Terms'][i].data}</div>
  186. </div>
  187. </aside>`
  188. }
  189. $('.infoCard__terms').html(termStr);
  190. }
  191. function renderTab(content) {
  192. let tabTitleStr = '';
  193. for(let i = 0;i < content.length; i ++) {
  194. if(i == 0) {
  195. tabTitleStr += `<li class="nav-item p-0 active" role="presentation">
  196. <a class="nav-item-link nav-item-active bg-transparent active" id="pills-${content[i]['Tabtag']}-tab"
  197. data-bs-toggle="pill" data-bs-target="#pills-${content[i]['Tabtag']}" type="button" role="tab"
  198. aria-controls="pills-${content[i]['Tabtag']}" aria-selected="false" data-link="https://hhh.com.tw/videos/lists/">${content[i]['Title']}</a>
  199. </li>`
  200. } else {
  201. tabTitleStr += `<li class="nav-item p-0" role="presentation">
  202. <a class="nav-item-link nav-item-active bg-transparent" id="pills-${content[i]['Tabtag']}-tab"
  203. data-bs-toggle="pill" data-bs-target="#pills-${content[i]['Tabtag']}" type="button" role="tab"
  204. aria-controls="pills-${content[i]['Tabtag']}" aria-selected="false" data-link="https://hhh.com.tw/videos/lists/">${content[i]['Title']}</a>
  205. </li>`
  206. }
  207. }
  208. $('#pills-tab').html(tabTitleStr);
  209. $('.pill-aside').html(tabTitleStr);
  210. }
  211. function renderTabContent(content) {
  212. let tabStr = '';
  213. for(let i = 0;i < content.length; i ++) {
  214. let cardData = ''
  215. if(content[i].info) {
  216. for(let j = 0;j < content[i].info.length; j ++) {
  217. cardData += `<div class="company__block">
  218. <h4 class="company__title">${content[i].info[j].title}</h4>
  219. <div class="company__text">
  220. ${content[i].info[j].data}
  221. </div>
  222. </div>`
  223. }
  224. tabStr += `<div class="tab-pane fade " id="pills-${content[i]['Tabtag']}" role="tabpanel"
  225. aria-labelledby="pills-${content[i]['Tabtag']}-tab">
  226. <div class="row justfy-content-between">
  227. <div class="col-md-8">
  228. <article class="company__article">
  229. ${cardData}
  230. </article>
  231. </div>
  232. </div>
  233. </div>`
  234. } else {
  235. for(let j = 0;j < (content[i].Carddata.length < num_per_page? content[i].Carddata.length: num_per_page); j ++) {
  236. cardData += `<div class="col-md-4">
  237. <a href="" target="_blank">
  238. <div class="card">
  239. <div class="card__bgImg" style="background-image: url(${content[i].Carddata[j]['imgURL']});">
  240. </div>
  241. <div class="card-body">
  242. <h5 class="card-title card__title mt-0">${content[i].Carddata[j]['title']}</h5>
  243. <p class="card-text mb-0">
  244. <a href="" class="card__tag" target="_blank">混搭風</a>
  245. <a href="" class="card__tag" target="_blank">混搭風</a>
  246. <a href="" class="card__tag" target="_blank">混搭風</a>
  247. </p>
  248. </div>
  249. </div>
  250. </a>
  251. </div>`
  252. }
  253. tabStr += `<div class="tab-pane fade " id="pills-${content[i]['Tabtag']}" role="tabpanel"
  254. aria-labelledby="pills-${content[i]['Tabtag']}-tab">
  255. <div class="row work__row">
  256. ${cardData}
  257. </div>
  258. </div>`
  259. let key = content[i]['Tabtag'];
  260. totalPages[key] = content[i].Carddata.length;
  261. }
  262. }
  263. console.log(tabStr);
  264. console.log(totalPages);
  265. $('#pills-tabContent').html(tabStr);
  266. $('#pills-intro').addClass('active', 'show');
  267. $('#pills-intro').addClass('show');
  268. $('#pills-video .card__bgImg').append('<img src="https://hhh.com.tw/assets/images/rv_web/play.svg" alt="" width="50" height="50">')
  269. $('.infoContent .nav-item-link').click(checkTab);
  270. checkTab();
  271. }
  272. function checkTab() {
  273. if($('#pills-intro-tab').hasClass('active')) {
  274. $('.likeSee').attr('hidden', false)
  275. } else {
  276. $('.likeSee').attr('hidden', true)
  277. }
  278. }
  279. let sticky = document.querySelector('.sec-00').offsetHeight;
  280. window.addEventListener('scroll', fixedOnScroll);
  281. const navbar = document.querySelector('.navbar-main');
  282. function fixedOnScroll() {
  283. if(window.pageYOffset >= sticky){
  284. navbar.classList.add('sticky');
  285. } else {
  286. navbar.classList.remove('sticky');
  287. }
  288. }
  289. $(window).scroll(function() {
  290. if ( $(this).scrollTop() > 800 ){
  291. $('.fixed-btn').fadeIn(222);
  292. } else {
  293. $('.fixed-btn').stop().fadeOut(222);
  294. }
  295. }).scroll();
  296. function loadMore(designer) {
  297. let nowTab = document.querySelector('.infoContent .tab-pane.show')
  298. if(nowTab === document.querySelector('#pills-intro')) {
  299. let pageNum = Math.ceil(totalPages.intro / 9);
  300. if ($(this).scrollTop() > 1800) {
  301. if(n >= pageNum) {
  302. n = pageNum;
  303. return;
  304. } else {
  305. n ++;
  306. console.log('test');
  307. let append = '';
  308. let d = designer['Content'][0].Carddata.slice(9*n, (9*n)+9);
  309. for(let j = 0;j < d.length; j ++) {
  310. append += `<div class="col-md-4">
  311. <a href="" target="_blank">
  312. <div class="card">
  313. <div class="card__bgImg" style="background-image: url(${d[j]['imgURL']});">
  314. </div>
  315. <div class="card-body">
  316. <h5 class="card-title card__title mt-0">${d[j]['title']}</h5>
  317. <p class="card-text mb-0">
  318. <a href="" class="card__tag" target="_blank">混搭風</a>
  319. <a href="" class="card__tag" target="_blank">混搭風</a>
  320. <a href="" class="card__tag" target="_blank">混搭風</a>
  321. </p>
  322. </div>
  323. </div>
  324. </a>
  325. </div>`
  326. }
  327. $('#pills-intro .work__row').append(append);
  328. }
  329. }
  330. } else if (nowTab === document.querySelector('#pills-video')) {
  331. let pageNum = Math.ceil(totalPages.intro / 9);
  332. if ($(this).scrollTop() > 1800) {
  333. if(n >= pageNum) {
  334. n = pageNum;
  335. return;
  336. } else {
  337. n ++;
  338. console.log('test');
  339. let append = '';
  340. let d = designer['Content'][0].Carddata.slice(9*n, (9*n)+9);
  341. for(let j = 0;j < d.length; j ++) {
  342. append += `<div class="col-md-4">
  343. <a href="" target="_blank">
  344. <div class="card">
  345. <div class="card__bgImg" style="background-image: url(${d[j]['imgURL']});">
  346. </div>
  347. <div class="card-body">
  348. <h5 class="card-title card__title mt-0">${d[j]['title']}</h5>
  349. <p class="card-text mb-0">
  350. <a href="" class="card__tag" target="_blank">混搭風</a>
  351. <a href="" class="card__tag" target="_blank">混搭風</a>
  352. <a href="" class="card__tag" target="_blank">混搭風</a>
  353. </p>
  354. </div>
  355. </div>
  356. </a>
  357. </div>`
  358. }
  359. $('#pills-video .work__row').append(append);
  360. }
  361. }
  362. } else if (nowTab === document.querySelector('#pills-columns')) {
  363. let pageNum = Math.ceil(totalPages.intro / 9);
  364. if ($(this).scrollTop() > 1800) {
  365. if(n >= pageNum) {
  366. n = pageNum;
  367. return;
  368. } else {
  369. n ++;
  370. console.log('test');
  371. let append = '';
  372. let d = designer['Content'][0].Carddata.slice(9*n, (9*n)+9);
  373. for(let j = 0;j < d.length; j ++) {
  374. append += `<div class="col-md-4">
  375. <a href="" target="_blank">
  376. <div class="card">
  377. <div class="card__bgImg" style="background-image: url(${d[j]['imgURL']});">
  378. </div>
  379. <div class="card-body">
  380. <h5 class="card-title card__title mt-0">${d[j]['title']}</h5>
  381. <p class="card-text mb-0">
  382. <a href="" class="card__tag" target="_blank">混搭風</a>
  383. <a href="" class="card__tag" target="_blank">混搭風</a>
  384. <a href="" class="card__tag" target="_blank">混搭風</a>
  385. </p>
  386. </div>
  387. </div>
  388. </a>
  389. </div>`
  390. }
  391. $('#pills-columns .work__row').append(append);
  392. }
  393. }
  394. }
  395. }
  396. $('.btn-gotop').click(function () {
  397. $('html, body').animate({
  398. scrollTop: 0
  399. }, 500)
  400. });
  401. $('.sec-00__close').click(function(){
  402. $(this).css('display', 'none');
  403. $('.sec-00').addClass('bannerClose');
  404. //$('.sec-02').css('padding-top', '53px');
  405. sticky = 0;
  406. });
  407. document.addEventListener('lazybeforeunveil', function(e){
  408. var bg = e.target.getAttribute('data-bg');
  409. if(bg){
  410. e.target.style.backgroundImage = 'url(' + bg + ')';
  411. }
  412. });