SearchLayerMob.html 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561
  1. <!DOCTYPE html>
  2. <html lang="ko"
  3. xmlns:th="http://www.thymeleaf.org">
  4. <!--
  5. *******************************************************************************
  6. * @source : SearchLayerMob.html
  7. * @desc : 검색 레이어 Page
  8. *============================================================================
  9. * STYLE24
  10. * Copyright(C) 2020 TSIT, All rights reserved.
  11. *============================================================================
  12. * VER DATE AUTHOR DESCRIPTION
  13. * === =========== ========== =============================================
  14. * 1.0 2021.06.14 bin2107 최초 작성
  15. *******************************************************************************
  16. -->
  17. <body>
  18. <div class="modal-dialog" role="document">
  19. <div class="modal-content">
  20. <div class="modal-header htop">
  21. <h5 class="modal-title sr-only" id="schPopLabel">통합검색</h5>
  22. </div>
  23. <div class="modal-body">
  24. <section class="sch_result">
  25. <!-- 1.통합검색 default -->
  26. <div class="inner">
  27. <form id="searchMainForm" name="searchMainForm">
  28. <input type="hidden" name="brandGroupNo" th:value="${brandGroupNo}"/>
  29. <div class="sch_title">
  30. <input type="text" class="form_control" name="keyword" placeholder="검색어를 입력하세요." autocomplete="off" onkeyup="fnOnkeyupKeyword(this);">
  31. <button type="button" class="btn_x" id="deleteKeyword" style="display:none;">X</button>
  32. <button type="button" class="btn_sch" id="btnSearchKeyword"><img th:src="${@environment.getProperty('domain.uximage')} + '/images/mo/ico_btn_search.png'" alt=""></button>
  33. </div>
  34. </form>
  35. </div>
  36. <div class="inner default_box" id="defaultArea">
  37. <div class="filter-list">
  38. <div class="f_left">
  39. <h3>최근 검색어</h3>
  40. </div>
  41. <div class="f_right">
  42. </div>
  43. </div>
  44. <div class="search-list" th:classappend="${#lists.isEmpty(recentlyKeywordList)?'nodata':''}"> <!-- 검색데이터 없을시 nodata 클래스 추가. -->
  45. <ul>
  46. <li th:if="${recentlyKeywordList}" th:each="oneData, status : ${recentlyKeywordList}">
  47. <a href="javascript:void(0);" th:onclick="fnSearchKeyword([[${oneData}]])">
  48. <p th:text="${oneData}"></p>
  49. </a>
  50. <button type="button" class="xBtn" th:onclick="fnDeleteCookie(this,[[${oneData}]]);"><span>삭제</span></button>
  51. </li>
  52. </ul>
  53. <p class="nodata_txt" th:if="${#lists.isEmpty(recentlyKeywordList)}">최근 검색어가 없습니다.</p>
  54. </div>
  55. <h3 class="hot-key" th:if="${brandGroupNo==null}">STYLE24에서 검색되고 있어요</h3>
  56. <div class="related_keyword" th:if="${brandGroupNo==null}">
  57. <div class="sub_category">
  58. <div class="cate_wrap" id="popularKeyArea">
  59. <!-- <a href="javascript:;" class="on">전체</a>-->
  60. </div>
  61. </div>
  62. </div>
  63. </div>
  64. <!-- //1.통합검색 default -->
  65. <!-- 3.지금 많이 보고 있어요 상품. -->
  66. <!--820임시주석 <div class="inner default_box" id="popularArea">
  67. <div class="now_view">
  68. <div class="store_product">
  69. <div class="allresult-tit">
  70. <h3>지금 많이 보고 있어요</h3>
  71. <button type="button" class="btn_refresh" onclick="fnRealtimeGoodsList();"><span th:text="${#calendars.format(#calendars.createNow(), 'HH:mm')}">17:30</span> 기준</button>
  72. </div>
  73. <div class="swiper-container sch_product">
  74. <div class="swiper-wrapper" id="itemViewArea">
  75. <th:block th:each="item, status : ${realtimeGoodsList}">
  76. <div class="swiper-slide">
  77. <div class="item_prod">
  78. <button type="button" class="itemLike" th:classappend="${item.wishCnt > 0}? 'likeit' : ''" onclick="cfnMoPutWishList(this);" th:attr="goodsCd=${item.itemId}">관심상품 추가</button>
  79. <a th:href="${item.itemUrl}">
  80. <img th:src="${item.imageUrl}" alt="">
  81. <div class="s-text">
  82. <div class="itemName" th:text="${item.itemName}"></div>
  83. <p class="itemTag" th:text="${item.count < 10 ? '10명 미만' : item.count + '명 보는중'}">508명 보는중</p>
  84. </div>
  85. </a>
  86. </div>
  87. </div>
  88. </th:block>
  89. </div>
  90. </div>
  91. </div>
  92. </div>
  93. </div> -->
  94. <!-- //3.지금 많이 보고 있어요 상품. -->
  95. <!-- 4.검색어 타이핑 -->
  96. <div class="inner searching_box" id="keyupArea" style="display:none;" th:if="${brandGroupNo==null}">
  97. <div class="filter-list store-list" id="brandStoreArea">
  98. </div>
  99. <div class="relative-list">
  100. </div>
  101. </div>
  102. <div class="inner searching_box" id="keyupCateArea" style="display:none;" th:if="${brandGroupNo==null}">
  103. <div class="sch_category">
  104. </div>
  105. </div>
  106. <div class="inner empty_box2" id="relateArea" style="display:none;">
  107. <div class="recommand_product">
  108. <div class="store_product">
  109. <div class="swiper-container recommand_slide">
  110. <h3>관련상품</h3>
  111. <div class="swiper-wrapper" id="relateItemArea">
  112. </div>
  113. </div>
  114. </div>
  115. </div>
  116. </div>
  117. <!-- //4.검색어 타이핑 -->
  118. <!-- 3.검색결과 없을때 -->
  119. <div class="inner empty_box" id="noDataArea" style="display:none;">
  120. <div class="relative-list nodata"> <!-- 검색결과 없을 시 nodata 클래스 추가 -->
  121. <p class="nodata_txt">&lsquo;<span id="noDataKeyword"></span>&rsquo; 에 맞는 상품을 찾지 못했습니다.<br>검색어를 변경해 보세요.</p>
  122. </div>
  123. <h3 class="hot-key">STYLE24에서 검색되고 있어요</h3>
  124. <div class="related_keyword">
  125. <div class="sub_category">
  126. <div class="cate_wrap" id="noDataRelatedKeyword">
  127. </div>
  128. </div>
  129. </div>
  130. </div>
  131. <div class="inner empty_box" id="recommandArea" style="display:none;">
  132. <div class="recommand_product">
  133. <div class="store_product">
  134. <div class="swiper-container recommand_slide">
  135. <h3>이런 상품은 어떤가요?</h3>
  136. <div class="swiper-wrapper" id="recommendItemArea">
  137. </div>
  138. </div>
  139. </div>
  140. </div>
  141. </div>
  142. <!-- //3.검색결과 없을때 -->
  143. </section>
  144. </div>
  145. </div>
  146. </div>
  147. <script src="/ux/plugins/gaga/gaga.paging.js"></script>
  148. <script th:inline="javascript">
  149. /*<![CDATA[*/
  150. var trendKeywordList = [[${trendKeywordList.trendList}]];
  151. var swiperschProduct = new Swiper('.swiper-container.sch_product', {
  152. slidesPerView: 3,
  153. spaceBetween: 7,
  154. autoplay: {
  155. delay: 4000,
  156. },
  157. freeMode: true,
  158. //centeredSlides: true,
  159. });
  160. var swiperschProduct = new Swiper('.swiper-container.recommand_slide', {
  161. slidesPerView: 2.2,
  162. spaceBetween: 8,
  163. autoplay: {
  164. delay: 4000,
  165. },
  166. freeMode: true,
  167. //centeredSlides: true,
  168. });
  169. $(".itemLike").click(function () {
  170. $(this).toggleClass("likeit");
  171. });
  172. var ckKeyword = "st24ck_today_keyword";
  173. var fnSetKeywordCookie = function(keyword) {
  174. var arrKeyword = new Array;
  175. var arrTempKeyword = new Array;
  176. var j = 0;
  177. arrKeyword = gagajf.getCookie(ckKeyword).split(",");
  178. if (arrKeyword.length > 0) {
  179. for (var i = 0; i < arrKeyword.length; i++) {
  180. // 쿠키에 없으면
  181. if (arrKeyword[i] != keyword && arrKeyword[i] != "") {
  182. arrTempKeyword[j++] = arrKeyword[i];
  183. }
  184. }
  185. arrTempKeyword[j++] = keyword;
  186. } else {
  187. gagajf.setCookie(ckKeyword, keyword, 1);
  188. }
  189. gagajf.setCookie(ckKeyword, arrTempKeyword, 1);
  190. }
  191. // 키워드 검색
  192. $('#btnSearchKeyword').on('click', function() {
  193. if (!gagajf.validation($('#searchMainForm'))) {
  194. return false;
  195. }
  196. let keyword = encodeURIComponent($('#searchMainForm input[name=keyword]').val());
  197. // 쿠키 세팅
  198. fnSetKeywordCookie(keyword);
  199. let actionUrl = _PAGE_SEARCH_GOODS + '?keyword=' + keyword + '&brandGroupNo=' + $('#searchMainForm input[name=brandGroupNo]').val();
  200. cfnGoToPage(actionUrl);
  201. });
  202. // 검색어 찾기
  203. var fnGetAutoSearch = function (){
  204. gagajf.ajaxFormSubmit("/display/search/auto/complete", document.searchMainForm, fnAutoCompleteList);
  205. }
  206. // 검색어 찾기 결과
  207. var fnAutoCompleteList = function (result){
  208. if(result.autoKeywords.length==0 && gagajf.isNull(result.brand.brandGroupNo) && result.cateList.length == 0 && gagajf.isNull(result.goodsList)){
  209. $('.sch_result .default_box').hide();
  210. $('.sch_result .searching_box').hide();
  211. $('.sch_result .empty_box').show();
  212. $("#noDataArea").find('#noDataKeyword').text($("#searchMainForm").find('input[name=keyword]').val());
  213. // 검색어 연관 상품 추천
  214. fnRecommendItemList($("#searchMainForm").find('input[name=keyword]').val());
  215. // 인기검색어
  216. fnTrendKeywordList();
  217. }else{
  218. $('.sch_result .default_box').hide();
  219. $('.sch_result .searching_box').show();
  220. $('.sch_result .empty_box').hide();
  221. $('.sch_result .empty_box2').hide();
  222. // 자동완성 키워드
  223. if(result.autoKeywords != null && result.autoKeywords.length > 0){
  224. $("#keyupArea").find(".relative-list").html('');
  225. let tag = '';
  226. tag += '<ul>\n';
  227. $.each(result.autoKeywords, function (idx,item){
  228. tag += '<li>\n';
  229. tag += ' <a href="javascript:void(0);" onclick="fnSearchKeyword(\''+result.autoKeywords[idx]+'\');">\n';
  230. tag += ' <p><span>'+result.autoKeywords[idx]+'</span></p>\n';
  231. tag += ' </a>\n';
  232. tag += '</li>\n';
  233. });
  234. tag += '</ul>\n';
  235. $("#keyupArea").find(".relative-list").append(tag);
  236. }else{
  237. $("#keyupArea").find(".relative-list").html('');
  238. }
  239. // 브랜드
  240. if(result.brand != null && !gagajf.isNull(result.brand.brandGroupNo)){
  241. $("#brandStoreArea").show();
  242. $("#keyupArea").find(".store-list").html('');
  243. let tag = '';
  244. tag += '<div class="f_left">\n';
  245. tag += ' <h3>'+result.brand.brandGroupNm+' 공식 스토어</h3>\n';
  246. tag += '</div>\n';
  247. tag += '<div class="f_right">\n';
  248. tag += ' <a href="javascript:void(0);" onclick="cfnGoToBrandMain('+result.brand.brandGroupNo+');">바로가기</a>\n';
  249. tag += '</div>\n';
  250. $("#keyupArea").find(".store-list").append(tag);
  251. }else{
  252. $("#keyupArea").find(".store-list").html('');
  253. $("#brandStoreArea").hide();
  254. }
  255. if(result.cateList != null && result.cateList.length > 0){
  256. $("#keyupCateArea").show();
  257. $("#keyupCateArea").find(".sch_category").html('');
  258. let tag = '';
  259. tag += '<h3>카테고리</h3>\n';
  260. tag += '<ul>\n';
  261. $.each(result.cateList, function (idx, item){
  262. tag +='<li>\n';
  263. tag +=' <a href="javascript:void(0);" onclick="cfnGoToGoodsList(0,\'G032_101\' ';
  264. if(item.cate1No != null){
  265. tag += ', '+item.cate1No;
  266. }
  267. if(item.cate2No != null){
  268. tag += ', '+item.cate2No;
  269. }
  270. if(item.cate3No != null){
  271. tag += ', '+item.cate3No;
  272. }
  273. if(item.cate4No != null){
  274. tag += ', '+item.cate4No;
  275. }
  276. if(item.cate5No != null){
  277. tag += ', '+item.cate5No;
  278. }
  279. tag += ');">\n';
  280. if(item.cate1Nm != null){
  281. tag += ' <span>'+item.cate1Nm+'</span>\n';
  282. }
  283. if(item.cate2Nm != null){
  284. tag += ' <span>'+item.cate2Nm+'</span>\n';
  285. }
  286. if(item.cate3Nm != null){
  287. tag += ' <span>'+item.cate3Nm+'</span>\n';
  288. }
  289. if(item.cate4Nm != null){
  290. tag += ' <span>'+item.cate4Nm+'</span>\n';
  291. }
  292. if(item.cate5Nm != null){
  293. tag += ' <span>'+item.cate5Nm+'</span>\n';
  294. }
  295. tag +=' </a>\n';
  296. tag +='</li>\n';
  297. });
  298. tag += '</ul>\n';
  299. $("#keyupCateArea").find(".sch_category").append(tag);
  300. }else{
  301. $("#keyupCateArea").find(".sch_category").html('');
  302. $("#keyupCateArea").hide();
  303. }
  304. if(!gagajf.isNull(result.goodsList)){
  305. $("#relateArea").show();
  306. $("#relateItemArea").html('');
  307. let tag = '';
  308. $.each(result.goodsList, function (idx, item){
  309. if(idx<5) {
  310. tag += '<div class="swiper-slide">\n';
  311. tag += ' <div class="item_prod">\n';
  312. tag += ' <div class="item_state">\n';
  313. tag += ' <button type="button" class="itemLike';
  314. if(item.likeIt == 'likeit'){
  315. tag += ' likeit';
  316. }
  317. tag += '" onclick="cfnMoPutWishList(this);" goodsCd="'+item.goodsCd+'">관심상품 추가</button>\n';
  318. //tag += ' <button type="button" class="itemLike">관심상품 추가</button>\n';
  319. tag += ' <a href="javascript:void(0);" class="itemLink" onclick="cfnGoToGoodsDetail(\'' + item.goodsCd + '\',\'' + item.colorCd + '\');">\n';
  320. tag += ' <div class="itemPic">\n';
  321. tag += ' <img class="vLHTC pd_img" src="'+item.sysImgNm+'" alt="">\n';
  322. tag += ' </div>\n';
  323. tag += ' <p class="itemBrand">'+item.brandGroupNm+'</p>\n';
  324. tag += ' <div class="itemName">'+item.goodsFullNm+'</div>\n';
  325. tag += ' <p class="itemPrice">\n';
  326. if(item.listPrice != item.currPrice) {
  327. tag += ' <span class="itemPrice_original">'+ item.listPrice.addComma() +'</span>\n';
  328. }
  329. tag += item.currPrice.addComma() ;
  330. if(item.listPrice != item.currPrice) {
  331. tag += ' <span class="itemPercent">' + Math.round((item.listPrice - item.currPrice) / (item.listPrice * 1.0) * 100) + '%</span>\n';
  332. }
  333. tag += ' </p>\n';
  334. tag += ' </a>\n';
  335. tag += ' </div>\n';
  336. tag += ' </div>\n';
  337. tag += '</div>\n';
  338. }
  339. });
  340. $("#relateItemArea").html(tag);
  341. var swiperschProduct4 = new Swiper('.swiper-container.recommand_slide', {
  342. slidesPerView: 2.2,
  343. spaceBetween: 8,
  344. autoplay: {
  345. delay: 4000,
  346. },
  347. freeMode: true,
  348. //centeredSlides: true,
  349. });
  350. }else{
  351. $("#relateItemArea").html('');
  352. $("#relateArea").hide();
  353. }
  354. }
  355. }
  356. // 검색어 입력
  357. var fnOnkeyupKeyword = function (obj){
  358. var searchValue = $(obj).val();
  359. if(searchValue.length > 0){
  360. fnGetAutoSearch();
  361. }else{
  362. $('.sch_result .default_box').show();
  363. $('.sch_result .searching_box').hide();
  364. $('.sch_result .empty_box').hide();
  365. $('.sch_result .empty_box2').hide();
  366. }
  367. }
  368. document.getElementById("deleteKeyword").onclick = function (){
  369. $("#searchMainForm").find("input[name=keyword]").val('');
  370. fnOnkeyupKeyword($("#searchMainForm").find("input[name=keyword]"));
  371. }
  372. $(document).ready( function() {
  373. if (trendKeywordList.length > 0) {
  374. $("#popularKeyArea").html('');
  375. trendKeywordList.forEach(function (item, idx) {
  376. var tag = '';
  377. if (idx < 10) {
  378. tag += ' <a href="javascript:void(0);" onclick="fnSearchKeyword(\''+item.keyword+'\');">'+ item.keyword +'</a>';
  379. }
  380. $("#popularKeyArea").append(tag);
  381. });
  382. }else{
  383. $("#popularKeyArea").html('');
  384. }
  385. $("#keyupArea").hide();
  386. $("#keyupCateArea").hide();
  387. $("#deleteKeyword").hide();
  388. $("#noDataArea").hide();
  389. $("#recommandArea").hide();
  390. $("#relateArea").hide();
  391. });
  392. // 선택 단어 검색
  393. var fnSearchKeyword = function (obj){
  394. $("#searchMainForm").find("input[name=keyword]").val(obj);
  395. $('#btnSearchKeyword').trigger('click');
  396. }
  397. // 선택 단어 삭제
  398. var fnDeleteCookie = function (obj, keyword){
  399. $(obj).closest('li').remove();
  400. gagajf.setCookie('st24ck_today_keyword',keyword, -1);
  401. }
  402. // 검색어 입력 후 엔터키
  403. $('#searchMainForm input[name=keyword]').keypress(function (event) {
  404. if (event.which === 13) {
  405. event.preventDefault();
  406. $('#btnSearchKeyword').trigger('click');
  407. }
  408. });
  409. // 인기검색어 조회
  410. var fnTrendKeywordList = function (){
  411. $("#noDataRelatedKeyword").html('');
  412. var html = '';
  413. $.getJSON('/display/search/trend/keyword/list', function (result){
  414. if(result.trendList.length > 0){
  415. $.each(result.trendList, function (idx, item){
  416. html += '<a href="javascript:void(0);" onclick="fnSearchKeyword(\''+item.keyword+'\');"><span>#</span>'+item.keyword+'</a>';
  417. });
  418. }
  419. $("#noDataRelatedKeyword").append(html);
  420. });
  421. }
  422. // 실시간 상품 새로고침
  423. var fnRealtimeGoodsList = function (){
  424. $("#itemViewArea").html('');
  425. var html = '';
  426. $.getJSON('/display/realtime/goods/list', function (result){
  427. // console.log(result);
  428. if(result.length > 0){
  429. $.each(result, function (idx, item){
  430. html += '<div class="swiper-slide">\n';
  431. html += ' <div class="item_prod">\n';
  432. html += ' <button type="button" class="itemLike';
  433. if(item.wishCnt > 0){
  434. html += ' likeit';
  435. }
  436. html += '" onclick="cfnMoPutWishList(this);" goodsCd="'+item.itemId+'">관심상품 추가</button>\n';
  437. html += ' <a href="'+item.itemUrl+'">\n';
  438. html += ' <img src="'+item.imageUrl+'" alt="">\n';
  439. html += ' <div class="s-text">\n';
  440. html += ' <div class="itemName">'+item.itemName+'</div>\n';
  441. if(item.count < 10){
  442. html += ' <p class="itemTag">10명 미만</p>\n';
  443. }else{
  444. html += ' <p class="itemTag">'+item.count.addComma()+'명 보는중</p>\n';
  445. }
  446. html += ' </div>\n';
  447. html += ' </a>\n';
  448. html += ' </div>\n';
  449. html += '</div>\n';
  450. });
  451. }
  452. $("#itemViewArea").append(html);
  453. var swiperschProduct2 = new Swiper('.swiper-container.sch_product', {
  454. slidesPerView: 3,
  455. spaceBetween: 7,
  456. autoplay: {
  457. delay: 4000,
  458. },
  459. freeMode: true,
  460. //centeredSlides: true,
  461. });
  462. });
  463. }
  464. // 검색어 연관 상품 추천
  465. var fnRecommendItemList = function (keyword){
  466. if(gagajf.isNull(keyword)){
  467. keyword = "";
  468. }
  469. var data = {keyword : keyword.trim()};
  470. var html = '';
  471. $.getJSON('/display/recommend/item/list', data, function (result){
  472. $("#recommendItemArea").html('');
  473. if(result.length > 0){
  474. $.each(result, function (idx, item){
  475. html += '<div class="swiper-slide">\n';
  476. html += ' <div class="item_prod">\n';
  477. html += ' <div class="item_state">\n';
  478. html += ' <button type="button" class="itemLike';
  479. if(item.product.wishCnt > 0){
  480. html += ' likeit';
  481. }
  482. html += '" onclick="cfnMoPutWishList(this);" goodsCd="'+item.product.itemId+'">관심상품 추가</button>\n';
  483. //html += ' <button type="button" class="itemLike">관심상품 추가</button>\n';
  484. html += ' <a href="'+item.product.itemUrl+'" class="itemLink">\n';
  485. html += ' <div class="itemPic">\n';
  486. html += ' <img class="vLHTC pd_img" src="'+item.product.itemImage+'" alt="">\n';
  487. html += ' </div>\n';
  488. html += ' <p class="itemBrand">'+item.product.brandName+'</p>\n';
  489. html += ' <div class="itemName">'+item.product.itemName+'</div>\n';
  490. html += ' <p class="itemPrice">\n';
  491. if(item.product.salePrice < item.product.originalPrice) {
  492. html += ' <span class="itemPrice_original">'+ item.product.originalPrice.addComma() +'</span>\n';
  493. }
  494. html += item.product.salePrice.addComma() ;
  495. if(item.product.salePrice < item.product.originalPrice) {
  496. html += ' <span class="itemPercent">' + Math.round((item.product.originalPrice - item.product.salePrice) / (item.product.originalPrice * 1.0) * 100) + '%</span>\n';
  497. }
  498. html += ' </p>\n';
  499. html += ' </a>\n';
  500. html += ' </div>\n';
  501. html += ' </div>\n';
  502. html += '</div>\n';
  503. });
  504. }
  505. $("#recommendItemArea").append(html);
  506. var swiperschProduct3 = new Swiper('.swiper-container.recommand_slide', {
  507. slidesPerView: 2.2,
  508. spaceBetween: 8,
  509. autoplay: {
  510. delay: 4000,
  511. },
  512. freeMode: true,
  513. //centeredSlides: true,
  514. });
  515. });
  516. }
  517. /*]]>*/
  518. </script>
  519. </body>
  520. </html>