index-list-mb.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422
  1. let userAgent;
  2. let isSafari = false;
  3. let browserName;
  4. let num_per_page = 9;
  5. let n = 0;
  6. let totalPages = {
  7. intro: 0,
  8. video: 0,
  9. columns: 0,
  10. vr360: 0,
  11. company: 0,
  12. };
  13. let filter;
  14. const urlParams = new URLSearchParams(window.location.search);
  15. let getfilter = urlParams.get('q');
  16. let cid = urlParams.get('cid');
  17. console.log(getfilter, cid);
  18. $('.likeSee__views').click(function() {
  19. window.location.href = `./index_designerList_mb.html?q=views&cid=${cid}`
  20. $(this).css('color', '#EE7800');
  21. })
  22. $('.likeSee__sort').click(function() {
  23. window.location.href = `./index_designerList_mb.html?cid=${cid}`
  24. $(this).css('color', '#EE7800');
  25. })
  26. function getpathId(){
  27. let query = window.location.search.split('?').pop();
  28. return query.split('=')[1];
  29. }
  30. function getQuery() {
  31. let query = getfilter;
  32. console.log(query);
  33. if(query == 'views'){
  34. filter = 'views';
  35. $('.likeSee__views').css('color', '#EE7800');
  36. } else {
  37. filter = 'dateSort';
  38. $('.likeSee__sort').css('color', '#EE7800');
  39. }
  40. }
  41. window.onload = function(){
  42. //window.scrollBy(0, 1);
  43. if(screen.width >= 901){
  44. window.location.href = `../index_designerList.html?cid=${cid}`;
  45. }
  46. userAgent = navigator.userAgent;
  47. detectBrowser(userAgent);
  48. detectDirection ();
  49. let result;
  50. let designer;
  51. let id = 0;
  52. $.ajax({
  53. method: "GET",
  54. url: `./json/designers-${cid}.json`,
  55. dataType: "json",
  56. }).done(function (msg) {
  57. getQuery();
  58. designer = [...msg][id];
  59. console.log(designer['Content']);
  60. designer['Content'][0]['Carddata'].sort(function (a, b){
  61. return a[filter] > b[filter]? -1:1;
  62. })
  63. renderinfoCard(designer);
  64. renderTab(designer['Content']);
  65. renderTabContent(designer['Content']);
  66. renderModalTitle(designer['CompanyName']);
  67. console.log(filter);
  68. console.log(designer['Content'][0]['Carddata']);
  69. });
  70. }
  71. let over = document.querySelector('.infoContent__navBlock').offsetTop;
  72. function detectBrowser(agent){
  73. if(userAgent.match(/chrome|chromium|crios/i)){
  74. browserName = "chrome";
  75. }else if(userAgent.match(/firefox|fxios/i)){
  76. browserName = "firefox";
  77. } else if(userAgent.match(/safari/i)){
  78. browserName = "safari";
  79. }else if(userAgent.match(/opr\//i)){
  80. browserName = "opera";
  81. } else if(userAgent.match(/edg/i)){
  82. browserName = "edge";
  83. }else{
  84. browserName="No browser detection";
  85. }
  86. if(browserName === 'safari'){
  87. isSafari = true;
  88. }
  89. console.log(isSafari);
  90. }
  91. function detectDirection () {
  92. let height = (window.screen.width * 2) / 3;
  93. $('.sec-02 .slide-item').css('height', `${height}px`);
  94. let topHeight = (window.screen.width * 30) / 131;
  95. $('.sec-00 .slide-item').css('height', `${topHeight}px`);
  96. $('.sec-00 .container-fluid').css('height', `${topHeight}px`);
  97. }
  98. function renderinfoCard(designer) {
  99. $('.mb__hero__bgImg').attr('backgroundImage', `url(${designer['BannerImg']})`);
  100. $('.mb__infoCard__avatar').css('backgroundImage', `url(${designer['Designerimg']})`)
  101. $('.mb__infoCard__name').text(designer['DesignerName']);
  102. $('.mb__infoCard__seo').text(designer['Description']);
  103. $('.mb__infoCard__cmy').text(designer['CompanyName']);
  104. if(designer['Approve'] !== '') {
  105. $('.mb__infoCard__approve').text(designer['Approve']);
  106. }
  107. // Basics
  108. let str = '';
  109. for(let i = 0;i < designer['Basics'].length; i ++) {
  110. str += `<aside class="d-flex">
  111. <div class="mb__infoCard__detail__l">
  112. <div>${designer['Basics'][i].title}</div>
  113. </div>
  114. <div class="mb__infoCard__detail__r">
  115. <a href="${designer['Basics'][i].link}">${designer['Basics'][i].data}</a>
  116. </div>
  117. </aside>`
  118. }
  119. $('.mb__infoCard__basics').html(str);
  120. // Branches
  121. let otherStr = '';
  122. for(let i = 0;i < designer['Branches'].length; i ++) {
  123. otherStr += `<aside class="d-flex">
  124. <div class="mb__infoCard__detail__l">
  125. <div>${designer['Branches'][i].title}</div>
  126. </div>
  127. <div class="mb__infoCard__detail__r">
  128. <a href="${designer['Branches'][i].link}" >${designer['Branches'][i].data}</a>
  129. </div>
  130. </aside>`
  131. }
  132. $('.mb__infoCard__branches').html(otherStr);
  133. // scMedia
  134. let mediaStr = '';
  135. for(let i = 0;i < designer['scMedia'].length; i ++) {
  136. if(i === 4) {
  137. mediaStr += `<span>
  138. <img src="${designer['scMedia'][i].img}" class="dislike" alt="">
  139. <img src="https://hhh.com.tw/assets/images/rv_web/like.svg" class="like" alt="">
  140. </span>`;
  141. } else if (i === 3) {
  142. mediaStr += `<span class="send" data-bs-toggle="modal" data-bs-target="#emailModal">
  143. <img src="${designer['scMedia'][i].img}" alt="">
  144. </span>`;
  145. } else {
  146. mediaStr += `<a href="${designer['scMedia'][i].link}">
  147. <img src="${designer['scMedia'][i].img}" alt="">
  148. </a>`;
  149. }
  150. }
  151. $('.scMedia').html(mediaStr);
  152. document.querySelector('.dislike').addEventListener('click', function() {
  153. $('.dislike').css('display', 'none');
  154. $('.like').css('display', 'block');
  155. })
  156. document.querySelector('.like').addEventListener('click', function() {
  157. $('.dislike').css('display', 'block');
  158. $('.like').css('display', 'none');
  159. })
  160. // term condition
  161. let termStr = '';
  162. for(let i = 0;i < designer['Terms'].length; i ++) {
  163. termStr += `<aside class="d-flex">
  164. <div class="mb__infoCard__detail__l">
  165. <div>${designer['Terms'][i].title}</div>
  166. </div>
  167. <div class="mb__infoCard__detail__r">
  168. <div>${designer['Terms'][i].data}</div>
  169. </div>
  170. </aside>`
  171. }
  172. $('.mb__infoCard__terms').html(termStr);
  173. }
  174. function renderTab(content) {
  175. let tabTitleStr = '';
  176. for(let i = 0;i < content.length; i ++) {
  177. if(i == 0) {
  178. tabTitleStr += `<li class="nav-item p-0 active" role="presentation">
  179. <a class="nav-item-link nav-item-active bg-transparent active" id="pills-${content[i]['Tabtag']}-tab"
  180. data-bs-toggle="pill" data-bs-target="#pills-${content[i]['Tabtag']}" type="button" role="tab"
  181. aria-controls="pills-${content[i]['Tabtag']}" aria-selected="false" data-link="https://hhh.com.tw/videos/lists/">${content[i]['mb_title']}</a>
  182. </li>`
  183. } else if(content[i]['Display_mb']) {
  184. tabTitleStr += `<li class="nav-item p-0" role="presentation">
  185. <a class="nav-item-link nav-item-active bg-transparent" id="pills-${content[i]['Tabtag']}-tab"
  186. data-bs-toggle="pill" data-bs-target="#pills-${content[i]['Tabtag']}" type="button" role="tab"
  187. aria-controls="pills-${content[i]['Tabtag']}" aria-selected="false" data-link="https://hhh.com.tw/videos/lists/">${content[i]['mb_title']}</a>
  188. </li>`
  189. }
  190. }
  191. $('#pills-tab').html(tabTitleStr);
  192. $('.pill-aside').html(tabTitleStr);
  193. }
  194. function renderTabContent(content) {
  195. let tabStr = '';
  196. for(let i = 0;i < content.length; i ++) {
  197. let cardData = ''
  198. if(content[i].info) {
  199. for(let j = 0;j < content[i].info.length; j ++) {
  200. cardData += `<div class="company__block">
  201. <h4 class="company__title">${content[i].info[j].title}</h4>
  202. <div class="company__text">
  203. ${content[i].info[j].data}
  204. </div>
  205. </div>`
  206. }
  207. tabStr += `<div class="tab-pane fade " id="pills-${content[i]['Tabtag']}" role="tabpanel"
  208. aria-labelledby="pills-${content[i]['Tabtag']}-tab">
  209. <div class="row justfy-content-between">
  210. <div class="col-md-8">
  211. <article class="company__article">
  212. ${cardData}
  213. </article>
  214. </div>
  215. </div>
  216. </div>`
  217. } else {
  218. for(let j = 0;j < content[i].Carddata.length; j ++) {
  219. cardData += `<div class="col-6 col-md-4">
  220. <a href="" target="_blank">
  221. <div class="card">
  222. <div class="card__bgImg" style="background-image: url(${content[i].Carddata[j]['imgURL']});">
  223. </div>
  224. <div class="card-body">
  225. <h5 class="card-title card__title mt-0">${content[i].Carddata[j]['title']}</h5>
  226. <p class="card-text mb-0">
  227. <a href="" class="card__tag" target="_blank">混搭風</a>
  228. <a href="" class="card__tag" target="_blank">混搭風</a>
  229. <a href="" class="card__tag" target="_blank">混搭風</a>
  230. </p>
  231. </div>
  232. </div>
  233. </a>
  234. </div>`
  235. }
  236. if(content[i].Display_mb) {
  237. tabStr += `<div class="tab-pane fade " id="pills-${content[i]['Tabtag']}" role="tabpanel"
  238. aria-labelledby="pills-${content[i]['Tabtag']}-tab">
  239. <div class="row work__row">
  240. ${cardData}
  241. </div>
  242. </div>`
  243. let key = content[i]['Tabtag'];
  244. totalPages[key] = content[i].Carddata.length;
  245. }
  246. }
  247. }
  248. console.log(tabStr);
  249. //console.log(totalPages);
  250. $('#pills-tabContent').html(tabStr);
  251. $('#pills-tabContent').append('<div style="padding: 60px;"></div>');
  252. $('#pills-intro').addClass('active');
  253. $('#pills-intro').addClass('show');
  254. $('#pills-video .card__bgImg').append('<img src="https://hhh.com.tw/assets/images/rv_web/play.svg" alt="" width="50" height="50">')
  255. $('.infoContent .nav-item-link').click(checkTab);
  256. checkTab();
  257. }
  258. window.addEventListener('scroll', fixedOnScroll);
  259. const navBlock = document.querySelector('.infoContent__navBlock');
  260. function fixedOnScroll() {
  261. if(window.innerHeight < window.innerWidth){
  262. } else {
  263. detectDirection ();
  264. }
  265. if(window.pageYOffset >= over){
  266. navBlock.classList.add('tab_sticky');
  267. } else if(window.pageYOffset < over) {
  268. navBlock.classList.remove('tab_sticky');
  269. }
  270. }
  271. $('.navbar-toggler').click(function(){
  272. $(".sec-menu").css('display', 'block');
  273. $(".wholeBody").css('overflow-y', 'hidden');
  274. $('.sec-menu-block').addClass('slidein');
  275. $('.sec-menu-block').removeClass('slideout');
  276. });
  277. $('.navbar-back').click(function(){
  278. $(".sec-menu").css('display', 'none');
  279. $(".wholeBody").css('overflow-y', 'scroll');
  280. $('.sec-menu-block').removeClass('slidein');
  281. $('.sec-menu-block').addClass('slideout');
  282. });
  283. $('.subexpand').click(function(){
  284. $(this).parent().next().toggleClass('show');
  285. $(this).parent().toggleClass('show');
  286. });
  287. $('.navbar-search').click(function(){
  288. $(".sec-search").css('display', 'block');
  289. $(".wholeBody").css('overflow-y', 'hidden');
  290. })
  291. $('.navbar-backs').click(function(){
  292. $(".sec-search").css('display', 'none');
  293. $(".wholeBody").css('overflow-y', 'scroll');
  294. });
  295. $('.navbar-back-fav').click(function(){
  296. $(".sec-favor").css('display', 'none');
  297. })
  298. $('.btn-gotop').click(function () {
  299. $('html, body').animate({
  300. scrollTop: 0
  301. }, 500)
  302. });
  303. $(window).scroll(function() {
  304. if ( $(this).scrollTop() > 500 ){
  305. $('.fixed-btn').fadeIn(222);
  306. $('.freeCall').fadeIn(222);
  307. } else {
  308. $('.fixed-btn').stop().fadeOut(222);
  309. $('.freeCall').stop().fadeOut(222);
  310. }
  311. }).scroll();
  312. const searchBtn = document.querySelector('.searchBtn');
  313. const searchBar = document.querySelector('.searchBar');
  314. const searchHotLink = document.querySelectorAll('.sec-search-hots__link');
  315. searchBtn.addEventListener('click', search);
  316. searchBar.addEventListener('keyup', pressSearch);
  317. function search() {
  318. if(searchBar.value == '') {
  319. window.location.href = 'https://m.hhh.com.tw/search/lists/case/';
  320. } else {
  321. window.location.href = `https://m.hhh.com.tw/search/lists/case/${searchBar.value}-keyword/`;
  322. }
  323. }
  324. function pressSearch(e) {
  325. if (e.keyCode === 13) {
  326. e.preventDefault();
  327. search();
  328. }
  329. }
  330. searchHotLink.forEach((item, i) => {
  331. item.addEventListener('click', function() {
  332. window.location.href = `https://m.hhh.com.tw/search/lists/case/${this.textContent}-keyword/`;
  333. })
  334. })
  335. document.addEventListener('lazybeforeunveil', function(e){
  336. var bg = e.target.getAttribute('data-bg');
  337. if(bg){
  338. e.target.style.backgroundImage = 'url(' + bg + ')';
  339. }
  340. });
  341. $('.mb__infoCard__more').click(function() {
  342. $(this).hide();
  343. $('.other').css('display', 'block');
  344. over = document.querySelector('.infoContent__navBlock').offsetTop;
  345. })
  346. checkTab()
  347. $('.infoContent .nav-item-link').click(checkTab);
  348. function checkTab() {
  349. if($('#pills-intro-tab').hasClass('active')) {
  350. $('.likeSee').attr('hidden', false)
  351. } else {
  352. $('.likeSee').attr('hidden', true)
  353. }
  354. }
  355. function renderModalTitle(title) {
  356. $('#emailModal #title').val(title);
  357. }
  358. function putEmail() {
  359. 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,}))$/;
  360. if($('#email').val() !== null && emailPattern.test($('#email').val())) {
  361. $('#error').hide();
  362. $('#putEmail_hidden').css('display', 'block');
  363. $('#add_email').text($('#email').val());
  364. $('#email').val('');
  365. } else {
  366. $('#error').show();
  367. $('#error').text('email 格式有誤');
  368. }
  369. }