GoodsDealDescFormWeb.html 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. <!DOCTYPE html>
  2. <html lang="ko"
  3. xmlns:th="http://www.thymeleaf.org">
  4. <!--
  5. *******************************************************************************
  6. * @source : GoodsDetailDescFormWeb.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.03.24 eskim 최초 작성
  15. *******************************************************************************
  16. -->
  17. <div class="cont_head">
  18. <h3 class="sr-only">상품상세정보</h3>
  19. </div>
  20. <div class="cont_body" th:with="imgGoodsUrl=${@environment.getProperty('upload.goods.view')}, uxImgUrl=${@environment.getProperty('domain.uximage')}, imgUrl=${@environment.getProperty('upload.image.view')}">
  21. <!-- 상품설명 노출 -->
  22. <div class="descrp_box" th:if="${goodsInfo.tobeFormYn == 'Y'}">
  23. <div class="desc_simple"> <!-- 상품 간략설명-->
  24. <span class="tit_desc" th:if="${goodsInfo.goodsTitle != null and !goodsInfo.goodsTitle.empty}" th:utext="${#strings.unescapeJava(#strings.escapeJava(goodsInfo.goodsTitle))}">사이드 밴딩으로 편안한 만능 슬랙스!</span>
  25. <p class="ptxt01"th:if="${goodsInfo.goodsTitleDesc}" th:utext="${#strings.unescapeJava(#strings.escapeJava(goodsInfo.goodsTitleDesc))}">
  26. 슬림핏에 사이드 밴딩으로 편안함을 더해준 슬랙스입니다.
  27. </p>
  28. </div>
  29. <div class="desc_character" th:if="${goodsInfo.goodsSpecialDesc != null and !goodsInfo.goodsSpecialDesc.empty}"> <!-- 상품특징 -->
  30. <span class="tit_desc">상품특징</span>
  31. <p class="ptxt01" th:utext="${#strings.unescapeJava(#strings.escapeJava(goodsInfo.goodsSpecialDesc))}">
  32. - 지퍼플러 장식을 더해 완성도를 높여줌
  33. </p>
  34. </div>
  35. </div>
  36. <!-- //상품설명 노출 -->
  37. <!-- 관리자 에디터입력 내용 공지 html -->
  38. <div class="mdhtml_box">
  39. <th:block th:if="${goodsNoticeList != null and !goodsNoticeList.empty}" >
  40. <th:block th:each="goodsNotice, status : ${goodsNoticeList}" th:utext="${#strings.unescapeJava(#strings.escapeJava(goodsNotice.noticeContent))}"></th:block >
  41. </th:block>
  42. <!-- 공통상품베너 -->
  43. <th:block th:if="${goodsBannerList != null and !goodsBannerList.empty}">
  44. <th:block th:each="goodsBanner, status : ${goodsBannerList}" >
  45. <th:block th:if="${goodsBanner.strVar1 != null and not #strings.equals(goodsBanner.strVar1, '#')}">
  46. <div style="height:100px"></div><!-- 여백용 html -->
  47. <a th:href="${goodsBanner.strVar1}" target="_blank">
  48. <img th:src="${imgUrl+goodsBanner.imgPath1}" alt="">
  49. </a>
  50. </th:block>
  51. <th:block th:unless="${goodsBanner.strVar1 != null and not #strings.equals(goodsBanner.strVar1, '#')}">
  52. <div style="height:100px"></div><!-- 여백용 html -->
  53. <img th:src="${imgUrl+goodsBanner.imgPath1}" alt="">
  54. </th:block>
  55. </th:block>
  56. </th:block>
  57. <th:block th:each="goodsVideo, status : ${goodsVideoList}">
  58. <div class="movblock">
  59. <th:block th:if="${goodsVideo.videoGb == 'Y'}">
  60. <div style="height:100px"></div><!-- 여백용 html -->
  61. <iframe th:src="${'https://www.youtube.com/embed/'+goodsVideo.kmcKey+'?rel=0'}" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture" allowfullscreen></iframe>
  62. </th:block>
  63. <th:block th:unless="${goodsVideo.videoGb == 'Y'}">
  64. <div style="height:100px"></div><!-- 여백용 html -->
  65. <iframe width="100%" height="100%" th:src="${kollusMediaUrl+'/'+goodsVideo.kmcKey +'?player_version=html5'}" frameborder="0" allowfullscreen webkitallowfullscreen mozallowfullscreen></iframe>
  66. </th:block>
  67. </div>
  68. </th:block>
  69. <!-- 관리자 에디터입력 내용 노출 상단 html -->
  70. <th:block th:if="${goodsInfo.goodsTopDesc != null and !goodsInfo.goodsTopDesc.empty }" >
  71. <div style="height:100px"></div><!-- 여백용 html -->
  72. <th:block th:utext="${#strings.unescapeJava(#strings.escapeJava(goodsInfo.goodsTopDesc))}"></th:block>
  73. </th:block >
  74. <th:block th:if="${goodsInfo.tobeFormYn == 'N' and goodsInfo.goodsDesc != null and !goodsInfo.goodsDesc.empty}" >
  75. <div style="height:100px"></div><!-- 여백용 html -->
  76. <div id="goodsDescHtml"></div>
  77. </th:block>
  78. </div>
  79. <th:block th:if="${goodsInfo.tobeFormYn == 'Y'}">
  80. <!-- 착용컷 노출 -->
  81. <div class="view_outfit_box" th:if="${#strings.contains(goodsImgList,'_C1')
  82. or #strings.contains(goodsImgList,'_C2')
  83. or #strings.contains(goodsImgList,'_C3')
  84. or #strings.contains(goodsImgList,'_C4')
  85. or #strings.contains(goodsImgList,'_C5')}">
  86. <span class="tit_view">OUTFIT VIEW</span>
  87. <span class="model_info">(모델정보 : 185cm / 78kg / XL 착용)</span>
  88. <div class="view">
  89. <th:block th:each="goodsImg, status : ${goodsImgList}" th:if="${#strings.contains(goodsImg.sysImgNm,'_C1')
  90. or #strings.contains(goodsImg.sysImgNm,'_C2')
  91. or #strings.contains(goodsImg.sysImgNm,'_C3')
  92. or #strings.contains(goodsImg.sysImgNm,'_C4')
  93. or #strings.contains(goodsImg.sysImgNm,'_C5')}">
  94. <img th:src="${imgGoodsUrl+'/'+goodsImg.sysImgNm+'?RS=720'}" alt="" th:onerror="'this.src=\''+@{${uxImgUrl}+ '/images/pc/thumb/bg_item_none.png'}+'\';'">
  95. </th:block>
  96. </div>
  97. </div>
  98. <!-- //착용컷 노출 -->
  99. <!-- 상품컷 노출 -->
  100. <div class="view_detail_box" th:if="${#strings.contains(goodsImgList,'_01') or #strings.contains(goodsImgList,'_02')
  101. or #strings.contains(goodsImgList,'_D1') or #strings.contains(goodsImgList,'_D2')
  102. or #strings.contains(goodsImgList,'_D3') or #strings.contains(goodsImgList,'_D4')
  103. or #strings.contains(goodsImgList,'_D5') or #strings.contains(goodsImgList,'_D6')
  104. or #strings.contains(goodsImgList,'_D7') or #strings.contains(goodsImgList,'_D8')
  105. or #strings.contains(goodsImgList,'_D9') or #strings.contains(goodsImgList,'_D10')
  106. or #strings.contains(goodsImgList,'_D11') or #strings.contains(goodsImgList,'_D12')
  107. or #strings.contains(goodsImgList,'_D13') or #strings.contains(goodsImgList,'_D14')
  108. or #strings.contains(goodsImgList,'_D15') or #strings.contains(goodsImgList,'_D16')
  109. or #strings.contains(goodsImgList,'_D17') or #strings.contains(goodsImgList,'_D18')
  110. or #strings.contains(goodsImgList,'_D19') or #strings.contains(goodsImgList,'_D20')}">
  111. <span class="tit_view">PRODUCT VIEW</span>
  112. <div class="view">
  113. <th:block th:each="goodsImg, status : ${goodsImgList}" th:if="${#strings.contains(goodsImg.sysImgNm,'_01') or #strings.contains(goodsImg.sysImgNm,'_02')
  114. or #strings.contains(goodsImg.sysImgNm,'_D1') or #strings.contains(goodsImg.sysImgNm,'_D2')
  115. or #strings.contains(goodsImg.sysImgNm,'_D3') or #strings.contains(goodsImg.sysImgNm,'_D4')
  116. or #strings.contains(goodsImg.sysImgNm,'_D5') or #strings.contains(goodsImg.sysImgNm,'_D6')
  117. or #strings.contains(goodsImg.sysImgNm,'_D7') or #strings.contains(goodsImg.sysImgNm,'_D8')
  118. or #strings.contains(goodsImg.sysImgNm,'_D9') or #strings.contains(goodsImg.sysImgNm,'_D10')
  119. or #strings.contains(goodsImg.sysImgNm,'_D11') or #strings.contains(goodsImg.sysImgNm,'_D12')
  120. or #strings.contains(goodsImg.sysImgNm,'_D13') or #strings.contains(goodsImg.sysImgNm,'_D14')
  121. or #strings.contains(goodsImg.sysImgNm,'_D15') or #strings.contains(goodsImg.sysImgNm,'_D16')
  122. or #strings.contains(goodsImg.sysImgNm,'_D17') or #strings.contains(goodsImg.sysImgNm,'_D18')
  123. or #strings.contains(goodsImg.sysImgNm,'_D19') or #strings.contains(goodsImg.sysImgNm,'_D20')}">
  124. <img th:src="${imgGoodsUrl+'/'+goodsImg.sysImgNm+'?RS=720'}" alt="" th:onerror="'this.src=\''+@{${uxImgUrl}+ '/images/pc/thumb/bg_item_none.png'}+'\';'">
  125. </th:block>
  126. </div>
  127. </div>
  128. <!-- //상품컷 노출 -->
  129. <!-- 원단 노출 -->
  130. <div class="view_fabric_box" th:if="${#strings.contains(goodsImgList,'_F1')}">
  131. <span class="tit_view">FABRIC</span>
  132. <div class="view">
  133. <th:block th:each="goodsImg, status : ${goodsImgList}" th:if="${#strings.contains(goodsImg.sysImgNm,'_F1')}">
  134. <img th:src="${imgGoodsUrl+'/'+goodsImg.sysImgNm+'?RS=720'}" alt="" th:onerror="'this.src=\''+@{${uxImgUrl}+ '/images/pc/thumb/bg_item_none.png'}+'\';'">
  135. </th:block>
  136. </div>
  137. </div>
  138. <!-- //원단 노출 -->
  139. <!-- 라벨 노출 -->
  140. <div class="view_label_box" th:if="${#strings.contains(goodsImgList,'_L1')
  141. or #strings.contains(goodsImgList,'_L2')}">
  142. <span class="tit_view">LABEL INFO</span>
  143. <div class="view">
  144. <span>
  145. <th:block th:each="goodsImg, status : ${goodsImgList}" th:if="${#strings.contains(goodsImg.sysImgNm,'_L1')
  146. or #strings.contains(goodsImg.sysImgNm,'_L2')}">
  147. <img th:src="${imgGoodsUrl+'/'+goodsImg.sysImgNm+'?RS=250'}" alt="" th:onerror="'this.src=\''+@{${uxImgUrl}+ '/images/pc/thumb/bg_item_none.png'}+'\';'">
  148. </th:block>
  149. </span>
  150. </div>
  151. </div>
  152. <!-- //라벨 노출 -->
  153. <!-- //네이밍룰 안맞는 이미지 노출 -->
  154. <div class="view_detail_box" th:if="${not #strings.contains(goodsImgList,'_01')}">
  155. <div class="view">
  156. <th:block th:each="goodsImg, status : ${goodsImgList}" >
  157. <img th:src="${imgGoodsUrl+'/'+goodsImg.sysImgNm+'?RS=720'}" alt="" th:onerror="'this.src=\''+@{${uxImgUrl}+ '/images/pc/thumb/bg_item_none.png'}+'\';'">
  158. </th:block>
  159. </div>
  160. </div>
  161. </th:block>
  162. <!-- 관리자 에디터입력 내용 노출 하다단 html -->
  163. <div class="mdhtml_box" th:if="${goodsInfo.goodsDownDesc != null and !goodsInfo.goodsDownDesc.empty}" th:utext="${#strings.unescapeJava(#strings.escapeJava(goodsInfo.goodsDownDesc))}"></div>
  164. <!-- 브랜드 노출 -->
  165. <div class="brand_box">
  166. <p class="name" th:text="${goodsInfo.brandGroupNm}">TBJ 티비제이</p>
  167. <a href="javascript:void(0);" class="btn btn_default" th:onclick="cfnGoToBrandMain([[${goodsInfo.brandGroupNo}]])" ><span>브랜드 홈 바로가기</span></a>
  168. </div>
  169. <!-- //브랜드 노출 -->
  170. <!-- 상품필수정보 노출 -->
  171. <div class="required_box" >
  172. <div class="area_infotbl" th:if="${goodsInfo.goodsType == 'G056_N' and goodsNotiList != null and !goodsNotiList.empty}">
  173. <span class="title">상품고시정보</span>
  174. <div class="tbl type1 mt30">
  175. <table>
  176. <tbody>
  177. <tr th:each="goodsNoti, status : ${goodsNotiList}" >
  178. <th th:text="${goodsNoti.niItemNm}">스타일</th>
  179. <td th:text="${goodsNoti.niContent}">F94U-MD01XA60F0</td>
  180. </tr>
  181. </tbody>
  182. </table>
  183. </div>
  184. </div>
  185. <div class="area_infotbl" th:if="${goodsInfo.goodsType == 'G056_S' and goodsComposeList != null and !goodsComposeList.empty}">
  186. <span class="title">상품고시정보</span>
  187. <th:block th:each="goodsCompose, status : ${goodsComposeList}">
  188. <div class="tbl type1 mt30">
  189. <table>
  190. <tbody>
  191. <tr th:each="goodsNoti, status : ${goodsCompose.goodsNotiList}" >
  192. <th th:text="${goodsNoti.niItemNm}">스타일</th>
  193. <td th:text="${goodsNoti.niContent}">F94U-MD01XA60F0</td>
  194. </tr>
  195. </tbody>
  196. </table>
  197. </div>
  198. </th:block>
  199. </div>
  200. <th:block th:if="${goodsSafeNo != null}" >
  201. <th:block th:if="${goodsSafeNo.certTargetGb == 'G083_3'}" > <!-- 상세별도표시 -->
  202. <div class="area_kcl no-mark">
  203. <p class="tit normal"><th:block th:if="${goodsSafeNo.certFormNm}" th:text="${goodsSafeNo.certFormNm}"></th:block>
  204. <th:block th:if="${goodsSafeNo.certTypeNm}" th:text="${' ' + goodsSafeNo.certTypeNm}"></th:block> / 제품 상세정보 내 별도 표기</p>
  205. <p class="normal">제품 상세정보 내 표기되어 있습니다. 상품 정보를 확인해주세요.</p>
  206. <p class="t_info dot_info">해당 인증정보는 판매자가 등록한 것으로 등록정보에 대한 일체의 책임은 판매자에게 있습니다.</p>
  207. </div>
  208. </th:block>
  209. <th:block th:unless="${goodsSafeNo.certTargetGb == 'G083_3'}" > <!-- 인증 -->
  210. <th:block th:if="${goodsSafeNo.certType == 'G081_3'}" > <!-- 공급자적합성 -->
  211. <div class="area_kcl">
  212. <i class="ico ico_kcl"></i>
  213. <p class="tit normal"><th:block th:if="${goodsSafeNo.certFormNm}" th:text="${goodsSafeNo.certFormNm}"></th:block>
  214. <th:block th:if="${goodsSafeNo.certTypeNm}" th:text="${' ' + goodsSafeNo.certTypeNm}"></th:block> / 공급자적합성확인</p>
  215. <p class="normal">공급자 적합성 확인 품목으로 국가통합인증을 필함</p>
  216. <p class="t_info dot_info">해당 인증정보는 판매자가 등록한 것으로 등록정보에 대한 일체의 책임은 판매자에게 있습니다.</p>
  217. </div>
  218. </th:block>
  219. <th:block th:unless="${goodsSafeNo.certType == 'G081_3'}" > <!-- 공급자적합성 외 -->
  220. <div class="area_kcl" >
  221. <i class="ico ico_kcl"></i>
  222. <th:block th:if="${goodsSafeNo.certFormGb != 'G084_4' and goodsSafeNo.certFormGb != 'G084_5' }">
  223. <p class="tit normal" >
  224. <th:block th:if="${goodsSafeNo.certDiv}" th:text="${goodsSafeNo.certDiv}"></th:block>
  225. <th:block th:if="${goodsSafeNo.certOrganName}" th:text="${' /' + goodsSafeNo.certOrganName}"></th:block>
  226. </p>
  227. </th:block>
  228. <th:block th:unless="${goodsSafeNo.certFormGb != 'G084_4' and goodsSafeNo.certFormGb != 'G084_5' }">
  229. <p class="tit normal">
  230. <th:block th:if="${goodsSafeNo.certFormNm}" th:text="${goodsSafeNo.certFormNm}"></th:block>
  231. <th:block th:if="${goodsSafeNo.certTypeNm}" th:text="${' ' + goodsSafeNo.certTypeNm}"></th:block>
  232. </p>
  233. </th:block>
  234. <p class="normal" >
  235. <th:block th:if="${goodsSafeNo.certNum}" th:text="${'인증번호: ' + goodsSafeNo.certNum}"></th:block>
  236. <th:block th:if="${goodsSafeNo.certFormGb != 'G084_4' and goodsSafeNo.certFormGb != 'G084_5' }">
  237. <a th:href="@{http://www.safetykorea.kr/search/searchPop(certNum=${goodsSafeNo.certNum})}" target="_blank" class="linktxt3">상세보기</a>
  238. </th:block>
  239. </p>
  240. <p class="t_info dot_info">
  241. 해당 인증정보는 판매자가 등록한 것으로 등록정보에 대한 일체의 책임은 판매자에게 있습니다.
  242. </p>
  243. </div>
  244. </th:block>
  245. </th:block>
  246. </th:block>
  247. <div class="area_infotbl">
  248. <span class="title">상품기본정보</span>
  249. <div class="tbl type1 mt30">
  250. <table>
  251. <tbody>
  252. <tr>
  253. <th>상품코드</th>
  254. <td th:text="${goodsInfo.goodsCd}">14443216</td>
  255. </tr>
  256. <tr>
  257. <th>상품구분</th>
  258. <td th:text="${goodsInfo.goodsGbNm}">병행수입</td>
  259. </tr>
  260. <tr>
  261. <th>브랜드</th>
  262. <td th:text="${goodsInfo.brandGroupNm}">TBJ</td>
  263. </tr>
  264. <tr>
  265. <th>상품명</th>
  266. <td th:text="${goodsInfo.goodsNm}">남성 테이퍼드 핏 겨울 기모면 스판 올 밴딩 팬츠</td>
  267. </tr>
  268. <th:block th:if="${goodsInfo.goodsType == 'G056_N' and goodsNotiList != null and !goodsNotiList.empty}">
  269. <th:block th:each="goodsNoti, status : ${goodsNotiList}" th:if="${goodsNoti.niItemCd == 'G005_005'}">
  270. <tr>
  271. <th th:text="${goodsNoti.niItemNm}">제조사</th>
  272. <td th:text="${goodsNoti.niContent}"></td>
  273. </tr>
  274. </th:block>
  275. </th:block>
  276. <tr>
  277. <th>제조국</th>
  278. <td th:text="${goodsInfo.originNm}">베트남</td>
  279. </tr>
  280. </tbody>
  281. </table>
  282. </div>
  283. <p class="t_info dot_info mt20">
  284. 주문제작 상품의 경우 주문 후 제작되어 판매되는 상품으로 제작 시점부터 반품/교환이 어려울 수 있습니다.
  285. </p>
  286. </div>
  287. </div>
  288. <!-- //상품필수정보 노출 -->
  289. </div>
  290. <div class="btn_more_box covered">
  291. <button type="button" class="btn btn_default btn_md">
  292. <span>상세정보 더보기</span>
  293. </button>
  294. </div>
  295. <script th:inline="javascript">
  296. /*<![CDATA[*/
  297. // 상품상세 asis html 이지미 경로 수정
  298. $(document).ready( function() {
  299. $(".pd_descrp_pop .cont_body").find('img').each(function() {
  300. let tmpImgSrc = $(this).attr('src');
  301. if (tmpImgSrc.indexOf('Upload') == 1 ){ // /Upload
  302. $(this).attr('src' , tmpImgSrc.replace('/Upload', _imgUrl+"/Local").replace('/Upload/Local', "/Local"));
  303. }
  304. });
  305. //210526_ 추가 : 이미지 style 속성 제거
  306. $(".mdhtml_box style").remove();$(".mdhtml_box img").removeAttr("style");
  307. });
  308. //상품상세 적용
  309. // 입점 html 에 태그가 정상적이지 않아 스크립트로 처리
  310. let goodsDesc = [[${goodsInfo.goodsDesc}]];
  311. if ("N" == [[${goodsInfo.tobeFormYn}]] && !gagajf.isNull(goodsDesc)){
  312. $('#goodsDescHtml').html([[${#strings.unescapeJava(#strings.escapeJava(goodsInfo.goodsDesc))}]]);
  313. }
  314. /*]]>*/
  315. </script>
  316. </html>