index.js 13 KB

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