OrderFormWeb.html 59 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841
  1. <!DOCTYPE html>
  2. <html lang="ko" xmlns:th="http://www.thymeleaf.org"
  3. xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout"
  4. layout:decorator="web/common/layout/DefaultLayoutWeb">
  5. <!--
  6. *******************************************************************************
  7. * @source : OrderFormWeb.html
  8. * @desc : 주문/결제 Page
  9. *============================================================================
  10. * STYLE24
  11. * Copyright(C) 2020 TSIT, All rights reserved.
  12. *============================================================================
  13. * VER DATE AUTHOR DESCRIPTION
  14. * === =========== ========== =============================================
  15. * 1.0 2021.02.01 jsh77b 최초 작성
  16. *******************************************************************************
  17. -->
  18. <body>
  19. <th:block layout:fragment="content">
  20. <link rel="stylesheet" type="text/css" href="/ux/pc/css/swiper.min.css">
  21. <script type="text/javascript" src="/ux/pc/js/swiper.min.js"></script>
  22. <script type="text/javascript" src="/ux/pc/js/slick.min.js"></script>
  23. <script type="text/javascript" src="/ux/pc/js/jquery-ui.js"></script>
  24. <!-- payment.js -->
  25. <script type="text/javascript" th:src="${@environment.getProperty('pg.kcp.js.url')}" src=""></script>
  26. <script type="text/javascript" src="/ux/pc/js/payment.js"></script>
  27. <script type="text/javascript">
  28. $(document).on("click", "#buyBtn", function() {
  29. $.ajax({
  30. type: "POST",
  31. url : '/order/create/preOrder',
  32. dataType : 'html',
  33. data : {
  34. pgGb : "PAYCO"
  35. , payMeans : "G014_30"
  36. , ordNo : "5"
  37. , goodsNm : "상품 테스트"
  38. , payAmt : "1233"
  39. , ordNm : "이태영"
  40. , ordEmail : "xodud1202@naver.com"
  41. , ordTelno : "02-0000-0000"
  42. , ordPhnno : "010-7111-0000"
  43. },
  44. error : function(e) {
  45. alert(3);
  46. },
  47. success : function(result) {
  48. $("#order_info").html(result);
  49. jsf__pay(document.order_info);
  50. }
  51. });
  52. });
  53. </script>
  54. <form id="order_info" name="order_info" method="post" action="/order/pay/result/response" ></form>
  55. <input type="button" id="buyBtn" value="테스트버튼" style="width:200px; height:200px;"/>
  56. <!-- // xodud1202 -->
  57. <!-- card007 -->
  58. <script type="text/javascript">
  59. $(document).on("click", "#kakaoBtn", function() {
  60. $.ajax( {
  61. type: "POST",
  62. url : '/order/create/order',
  63. dataType : 'html',
  64. data : {cartSq : 8},
  65. success : function(result) {
  66. $("#order_info").html(result);
  67. fnKakaoPaymentReady();
  68. }
  69. });
  70. });
  71. // 카카오페이 결제준비 처리
  72. var fnKakaoPaymentReady = function() {
  73. const protocol = 'http:';
  74. let url = '/order/kakao/payment/ready';
  75. let redirectUrl = '/order/kakao/payment/request';
  76. let data = {};
  77. data.ordNo = $('#order_info input[name=ordr_idxx]').val();
  78. data.goodsNm = $('#order_info input[name=good_name]').val();
  79. data.ordQty = $('#ordQty').text();
  80. data.realOrdAmt = $('#order_info input[name=good_mny]').val();
  81. data.approvalUrl = protocol + _frontUrl + redirectUrl;
  82. data.failUrl = protocol + _frontUrl + redirectUrl;
  83. data.cancelUrl = protocol + _frontUrl + redirectUrl;
  84. let jsonData = JSON.stringify(data);
  85. gagajf.ajaxJsonSubmit(url, jsonData, function(result) {
  86. let tid = result.kakaoPay.tid;
  87. let nextRedirectUrl = result.kakaoPay.next_redirect_pc_url;
  88. let option = 'width=420, height=520';
  89. $('#order_info').append('<input type=hidden name="pgTid" value="' + tid + '" />');
  90. window.open(nextRedirectUrl, 'kakaoPaymentPopup', option);
  91. });
  92. }
  93. // 카카오페이 결제 승인 요청
  94. var fnKakaoPaymentRequest = function(pgToken) {
  95. $('#order_info').append('<input type=hidden name="pgToken" value="' + pgToken + '" />');
  96. let url = '/order/kakao/payment/approve';
  97. let data = {};
  98. data.pgTid = $('#order_info input[name=pgTid]').val();
  99. data.ordNo = $('#order_info input[name=ordr_idxx]').val();
  100. data.pgToken = $('#order_info input[name=pgToken]').val();
  101. let jsonData = JSON.stringify(data);
  102. gagajf.ajaxJsonSubmit(url, jsonData, function(result) {
  103. console.log('====== kakaoPaymentRequest ======');
  104. console.log(result.payment);
  105. console.log(' ');
  106. fnKakaoPaymentOrder();
  107. });
  108. return true;
  109. }
  110. // 카카오페이 결제 정보 조회
  111. var fnKakaoPaymentOrder = function() {
  112. let url = '/order/kakao/payment/order';
  113. let data = {};
  114. data.pgTid = $('#order_info input[name=pgTid]').val();
  115. let jsonData = JSON.stringify(data);
  116. gagajf.ajaxJsonSubmit(url, jsonData, function(result) {
  117. console.log('====== kakaoPaymentOrder ======');
  118. console.log(result.kakaoPay);
  119. console.log(' ');
  120. fnCancelKakaoPayment();
  121. });
  122. return true;
  123. }
  124. // 카카오페이 결제 취소
  125. var fnCancelKakaoPayment = function() {
  126. let url = '/order/kakao/payment/cancel';
  127. let data = {};
  128. data.pgTid = $('#order_info input[name=pgTid]').val();
  129. data.cnclRtnAmt = 1000;
  130. //data.allCanYn = 'Y';
  131. let jsonData = JSON.stringify(data);
  132. gagajf.ajaxJsonSubmit(url, jsonData, function(result) {
  133. console.log('====== kakaoPaymentCancel ======');
  134. console.log(result.kakaoPay);
  135. console.log(' ');
  136. });
  137. }
  138. </script>
  139. <!-- =========== 네이버페이 ============= -->
  140. <script src="https://nsp.pay.naver.com/sdk/js/naverpay.min.js"></script>
  141. <script th:inline="javascript">
  142. let custNo = [[${sessionInfo.custNo}]];
  143. let naverPayClientId = [[${@environment.getProperty('naverPay.clientId')}]];
  144. let redirectUrl = '/order/naver/payment/request';
  145. const protocol = 'http:';
  146. var oPay = Naver.Pay.create({
  147. "mode" : "development", // development or production
  148. "clientId": naverPayClientId // clientId
  149. });
  150. $(document).on("click", "#naverBtn", function() {
  151. $.ajax( {
  152. type: "POST",
  153. url : '/order/create/order',
  154. dataType : 'html',
  155. data : {cartSq : 8},
  156. success : function(result) {
  157. $("#order_info").html(result);
  158. fnNaverPaymentReady();
  159. }
  160. });
  161. });
  162. // 네이버페이 결제준비 처리
  163. var fnNaverPaymentReady = function() {
  164. const protocol = 'http:';
  165. let url = '/order/naver/payment/ready';
  166. let redirectUrl = '/order/naver/payment/request';
  167. let data = {};
  168. data.ordNo = $('#order_info input[name=ordr_idxx]').val();
  169. data.goodsNm = $('#order_info input[name=good_name]').val();
  170. data.ordQty = $('#ordQty').text();
  171. data.realOrdAmt = $('#order_info input[name=good_mny]').val();
  172. data.returnUrl = protocol + _frontUrl + redirectUrl;
  173. let jsonData = JSON.stringify(data);
  174. gagajf.ajaxJsonSubmit(url, jsonData, function(result) {
  175. let reserveId = result.naverPay.body.reserveId;
  176. let url = "https://test-pay.naver.com/payments/" + reserveId;
  177. let option = 'width=750, height=' + $(window).height();
  178. window.open(url, 'naverPaymentPopup', option);
  179. });
  180. }
  181. // 네이버페이 결제 승인 요청
  182. var fnNaverPaymentRequest = function(paymentId) {
  183. $('#order_info').append('<input type=hidden name="pgTid" value="' + paymentId + '" />');
  184. let url = '/order/naver/payment/approve';
  185. let data = {};
  186. data.pgTid = $('#order_info input[name=pgTid]').val();
  187. let jsonData = JSON.stringify(data);
  188. gagajf.ajaxJsonSubmit(url, jsonData, function(result) {
  189. console.log('====== naverPaymentRequest ======');
  190. console.log(result.payment);
  191. console.log(' ');
  192. fnNaverPaymentOrder();
  193. });
  194. return true;
  195. }
  196. // 네이버페이 결제 정보 조회
  197. var fnNaverPaymentOrder = function() {
  198. let url = '/order/naver/payment/order';
  199. let data = {};
  200. data.pgTid = $('#order_info input[name=pgTid]').val();
  201. let jsonData = JSON.stringify(data);
  202. gagajf.ajaxJsonSubmit(url, jsonData, function(result) {
  203. console.log('====== naverPaymentOrder ======');
  204. console.log(result.kakaoPay);
  205. console.log(' ');
  206. fnCancelNaverPayment();
  207. });
  208. return true;
  209. }
  210. // 네이버페이 결제 취소
  211. var fnCancelNaverPayment = function() {
  212. let url = '/order/naver/payment/cancel';
  213. let data = {};
  214. data.pgTid = $('#order_info input[name=pgTid]').val();
  215. data.cancelRequester = '1';
  216. data.cancelReason = '고객변심';
  217. data.cnclRtnAmt = 1000;
  218. //data.allCanYn = 'Y';
  219. let jsonData = JSON.stringify(data);
  220. gagajf.ajaxJsonSubmit(url, jsonData, function(result) {
  221. console.log('====== naverPaymentCancel ======');
  222. console.log(result.kakaoPay);
  223. console.log(' ');
  224. });
  225. }
  226. </script>
  227. <input type="button" id="kakaoBtn" value="카카오테스트버튼" style="width:200px; height:200px;"/>
  228. <input type="button" id="naverBtn" value="네이버테스트버튼" style="width:200px; height:200px;"/>
  229. <!-- // card007 -->
  230. <!-- container -->
  231. <form id="payForm" name="payForm">
  232. <br>
  233. <!-- 주문고객정보 -->
  234. <table border="1" style="font-size:10px; text-align:center;">
  235. <tr style="height:30px;">
  236. <th>custNm</th>
  237. <th>email</th>
  238. <th>cellPhnno</th>
  239. <th>recipZipcode</th>
  240. <th>recipBaseAddr</th>
  241. <th>recipDtlAddr</th>
  242. <th>delvMemo</th>
  243. <th>foreignBuyYn</th>
  244. <th>orderMadeYn</th>
  245. </tr>
  246. <tr style="height:30px;">
  247. <td class="custNm"></td>
  248. <td class="email"></td>
  249. <td class="cellPhnno"></td>
  250. <td class="recipZipcode"></td>
  251. <td class="recipBaseAddr"></td>
  252. <td class="recipDtlAddr"></td>
  253. <td class="delvMemo"></td>
  254. <td class="foreignBuyYn"></td>
  255. <td class="orderMadeYn"></td>
  256. </tr>
  257. </table>
  258. <br>
  259. <!-- 사은품정보 -->
  260. <table border="1" style="font-size:10px; text-align:center;">
  261. <tr style="height:30px;">
  262. <th>freegiftValArr</th>
  263. <th>freegiftUsePointArr</th>
  264. </tr>
  265. <tr style="height:30px;">
  266. <td class="freegiftValArr"></td>
  267. <td class="freegiftUsePointArr"></td>
  268. </tr>
  269. </table>
  270. <br>
  271. <!-- 주문상세금액 -->
  272. <table border="1" style="font-size:10px; text-align:center;">
  273. <tr style="height:30px;">
  274. <th>cartSq</th>
  275. <th>orgCurrPrice</th>
  276. <th>cpn1DcSq</th>
  277. <th>cpn1DcAmt</th>
  278. <th>optAddPrice</th>
  279. <th>goodsQty</th>
  280. <th>ordAmt</th>
  281. <th>tmtb1Sq</th>
  282. <th>tmtb1DcAmt</th>
  283. <th>tmtb2Sq</th>
  284. <th>tmtb2DcAmt</th>
  285. <th>goodsCpnSq</th>
  286. <th>goodsCpnDcAmt</th>
  287. <th>cartCpnSq</th>
  288. <th>cartCpnDcAmt</th>
  289. <th>prePntDcAmt1</th>
  290. <th>dcSumAmt</th>
  291. <th>pntDcAmt1</th>
  292. <th>gfcdUseAmt1</th>
  293. <th>realOrdAmt1</th>
  294. <th>savePntAmt1</th>
  295. <th>shoDelvYn</th>
  296. <th>foreignYn</th>
  297. <th>orderMadeYn</th>
  298. </tr>
  299. <th:block th:each="delvAllCart, index : ${delvCartGoodsList}">
  300. <th:block th:if="${delvAllCart != null and #lists.size(delvAllCart) > 0}">
  301. <th:block th:each="goods, i : ${delvAllCart}">
  302. <tr style="height:30px;">
  303. <td class="cartSq" th:text="${goods.cartSq}"></td>
  304. <td class="orgCurrPrice" th:text="${goods.orgCurrPrice}"></td>
  305. <td class="cpn1CpnSq" th:text="${goods.cpn1CpnSq}"></td>
  306. <td class="cpn1DcAmt" th:text="${goods.orgCurrPrice} - ${goods.currPrice}"></td>
  307. <td class="optAddPrice" th:text="${goods.optAddPrice}"></td>
  308. <td class="goodsQty" th:text="${goods.goodsQty}"></td>
  309. <td class="ordAmt">0</td>
  310. <th:block th:if="${goods.applyQtySectionYn} == 'Y' and ${goods.qtyTmtbSq} > 0">
  311. <td class="tmtb1Sq" th:text="${goods.qtyTmtbSq}"></td>
  312. <td class="tmtb1DcAmt" th:text="${goods.tmtb1DcAmt}"></td>
  313. </th:block>
  314. <th:block th:if="${goods.applyQtySectionYn} != 'Y'">
  315. <td class="tmtb1Sq">0</td>
  316. <td class="tmtb1DcAmt">0</td>
  317. </th:block>
  318. <th:block th:if="${goods.applyAmtSectionYn} == 'Y' and ${goods.amtTmtbSq} > 0">
  319. <td class="tmtb2Sq" th:text="${goods.amtTmtbSq}"></td>
  320. <td class="tmtb2DcAmt" th:text="${goods.tmtb2DcAmt}"></td>
  321. </th:block>
  322. <th:block th:if="${goods.applyAmtSectionYn} != 'Y'">
  323. <td class="tmtb2Sq" >0</td>
  324. <td class="tmtb2DcAmt" >0</td>
  325. </th:block>
  326. <td class="goodsCpnSq">0</td>
  327. <td class="goodsCpnDcAmt">0</td>
  328. <td class="cartCpnSq">0</td>
  329. <td class="cartCpnDcAmt">0</td>
  330. <td class="prePntDcAmt1" th:text="${goods.prePntDcAmt}"></td>
  331. <td class="dcSumAmt">0</td>
  332. <td class="pntDcAmt1">0</td>
  333. <td class="gfcdUseAmt1">0</td>
  334. <td class="realOrdAmt1">0</td>
  335. <td class="savePntAmt1" th:text="${goods.savePntAmt}"></td>
  336. <td class="shotDelvYn" th:text="${goods.shotDelvYn}"></td>
  337. <td class="foreignBuyYn" th:text="${goods.foreignBuyYn}"></td>
  338. <td class="orderMadeYn" th:text="${goods.orderMadeYn}"></td>
  339. </tr>
  340. </th:block>
  341. </th:block>
  342. </th:block>
  343. </table>
  344. <br>
  345. <!-- 주문금액합계 -->
  346. <table border="1" style="font-size:10px; text-align:center;">
  347. <tr style="height:30px;">
  348. <th>orgGoodsSumAmt</th>
  349. <th>delvSumAmt</th>
  350. <th>freegiftUsePnt</th>
  351. <th>cpn1DcSumAmt</th>
  352. <th>ordSumAmt</th>
  353. <th>tmtb1DcSumAmt</th>
  354. <th>tmtb2DcSumAmt</th>
  355. <th>tmtbDcSumAmt</th>
  356. <th>goodsCpnDcSumAmt</th>
  357. <th>cartCpnDcSumAmt</th>
  358. <th>delvCpnDcSumAmt</th>
  359. <th>cpnDcSumAmt</th>
  360. <th>prePntDcAmt</th>
  361. <th>pntDcSumAmt</th>
  362. <th>gfcdUseSumAmt</th>
  363. <th>realOrdSumAmt</th>
  364. <th>savePntSumAmt</th>
  365. </tr>
  366. <tr style="height:30px;">
  367. <td class="orgGoodsSumAmt">0</td>
  368. <td class="delvSumAmt" th:text="${sumDelvFee}"></td>
  369. <td class="freegiftUsePnt">0</td>
  370. <td class="cpn1DcSumAmt">0</td>
  371. <td class="ordSumAmt">0</td>
  372. <td class="tmtb1DcSumAmt">0</td>
  373. <td class="tmtb2DcSumAmt">0</td>
  374. <td class="tmtbDcSumAmt">0</td>
  375. <td class="goodsCpnDcSumAmt">0</td>
  376. <td class="cartCpnDcSumAmt">0</td>
  377. <td class="delvCpnDcSumAmt">0</td>
  378. <td class="cpnDcSumAmt">0</td>
  379. <td class="prePntDcSumAmt">0</td>
  380. <td class="pntDcSumAmt">0</td>
  381. <td class="gfcdUseSumAmt">0</td>
  382. <td class="realOrdSumAmt">0</td>
  383. <td class="savePntSumAmt">0</td>
  384. </tr>
  385. </table>
  386. <div id="container" class="container od">
  387. <div class="wrap">
  388. <div class="content odPayment">
  389. <!-- 페이지특정 클래스 = odPayment -->
  390. <div class="cont_head">
  391. <h2>주문&#47;결제</h2>
  392. <div class="oder_steps">
  393. <ul>
  394. <li>01 쇼핑백</li>
  395. <li class="on">02 주문/결제</li>
  396. <li>03 주문완료</li>
  397. </ul>
  398. </div>
  399. </div>
  400. <div class="cont_body">
  401. <!-- CONT-BODY -->
  402. <form class="form_wrap">
  403. <div class="od_cont">
  404. <div class="sec_head">
  405. <div class="tbl type4">
  406. <table>
  407. <colgroup>
  408. <col width="240">
  409. <col width="*">
  410. </colgroup>
  411. <tbody>
  412. <tr>
  413. <th>총 <span class="c_primary bold" th:text="${delvFeeCdCnt}"></span> 건으로 나뉘어 배송 예정</th>
  414. <td class="t_l">
  415. <span>총알배송<em class="c_primary bold" th:text="${shotCnt}" id="shotCnt"></em>건</span>
  416. <span>STYLE24<em class="c_primary bold" th:text="${wmsCnt}" id="wmsCnt"></em>건</span>
  417. <span>업체직배송<em class="c_primary bold" th:text="${delvCnt}"></em>건</span>
  418. <span>예약배송<em class="c_primary bold" th:text="${resCnt}"></em>건</span>
  419. </td>
  420. </tr>
  421. </tbody>
  422. </table>
  423. </div>
  424. </div>
  425. <div class="sec_body">
  426. <div class="foldGroup">
  427. <ul>
  428. <!-- 주문고객정보 -->
  429. <li class="fold_mbinfo" id="custemerInfo" style="display:none"></li>
  430. <!-- //주문고객정보 -->
  431. <!-- 배송지정보 -->
  432. <li class="fold_mbinfo" id="deliveryAddrInfo" style="display:none"></li>
  433. <!-- //배송지정보 -->
  434. <!-- 사은품선택 -->
  435. <li id="freegiftInfo" style="display:none"></li>
  436. <!-- //사은품선택 -->
  437. <!-- 할인/혜택 사용 -->
  438. <li id="dcAmtInfo" style="display:none"></li>
  439. <!-- //할인/혜택 사용 -->
  440. <!-- 결제수단 선택 -->
  441. <li class="fold_paymethod" id="paymentInfo" style="display:none"></li>
  442. <!-- //결제수단 선택 -->
  443. </ul>
  444. </div>
  445. </div>
  446. </div>
  447. <div class="od_side">
  448. <div class="area_order">
  449. <div class="tit_box">
  450. <h3 class="subH2">주문내역</h3>
  451. <span> <em class="number" th:text="${goodsTotCnt}"></em>개의 상품</span>
  452. </div>
  453. <div id="orderListInfo" style="display:none">
  454. </div>
  455. <div class="od_amount_box">
  456. <dl>
  457. <div>
  458. <dt>상품금액</dt>
  459. <dd id="orgGoodsSumAmt" th:text="|${#numbers.formatInteger(orgGoodsSumAmt, 1, 'COMMA')}원|"></dd>
  460. </div>
  461. <div>
  462. <dt>배송비</dt>
  463. <dd id="delvSumAmt" th:text="|${#numbers.formatInteger(sumDelvFee, 1, 'COMMA')}원|"></dd>
  464. </div>
  465. <div>
  466. <dt>할인금액</dt>
  467. <th:block th:if="${cpn1DcSumAmt} > 0">
  468. <dd><span class="disc_amount" id="cpn1DcSumAmt" th:text="|-${#numbers.formatInteger(cpn1DcSumAmt, 1, 'COMMA')}원|"></span></dd>
  469. </th:block>
  470. <th:block th:if="${cpn1DcSumAmt} < 1">
  471. <dd><span class="disc_amount" id="cpn1DcSumAmt" th:text="|${#numbers.formatInteger(cpn1DcSumAmt, 1, 'COMMA')}원|"></span></dd>
  472. </th:block>
  473. </div>
  474. <div>
  475. <dt>다다익선할인금액</dt>
  476. <th:block th:if="${tmtbDcSumAmt} > 0">
  477. <dd><span class="disc_amount" id="tmtbDcSumAmt" th:text="|-${#numbers.formatInteger(tmtbDcSumAmt, 1, 'COMMA')}원|"></span></dd>
  478. </th:block>
  479. <th:block th:if="${tmtbDcSumAmt} < 1">
  480. <dd><span class="disc_amount" id="tmtbDcSumAmt" th:text="|${#numbers.formatInteger(tmtbDcSumAmt, 1, 'COMMA')}원|"></span></dd>
  481. </th:block>
  482. </div>
  483. <div>
  484. <dt>쿠폰할인금액</dt>
  485. <dd><span class="disc_amount" id="couponDcSumAmt"></span></dd>
  486. </div>
  487. <div>
  488. <dt>선포인트 사용</dt>
  489. <th:block th:if="${prePntDcAmt} > 0">
  490. <dd><span class="disc_amount" id="prePntDcAmt" th:text="|-${#numbers.formatInteger(prePntDcAmt, 1, 'COMMA')}원|"></span></dd>
  491. </th:block>
  492. <th:block th:if="${prePntDcAmt} < 1">
  493. <dd><span class="disc_amount" id="prePntDcAmt" th:text="|${#numbers.formatInteger(prePntDcAmt, 1, 'COMMA')}원|"></span></dd>
  494. </th:block>
  495. </div>
  496. <div>
  497. <dt>포인트 사용</dt>
  498. <dd><span class="disc_amount" id="pntDcAmt">0원</span></dd>
  499. </div>
  500. <div>
  501. <dt>상품권 사용</dt>
  502. <dd><span class="disc_amount" id="gfcdUseAmt">0원</span></dd>
  503. </div>
  504. </dl>
  505. </div>
  506. <div class="totalprice_box">
  507. <dl>
  508. <dt>총 결제 예정 금액</dt>
  509. <dd data-weight="price" data-font="lato">
  510. <span id="realOrdAmt"></span>원
  511. </dd>
  512. </dl>
  513. <p class="info_point">스타일 포인트
  514. <span class="save_point" id="savePntSumAmt" th:text="|${#numbers.formatInteger(savePntSumAmt, 1, 'COMMA')}P|"></span> 적립예정
  515. </p>
  516. </div>
  517. </div>
  518. </div>
  519. </form>
  520. <!-- // CONT-BODY -->
  521. </div>
  522. </div>
  523. </div>
  524. </div>
  525. </form>
  526. <!-- // container -->
  527. <footer id="footer"></footer>
  528. <!-- 배송지변경팝업 -->
  529. <div class="modal fade od_pop adrsChange_pop" id="adrsChangePop" tabindex="-1" role="dialog" aria-labelledby="adrsChangeLabel" aria-hidden="true"></div>
  530. <!-- 배송지수정팝업 -->
  531. <div class="modal fade od_pop adrsModify_pop" id="adrsModifyPop" tabindex="-1" role="dialog" aria-labelledby="adrsModifyLabel" aria-hidden="true"></div>
  532. <!-- 배송지추가팝업 -->
  533. <div class="modal fade od_pop adrsAdd_pop" id="adrsAddPop" tabindex="-1" role="dialog" aria-labelledby="adrsAddLabel" aria-hidden="true"></div>
  534. <!-- 배송요청사항수정 팝업 -->
  535. <div class="modal fade od_pop rqstModify_pop" id="rqstModifyPop" tabindex="-1" role="dialog" aria-labelledby="rqstModifyLabel" aria-hidden="true"></div>
  536. <!-- 사은품지급안내 팝업 -->
  537. <div class="modal fade od_pop infoGift_pop" id="infoGiftPop" tabindex="-1" role="dialog" aria-labelledby="infoGiftLabel" aria-hidden="true"></div>
  538. <script th:inline="javascript">
  539. // 배송관련정보 변수선언
  540. var cartGoodsList = [[${cartGoodsList}]] // 배송목록
  541. var shotCnt = [[${shotCnt}]]; // 자사 총알 배송건수
  542. var wmsCnt = [[${wmsCnt}]]; // 자사 일반 배송건수
  543. var shotWmsCnt = [[${shotWmsCnt}]]; // 자사 총알,일반 배송건수
  544. var resCnt = [[${resCnt}]]; // 자사 예약 배송건수
  545. var delvCnt = [[${delvCnt}]]; // 입점 일반 배송건수
  546. var orgSumDelvFee = [[${sumDelvFee}]]; // 최초배송비합계
  547. var prePntDcAmt = [[${prePntDcAmt}]]; // 선포인트사용가능금액
  548. var custNm = [[${order.custNm}]]; // 주문자명
  549. var cellPhnno = [[${order.cellPhnno}]]; // 핸드폰번호
  550. var email = [[${order.email}]]; // 이메일
  551. var recipZipcode = [[${order.recipZipcode}]]; // 우편번호
  552. var recipBaseAddr = [[${order.recipBaseAddr}]]; // 기본주소
  553. var recipDtlAddr = [[${order.recipDtlAddr}]]; // 상세주소
  554. var cartSqArr = [[${order.cartSqArr}]]; // 장바구니시퀀스 목록
  555. var shotDelvUseYn = [[${order.shotDelvUseYn}]]; // 총알배송사용여부(장바구니)
  556. var shotDelvYn = [[${order.shotDelvUseYn}]]; // 총알배송사용여부(장바구니)
  557. var foreignBuyYn = [[${foreignBuyYn}]]; // 해외구매대행여부
  558. var orderMadeYn = [[${orderMadeYn}]]; // 주문제작상품여부
  559. var custCpnSq = 0;
  560. var cpnIndex = 0;
  561. var cpnApplyTemp = false;
  562. //AJAX 로드를 위한 변수 설정
  563. var jsonObj = {};
  564. var jsonData = null;
  565. // 컨텐츠 호출
  566. $(document).ready( function() {
  567. // 장바구니시퀀스 배열 변환
  568. cartSqArr = String(cartSqArr).split(",");
  569. // AJAX 로드를 위한 변수 설정
  570. jsonObj = {
  571. "custNm" : custNm
  572. , "cellPhnno" : cellPhnno
  573. , "email" : email
  574. , "recipZipcode" : recipZipcode
  575. , "recipBaseAddr" : recipBaseAddr
  576. , "recipDtlAddr" : recipDtlAddr
  577. , "cartSqArr" : cartSqArr
  578. , "dispYn" : "N"
  579. , "shotDelvYn" : shotDelvUseYn
  580. , "foreignBuyYn" : foreignBuyYn
  581. , "orderMadeYn" : orderMadeYn
  582. }
  583. jsonData = JSON.stringify(jsonObj);
  584. // 1. AJAX 정보(회원정보로드)
  585. custemerInfoSet(jsonData);
  586. });
  587. // 1. 함수기능 정의
  588. // 1.1 고객정보로드
  589. var custemerInfoSet = function(jsonData) {
  590. $.ajax( {
  591. type : "POST",
  592. url : '/order/custemerInfo',
  593. data : jsonData,
  594. dataType : 'html',
  595. beforeSend : function(xhr, settings) {
  596. xhr.setRequestHeader("AJAX" , "true");
  597. xhr.setRequestHeader('Accept' , 'application/json');
  598. xhr.setRequestHeader('Content-Type' , 'application/json');
  599. gagajf.showProgressbar(true);
  600. },
  601. success : function(result) {
  602. if (result != null) {
  603. $("#custemerInfo").css("display", "block");
  604. $("#custemerInfo").html(result);
  605. // 고객정보설정
  606. $(".custNm").text($("input[name='custNm'").val());
  607. $(".email").text($("input[name='email'").val());
  608. $(".cellPhnno").text($("input[name='cellPhnno'").val());
  609. }
  610. // 1.2 배송정보로드
  611. deliveryAddrInfoSet(jsonData);
  612. }
  613. });
  614. }
  615. // 1.2 배송정보로드
  616. var deliveryAddrInfoSet = function(jsonData) {
  617. $.ajax( {
  618. type : "POST",
  619. url : '/order/deliveryAddrInfo',
  620. data : jsonData,
  621. dataType : 'html',
  622. beforeSend : function(xhr, settings) {
  623. xhr.setRequestHeader("AJAX" , "true");
  624. xhr.setRequestHeader('Accept' , 'application/json');
  625. xhr.setRequestHeader('Content-Type' , 'application/json');
  626. gagajf.showProgressbar(true);
  627. },
  628. success : function(result) {
  629. if (result != null) {
  630. $("#deliveryAddrInfo").css("display", "block");
  631. $("#deliveryAddrInfo").html(result);
  632. // 배송정보설정
  633. $(".recipZipcode").text($("input[name='recipZipcode'").val());
  634. $(".recipBaseAddr").text($("input[name='recipBaseAddr'").val());
  635. $(".recipDtlAddr").text($("input[name='recipDtlAddr'").val());
  636. $(".delvMemo").text($("input[name='delvMemo'").val());
  637. $(".foreignBuyYn").text($("input[name='foreignBuyYn'").val());
  638. $(".orderMadeYn").text($("input[name='orderMadeYn'").val());
  639. }
  640. // 1.3 총알배송가능 지역, 총알배송 가능 시간 체크(초기로드정보)
  641. fnGetDailyDeliveryCheck(true);
  642. }
  643. });
  644. }
  645. // 1.3 총알배송가능 지역, 총알배송 가능 시간 체크
  646. var fnGetDailyDeliveryCheck = function (temp) {
  647. // 장바구니 총알배송 사용여부 체크 N
  648. if (shotDelvUseYn == "N") {
  649. // 초기에 한번 데이타 로드
  650. if (temp) {
  651. // 1.4 주문상품목록로드
  652. orderListInfoSet(jsonData, temp);
  653. }
  654. } else {
  655. // 배송지 우편번호 체크
  656. var zipcode = $("input[name='recipZipcode']").val();
  657. // 총알배송여부 체크 배송지정보 존재여부 체크
  658. if (zipcode == null || zipcode == '') {
  659. //alert("배송지정보가 없습니다. 기본 총알배송 가능지역으로 설정 합니다.");
  660. zipcode = "04320"; // 기본 서울역 우편번호로 설정
  661. }
  662. // TODO
  663. var shotDelvObj = {"zipNo" : zipcode};
  664. gagajf.ajaxJsonSubmit(
  665. "/order/getDailyDeliveryCheck"
  666. , JSON.stringify(shotDelvObj)
  667. , function (result) {
  668. // 총알배송여부체크
  669. var tempShotDelvYn = "N";
  670. if (parseInt(result) > 0) {
  671. tempShotDelvYn = "Y";
  672. }
  673. // json 값 설정
  674. var orderListObj = {"cartSqArr":cartSqArr, "shotDelvYn":tempShotDelvYn};
  675. var orderListJsonData = JSON.stringify(orderListObj);
  676. if (temp) {
  677. // 1.3 주문상품목록로드
  678. orderListInfoSet(orderListJsonData, temp);
  679. } else {
  680. if (tempShotDelvYn != shotDelvYn) {
  681. orderListInfoSet(orderListJsonData, temp);
  682. }
  683. }
  684. shotDelvYn = tempShotDelvYn;
  685. }
  686. )
  687. }
  688. }
  689. // 1.4 주문상품목록로드
  690. var orderListInfoSet = function(orderListJsonData, temp) {
  691. $.ajax( {
  692. type : "POST",
  693. url : '/order/orderListInfo',
  694. data : orderListJsonData,
  695. dataType : 'html',
  696. beforeSend : function(xhr, settings) {
  697. xhr.setRequestHeader("AJAX" , "true");
  698. xhr.setRequestHeader('Accept' , 'application/json');
  699. xhr.setRequestHeader('Content-Type' , 'application/json');
  700. gagajf.showProgressbar(true);
  701. },
  702. success : function(result) {
  703. if (result != null) {
  704. $("#orderListInfo").css("display", "block");
  705. $("#orderListInfo").html(result);
  706. }
  707. // 1.5 사은품정보로드
  708. if (temp) {
  709. freegiftInfoSet(jsonData);
  710. }
  711. }
  712. });
  713. }
  714. // 1.5 사은품정보로드
  715. var freegiftInfoSet = function(jsonData) {
  716. $.ajax( {
  717. type : "POST",
  718. url : '/order/freegiftInfo',
  719. data : jsonData,
  720. dataType : 'html',
  721. beforeSend : function(xhr, settings) {
  722. xhr.setRequestHeader("AJAX" , "true");
  723. xhr.setRequestHeader('Accept' , 'application/json');
  724. xhr.setRequestHeader('Content-Type' , 'application/json');
  725. gagajf.showProgressbar(true);
  726. },
  727. success : function(result) {
  728. if (result != null) {
  729. $("#freegiftInfo").html(result);
  730. var total_gift = 0;
  731. var total_deduct = 0;
  732. // 2.2 사은품선택 라디오 버튼 기능
  733. $(".freegiftRdo").on("click", function() {
  734. total_gift = 0;
  735. total_deduct = 0;
  736. $(".freegiftRdo").each(function(){
  737. if ($(this).attr("allYn") == "Y" ) {
  738. total_gift += 1;
  739. }
  740. // 라디오버튼 사은품 체크
  741. if ($(this).is(":checked")) {
  742. // 수령거부가 아닐때 체크
  743. if ($(this).val() != "noSel") {
  744. total_gift += 1;
  745. total_deduct += parseInt($(this).attr("usepoint"));
  746. }
  747. }
  748. });
  749. $(".total_gift").text(total_gift); // 사은품총선택개수
  750. $(".total_deduct").text(total_deduct.addComma()); // 사은품총사용포인트
  751. $(".freegiftUsePnt").text(total_deduct);
  752. // 포인트초기화기능
  753. pntDcAmtReset();
  754. });
  755. // 사은품테이블 그리기
  756. $(".gift_box").each(function(){
  757. $(this).find(".freegiftRdo").each(function(){
  758. if ($(this).attr("allYn") == "Y" ) {
  759. total_gift += 1;
  760. }
  761. $(".total_gift").text(total_gift); // 사은품총선택개수
  762. });
  763. });
  764. }
  765. // 1.6 결제타입로드
  766. paymentInfoSet(jsonData);
  767. }
  768. });
  769. }
  770. // 1.6 결제타입로드
  771. var paymentInfoSet = function(jsonData) {
  772. $.ajax( {
  773. type : "POST",
  774. url : '/order/paymentInfo',
  775. data : jsonData,
  776. dataType : 'html',
  777. beforeSend : function(xhr, settings) {
  778. xhr.setRequestHeader("AJAX" , "true");
  779. xhr.setRequestHeader('Accept' , 'application/json');
  780. xhr.setRequestHeader('Content-Type' , 'application/json');
  781. gagajf.showProgressbar(true);
  782. },
  783. success : function(result) {
  784. if (result != null) {
  785. $("#paymentInfo").css("display", "block");
  786. $("#paymentInfo").html(result);
  787. // 1.8 할인영역 설정
  788. dcAmtInfoSet(jsonData);
  789. }
  790. }
  791. });
  792. }
  793. // 1.7 프로모션 쿠폰 적용 함수
  794. var serialCpnApply = function(){
  795. let data = {
  796. rdCpnNm : $("#payForm #serialCpnNm").val()
  797. }
  798. let jsonData = JSON.stringify(data);
  799. $.ajax( {
  800. type : "POST",
  801. url : '/cart/list/serialCpnApply',
  802. contentType : 'application/json',
  803. dataType : 'json',
  804. data : jsonData,
  805. success : function(result) {
  806. var jsonObj = {"cartSqArr" : cartSqArr,"dispYn" : "Y"};
  807. var jsonData = JSON.stringify(jsonObj);
  808. // 성공일때는 쿠폰정보 및 포인트 정보 reset
  809. if (result.serialCpnInfo.result == "SUCCESS") {
  810. // 1.8 할인영역 재로드
  811. dcAmtInfoSet(jsonData);
  812. } else {
  813. alert(result.serialCpnInfo.result);
  814. }
  815. }
  816. });
  817. }
  818. // 1.8 할인영역 설정 (쿠폰, 선포인트, 포인트, 상품권)
  819. var dcAmtInfoSet = function(jsonData) {
  820. // 1.8.1 할인정보로드
  821. $.ajax( {
  822. type : "POST",
  823. url : '/order/dcAmtInfo',
  824. data : jsonData,
  825. dataType : 'html',
  826. beforeSend : function(xhr, settings) {
  827. xhr.setRequestHeader("AJAX" , "true");
  828. xhr.setRequestHeader('Accept' , 'application/json');
  829. xhr.setRequestHeader('Content-Type' , 'application/json');
  830. gagajf.showProgressbar(true);
  831. },
  832. success : function(result) {
  833. if (result != null) {
  834. $("#dcAmtInfo").css("display", "block");
  835. $("#dcAmtInfo").html(result);
  836. // 1.8.2 쿠폰적용초기화(할인율최고)
  837. custCpnInit();
  838. // 1.8.3 쿠폰 SELECT BOX 기능 설정(js적용)
  839. $('.select_custom.type1').each(function(index){
  840. var selecter01 = new sCombo($(this));
  841. // 선택박스 버튼기능 구현
  842. $(this).find("ul li").each(function(i){
  843. // SELECT BOX 버튼 기능 설정
  844. $(this).on("click", function(){
  845. // 쿠폰 선택없음
  846. if ($(this).prop("value") == 0) {
  847. // 쿠폰 선택없음
  848. cpnApplyDel($(this));
  849. }
  850. // 쿠폰선택
  851. else {
  852. // 쿠폰중복체크 후 적용
  853. if (custCpnDuplicationCheck($(this).prop("value"), index)) {
  854. // 쿠폰적용
  855. custCpnApply($(this));
  856. } else {
  857. alert("이미 적용된 쿠폰 입니다.");
  858. // 쿠폰적용불가
  859. custCpnNotApply($(this));
  860. }
  861. // 쿠폰할인금액 SUM
  862. custCpnSumAmtCal();
  863. // 최대할인혜택적용 체크해제
  864. if ($("#chk-maxdisc").is(":checked")) {
  865. $("#chk-maxdisc").attr("checked", false);
  866. }
  867. }
  868. });
  869. });
  870. });
  871. // 1.8.4 쿠폰 최대할인금액 초기화 버튼 설정
  872. $("#chk-maxdisc").on("click", function(){
  873. if ($(this).is(":checked")) {
  874. custCpnInit();
  875. }
  876. });
  877. // 1.8.5 쿠폰할인적용 삭제 버튼
  878. $(".btn_del_coupon").on("click", function(){
  879. //선택없음선택
  880. $(this).parent().parent().find("ul li").each(function(i){
  881. if (i == 0) {
  882. cpnApplyDel($(this)); // 쿠폰 선택없음
  883. }
  884. });
  885. });
  886. // 1.8.6 선포인트 적용 버튼 기능
  887. $("input[name='rdi-beforpoint']").each(function(){
  888. // 선포인트 초기 설정 사용함
  889. if ($(this).val() == "Y") {
  890. $(this).attr("checked", true);
  891. }
  892. // 버튼기능 구현
  893. $(this).on("click", function(){
  894. var rmPrePntAmt = parseInt($("input[name='rmPrePntAmt']").val());
  895. // 선포인트적용
  896. if ($(this).val() == "Y") {
  897. $("#prePntDcAmt").text("-"+rmPrePntAmt.addComma()+"원");
  898. } else {
  899. $("#prePntDcAmt").text("0원");
  900. }
  901. // 쿠폰할인금액 SUM
  902. custCpnSumAmtCal();
  903. });
  904. });
  905. // 1.8.7 포인트 적용버튼 기능
  906. $("#btn_point_apply").on("click", function(){
  907. var rmPntAmt = parseInt($("input[name='rmPntAmt']").val());
  908. var freegiftUsePnt = parseInt($(".freegiftUsePnt").text());
  909. var pntDcAmt = parseInt($("input[name='pntDcAmtStr']").val());
  910. var realOrdAmt = parseInt($(".realOrdSumAmt").text());
  911. var applyPntDcAmt = (realOrdAmt * 40) / 100;
  912. rmPntAmt = rmPntAmt - freegiftUsePnt;
  913. // 입력여부체크
  914. if (pntDcAmt < 1) {
  915. alert("사용할 포인트를 입력해주세요");
  916. // 포인트리셋기능
  917. pntDcAmtReset();
  918. return false;
  919. }
  920. // 보유포인트보다 초과 사용 불가
  921. if (pntDcAmt > rmPntAmt) {
  922. alert("보유포인트 보다 초과 사용 할 수 없습니다.");
  923. // 포인트리셋기능
  924. pntDcAmtReset();
  925. return false;
  926. }
  927. // TODO 포인트 사용금액 1000P 이상 사용
  928. if (pntDcAmt < 1000) {
  929. alert("포인트는 최소 1,000P이상 사용해야 합니다.");
  930. // 포인트리셋기능
  931. pntDcAmtReset();
  932. return false;
  933. }
  934. // 실결제금액보다 크게 적용 되었을때 적용 불가능
  935. if (pntDcAmt > applyPntDcAmt) {
  936. alert("결제금액의 최대 40%를 초과 사용 할 수 없습니다.");
  937. // 포인트리셋기능
  938. pntDcAmtReset();
  939. return false;
  940. }
  941. // 포인트 적용
  942. $(".pntDcSumAmt").text(pntDcAmt);
  943. $("#pntDcAmt").text("-"+pntDcAmt.addComma()+"원");
  944. // 상품권리렛기능
  945. gfcdUseAmtReset();
  946. });
  947. // 1.8.8 상품권 적용버튼 기능
  948. $("#btn_gfcd_apply").on("click", function(){
  949. var rmGfcdAmt = parseInt($("input[name='rmGfcdAmt']").val());
  950. var gfcdUseAmt = parseInt($("input[name='gfcdUseAmtStr']").val());
  951. // 입력여부체크
  952. if (gfcdUseAmt < 1 || $("input[name='gfcdUseAmtStr']").val() == "") {
  953. alert("사용할 금액을 입력해주세요");
  954. // 상품권리셋기능
  955. gfcdUseAmtReset();
  956. return false;
  957. }
  958. // 보유금액보다 초과 사용 불가
  959. if (gfcdUseAmt > rmGfcdAmt) {
  960. alert("보유금액 보다 초과 사용 할 수 없습니다.");
  961. // 상품권리셋기능
  962. gfcdUseAmtReset();
  963. return false;
  964. }
  965. // TODO 포인트 사용금액 1000원 이상 사용
  966. if (gfcdUseAmt < 1000) {
  967. alert("상품권 사용금액은 최소 1,000원 이상 사용해야 합니다.");
  968. // 상품권리셋기능
  969. gfcdUseAmtReset();
  970. return false;
  971. }
  972. // 상품권 적용
  973. $(".gfcdUseSumAmt").text(gfcdUseAmt);
  974. $("#gfcdUseAmt").text("-"+gfcdUseAmt.addComma()+"원");
  975. // 금액전체계산
  976. custCpnSumAmtCal();
  977. });
  978. }
  979. }
  980. });
  981. }
  982. // 1.9 쿠폰 최대할인율 쿠폰적용
  983. var custCpnInit = function() {
  984. // 쿠폰적용없음적용
  985. $(".select_custom.type1").each(function(index){
  986. // select box 쿠폰 적용
  987. var cpnCartSq = $(this).find("input[name='cpnCartSq']").val();
  988. // 장바구니시퀀스 체크
  989. $(".cartSq").each(function(){
  990. if (cpnCartSq == $(this).text()) {
  991. $(this).parent().find(".goodsCpnSq").text("0"); // 상품쿠폰시퀀스
  992. $(this).parent().find(".goodsCpnDcAmt").text("0"); // 상품쿠폰할인금액
  993. }
  994. });
  995. $(this).find("input[name='custCpnSq']").val("0");
  996. $(this).find("input[name='cpnDcAmt']").val("0");
  997. $(this).find(".select").text("선택없음");
  998. $(this).find(".cp_discount").css("display", "none");
  999. });
  1000. // 최대할인율 쿠폰적용
  1001. $('.select_custom.type1').each(function(index){
  1002. cpnIndex = 0;
  1003. cpnApplyTemp = false;
  1004. // select 박스 반복문 실행
  1005. $(this).find("ul li").each(function(i){
  1006. cpnIndex++;
  1007. // 1이상부터 중복 체크
  1008. if (cpnApplyTemp == false) {
  1009. if (cpnIndex > 1) {
  1010. if (custCpnDuplicationCheck($(this).prop("value"), index)) {
  1011. // 쿠폰적용
  1012. custCpnApply($(this));
  1013. // 쿠폰할인적용
  1014. cpnApplyTemp = true;
  1015. }
  1016. }
  1017. }
  1018. });
  1019. });
  1020. // 포인트기능 리렛
  1021. pntDcAmtReset();
  1022. }
  1023. // 1.10 쿠폰중복사용체크
  1024. var custCpnDuplicationCheck = function(custCpnSq, index) {
  1025. var selCustSq = 0;
  1026. var cnt = 0;
  1027. // 쿠폰중본사용체크
  1028. $("input[name='custCpnSq']").each(function(i){
  1029. if (index != i) {
  1030. selCustSq = $(this).val();
  1031. if (selCustSq == custCpnSq) {
  1032. cnt++;
  1033. }
  1034. }
  1035. });
  1036. // 쿠폰적용불가
  1037. if (cnt > 0) {
  1038. return false;
  1039. }
  1040. // 쿠폰적용가능
  1041. else {
  1042. return true;
  1043. }
  1044. }
  1045. // 1.11 쿠폰중복체크 후 적용가능
  1046. var custCpnApply = function(obj) {
  1047. // select box 쿠폰 적용
  1048. var cpnType = obj.parent().parent().find("input[name='cpnType']").val();
  1049. // 상품쿠폰적용
  1050. if (cpnType == "goodsCpn") {
  1051. // 적용된 할인금액 text 설정
  1052. var dcAmtStr = "- " + parseInt(obj.attr("data")).addComma() + " 원 할인적용";
  1053. obj.parent().parent().parent().parent().parent().find(".cp_amount").text(dcAmtStr);
  1054. var cpnCartSq = obj.parent().parent().find("input[name='cpnCartSq']").val();
  1055. // 장바구니시퀀스 체크
  1056. $(".cartSq").each(function(){
  1057. if (cpnCartSq == $(this).text()) {
  1058. $(this).parent().find(".goodsCpnSq").text(obj.prop("value")); // 상품쿠폰시퀀스
  1059. $(this).parent().find(".goodsCpnDcAmt").text(obj.attr("data")); // 상품쿠폰할인금액
  1060. }
  1061. });
  1062. obj.parent().parent().find("input[name='cpnDcAmt']").val(obj.attr("data"));
  1063. }
  1064. // 장바구니쿠폰적용
  1065. else if (cpnType == "cartCpn") {
  1066. var dcWay = obj.parent().find("input[name='dcWay']").val();
  1067. var dcVal = obj.parent().find("input[name='dcVal']").val();
  1068. var cartCpnDcSumAmt = 0;
  1069. var tempSumAmt = 0;
  1070. var cartSqLen = $(".cartSq").length;
  1071. var leftAmt = 0;
  1072. var index = 1;
  1073. // 장바구니쿠폰 해당 장바구니상품들 할인가 적용
  1074. obj.find("input[name='cartCpnCartSq']").each(function(){
  1075. var cartCpnCartSq = $(this).val();
  1076. var cartCpnDcAmt = 0;
  1077. // 장바구니시퀀스 체크
  1078. $(".cartSq").each(function(){
  1079. if (cartCpnCartSq == $(this).text()) {
  1080. var orgCurrPrice = parseInt($(this).parent().find(".orgCurrPrice").text());
  1081. var tmtb1DcAmt = parseInt($(this).parent().find(".tmtb1DcAmt").text());
  1082. var tmtb2DcAmt = parseInt($(this).parent().find(".tmtb2DcAmt").text());
  1083. var goodsCpnDcAmt = parseInt($(this).parent().find(".goodsCpnDcAmt").text());
  1084. var tempAmt = orgCurrPrice - tmtb1DcAmt - tmtb2DcAmt - goodsCpnDcAmt;
  1085. tempSumAmt = tempSumAmt + tempAmt;
  1086. // 할인율일때 할인금액
  1087. if (dcWay == "G240_20") {
  1088. cartCpnDcAmt = (tempAmt * dcVal) / 100;
  1089. cartCpnDcSumAmt = cartCpnDcSumAmt + cartCpnDcAmt;
  1090. $(this).parent().find(".cartCpnSq").val(obj.prop("value"));
  1091. $(this).parent().find(".cartCpnDcAmt").val(cartCpnDcAmt);
  1092. }
  1093. }
  1094. });
  1095. });
  1096. // 금액일때 할인금액 적용
  1097. if (dcWay == "G240_10") {
  1098. cartCpnDcSumAmt = dcVal;
  1099. leftAmt = dcVal;
  1100. index = 1;
  1101. // 장바구니쿠폰 해당 장바구니상품들 할인가 적용
  1102. obj.find("input[name='cartCpnCartSq']").each(function(){
  1103. var cartCpnCartSq = $(this).val();
  1104. var cartCpnDcAmt = 0;
  1105. // 장바구니시퀀스 체크
  1106. $(".cartSq").each(function(){
  1107. if (cartCpnCartSq == $(this).text()) {
  1108. var orgCurrPrice = parseInt($(this).parent().find(".orgCurrPrice").text());
  1109. var tmtb1DcAmt = parseInt($(this).parent().find(".tmtb1DcAmt").text());
  1110. var tmtb2DcAmt = parseInt($(this).parent().find(".tmtb2DcAmt").text());
  1111. var goodsCpnDcAmt = parseInt($(this).parent().find(".goodsCpnDcAmt").text());
  1112. var tempAmt = orgCurrPrice - tmtb1DcAmt - tmtb2DcAmt - goodsCpnDcAmt;
  1113. var tempDiv = parseInt((tempAmt / tempSumAmt) * 100);
  1114. var cartCpnDcAmt = 0;
  1115. if (index == cartSqLen) {
  1116. cartCpnDcAmt = leftAmt;
  1117. } else {
  1118. cartCpnDcAmt = parseInt((cartCpnDcSumAmt * tempDiv) / 100);
  1119. leftAmt = leftAmt - cartCpnDcAmt;
  1120. }
  1121. $(this).parent().find(".cartCpnSq").text(obj.prop("value"));
  1122. $(this).parent().find(".cartCpnDcAmt").text(cartCpnDcAmt);
  1123. index++;
  1124. }
  1125. });
  1126. });
  1127. }
  1128. obj.parent().parent().find("input[name='cpnDcAmt']").val(cartCpnDcSumAmt);
  1129. var dcAmtStr = "- " + cartCpnDcSumAmt.addComma() + " 원 할인적용";
  1130. obj.parent().parent().parent().parent().parent().find(".cp_amount").text(dcAmtStr);
  1131. }
  1132. // 배송비쿠폰적용
  1133. else if (cpnType == "delvCpn") {
  1134. // 적용된 할인금액 text 설정
  1135. var dcAmtStr = "- " + parseInt(obj.attr("data")).addComma() + " 원 할인적용";
  1136. obj.parent().parent().parent().parent().parent().find(".cp_amount").text(dcAmtStr);
  1137. var cpnCartSq = obj.parent().parent().find("input[name='cpnCartSq']").val();
  1138. obj.parent().parent().find("input[name='cpnDcAmt']").val(obj.attr("data"));
  1139. obj.parent().parent().find("input[name='delvFeeCd']").val(obj.attr("delvfeecd"));
  1140. $(".delvCpnDcSumAmt").text(obj.attr("data"));
  1141. }
  1142. // select box 쿠폰 적용 (공통적용)
  1143. obj.parent().parent().find("input[name='custCpnSq']").val(obj.prop("value"));
  1144. obj.parent().parent().find(".select").text(obj.text());
  1145. // 선택된 할인금액 노출
  1146. obj.parent().parent().parent().parent().parent().find(".cp_discount").css("display", "block");
  1147. // 포인트기능 리렛
  1148. pntDcAmtReset();
  1149. }
  1150. // 1.12 쿠폰중복체크 후 적용불가
  1151. var custCpnNotApply = function(obj) {
  1152. // 이전에 등록된 쿠폰시퀀스
  1153. var custCpnSq = obj.parent().parent().find("input[name='custCpnSq']").val();
  1154. // 이전에 등록된 쿠폰시퀀스 비교후 데이타 원복
  1155. obj.parent().find("li").each(function(){
  1156. if ($(this).prop("value") == custCpnSq) {
  1157. $(this).parent().parent().find(".select").text($(this).text());
  1158. if (custCpnSq == 0) {
  1159. $(this).parent().parent().parent().parent().parent().find(".cp_discount").css("display", "none");
  1160. } else {
  1161. $(this).parent().parent().parent().parent().parent().find(".cp_discount").css("display", "block");
  1162. }
  1163. }
  1164. });
  1165. // 포인트기능 리렛
  1166. pntDcAmtReset();
  1167. }
  1168. // 1.13 쿠폰 선택없음 기능 구현
  1169. var cpnApplyDel = function(obj) {
  1170. // 쿠폰타입(상품쿠폰, 장바구니쿠폰, 배송비쿠폰)
  1171. var cpnType = obj.parent().parent().find("input[name='cpnType']").val();
  1172. // 상품쿠폰적용
  1173. if (cpnType == "goodsCpn") {
  1174. // select box 쿠폰 적용
  1175. var cpnCartSq = obj.parent().parent().find("input[name='cpnCartSq']").val();
  1176. // 장바구니시퀀스 체크
  1177. $(".cartSq").each(function(){
  1178. if (cpnCartSq == $(this).text()) {
  1179. $(this).parent().find(".goodsCpnSq").text("0"); // 상품쿠폰시퀀스
  1180. $(this).parent().find(".goodsCpnDcAmt").text("0"); // 상품쿠폰할인금액
  1181. }
  1182. });
  1183. }
  1184. // 장바구니쿠폰적용
  1185. else if (cpnType == "cartCpn") {
  1186. // 장바구니쿠폰 시퀀스 0, 장바구니할인금액 0
  1187. $(".cartSq").each(function(){
  1188. $(this).parent().find(".cartCpnSq").text("0");
  1189. $(this).parent().find(".cartCpnDcAmt").text("0");
  1190. });
  1191. }
  1192. // 배송비쿠폰적용
  1193. else if (cpnType == "delvCpn") {
  1194. // 장바구니쿠폰 시퀀스 0, 장바구니할인금액 0
  1195. //$("input[name='custCpnSq']").each(function(){
  1196. //$(this).parent().find("input[name='delvFeeCd']").val("0");
  1197. //});
  1198. obj.parent().parent().find("input[name='delvFeeCd']").val("0");
  1199. }
  1200. obj.parent().parent().find("input[name='custCpnSq']").val("0");
  1201. obj.parent().parent().find("input[name='cpnDcAmt']").val("0");
  1202. obj.parent().parent().find(".select").text("선택없음");
  1203. obj.parent().parent().parent().parent().parent().find(".cp_discount").css("display", "none");
  1204. // 포인트기능 리렛
  1205. pntDcAmtReset();
  1206. // 최대할인혜택적용 체크해제
  1207. if ($("#chk-maxdisc").is(":checked")) {
  1208. $("#chk-maxdisc").attr("checked", false);
  1209. }
  1210. }
  1211. // 1.14 선포인트리셋기능 (사용안함)
  1212. var prePntDcAmtReset = function() {
  1213. var rmPrePntAmt = parseInt($("input[name='rmPrePntAmt']").val());
  1214. $("input[name='prePntDcAmt']").val(rmPrePntAmt);
  1215. // 선포인트사용여부 체크 후 적용
  1216. $("input[name='rdi-beforpoint']").each(function(){
  1217. // 선포인트 초기 설정 사용함
  1218. if ($(this).val() == "Y") {
  1219. $(this).attr("checked", true);
  1220. }
  1221. });
  1222. $("#prePntDcAmt").text("-"+rmPrePntAmt.addComma()+"원");
  1223. // 포인트기능 리렛
  1224. pntDcAmtReset();
  1225. }
  1226. // 1.15 포인트리셋기능
  1227. var pntDcAmtReset = function() {
  1228. $(".pntDcSumAmt").text("0");
  1229. $("input[name='pntDcAmtStr']").val("");
  1230. $("#pntDcAmt").text("0원");
  1231. // 상품권리셋기능
  1232. gfcdUseAmtReset();
  1233. }
  1234. // 1.16 상품권리셋기능
  1235. var gfcdUseAmtReset = function() {
  1236. $(".gfcdUseSumAmt").text("0");
  1237. $("input[name='gfcdUseAmtStr']").val("");
  1238. $("#gfcdUseAmt").text("0원");
  1239. // 금액전체계산
  1240. custCpnSumAmtCal();
  1241. }
  1242. // 1.17 쿠폰할인금액합계설정(금액전체계산)
  1243. var custCpnSumAmtCal = function() {
  1244. var cpnDcSumAmt = 0;
  1245. var cpnApplyCnt = 0;
  1246. $("input[name='cpnDcAmt']").each(function(){
  1247. cpnDcSumAmt = cpnDcSumAmt + parseInt($(this).val());
  1248. // 적용된 쿠폰 수량
  1249. if (parseInt($(this).val()) > 0) {
  1250. cpnApplyCnt++;
  1251. }
  1252. });
  1253. // 쿠폰영역
  1254. $(".maxdisc_amount").text("(-" + cpnDcSumAmt.addComma() + "원)"); // 쿠폰할인금액합계
  1255. $("#cpnApplyCnt").text(cpnApplyCnt + "장");
  1256. // 상품목록영역
  1257. $("#couponDcSumAmt").text("-" + cpnDcSumAmt.addComma() + "원"); // 쿠폰할인금액합계
  1258. $(".cpnDcSumAmt").text(cpnDcSumAmt);
  1259. // 배송비할인적용
  1260. $("input[name='cpnType']").each(function(){
  1261. if ($(this).val() == "delvCpn") {
  1262. var delvSumAmt = parseInt(orgSumDelvFee) - parseInt($(this).parent().find("input[name='cpnDcAmt']").val());
  1263. // 최종배송비
  1264. $("#delvSumAmt").text(delvSumAmt.addComma() + "원");
  1265. $(".delvSumAmt").text(delvSumAmt);
  1266. }
  1267. });
  1268. // 2021.03.06 주문상세 테이블 적용
  1269. // 포인트금액 상품상세에 포인트금액 분배 작업
  1270. var prePntDcAmtYn = $("input[name='rdi-beforpoint']:checked").val();
  1271. var leftPntAmt = parseInt($(".pntDcSumAmt").text());
  1272. var leftGfcdAmt = parseInt($(".gfcdUseSumAmt").text());
  1273. var cartSqLenght = $(".cartSq").length;
  1274. var index = 1;
  1275. var orgGoodsSumAmt = 0;
  1276. var cpn1DcSumAmt = 0;
  1277. var ordSumAmt = 0;
  1278. var tmtb1DcSumAmt = 0;
  1279. var tmtb2DcSumAmt = 0;
  1280. var tmtbDcSumAmt = 0;
  1281. var goodsCpnDcSumAmt = 0;
  1282. var cartCpnDcSumAmt = 0;
  1283. var delvCpnDcSumAmt = 0;
  1284. var cpnDcSumAmt = 0;
  1285. var prePntDcSumAmt = 0;
  1286. var pntDcSumAmt = parseInt($(".pntDcSumAmt").text());
  1287. var gfcdUseSumAmt = parseInt($(".gfcdUseSumAmt").text());
  1288. var realOrdSumAmt = 0;
  1289. var savePntSumAmt = 0;
  1290. $(".cartSq").each(function(){
  1291. var orgCurrPrice = parseInt($(this).parent().find(".orgCurrPrice").text());
  1292. var cpn1DcAmt = parseInt($(this).parent().find(".cpn1DcAmt").text());
  1293. var optAddPrice = parseInt($(this).parent().find(".optAddPrice").text());
  1294. var goodsQty = parseInt($(this).parent().find(".goodsQty").text());
  1295. var tmtb1DcAmt = parseInt($(this).parent().find(".tmtb1DcAmt").text());
  1296. var tmtb2DcAmt = parseInt($(this).parent().find(".tmtb2DcAmt").text());
  1297. var goodsCpnDcAmt = parseInt($(this).parent().find(".goodsCpnDcAmt").text());
  1298. var cartCpnDcAmt = parseInt($(this).parent().find(".cartCpnDcAmt").text());
  1299. var prePntDcAmt1 = parseInt($(this).parent().find(".prePntDcAmt1").text());
  1300. var dcSumAmt = 0;
  1301. var savePntAmt1 = parseInt($(this).parent().find(".savePntAmt1").text());
  1302. // 주문금액 = ((판매가 - 즉시할인가) + 옵션추가금액) * 장바구니수량
  1303. orgGoodsSumAmt = orgGoodsSumAmt + (orgCurrPrice + optAddPrice) * goodsQty;
  1304. cpn1DcSumAmt = cpn1DcSumAmt + cpn1DcAmt;
  1305. tmtb1DcSumAmt = tmtb1DcSumAmt + tmtb1DcAmt;
  1306. tmtb2DcSumAmt = tmtb2DcSumAmt + tmtb2DcAmt;
  1307. tmtbDcSumAmt = tmtbDcSumAmt + (tmtb1DcAmt + tmtb2DcAmt);
  1308. goodsCpnDcSumAmt = goodsCpnDcSumAmt + goodsCpnDcAmt;
  1309. cartCpnDcSumAmt = cartCpnDcSumAmt + cartCpnDcAmt;
  1310. cpnDcSumAmt = cpnDcSumAmt + (goodsCpnDcAmt + cartCpnDcAmt);
  1311. prePntDcSumAmt = prePntDcSumAmt + prePntDcAmt1;
  1312. var ordAmt = ((orgCurrPrice - cpn1DcAmt) + optAddPrice) * goodsQty;
  1313. ordSumAmt = ordSumAmt + ordAmt;
  1314. // 선포인트사용여부
  1315. // 할인금액합계 = 다다익선수량금액 + 다다익선금액금액 + 상품쿠폰금액 + 장바구니금액 + 선포인트금액
  1316. if (prePntDcAmtYn == "Y") {
  1317. dcSumAmt = tmtb1DcAmt + tmtb2DcAmt + goodsCpnDcAmt + cartCpnDcAmt + prePntDcAmt1;
  1318. } else {
  1319. dcSumAmt = tmtb1DcAmt + tmtb2DcAmt + goodsCpnDcAmt + cartCpnDcAmt;
  1320. }
  1321. // 주문금액설정
  1322. $(this).parent().find(".ordAmt").text(ordAmt);
  1323. $(this).parent().find(".dcSumAmt").text(dcSumAmt);
  1324. savePntSumAmt = savePntSumAmt + savePntAmt1;
  1325. });
  1326. // 포인트, 상품권 금액 분배
  1327. $(".cartSq").each(function(){
  1328. var ordAmt = parseInt($(this).parent().find(".ordAmt").text());
  1329. var dcSumAmt = parseInt($(this).parent().find(".dcSumAmt").text());
  1330. var tempDiv = parseInt((ordAmt / ordSumAmt) * 100);
  1331. var pntDcAmt1 = 0;
  1332. var gfcdUseAmt1 = 0;
  1333. if (index == cartSqLenght) {
  1334. pntDcAmt1 = leftPntAmt;
  1335. gfcdUseAmt1 = leftGfcdAmt;
  1336. } else {
  1337. pntDcAmt1 = parseInt((pntDcSumAmt * tempDiv) / 100);
  1338. gfcdUseAmt1 = parseInt((gfcdUseSumAmt * tempDiv) / 100);
  1339. leftPntAmt = leftPntAmt - pntDcAmt1;
  1340. leftGfcdAmt = leftGfcdAmt - gfcdUseAmt1;
  1341. }
  1342. var realOrdAmt1 = ordAmt - dcSumAmt - (pntDcAmt1 - gfcdUseAmt1);
  1343. realOrdSumAmt = realOrdSumAmt + realOrdAmt1;
  1344. $(this).parent().find(".pntDcAmt1").text(pntDcAmt1);
  1345. $(this).parent().find(".gfcdUseAmt1").text(gfcdUseAmt1);
  1346. $(this).parent().find(".realOrdAmt1").text(realOrdAmt1);
  1347. index++;
  1348. });
  1349. $(".orgGoodsSumAmt").text(orgGoodsSumAmt);
  1350. $(".cpn1DcSumAmt").text(cpn1DcSumAmt);
  1351. $(".ordSumAmt").text(ordSumAmt);
  1352. $(".tmtb1DcSumAmt").text(tmtb1DcSumAmt);
  1353. $(".tmtb2DcSumAmt").text(tmtb2DcSumAmt);
  1354. $(".tmtbDcSumAmt").text(tmtbDcSumAmt);
  1355. $(".goodsCpnDcSumAmt").text(goodsCpnDcSumAmt);
  1356. $(".cartCpnDcSumAmt").text(cartCpnDcSumAmt);
  1357. $(".cpnDcSumAmt").text(cpnDcSumAmt);
  1358. $(".prePntDcSumAmt").text(prePntDcSumAmt);
  1359. $(".realOrdSumAmt").text(realOrdSumAmt);
  1360. $(".savePntSumAmt").text(savePntSumAmt);
  1361. $("#realOrdAmt").text(realOrdSumAmt.addComma() + "원"); // 총 결제 예정 금액
  1362. var tempSavePnt = savePntSumAmt - prePntDcAmt;
  1363. // 사은품사용 후 보유포인트
  1364. var rmPntAmt = parseInt($("input[name='rmPntAmt']").val());
  1365. var freegiftUsePnt = parseInt($(".freegiftUsePnt").text());
  1366. rmPntAmt = rmPntAmt - freegiftUsePnt;
  1367. $(".rmPntAmt").text("보유 : " + rmPntAmt.addComma() + "P");
  1368. // 걸제영역
  1369. $("#btn_payment").text("동의 후 "+realOrdSumAmt.addComma()+"원 결제하기");
  1370. // 적립포인트
  1371. $("#savePntSumAmt").text(savePntSumAmt.addComma()+"P");
  1372. // 사은품정보 설정
  1373. var freegiftValArr = [];
  1374. var freegiftUsePointArr = [];
  1375. $(".gift_box").each(function(){
  1376. $(this).find(".freegiftRdo").each(function(){
  1377. // 사은품필수
  1378. if ($(this).attr("allYn") == "Y" ) {
  1379. freegiftValArr.push($(this).val());
  1380. freegiftUsePointArr.push($(this).attr("usepoint"));
  1381. }
  1382. // 라디오버튼 선택 사은품 체크
  1383. if ($(this).is(":checked")) {
  1384. // 수령거부가 아닐때 체크
  1385. if ($(this).val() != "noSel") {
  1386. freegiftValArr.push($(this).val());
  1387. freegiftUsePointArr.push($(this).attr("usepoint"));
  1388. }
  1389. }
  1390. });
  1391. });
  1392. $(".freegiftValArr").text(freegiftValArr); // 사은품시퀀스배열
  1393. $(".freegiftUsePointArr").text(freegiftUsePointArr); // 사은품사용포인트배열
  1394. };
  1395. </script>
  1396. <script th:inline="javascript">
  1397. // 화면준비상태
  1398. $(document).ready( function() {
  1399. // 배송지변경 팝업열기
  1400. $(document).on('click','#btn_adrsChange_pop',function(e){
  1401. $.ajax( {
  1402. type : "POST",
  1403. url : '/order/delvAddrChangePop',
  1404. dataType : 'html',
  1405. success : function(result) {
  1406. if (result != null) {
  1407. $("#adrsChangePop").html(result);
  1408. $("#adrsChangePop").modal("show");
  1409. }
  1410. }
  1411. });
  1412. return false;
  1413. });
  1414. // 배송지추가 팝업열기
  1415. $(document).on('click','#btn_addrAdd_pop',function(e){
  1416. $.ajax( {
  1417. type : "POST",
  1418. url : '/order/delvAddrAddPop',
  1419. dataType : 'html',
  1420. success : function(result) {
  1421. if (result != null) {
  1422. $("#adrsAddPop").html(result);
  1423. $("#adrsAddPop").modal("show");
  1424. }
  1425. }
  1426. });
  1427. return false;
  1428. });
  1429. // 배송지수정 팝업열기
  1430. $("#btn_addrModify_pop").on("click", function(e){
  1431. $.ajax( {
  1432. type : "POST",
  1433. url : '/order/delvAddrModifyPop',
  1434. dataType : 'html',
  1435. success : function(result) {
  1436. if (result != null) {
  1437. $("#adrsModifyPop").html(result);
  1438. $("#adrsModifyPop").modal("show");
  1439. }
  1440. }
  1441. });
  1442. return false;
  1443. });
  1444. // 배송요청사항 팝업열기
  1445. $("#btn_rqstModify_pop").on("click", function(e){
  1446. var jsonObj = new Object();
  1447. jsonObj.delvMemo = $("input[name='delvMemo']").val();
  1448. $.ajax({
  1449. type : "POST",
  1450. url : "/order/delvMemoChangePop",
  1451. data : jsonObj,
  1452. dataType : "html",
  1453. success : function(result) {
  1454. if (result != null) {
  1455. $("#rqstModifyPop").html(result);
  1456. $("#rqstModifyPop").modal("show");
  1457. }
  1458. }
  1459. });
  1460. return false;
  1461. });
  1462. // 해외배송 입력
  1463. $(document).on('change','.odPayment .area_overseas #rdi-overs1', function(e){
  1464. $('.info_box.overs2').hide();
  1465. $('.info_box.overs1').show();
  1466. return false;
  1467. }).on('change','.odPayment .area_overseas #rdi-overs2', function(e){
  1468. $('.info_box.overs1').hide();
  1469. $('.info_box.overs2').show();
  1470. return false;
  1471. });
  1472. // 사은품지급안내 팝업열기
  1473. $("#btn_infoGift_pop").on("click",function(e){
  1474. $.ajax({
  1475. type : "POST",
  1476. url : "/order/freegiftInfoPop",
  1477. dataType : "html",
  1478. success : function(result) {
  1479. if (result != null) {
  1480. $("#infoGiftPop").html(result);
  1481. $("#infoGiftPop").modal("show");
  1482. }
  1483. }
  1484. });
  1485. return false;
  1486. });
  1487. // 할인쿠폰 확인
  1488. $(document).on('click','.odPayment .area_seldiscount .btn_coupon_toggle',function(e){
  1489. $('.coupon_list').toggle();
  1490. $(this).toggleClass('on');
  1491. return false;
  1492. });
  1493. // 결제수단 선택
  1494. $(document).on('change','.odPayment .area_paymethod .paymethod_radio input',function(e){
  1495. $('.radio_blk').removeClass('on');
  1496. $(this).parents('.radio_blk').addClass('on');
  1497. $(this).parents('.radio_blk').find('.paymethod_box').show();
  1498. $(this).parents('.radio_blk').siblings('div').find('.paymethod_box').hide();
  1499. var paymethodlabel = $(this).prop('labels');
  1500. $(this).parents('li').find('.fold_head .data span').text($(paymethodlabel).text());
  1501. // 간편결제 카드추가 슬라이드
  1502. var swiper = new Swiper('.paymethod_box .card_quickpay .list_card', {
  1503. slidesPerView: 'auto',
  1504. spaceBetween: 160,
  1505. centeredSlides: true,
  1506. navigation: {
  1507. nextEl: '.list_card .swiper-button-next',
  1508. prevEl: '.list_card .swiper-button-prev',
  1509. },
  1510. });
  1511. return false;
  1512. });
  1513. // STYLE24 간편결제 배너닫기
  1514. $(document).on('click','.odPayment .area_paymethod .quickpay_bnr .btn_close_bnr',function(e){
  1515. $('.quickpay_bnr').hide();
  1516. });
  1517. // 결제수단 선택 > 즐겨찾기 추가시
  1518. $(document).on('click','.odPayment .area_paymethod .paymethod_box .card .etc .btn_favorcard',function(e){
  1519. $(this).toggleClass('active');
  1520. return false;
  1521. });
  1522. // 결제수단 > 일반결제> 실시간계좌이체 선택시
  1523. $(document).on('change','.odPayment input:radio[name=rdi-paynormal]',function(e){
  1524. var paynormalValue = $(this).attr('id');
  1525. if (paynormalValue == 'rdi-paynormal2') {
  1526. $('.area_paymethod .agree_insurance').show();
  1527. } else {
  1528. $('.area_paymethod .agree_insurance').hide();
  1529. }
  1530. return false;
  1531. });
  1532. // 개인정보동의 열고닫기
  1533. $(document).on('click','.area_paymentinfo .payinfo_blk a',function(e){
  1534. e.preventDefault();
  1535. $(this).parents('.payinfo_blk').toggleClass('on');
  1536. var privacyToggle = $(this).find('span');
  1537. $(privacyToggle).text($(privacyToggle).text() == '보기' ? '닫기' : '보기');
  1538. return false;
  1539. });
  1540. // 간편결제등록 > STEP1.이용약관 팝업열기
  1541. $(document).on('click','.btn_addcard',function(e){
  1542. $("#qPayAgree_pop").modal("show");
  1543. return false;
  1544. });
  1545. // 간편결제등록 > STEP1.이용약관 체크
  1546. $(document).on('click','.area_QpayCk .agr_select button',function(e){
  1547. $(this).parents('.area_QpayCk').find('.info_agrQpay').toggle();
  1548. var payagrToggle = $(this).find('span');
  1549. $(payagrToggle).text($(payagrToggle).text() == '약관열기' ? '약관닫기' : '약관열기');
  1550. return false;
  1551. });
  1552. // 간편결제등록 > STEP1.이용약관 체크박스 전체선택
  1553. $(document).on('click','#chk-Qpay-agrAll',function(e){
  1554. $(this).parents(".qPayAgree_pop").find('.agree_Qpay input').prop("checked", $(this).is(":checked"));
  1555. });
  1556. // 간편결제등록 > STEP1.이용약관 체크박스 개별선택
  1557. $(document).on("click", ".agree_Qpay input",function(e){
  1558. var is_checked = true;
  1559. $(".agree_Qpay input").each(function(){
  1560. is_checked = is_checked && $(this).is(":checked");
  1561. });
  1562. $("#chk-Qpay-agrAll").prop("checked", is_checked);
  1563. });
  1564. // 간편결제등록 > 본인인증 팝업열기
  1565. $(document).on('click','#btn_qPayidConfirm_pop',function(e){
  1566. $("#qPayidConfirm_pop").modal("show");
  1567. return false;
  1568. });
  1569. });
  1570. </script>
  1571. </th:block>
  1572. </body>
  1573. </html>