GoodsQnaFormWeb.html 6.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188
  1. <!DOCTYPE html>
  2. <html lang="ko"
  3. xmlns:th="http://www.thymeleaf.org"
  4. xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
  5. layout:decorator="web/common/layout/CallcenterLayoutWeb">
  6. <!--
  7. *******************************************************************************
  8. * @source : GoodsQnaFormWeb.html
  9. * @desc : 상품문의 Page
  10. *============================================================================
  11. * STYLE24
  12. * Copyright(C) 2020 TSIT, All rights reserved.
  13. *============================================================================
  14. * VER DATE AUTHOR DESCRIPTION
  15. * === =========== ========== =============================================
  16. * 1.0 2021.02.19 gagamel 최초 작성
  17. *******************************************************************************
  18. -->
  19. <body>
  20. <th:block layout:fragment="content">
  21. <div id="container" class="container cs">
  22. <div class="breadcrumb">
  23. <ul>
  24. <li class="bread_home"><a href="javascript:void(0);" onclick="cfnGoToPage(_PAGE_MAIN);">홈</a></li>
  25. <li class="bread_2depth"><a href="javascript:void(0);" onclick="cfnGoToPage(_PAGE_FAQ);">고객센터</a></li>
  26. <li class="bread_3depth">상품문의</li>
  27. </ul>
  28. </div>
  29. <div class="wrap">
  30. <div class="content faq">
  31. <div class="cont_body">
  32. <!-- CONT-BODY -->
  33. <div class="lnb" id="callcenterLnb">
  34. </div>
  35. <div class="cont">
  36. <div>
  37. <div class="sec_head">
  38. <h3>1:1 문의</h3>
  39. </div>
  40. <div class="sec_body">
  41. <div class="history_wrap clear">
  42. <div class="hist_status">
  43. <ul>
  44. <li>
  45. <span>총 문의</span>
  46. <a href="javascript:void(0);" onclick="" th:text="${qnaCountInfo.totCnt}">12</a>
  47. </li>
  48. <li>
  49. <span>답변 완료</span>
  50. <a href="javascript:void(0);" onclick="" th:text="${qnaCountInfo.ansCnt}">8</a>
  51. </li>
  52. <li>
  53. <span>처리 중</span>
  54. <a href="javascript:void(0);" onclick="" th:text="${qnaCountInfo.ingCnt}" class="doing">0</a>
  55. </li>
  56. </ul>
  57. </div>
  58. <div class="txt">
  59. <p>상품에 관련된 문의 내용을 확일할 수 있습니다.<br/>상품별 문의는 해당 상품 페이지에서 등록 가능하며 답변이 달린<br/>내용은 고객센터 또는 해당 상품페이지에서 확인 가능합니다.</p>
  60. </div>
  61. </div>
  62. <div class="ui_row" id="divQna"> <!-- 데이터 없을시 클래스 nodata 추가 -->
  63. <!-- list -->
  64. <div class="foldGroup case1">
  65. <ul id="ulQna">
  66. </ul>
  67. </div>
  68. <!-- //list -->
  69. </div>
  70. <div class="ui_foot">
  71. <div class="ui_row">
  72. <ul class="pageNav">
  73. </ul>
  74. </div>
  75. </div>
  76. </div>
  77. </div>
  78. </div>
  79. <!-- // CONT-BODY -->
  80. </div>
  81. </div>
  82. </div>
  83. </div>
  84. <!-- // container -->
  85. <form id="qnaForm" name="qnaForm" action="#" th:action="@{'/callcenter/goods/qna/list'}">
  86. <input type="hidden" name="pageNo" value ="1"/>
  87. <input type="hidden" name="pageSize" value ="10"/>
  88. </form>
  89. <script src="/ux/plugins/gaga/gaga.paging.js"></script>
  90. <script th:inline="javascript">
  91. /*<![CDATA[*/
  92. $(document).ready(function() {
  93. // 고객센터 LNB 설정
  94. fnSetCallcenterLnb(3);
  95. fnGetList();
  96. });
  97. let fnGetList = function() {
  98. // Initialize a pagination
  99. gagaPaging.init('qnaForm', fnGetListCallback, 'pageNav', 10);
  100. // Load data
  101. gagaPaging.load(1);
  102. }
  103. var fnGetListCallback = function(result) {
  104. $('#ulQna').html('');
  105. // 목록
  106. if (result.dataList != null && result.dataList.length > 0) {
  107. $.each(result.dataList, function(idx, item) {
  108. let tag = '<li>\n';
  109. tag += ' <div class="fold_head">\n';
  110. tag += ' <a href="javascript:void(0)">\n';
  111. tag += ' <div>\n';
  112. tag += ' <span class="fold_state ' + (item.ansStat == "G060_10" ? "doing" : "done") + '">' + item.ansStatNm + '</span>\n'; //답변완료 : done / 처리중 : doing
  113. tag += ' <div class="fold_tit">\n';
  114. tag += ' <span class="prod">' + item.goodsNm + ' ' + item.relGoodsCd + '</span>\n';
  115. tag += ' <span>' + item.questTitle + '</span>\n';
  116. tag += ' </div>\n';
  117. tag += ' <span class="data">' + item.questDt + '</span>\n';
  118. tag += ' </div>\n';
  119. tag += ' </a>\n';
  120. tag += ' </div>\n';
  121. tag += ' <div class="fold_cont" style="display: none;">\n';
  122. tag += ' <div class="fold_detail">\n'; //문의 내용
  123. tag += ' <div>\n';
  124. tag += ' <p>' + item.questContent + '</p>\n';
  125. tag += ' </div>\n';
  126. if (item.ansStat == 'G060_10') { // 처리중일때
  127. tag += ' <button type="button" class="btn btn_default btn_del" onclick="fnDeleteQna(' + item.counselSq + ');"><span><i class="ico ico_trash"></i>삭제</span></button>\n';
  128. }
  129. tag += ' </div>\n';
  130. if (item.ansStat == 'G060_20') { // 답변완료 상태일 때
  131. tag += ' <div class="fold_answer">\n'; //문의 답변
  132. tag += ' <div class="answer_head">답변이 등록되었습니다.</div>\n';
  133. tag += ' <div class="answer_body">' + item.ansContent + '</div>\n';
  134. tag += ' <span class="data">' + item.ansDt + '</span>\n';
  135. tag += ' </div>\n';
  136. }
  137. tag += ' </div>\n';
  138. tag += '</li>\n';
  139. $('#ulQna').append(tag);
  140. });
  141. } else {
  142. let tag = '<li>내역이 없습니다.</li>\n';
  143. $('#ulQna').append(tag);
  144. $('#divQna').addClass('nodata');
  145. }
  146. // Create pagination
  147. gagaPaging.createPagination(result.paging.pageable);
  148. }
  149. // 삭제
  150. let fnDeleteQna = function(counselSq) {
  151. mcxDialog.confirm("등록된 내용을 삭제하시겠습니까?", {
  152. cancelBtnText: "취소",
  153. sureBtnText: "확인",
  154. sureBtnClick: function() {
  155. let params = new Object();
  156. params.counselSq = counselSq;
  157. var jsonData = JSON.stringify(params);
  158. gagajf.ajaxJsonSubmit('/callcenter/goods/qna/delete'
  159. , jsonData
  160. , function() {
  161. fnGetList();
  162. });
  163. }
  164. });
  165. }
  166. /*]]>*/
  167. </script>
  168. </th:block>
  169. </body>
  170. </html>