OrderFormWeb.html 90 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438143914401441144214431444144514461447144814491450145114521453145414551456145714581459146014611462146314641465146614671468146914701471147214731474147514761477147814791480148114821483148414851486148714881489149014911492149314941495149614971498149915001501150215031504150515061507150815091510151115121513151415151516151715181519152015211522152315241525152615271528152915301531153215331534153515361537153815391540154115421543154415451546154715481549155015511552155315541555155615571558155915601561156215631564156515661567156815691570157115721573157415751576157715781579158015811582158315841585158615871588158915901591159215931594159515961597159815991600160116021603160416051606160716081609161016111612161316141615161616171618161916201621162216231624162516261627162816291630163116321633163416351636163716381639164016411642164316441645164616471648164916501651165216531654165516561657165816591660166116621663166416651666166716681669167016711672167316741675167616771678167916801681168216831684168516861687168816891690169116921693169416951696169716981699170017011702170317041705170617071708170917101711171217131714171517161717171817191720172117221723172417251726172717281729173017311732173317341735173617371738173917401741174217431744174517461747174817491750175117521753175417551756175717581759176017611762176317641765176617671768176917701771177217731774177517761777177817791780178117821783178417851786178717881789179017911792179317941795179617971798179918001801180218031804180518061807180818091810181118121813181418151816181718181819182018211822182318241825182618271828182918301831183218331834183518361837183818391840184118421843184418451846184718481849185018511852185318541855185618571858185918601861186218631864186518661867186818691870187118721873187418751876187718781879188018811882188318841885188618871888188918901891189218931894189518961897189818991900190119021903190419051906190719081909191019111912191319141915191619171918191919201921192219231924192519261927192819291930193119321933193419351936193719381939194019411942194319441945194619471948194919501951195219531954195519561957195819591960196119621963196419651966196719681969197019711972197319741975197619771978197919801981198219831984198519861987198819891990199119921993199419951996199719981999200020012002200320042005200620072008200920102011201220132014201520162017201820192020202120222023202420252026202720282029203020312032203320342035203620372038203920402041204220432044204520462047204820492050205120522053205420552056205720582059206020612062206320642065206620672068206920702071207220732074207520762077207820792080208120822083208420852086208720882089209020912092209320942095209620972098209921002101210221032104210521062107210821092110211121122113211421152116211721182119212021212122212321242125212621272128212921302131213221332134213521362137213821392140214121422143214421452146214721482149215021512152215321542155215621572158215921602161216221632164216521662167216821692170217121722173217421752176217721782179218021812182218321842185218621872188218921902191219221932194219521962197219821992200220122022203220422052206220722082209221022112212221322142215221622172218221922202221222222232224222522262227222822292230223122322233223422352236223722382239224022412242224322442245224622472248224922502251225222532254225522562257225822592260226122622263226422652266226722682269227022712272227322742275227622772278227922802281228222832284228522862287228822892290229122922293229422952296229722982299230023012302230323042305230623072308230923102311231223132314231523162317231823192320232123222323232423252326232723282329233023312332233323342335233623372338233923402341234223432344234523462347234823492350235123522353235423552356235723582359236023612362236323642365236623672368236923702371237223732374237523762377237823792380238123822383238423852386238723882389239023912392239323942395239623972398239924002401240224032404240524062407240824092410241124122413241424152416241724182419242024212422242324242425242624272428242924302431243224332434243524362437243824392440244124422443244424452446244724482449245024512452245324542455245624572458245924602461246224632464246524662467246824692470247124722473247424752476247724782479248024812482248324842485248624872488248924902491249224932494249524962497249824992500250125022503250425052506250725082509251025112512251325142515251625172518251925202521252225232524252525262527252825292530253125322533253425352536253725382539254025412542254325442545254625472548254925502551255225532554255525562557255825592560256125622563256425652566256725682569257025712572257325742575
  1. <!DOCTYPE html>
  2. <html lang="ko" xmlns:th="http://www.thymeleaf.org" xmlns:layout="http://www.ultraq.net.nz/thymeleaf/layout" layout:decorator="web/common/layout/DefaultLayoutWeb">
  3. <!--
  4. *******************************************************************************
  5. * @source : OrderFormWeb.html
  6. * @desc : 주문/결제 Page
  7. *============================================================================
  8. * STYLE24
  9. * Copyright(C) 2020 TSIT, All rights reserved.
  10. *============================================================================
  11. * VER DATE AUTHOR DESCRIPTION
  12. * === =========== ========== =============================================
  13. * 1.0 2021.02.01 jsh77b 최초 작성
  14. *******************************************************************************
  15. -->
  16. <body>
  17. <th:block layout:fragment="content">
  18. <link rel="stylesheet" type="text/css" href="/ux/pc/css/swiper.min.css">
  19. <script type="text/javascript" src="/ux/pc/js/swiper.min.js"></script>
  20. <script type="text/javascript" src="/ux/pc/js/jquery-ui.js"></script>
  21. <!-- payment.js -->
  22. <script type="text/javascript" th:src="${@environment.getProperty('pg.kcp.js.url')}" src=""></script>
  23. <script type="text/javascript" src="/biz/payment.js"></script>
  24. <!-- 주문정보form -->
  25. <form id="order_info" name="order_info" method="post" action="/order/pay/result/response" style="display:none"></form>
  26. <!-- //주문정보form -->
  27. <!-- 주문금액정보표현 -->
  28. <form id="orderAmtForm" name="orderAmtForm">
  29. <!-- 주문자정보 -->
  30. <table border="1" style="font-size:10px; text-align:center; margin-top:20px; display:none; width:100%;" name="orderInfo" id="orderInfo">
  31. <tbody>
  32. <tr style="height:30px;">
  33. <td class="custNm"></td>
  34. <td class="email"></td>
  35. <td class="cellPhnno"></td>
  36. <td class="recipNm"></td>
  37. <td class="recipPhnno"></td>
  38. <td class="recipZipcode"></td>
  39. <td class="recipBaseAddr"></td>
  40. <td class="recipDtlAddr"></td>
  41. <td class="delvMemo"></td>
  42. <td class="sexGb"></td>
  43. <td class="birthYmd"></td>
  44. </tr>
  45. </tbody>
  46. </table>
  47. <!-- //주문자정보 -->
  48. <!-- 사은품정보 -->
  49. <table border="1" style="font-size:10px; text-align:center; margin-top:20px; display:none; width:100%;" name="freegiftInfo">
  50. <tr style="height:30px;">
  51. <td class="freegiftValArr"></td>
  52. <td class="freegiftUsePointArr"></td>
  53. <td class="freegiftSqArr"></td>
  54. <td class="freegiftGoodsArr"></td>
  55. </tr>
  56. </table>
  57. <!-- //사은품정보 -->
  58. <!-- 주문상세금액 -->
  59. <table border="1" style="font-size:10px; text-align:center; margin-top:20px; display:none; width:100%;" name="orderDetailInfo" id="orderDetailInfo">
  60. <th:block th:each="delvAllCart, index : ${delvAllCartList}">
  61. <th:block th:if="${delvAllCart != null and #lists.size(delvAllCart) > 0}">
  62. <th:block th:each="goods, i : ${delvAllCart}">
  63. <tr style="height:30px;">
  64. <td class="cartSq" th:text="${goods.cartSq}"></td>
  65. <td class="goodsNm" th:text="${goods.goodsNm}" style="display:none"></td>
  66. <td class="goodsCd" th:text="${goods.goodsCd}"></td>
  67. <td class="goodsType" th:text="${goods.goodsType}"></td>
  68. <td class="itemCd" th:text="${goods.itemCd}"></td>
  69. <td class="optCd" th:text="${goods.optCd}"></td>
  70. <td class="optCd1" th:text="${goods.optCd1}" style="display:none"></td>
  71. <td class="optCd2" th:text="${goods.optCd2}" style="display:none"></td>
  72. <td class="itemQtyr" th:text="${goods.itemQtyr}" style="display:none"></td>
  73. <td class="orgCurrPrice" th:text="${goods.orgCurrPrice}"></td>
  74. <td class="cpn1CpnSq" th:text="${goods.cpn1CpnSq}"></td>
  75. <td class="cpn1DcAmt" th:text="${goods.orgCurrPrice} - ${goods.currPrice}"></td>
  76. <td class="optAddPrice" th:text="${goods.optAddPrice}"></td>
  77. <td class="goodsQty" th:text="${goods.goodsQty}"></td>
  78. <td class="ordAmt">0</td>
  79. <th:block th:if="${goods.applyQtySectionYn} == 'Y' and ${goods.qtyTmtbSq} > 0">
  80. <td class="tmtb1Sq" th:text="${goods.qtyTmtbSq}"></td>
  81. <td class="tmtb1DcAmt" th:text="${goods.tmtb1DcAmt}"></td>
  82. </th:block>
  83. <th:block th:if="${goods.applyQtySectionYn} != 'Y'">
  84. <td class="tmtb1Sq">0</td>
  85. <td class="tmtb1DcAmt">0</td>
  86. </th:block>
  87. <th:block th:if="${goods.applyAmtSectionYn} == 'Y' and ${goods.amtTmtbSq} > 0">
  88. <td class="tmtb2Sq" th:text="${goods.amtTmtbSq}"></td>
  89. <td class="tmtb2DcAmt" th:text="${goods.tmtb2DcAmt}"></td>
  90. </th:block>
  91. <th:block th:if="${goods.applyAmtSectionYn} != 'Y'">
  92. <td class="tmtb2Sq" >0</td>
  93. <td class="tmtb2DcAmt" >0</td>
  94. </th:block>
  95. <td class="goodsCpnSq">0</td>
  96. <td class="goodsCpnDcAmt">0</td>
  97. <td class="cartCpnSq">0</td>
  98. <td class="cartCpnDcAmt">0</td>
  99. <td class="prePntDcAmt1" th:text="${goods.prePntDcAmt}"></td>
  100. <td class="dcSumAmt">0</td>
  101. <td class="pntDcAmt1">0</td>
  102. <td class="gfcdUseAmt1">0</td>
  103. <td class="realOrdAmt1">0</td>
  104. <td class="savePntAmt1">0</td>
  105. <td class="shotDelvYn" th:text="${goods.shotDelvYn}"></td>
  106. <td class="foreignBuyYn" th:text="${goods.foreignBuyYn}"></td>
  107. <td class="orderMadeYn" th:text="${goods.orderMadeYn}"></td>
  108. <td class="delvFeeCd" th:text="${goods.delvFeeCd}"></td>
  109. <td class="pntPrate" th:text="${goods.pntPrate}"></td>
  110. <td class="pntMrate" th:text="${goods.pntMrate}"></td>
  111. </tr>
  112. </th:block>
  113. </th:block>
  114. </th:block>
  115. </table>
  116. <!-- //주문상세금액 -->
  117. <!-- 배송단위목록 -->
  118. <table border="1" style="font-size:10px; text-align:center; margin-top:20px; display:none; width:100%;" name="delvFeeCdInfo" id="delvFeeCdInfo">
  119. <th:block th:each="delvFeeCd, index : ${delvFeeCdList}">
  120. <tr style="height:30px;">
  121. <td class="supplyCompCd" th:text="${delvFeeCd.supplyCompCd}"></td>
  122. <td class="delvFeeCd" th:text="${delvFeeCd.delvFeeCd}"></td>
  123. <td class="delvFee" th:text="${delvFeeCd.delvFee}"></td>
  124. <td class="delvCpnSq">0</td>
  125. <td class="delvCpnDcAmt">0</td>
  126. </tr>
  127. </th:block>
  128. </table>
  129. <!-- //배송단위목록 -->
  130. <!-- 주문금액합계 -->
  131. <table border="1" style="font-size:10px; text-align:center; margin-top:20px; display:none; width:100%;" name="orderSumAmtInfo" id="orderSumAmtInfo">
  132. <tr style="height:30px;">
  133. <td class="orgGoodsSumAmt">0</td>
  134. <td class="delvSumAmt" th:text="${sumDelvFee}"></td>
  135. <td class="freegiftUsePnt">0</td>
  136. <td class="cpn1DcSumAmt">0</td>
  137. <td class="ordSumAmt">0</td>
  138. <td class="tmtb1DcSumAmt">0</td>
  139. <td class="tmtb2DcSumAmt">0</td>
  140. <td class="tmtbDcSumAmt">0</td>
  141. <td class="goodsCpnDcSumAmt">0</td>
  142. <td class="cartCpnDcSumAmt">0</td>
  143. <td class="delvCpnDcSumAmt">0</td>
  144. <td class="cpnDcSumAmt">0</td>
  145. <td class="prePntDcSumAmt">0</td>
  146. <td class="pntDcSumAmt">0</td>
  147. <td class="gfcdUseSumAmt">0</td>
  148. <td class="realOrdSumAmt">0</td>
  149. <td class="savePntSumAmt">0</td>
  150. </tr>
  151. </table>
  152. <!-- //주문금액합계 -->
  153. </form>
  154. <!-- //주문금액정보표현 -->
  155. <!-- 주문고객정보 -->
  156. <form id="orderForm" name="orderForm">
  157. <div id="container" class="container od">
  158. <div class="wrap">
  159. <div class="content odPayment">
  160. <!-- 페이지특정 클래스 = odPayment -->
  161. <div class="cont_head">
  162. <h2>주문/결제</h2>
  163. <div class="oder_steps">
  164. <ul>
  165. <li>01 쇼핑백</li>
  166. <li class="on">02 주문/결제</li>
  167. <li>03 주문완료</li>
  168. </ul>
  169. </div>
  170. </div>
  171. <div class="cont_body">
  172. <!-- CONT-BODY -->
  173. <div class="od_cont">
  174. <form class="form_wrap">
  175. <div class="sec_head">
  176. <div class="tbl type4">
  177. <table>
  178. <colgroup>
  179. <col width="240">
  180. <col width="*">
  181. </colgroup>
  182. <tbody>
  183. <tr>
  184. <th>총 <span class="number" id="delvFeeCdCnt" th:text="${delvFeeCdCnt}"></span> 건으로 나뉘어 배송 예정</th>
  185. <td>
  186. <span> 총알배송<em class="number" th:text="${shotCnt}" id="shotCnt"></em>건</span>
  187. <span> STYLE24<em class="number" th:text="${wmsCnt}" id="wmsCnt"></em>건</span>
  188. <span> 업체직배송<em class="number" th:text="${delvCnt}"></em>건</span>
  189. <span> 예약배송<em class="number" th:text="${resCnt}"></em>건</span>
  190. </td>
  191. </tr>
  192. </tbody>
  193. </table>
  194. </div>
  195. </div>
  196. <div class="sec_body">
  197. <!-- -->
  198. <div class="foldGroup">
  199. <ul>
  200. <!-- 주문고객정보 -->
  201. <li class="fold_mbinfo" id="custemerInfo" style="display:none"></li>
  202. <!-- //주문고객정보 -->
  203. <!-- 배송지정보 -->
  204. <li class="fold_mbinfo" id="deliveryAddrInfo" style="display:none"></li>
  205. <!-- //배송지정보 -->
  206. <!-- //사은품정보 -->
  207. <li id="freegiftInfo" style="display:none"></li>
  208. <!-- //사은품정보 -->
  209. <!-- 할인/혜택 사용 -->
  210. <li id="dcAmtInfo" style="display:none"></li>
  211. <!-- //할인/혜택 사용 -->
  212. <!-- 결제수단 선택 -->
  213. <li class="fold_paymethod" id="paymentInfo" style="display:none"></li>
  214. <!-- //결제수단 선택 -->
  215. </ul>
  216. </div>
  217. <div class="area_paymentinfo">
  218. <!-- @ 2021.06.11 자사만, (무통장, 실시간) 미노출 -->
  219. <!-- @ 입점있으면 무조건 노출 -->
  220. <div class="paymentinfo">
  221. <div class="payinfo_blk">
  222. <a href="javascript:void(0);">개인정보 제공에 대한 동의<span>보기</span></a>
  223. <div class="infotxt">STYLE24는 다음과 같이 회원님의 개인정보를 제3자에게 제공합니다.
  224. <table>
  225. <colgroup>
  226. <col width="25%">
  227. <col width="*">
  228. <col width="25%">
  229. <col width="25%">
  230. </colgroup>
  231. <thead>
  232. <tr>
  233. <th>제공받는 자</th>
  234. <th>제공하는 항목</th>
  235. <th>제공 목적</th>
  236. <th>보유 및 이용기간</th>
  237. </tr>
  238. </thead>
  239. <tbody>
  240. <tr class="paymentinfo agree1">
  241. <td>서울보증보험㈜, ㈜유세이프</td>
  242. <td>
  243. 구매자명, 구매자 생년월일,
  244. 구매자 성별, 구매자 연락처
  245. (일반전화 및 핸드폰), 구매자
  246. 이메일, 주문번호,
  247. 배송지 정보, 주문 금액
  248. </td>
  249. <td>쇼핑몰보증보험 가입 및 보험가입 제반 사항</td>
  250. <td>개별서비스 제공기간</td>
  251. </tr>
  252. <!-- 입점업체가 있을때 노출 -->
  253. <th:block th:if="${delvCnt} > 0">
  254. <tr class="paymentinfo agree2">
  255. <td>
  256. <th:block th:each="delvFeeCd, i : ${delvFeeCdList}">
  257. <th:block th:unless="${delvFeeCd.delvFeeCd} == 'WMS'">
  258. <th:block th:if="${i.count == #lists.size(delvFeeCdList)}">
  259. <th:block th:text="|${delvFeeCd.supplyCompNm}|"></th:block>
  260. </th:block>
  261. <th:block th:if="${i.count < #lists.size(delvFeeCdList)}">
  262. <th:block th:text="|${delvFeeCd.supplyCompNm},|"></th:block>
  263. </th:block>
  264. </th:block>
  265. </th:block>
  266. </td>
  267. <td>성명, 주소, 연락처</td>
  268. <td>주문상품의 배송, 고객상담 및 불만처리</td>
  269. <td>이용목적 달성 시 까지</td>
  270. </tr>
  271. </th:block>
  272. <!-- //입점업체가 있을때 노출 -->
  273. </tbody>
  274. </table>
  275. </div>
  276. </div>
  277. </div>
  278. <div class="agree_payment">
  279. 위 주문내역을 확인 하였으며, 회원 본인은 결제에 동의합니다. (전자상거래법 제 8조 제2항)
  280. </div>
  281. </div>
  282. <div class="area_paybtn">
  283. <div class="form_field">
  284. <button type="button" class="btn btn_primary btn_block" id="btn_payment">
  285. <span>동의 후 <em class="realOrdAmt"></em> 결제하기</span>
  286. </button>
  287. </div>
  288. </div>
  289. </div>
  290. </form>
  291. </div>
  292. <div class="od_side">
  293. <div class="area_order">
  294. <div class="tit_box">
  295. <h3>주문내역</h3>
  296. <span> <em class="number" th:text="${goodsTotCnt}"></em> 개의 상품
  297. </span>
  298. </div>
  299. <div id="orderListInfo" style="display:none"></div>
  300. <div class="od_amount_box">
  301. <dl>
  302. <div>
  303. <dt>상품금액</dt>
  304. <dd id="orgGoodsSumAmt" th:text="|${#numbers.formatInteger(listSumAmt, 1, 'COMMA')} 원|"></dd>
  305. </div>
  306. <div>
  307. <dt>배송비</dt>
  308. <dd id="delvSumAmt" th:text="|${#numbers.formatInteger(sumDelvFee, 1, 'COMMA')} 원|"></dd>
  309. </div>
  310. <div>
  311. <dt>상품할인금액</dt>
  312. <th:block th:if="${goodsDcSumAmt} > 0">
  313. <dd><span class="disc_amount" th:text="|-${#numbers.formatInteger(goodsDcSumAmt, 1, 'COMMA')} 원|"></span></dd>
  314. </th:block>
  315. <th:block th:if="${goodsDcSumAmt} < 1">
  316. <dd><span class="disc_amount" th:text="|${#numbers.formatInteger(goodsDcSumAmt, 1, 'COMMA')} 원|"></span></dd>
  317. </th:block>
  318. </div>
  319. <div>
  320. <dt>즉시할인금액</dt>
  321. <th:block th:if="${cpn1DcSumAmt} > 0">
  322. <dd><span class="disc_amount" id="cpn1DcSumAmt" th:text="|-${#numbers.formatInteger(cpn1DcSumAmt, 1, 'COMMA')} 원|"></span></dd>
  323. </th:block>
  324. <th:block th:if="${cpn1DcSumAmt} < 1">
  325. <dd><span class="disc_amount" id="cpn1DcSumAmt" th:text="|${#numbers.formatInteger(cpn1DcSumAmt, 1, 'COMMA')} 원|"></span></dd>
  326. </th:block>
  327. </div>
  328. <!-- 회원인경우 노출 -->
  329. <th:block th:if="${isLogin}">
  330. <div>
  331. <dt>다다익선할인금액</dt>
  332. <th:block th:if="${tmtbDcSumAmt} > 0">
  333. <dd><span class="disc_amount" id="tmtbDcSumAmt" th:text="|-${#numbers.formatInteger(tmtbDcSumAmt, 1, 'COMMA')} 원|"></span></dd>
  334. </th:block>
  335. <th:block th:if="${tmtbDcSumAmt} < 1">
  336. <dd><span class="disc_amount" id="tmtbDcSumAmt" th:text="|${#numbers.formatInteger(tmtbDcSumAmt, 1, 'COMMA')} 원|"></span></dd>
  337. </th:block>
  338. </div>
  339. <div>
  340. <dt>쿠폰할인</dt>
  341. <dd><span class="disc_amount" id="couponDcSumAmt"></span></dd>
  342. </div>
  343. <div>
  344. <dt>선포인트 사용</dt>
  345. <th:block th:if="${prePntDcAmt} > 0">
  346. <dd><span class="disc_amount" id="prePntDcAmt" th:text="|-${#numbers.formatInteger(prePntDcAmt, 1, 'COMMA')} 원|"></span></dd>
  347. </th:block>
  348. <th:block th:if="${prePntDcAmt} < 1">
  349. <dd><span class="disc_amount" id="prePntDcAmt" th:text="|${#numbers.formatInteger(prePntDcAmt, 1, 'COMMA')} 원|"></span></dd>
  350. </th:block>
  351. </div>
  352. <div>
  353. <dt>포인트 사용</dt>
  354. <dd><span class="disc_amount" id="pntDcAmt"></span></dd>
  355. </div>
  356. <div>
  357. <dt>상품권 사용</dt>
  358. <dd><span class="disc_amount" id="gfcdUseAmt"></span></dd>
  359. </div>
  360. </th:block>
  361. </dl>
  362. </div>
  363. <div class="totalprice_box">
  364. <dl>
  365. <dt>총 결제 예정 금액</dt>
  366. <dd><span id="realOrdAmt"></span> 원</dd>
  367. </dl>
  368. <p class="info_point">
  369. <!-- 회원인경우 노출 -->
  370. <th:blcok th:if="${isLogin}">
  371. <span span class="save_point" id="savePntSumAmt" th:text="|${#numbers.formatInteger(savePntSumAmt, 1, 'COMMA')} P|"></span> 적립예정
  372. </th:blcok>
  373. <!-- 비회원인경우 노출-->
  374. <th:blcok th:if="!${isLogin}">
  375. 회원가입 후 구매하면&nbsp;&nbsp;<span span class="save_point" id="savePntSumAmt" th:text="|${#numbers.formatInteger(savePntSumAmt, 1, 'COMMA')} P|"></span> 적립예정
  376. </th:blcok>
  377. </p>
  378. </div>
  379. </div>
  380. </div>
  381. <!-- // CONT-BODY -->
  382. </div>
  383. </div>
  384. </div>
  385. </div>
  386. </form>
  387. <!-- 사은품지급안내 팝업 -->
  388. <div class="modal fade infoGift_pop" id="infoGiftPop" tabindex="-1" role="dialog" aria-labelledby="infoGiftLabel" aria-hidden="true">
  389. <div class="modal-dialog" role="document">
  390. <div class="modal-content">
  391. <div class="modal-header"><h5 class="modal-title" id="infoGiftLabel">STYLE24 사은품 지급 안내</h5></div>
  392. <div class="modal-body">
  393. <div class="pop_cont">
  394. <div class="cont_box">
  395. <ul>
  396. <li>스타일포인트 차감 사은품을 선택하신 경우, 결제 시 고객님의 누적 포인트에서 차감됩니다.</li>
  397. <li>보유한 포인트의 금액을 넘어선 사은품은 신청이 불가합니다.</li>
  398. <li>사은품 신청 시 해외배송은 불가합니다. <br> <span class="t_info">(적립포인트 사은품 및 온라인 사은품 제외)</span></li>
  399. </ul>
  400. </div>
  401. </div>
  402. </div>
  403. </div>
  404. </div>
  405. <a href="#close-modal" rel="modal:close" id="infoGiftPop_close" class="close-modal">Close</a>
  406. </div>
  407. <!-- //사은품지급안내 팝업 -->
  408. <!-- 할인쿠폰 변겅 팝업 -->
  409. <div class="modal fade couponModify_pop" id="couponModifyPop" tabindex="-1" role="dialog" aria-labelledby="couponModifyLabel" aria-hidden="true">
  410. <div class="modal-dialog" role="document">
  411. <div class="modal-content">
  412. <!-- 할인쿠폰 변겅 팝업 내용 -->
  413. </div>
  414. </div>
  415. <a href="#close-modal" rel="modal:close" id="couponModifyPop_close" class="close-modal">Close</a>
  416. </div>
  417. <!-- //할인쿠폰 변겅 팝업 -->
  418. <script th:inline="javascript">
  419. // 배송관련정보 변수선언
  420. var cartGoodsList = [[${cartGoodsList}]] // 배송목록
  421. var shotCnt = [[${shotCnt}]]; // 자사 총알 배송건수
  422. var wmsCnt = [[${wmsCnt}]]; // 자사 일반 배송건수
  423. var shotWmsCnt = [[${shotWmsCnt}]]; // 자사 총알,일반 배송건수
  424. var resCnt = [[${resCnt}]]; // 자사 예약 배송건수
  425. var delvCnt = [[${delvCnt}]]; // 입점 일반 배송건수
  426. var orgSumDelvFee = [[${sumDelvFee}]]; // 최초배송비합계
  427. var prePntDcAmt = [[${prePntDcAmt}]]; // 선포인트사용가능금액
  428. var custNm = [[${order.custNm}]]; // 주문자명
  429. var cellPhnno = [[${order.cellPhnno}]]; // 핸드폰번호
  430. var email = [[${order.email}]]; // 이메일
  431. var recipZipcode = [[${order.recipZipcode}]]; // 우편번호
  432. var recipBaseAddr = [[${order.recipBaseAddr}]]; // 기본주소
  433. var recipDtlAddr = [[${order.recipDtlAddr}]]; // 상세주소
  434. var cartSqArr = [[${order.cartSqArr}]]; // 장바구니시퀀스 목록
  435. var shotDelvUseYn = [[${order.shotDelvUseYn}]]; // 총알배송사용여부(장바구니)
  436. var shotDelvYn = [[${order.shotDelvUseYn}]]; // 총알배송사용여부(장바구니)
  437. var foreignBuyYn = [[${order.foreignBuyYn}]]; // 해외구매대행
  438. var foreignBuyYn = [[${foreignBuyYn}]]; // 해외구매대행여부
  439. var orderMadeYn = [[${orderMadeYn}]]; // 주문제작상품여부
  440. var isLogin = [[${isLogin}]]; // 로그인여부
  441. var devTempYn = [[${devTempYn}]]; // 개발자모드가능여부
  442. var frontGb = [[${frontGb}]]; // 프론트구분
  443. var custCpnSq = 0;
  444. var cpnIndex = 0;
  445. var cpnApplyTemp = false;
  446. //AJAX 로드를 위한 변수 설정
  447. var jsonObj = {};
  448. // 컨텐츠 호출
  449. $(document).ready( function() {
  450. var dispYn = "N";
  451. // 장바구니시퀀스 배열 변환
  452. cartSqArr = String(cartSqArr).split(",");
  453. if (isLogin == false) {
  454. //dispYn = "Y";
  455. }
  456. // AJAX 로드를 위한 변수 설정
  457. jsonObj = {
  458. "custNm" : custNm
  459. , "cellPhnno" : cellPhnno
  460. , "email" : email
  461. , "recipZipcode" : recipZipcode
  462. , "recipBaseAddr" : recipBaseAddr
  463. , "recipDtlAddr" : recipDtlAddr
  464. , "cartSqArr" : cartSqArr
  465. , "dispYn" : dispYn
  466. , "shotDelvYn" : shotDelvUseYn
  467. , "shotDelvUseYn" : shotDelvUseYn
  468. , "foreignBuyYn" : foreignBuyYn
  469. , "orderMadeYn" : orderMadeYn
  470. , "custDelvAddrSq" : 0
  471. , "cartGoodsList" : cartGoodsList
  472. }
  473. jsonData = JSON.stringify(jsonObj);
  474. // 1. AJAX 정보(회원정보로드)
  475. custemerInfoSet();
  476. // 999. 개발화면정보설정
  477. var devTemp = false;
  478. var arr = []
  479. arr[0] = "orderInfo";
  480. arr[1] = "freegiftInfo";
  481. arr[2] = "orderDetailInfo";
  482. arr[3] = "delvFeeCdInfo";
  483. arr[4] = "orderSumAmtInfo";
  484. // 개발자모드실행
  485. if (devTemp == true && devTempYn == true) {
  486. $("table").each(function(){
  487. var name = $(this).attr("name");
  488. for (i=0 ; i<arr.length ; i++) {
  489. if (name == arr[i]) {
  490. $(this).show();
  491. }
  492. }
  493. });
  494. }
  495. });
  496. // 1. 함수기능 정의
  497. // 1.1 고객정보로드
  498. var custemerInfoSet = function() {
  499. $.ajax( {
  500. type : "POST",
  501. url : '/order/custemerInfo',
  502. data : JSON.stringify(jsonObj),
  503. dataType : 'html',
  504. beforeSend : function(xhr, settings) {
  505. xhr.setRequestHeader("AJAX" , "true");
  506. xhr.setRequestHeader('Accept' , 'application/json');
  507. xhr.setRequestHeader('Content-Type' , 'application/json');
  508. },
  509. success : function(result) {
  510. if (result != null) {
  511. $("#custemerInfo").css("display", "block");
  512. $("#custemerInfo").html(result);
  513. // 고객정보설정
  514. $("#orderAmtForm .custNm").text($("#orderForm input[name='custNm']").val());
  515. $("#orderAmtForm .email").text($("#orderForm input[name='email']").val());
  516. $("#orderAmtForm .cellPhnno").text($("#orderForm input[name='cellPhnno']").val());
  517. $("#orderAmtForm .sexGb").text($("#orderForm input[name='sexGb']").val());
  518. $("#orderAmtForm .birthYmd").text($("#orderForm input[name='birthYmd']").val());
  519. }
  520. // 1.2 배송정보로드
  521. deliveryAddrInfoSet(jsonObj, true);
  522. }
  523. });
  524. }
  525. // 1.2 배송정보로드
  526. var deliveryAddrInfoSet = function(delvObj, temp) {
  527. // 2021.04.29 AJAX 로드를 위한 변수 설정
  528. delvObj.foreignBuyYn = foreignBuyYn;
  529. delvObj.orderMadeYn = orderMadeYn;
  530. $.ajax( {
  531. type : "POST",
  532. url : '/order/deliveryAddrInfo',
  533. data : JSON.stringify(delvObj),
  534. dataType : 'html',
  535. beforeSend : function(xhr, settings) {
  536. xhr.setRequestHeader("AJAX" , "true");
  537. xhr.setRequestHeader('Accept' , 'application/json');
  538. xhr.setRequestHeader('Content-Type' , 'application/json');
  539. },
  540. success : function(result) {
  541. $("#deliveryAddrInfo").css("display", "block");
  542. $("#deliveryAddrInfo").html(result);
  543. // 2021.05.16 배송정보가 있으면 노출
  544. if ($("#orderForm input[name='recipZipcode']").val() != "00000") {
  545. $("#orderForm .area_receiveinfo.exist").show();
  546. $("#orderForm .area_receiveinfo.none").hide();
  547. } else {
  548. $("#orderForm .area_receiveinfo.exist").hide();
  549. $("#orderForm .area_receiveinfo.none").show();
  550. }
  551. // 배송정보설정
  552. $("#orderAmtForm .recipNm").text($("#orderForm input[name='recipNm']").val());
  553. $("#orderAmtForm .recipPhnno").text($("#orderForm input[name='recipPhnno']").val());
  554. $("#orderAmtForm .recipZipcode").text($("#orderForm input[name='recipZipcode']").val());
  555. $("#orderAmtForm .recipBaseAddr").text($("#orderForm input[name='recipBaseAddr']").val());
  556. $("#orderAmtForm .recipDtlAddr").text($("#orderForm input[name='recipDtlAddr']").val());
  557. $("#orderAmtForm .delvMemo").text($("#orderForm input[name='delvMemo']").val());
  558. // 2. 버튼기능구현
  559. // 2.1 회원 배송지변경 팝업열기
  560. $('#orderForm .btn_adrsChange_pop').on("click", function(){
  561. // 회원인경우
  562. if (isLogin == true) {
  563. $.ajax( {
  564. type : "POST",
  565. url : '/common/delvAddrChangePop',
  566. data : JSON.stringify(jsonObj),
  567. dataType : 'html',
  568. beforeSend : function(xhr, settings) {
  569. xhr.setRequestHeader("AJAX" , "true");
  570. xhr.setRequestHeader('Accept' , 'application/json');
  571. xhr.setRequestHeader('Content-Type' , 'application/json');
  572. },
  573. success : function(result) {
  574. $("#adrsChangePop .modal-dialog .modal-content").html(result);
  575. $("#adrsChangePop").modal("show");
  576. }
  577. });
  578. }
  579. // 비회원인경우
  580. else {
  581. $.ajax( {
  582. type : "POST",
  583. url : '/common/delvAddrAddPop',
  584. data : JSON.stringify(jsonObj),
  585. dataType : 'html',
  586. beforeSend : function(xhr, settings) {
  587. xhr.setRequestHeader("AJAX" , "true");
  588. xhr.setRequestHeader('Accept' , 'application/json');
  589. xhr.setRequestHeader('Content-Type' , 'application/json');
  590. },
  591. success : function(result) {
  592. $("#adrsAddPop .modal-dialog .modal-content").html(result);
  593. $("#adrsAddPop").modal("show");
  594. }
  595. });
  596. }
  597. });
  598. // 2.2 배송요청사항 팝업열기
  599. $("#btn_rqstModify_pop").on("click", function(e){
  600. var jsonObj = new Object();
  601. jsonObj.delvMemo = $("#orderForm input[name=delvMemo]").val();
  602. $.ajax({
  603. type : "POST",
  604. url : "/common/delvMemoChangePop",
  605. data : JSON.stringify(jsonObj),
  606. dataType : "html",
  607. beforeSend : function(xhr, settings) {
  608. xhr.setRequestHeader("AJAX" , "true");
  609. xhr.setRequestHeader('Accept' , 'application/json');
  610. xhr.setRequestHeader('Content-Type' , 'application/json');
  611. },
  612. success : function(result) {
  613. if (result != null) {
  614. $("#rqstModifyPop .modal-dialog .modal-content").html(result);
  615. $("#rqstModifyPop").modal("show");
  616. }
  617. }
  618. });
  619. return false;
  620. });
  621. // 2021.07.06 값이 있으면 체크박스 활성화
  622. if ($("#orderForm input[name=entryNo]").val() != "") {
  623. if ($("#orderForm #chk-overs-agr").is(":checked") == false) {
  624. $("#orderForm #chk-overs-agr").trigger("click");
  625. }
  626. }
  627. // 1.3 총알배송가능 지역, 총알배송 가능 시간 체크(초기로드정보)
  628. fnGetDailyDeliveryCheck(temp);
  629. }
  630. });
  631. }
  632. // 1.3 총알배송가능 지역, 총알배송 가능 시간 체크
  633. var fnGetDailyDeliveryCheck = function (temp) {
  634. jsonData = JSON.stringify(jsonObj);
  635. // 장바구니 총알배송 사용여부 체크 N
  636. if (shotDelvUseYn == "N") {
  637. // 초기에 한번 데이타 로드
  638. if (temp) {
  639. // 1.4 주문상품목록로드
  640. orderListInfoSet(jsonData, temp);
  641. }
  642. } else {
  643. // 배송지 우편번호 체크
  644. var zipcode = $("#orderForm input[name='recipZipcode']").val();
  645. // 총알배송여부 체크 배송지정보 존재여부 체크
  646. if (zipcode == null || zipcode == '') {
  647. //alert("배송지정보가 없습니다. 기본 총알배송 가능지역으로 설정 합니다.");
  648. zipcode = "04320"; // 기본 서울역 우편번호로 설정
  649. }
  650. var shotDelvObj = {"recipZipcode" : zipcode};
  651. gagajf.ajaxJsonSubmit(
  652. "/order/getDailyDeliveryCheck"
  653. , JSON.stringify(shotDelvObj)
  654. , function (result) {
  655. // 총알배송여부체크
  656. var tempShotDelvYn = "N";
  657. if (parseInt(result) > 0) {
  658. tempShotDelvYn = "Y";
  659. }
  660. // json 값 설정
  661. var orderListObj = {
  662. "cartSqArr" : cartSqArr
  663. , "shotDelvYn" : tempShotDelvYn
  664. , "cartGoodsList" : cartGoodsList
  665. };
  666. var orderListJsonData = JSON.stringify(orderListObj);
  667. if (temp) {
  668. // 1.3 주문상품목록로드
  669. orderListInfoSet(orderListJsonData, temp);
  670. } else {
  671. if (tempShotDelvYn != shotDelvYn) {
  672. orderListInfoSet(orderListJsonData, temp);
  673. }
  674. }
  675. shotDelvYn = tempShotDelvYn;
  676. }
  677. )
  678. }
  679. }
  680. // 1.4 주문상품목록로드
  681. var orderListInfoSet = function(orderListJsonData, temp) {
  682. $.ajax( {
  683. type : "POST",
  684. url : '/order/orderListInfo',
  685. data : orderListJsonData,
  686. dataType : 'html',
  687. beforeSend : function(xhr, settings) {
  688. xhr.setRequestHeader("AJAX" , "true");
  689. xhr.setRequestHeader('Accept' , 'application/json');
  690. xhr.setRequestHeader('Content-Type' , 'application/json');
  691. },
  692. success : function(result) {
  693. if (result != null) {
  694. $("#orderListInfo").css("display", "block");
  695. $("#orderListInfo").html(result);
  696. $("#delvFeeCdCnt").text($("#orderForm input[name=delvFeeCdCnt]").val());
  697. $("#shotCnt").text($("#orderForm input[name=shotCnt]").val());
  698. $("#wmsCnt").text($("#orderForm input[name=wmsCnt]").val());
  699. // 총알배송건수가 있으면 총알배송 태그 표시
  700. if (parseInt($("#orderForm input[name=shotCnt]").val()) > 0 ) {
  701. $("#orderForm .shotDelv").show();
  702. } else {
  703. $("#orderForm .shotDelv").hide();
  704. }
  705. }
  706. // 1.5 사은품정보로드
  707. if (temp) {
  708. freegiftInfoSet();
  709. }
  710. }
  711. });
  712. }
  713. // 1.5 사은품정보로드
  714. var freegiftInfoSet = function() {
  715. $.ajax( {
  716. type : "POST",
  717. url : '/order/freegiftInfo',
  718. data : JSON.stringify(jsonObj),
  719. dataType : 'html',
  720. beforeSend : function(xhr, settings) {
  721. xhr.setRequestHeader("AJAX" , "true");
  722. xhr.setRequestHeader('Accept' , 'application/json');
  723. xhr.setRequestHeader('Content-Type' , 'application/json');
  724. },
  725. success : function(result) {
  726. if (result != null) {
  727. $("#freegiftInfo").html(result);
  728. var total_gift = 0;
  729. var total_deduct = 0;
  730. // 2.2 사은품선택 라디오 버튼 기능
  731. $("#orderForm .freegiftRdo").on("click", function() {
  732. total_gift = 0;
  733. total_deduct = 0;
  734. // 2021.04.14 사은품 사용 포인트가 보유포인트보다 작아야 한다.
  735. var rmPntAmt = parseInt($("#orderForm input[name='rmPntAmt']").val());
  736. var freegiftUsePnt = parseInt($("#orderAmtForm .freegiftUsePnt").text());
  737. var usepoint = parseInt($(this).attr("usepoint"));
  738. rmPntAmt = rmPntAmt - freegiftUsePnt - usepoint;
  739. if (rmPntAmt < 0) {
  740. mcxDialog.alert("보유포인트가 부족합니다.");
  741. return false;
  742. }
  743. $("#orderForm .freegiftRdo").each(function(){
  744. if ($(this).attr("allYn") == "Y" ) {
  745. total_gift += 1;
  746. }
  747. // 라디오버튼 사은품 체크
  748. if ($(this).is(":checked")) {
  749. // 수령거부가 아닐때 체크
  750. if ($(this).val() != "noSel") {
  751. total_gift += 1;
  752. total_deduct += parseInt($(this).attr("usepoint"));
  753. }
  754. }
  755. });
  756. $("#orderForm .total_gift").text(total_gift); // 사은품총선택개수
  757. $("#orderForm .total_deduct").text(total_deduct.addComma()); // 사은품총사용포인트
  758. $("#orderAmtForm .freegiftUsePnt").text(total_deduct);
  759. // 2021.04.29 사은품기능 리셋
  760. var pntDcAmt = parseInt($("#orderAmtForm .pntDcSumAmt").text());
  761. if (pntDcAmt > 0) {
  762. mcxDialog.alert("적용된 할인/혜택이 초기화 됩니다.");
  763. pntDcAmtReset();
  764. }
  765. // 2021.05.07 금액계산실행
  766. custCpnSumAmtCal();
  767. });
  768. // 2021.07.05 선택사은품 무료가 2개일때 첫번째 무료만 선택
  769. var countArr = [];
  770. var temp = true;
  771. // 2021.04.29 무료사은품 기본선택
  772. $("#orderForm .gift_box .freegiftRdo").each(function(){
  773. var usepoint = parseInt($(this).attr("usepoint"));
  774. var count = parseInt($(this).attr("count"));
  775. temp = true;
  776. // 첫번째 무료 선택
  777. if (usepoint == 0 && count != 100) {
  778. for (i=0 ; i<countArr.length ; i++) {
  779. if (count == countArr[i]) {
  780. temp = false;
  781. }
  782. }
  783. if (temp) {
  784. countArr.push(count);
  785. $(this).trigger("click");
  786. // 2021.04.14 사은품 사용 포인트가 보유포인트보다 작아야 한다.
  787. var rmPntAmt = parseInt($("#orderForm input[name='rmPntAmt']").val());
  788. var freegiftUsePnt = parseInt($("#orderAmtForm .freegiftUsePnt").text());
  789. var usepoint = parseInt($(this).attr("usepoint"));
  790. rmPntAmt = rmPntAmt - freegiftUsePnt - usepoint;
  791. if (rmPntAmt < 0) {
  792. mcxDialog.alert("보유포인트가 부족합니다.");
  793. return false;
  794. }
  795. }
  796. }
  797. });
  798. // 2021.06.11 사은품 초기화 작업
  799. total_gift = 0;
  800. $("#orderForm .freegiftRdo").each(function(){
  801. if ($(this).attr("allYn") == "Y" ) {
  802. total_gift += 1;
  803. } else {
  804. // 라디오버튼 사은품 체크
  805. if ($(this).is(":checked")) {
  806. // 수령거부가 아닐때 체크
  807. if ($(this).val() != "noSel") {
  808. total_gift += 1;
  809. total_deduct += parseInt($(this).attr("usepoint"));
  810. }
  811. }
  812. }
  813. });
  814. $("#orderForm .total_gift").text(total_gift); // 사은품총선택개수
  815. $("#orderForm .total_deduct").text(total_deduct.addComma()); // 사은품총사용포인트
  816. $("#orderAmtForm .freegiftUsePnt").text(total_deduct);
  817. // 포인트초기화기능
  818. pntDcAmtReset();
  819. // 2021.04.29 사은품동의 체크 기능
  820. /*
  821. $("#orderForm #chk-agree_gift").on("click", function(){
  822. if ($(this).is(":checked") == false) {
  823. mcxDialog.alert("미동의시 사은품 지급이 되지 않습니다.");
  824. }
  825. });
  826. */
  827. }
  828. // 1.6 결제타입로드
  829. paymentInfoSet();
  830. }
  831. });
  832. }
  833. // 1.6 결제타입로드 (결제버튼기능구현)
  834. var paymentInfoSet = function() {
  835. $.ajax( {
  836. type : "POST",
  837. url : '/order/paymentInfo',
  838. data : JSON.stringify(jsonObj),
  839. dataType : 'html',
  840. beforeSend : function(xhr, settings) {
  841. xhr.setRequestHeader("AJAX" , "true");
  842. xhr.setRequestHeader('Accept' , 'application/json');
  843. xhr.setRequestHeader('Content-Type' , 'application/json');
  844. },
  845. success : function(result) {
  846. if (result != null) {
  847. $("#paymentInfo").css("display", "block");
  848. $("#paymentInfo").html(result);
  849. var payType = "";
  850. // 2021.07.05 결제타입초기값 체크
  851. if ($(".payTypeNm").text() != "선택없음") {
  852. if ($("#chk-agree_paymethod").is(":checked") == false) {
  853. $("#chk-agree_paymethod").trigger("click");
  854. }
  855. }
  856. // 결제타입명칭 설정
  857. $("#orderForm .area_paymethod .paymethod_box ul li").on("click", function(){
  858. payType = $(this).find(".payType").text();
  859. if ($(this).find("input[name=rdi-paynormal]").is(":checked")) {
  860. $("#orderForm .payTypeNm").text(payType);
  861. }
  862. // 2021.04.29 수정
  863. if ($("#orderForm input[name=insuranceYn]").is(":checked")) {
  864. $("#orderForm input[name=insuranceYn]").trigger("click");
  865. }
  866. $("#orderForm .area_paymentinfo .agree1").hide();
  867. // 2021.04.25 실시간계좌이체, 무통장입금시 보증보험 신청 약관 노출
  868. if (payType == "실시간계좌이체" || payType == "무통장입금" ) {
  869. $("#orderForm .area_paymethod .agree_insurance").show();
  870. } else {
  871. $("#orderForm .area_paymethod .agree_insurance").hide();
  872. }
  873. if (delvCnt > 0) {
  874. $("#orderForm .area_paymentinfo .paymentinfo.agree2").show();
  875. } else {
  876. $("#orderForm .area_paymentinfo .paymentinfo.agree2").hide();
  877. }
  878. });
  879. // 2021.04.25 실시간계좌이체, 무통장입금시 보증보험 신청 약관 노출
  880. // 2021.05.16 동의박스체크시노출
  881. $("#orderForm input[name=insuranceYn]").on("click", function(){
  882. var displayTemp = true;
  883. if (payType == "실시간계좌이체" || payType == "무통장입금" ) {
  884. if ($(this).is(":checked")) {
  885. $("#orderForm .area_paymethod .agree_insurance").show();
  886. $("#orderForm .area_paymentinfo .paymentinfo").show();
  887. $("#orderForm .area_paymentinfo .agree1").show();
  888. } else {
  889. displayTemp = false;
  890. }
  891. } else {
  892. displayTemp = false;
  893. }
  894. if (displayTemp == false) {
  895. if (delvCnt > 0) {
  896. $("#orderForm .area_paymentinfo .paymentinfo.agree2").show();
  897. } else {
  898. $("#orderForm .area_paymentinfo .paymentinfo.agree2").hide();
  899. }
  900. $("#orderForm .area_paymentinfo .agree1").hide();
  901. }
  902. });
  903. if (delvCnt > 0) {
  904. $("#orderForm .area_paymentinfo .paymentinfo.agree2").show();
  905. } else {
  906. $("#orderForm .area_paymentinfo .paymentinfo.agree2").hide();
  907. }
  908. // 2021.05.16 초기값설정
  909. $("#orderForm .area_paymentinfo .agree1").hide();
  910. // 결제하기
  911. $("#btn_payment").on("click", function(){
  912. // 사은품정보
  913. var prePntDcAmtYn = $("#orderForm input[name='rdi-beforpoint']:checked").val();
  914. var paynormal = $("#orderForm input[name='rdi-paynormal']:checked").val();
  915. var orderDetailList = [];
  916. var delvFeeCdList = [];
  917. var ordGoodsQty = 0;
  918. var goodsNm = "";
  919. var orgEntryNo = "";
  920. var entryNo = "";
  921. var insuranceYn = "N";
  922. // 2021.04.25
  923. if ($("#orderForm input[name=insuranceYn]").is(":checked")) {
  924. insuranceYn = "Y";
  925. }
  926. // 배송주소등록
  927. if ($("#orderAmtForm .recipZipcode").text() == "00000") {
  928. mcxDialog.alert("배송정보를 등록해 주세요.");
  929. // 배송정보화면노출
  930. deliveryAddrInfoDispYn("Y");
  931. return false;
  932. }
  933. // TODO 개인통관번호 동의 체크시 통관번호 등록
  934. if (foreignBuyYn == "Y") {
  935. if ($("#orderForm input[name=rdi-overseas]:checked").val() == "Y") {
  936. if (gagajf.isNull($("#orderForm input[name=entryNo]").val())) {
  937. mcxDialog.alert("개인통관고유부호를 입력해주세요.");
  938. $('#orderForm input[name=entryNo]').focus();
  939. // 배송정보화면노출
  940. deliveryAddrInfoDispYn("Y");
  941. return false;
  942. }
  943. orgEntryNo = $("#orderForm input[name=entryNo]").val();
  944. if (orgEntryNo.substr(0,1) != "P") {
  945. mcxDialog.alert("개인통관고유부호가 유효하지 않습니다.");
  946. $('#orderForm input[name=entryNo]').focus();
  947. // 배송정보화면노출
  948. deliveryAddrInfoDispYn("Y");
  949. return false;
  950. }
  951. if (orgEntryNo.length < 13) {
  952. mcxDialog.alert("개인통관고유부호가 유효하지 않습니다.");
  953. $('#orderForm input[name=entryNo]').focus();
  954. // 배송정보화면노출
  955. deliveryAddrInfoDispYn("Y");
  956. return false;
  957. }
  958. if (!$("#orderForm #chk-overs-agr").is(":checked")) {
  959. mcxDialog.alert("개인통관정보고유부호 정보 동의/저장항목을 체크해주세요.");
  960. // 배송정보화면노출
  961. deliveryAddrInfoDispYn("Y");
  962. return false;
  963. }
  964. }
  965. }
  966. // 주문제작상품일때 주문제작정보동의
  967. if (orderMadeYn == "Y") {
  968. if (!$("#orderForm #chk-custom-agr1").is(":checked")) {
  969. mcxDialog.alert("주문제작상품에 대한 동의를 하지 않으실 경우 해당 상품을 쇼핑백에서 제외하신 후 다시 결제를 시도해주세요.");
  970. // 배송정보화면노출
  971. deliveryAddrInfoDispYn("Y");
  972. return false;
  973. }
  974. }
  975. // 사은품지급할 경우 체크 2020.04.29 사은품지급이 필수가 아닙니다.
  976. if ($("#orderAmtForm .freegiftValArr").text().length > 0) {
  977. if (!$("#orderForm #chk-agree_gift").is(":checked")) {
  978. mcxDialog.alert("사은품 지급 정보 동의를 체크해주세요.");
  979. // 배송정보화면노출
  980. freegiftInfoDispYn("Y");
  981. return false;
  982. }
  983. }
  984. // 결재수단
  985. if (gagajf.isNull(paynormal)) {
  986. mcxDialog.alert("결제수단을 선택해 주세요.");
  987. // 결제수단정보노출
  988. paymentInfoDispYn("Y");
  989. return false;
  990. }
  991. var paynormalArr = paynormal.split("|");
  992. var pgGb = paynormalArr[0];
  993. var payMeans = paynormalArr[1];
  994. var custPayMeans = "N";
  995. // 자주쓰는결제타입
  996. if ($("#orderForm #chk-agree_paymethod").is(":checked") == true) {
  997. custPayMeans = "Y";
  998. }
  999. // 주문상세데이타 생성
  1000. $("#orderDetailInfo .cartSq").each(function(){
  1001. // 주문상세단위 총알배송여부 변경
  1002. var orderDetailShotDelvYn = $(this).parent().find(".shotDelvYn").text();
  1003. if (orderDetailShotDelvYn == "Y") {
  1004. if (shotDelvYn == "N") {
  1005. orderDetailShotDelvYn = "N";
  1006. }
  1007. }
  1008. // 개인통관번호
  1009. if ($(this).parent().find(".foreignBuyYn").text() == "Y") {
  1010. entryNo = orgEntryNo;
  1011. } else {
  1012. entryNo = "";
  1013. }
  1014. var orderDetailData = {
  1015. "cartSq" : $(this).text()
  1016. ,"currPrice" : $(this).parent().find(".orgCurrPrice").text()
  1017. ,"optAddPrice" : $(this).parent().find(".optAddPrice").text()
  1018. ,"ordAmt" : $(this).parent().find(".ordAmt").text()
  1019. ,"cpn1CpnSq" : $(this).parent().find(".cpn1CpnSq").text()
  1020. ,"cpn1DcAmt" : $(this).parent().find(".cpn1DcAmt").text()
  1021. ,"goodsQty" : $(this).parent().find(".goodsQty").text()
  1022. ,"tmtb1Sq" : $(this).parent().find(".tmtb1Sq").text()
  1023. ,"tmtb1DcAmt" : $(this).parent().find(".tmtb1DcAmt").text()
  1024. ,"tmtb2Sq" : $(this).parent().find(".tmtb2Sq").text()
  1025. ,"tmtb2DcAmt" : $(this).parent().find(".tmtb2DcAmt").text()
  1026. ,"goodsCpnSq" : $(this).parent().find(".goodsCpnSq").text()
  1027. ,"goodsCpnDcAmt" : $(this).parent().find(".goodsCpnDcAmt").text()
  1028. ,"cartCpnSq" : $(this).parent().find(".cartCpnSq").text()
  1029. ,"cartCpnDcAmt" : $(this).parent().find(".cartCpnDcAmt").text()
  1030. ,"prePntDcAmt" : $(this).parent().find(".prePntDcAmt1").text()
  1031. ,"pntDcAmt" : $(this).parent().find(".pntDcAmt1").text()
  1032. ,"gfcdUseAmt" : $(this).parent().find(".gfcdUseAmt1").text()
  1033. ,"realOrdAmt" : $(this).parent().find(".realOrdAmt1").text()
  1034. ,"savePntAmt" : $(this).parent().find(".savePntAmt1").text()
  1035. ,"shotDelvYn" : orderDetailShotDelvYn
  1036. ,"foreignBuyYn" : $(this).parent().find(".foreignBuyYn").text()
  1037. ,"makeGoodsYn" : $(this).parent().find(".orderMadeYn").text()
  1038. ,"delvFeeCd" : $(this).parent().find(".delvFeeCd").text()
  1039. ,"goodsCd" : $(this).parent().find(".goodsCd").text()
  1040. ,"itemCdArr" : $(this).parent().find(".itemCd").text().split(",")
  1041. ,"optCdArr" : $(this).parent().find(".optCd").text().split(",")
  1042. ,"optCd1Arr" : $(this).parent().find(".optCd1").text().split(",")
  1043. ,"optCd2Arr" : $(this).parent().find(".optCd2").text().split(",")
  1044. ,"itemQtyArr" : $(this).parent().find(".itemQtyr").text().split(",")
  1045. ,"goodsType" : $(this).parent().find(".goodsType").text()
  1046. ,"entryNo" : entryNo
  1047. ,"giftPackYn" : "N"
  1048. }
  1049. // 상품수
  1050. ordGoodsQty++;
  1051. orderDetailList.push(orderDetailData);
  1052. });
  1053. // 주문배송업체정보 생성
  1054. $("#delvFeeCdInfo .delvFeeCd").each(function(){
  1055. var delvFeeCdData = {
  1056. "delvFeeCd" : $(this).text()
  1057. ,"supplyCompCd" : $(this).parent().find(".supplyCompCd").text()
  1058. ,"delvFee" : $(this).parent().find(".delvFee").text()
  1059. ,"delvCpnSq" : $(this).parent().find(".delvCpnSq").text()
  1060. ,"delvCpnDcAmt" : $(this).parent().find(".delvCpnDcAmt").text()
  1061. }
  1062. delvFeeCdList.push(delvFeeCdData);
  1063. });
  1064. // 2021.04.29 상픈품 체크박스 미동의시 사은품 미지급
  1065. var freegiftValArr = $("#orderAmtForm .freegiftValArr").text().split(",");
  1066. var freegiftSqArr = $("#orderAmtForm .freegiftSqArr").text().split(",");
  1067. var freegiftGoodsArr = $("#orderAmtForm .freegiftGoodsArr").text().split(",");
  1068. var freegiftUsePointArr = $("#orderAmtForm .freegiftUsePointArr").text().split(",");
  1069. /*
  1070. if (!$("#orderForm #chk-agree_gift").is(":checked") == false) {
  1071. freegiftValArr = "";
  1072. freegiftSqArr = "";
  1073. freegiftGoodsArr = "";
  1074. freegiftUsePointArr = "";
  1075. }
  1076. */
  1077. // 주문데이타 생성
  1078. var orderData = {
  1079. "custNm" : $("#orderAmtForm .custNm").text()
  1080. ,"email" : $("#orderAmtForm .email").text()
  1081. ,"recipNm" : $("#orderAmtForm .recipNm").text()
  1082. ,"recipPhnno" : $("#orderAmtForm .recipPhnno").text()
  1083. ,"recipZipcode" : $("#orderAmtForm .recipZipcode").text()
  1084. ,"recipBaseAddr" : $("#orderAmtForm .recipBaseAddr").text()
  1085. ,"recipDtlAddr" : $("#orderAmtForm .recipDtlAddr").text()
  1086. ,"delvMemo" : $("#orderAmtForm .delvMemo").text()
  1087. ,"insuranceYn" : insuranceYn
  1088. ,"sexGb" : $("#orderAmtForm .sexGb").text()
  1089. ,"birthYmd" : $("#orderAmtForm .birthYmd").text()
  1090. ,"prePntDcAmtYn" : prePntDcAmtYn
  1091. ,"orderDetailList" : orderDetailList
  1092. ,"delvFeeCdList" : delvFeeCdList
  1093. ,"shotDelvYn" : shotDelvYn
  1094. ,"entryNo" : entryNo
  1095. ,"pgGb" : pgGb
  1096. ,"payMeans" : payMeans // 네이버페이, 카카오페이
  1097. ,"payAmt" : $("#orderAmtForm .realOrdSumAmt").text()
  1098. ,"ordNm" : $("#orderAmtForm .custNm").text()
  1099. ,"ordPhnno" : $("#orderAmtForm .cellPhnno").text()
  1100. ,"goodsNm" : $("#orderAmtForm .goodsNm").eq(0).text()
  1101. ,"ordGoodsQty" : ordGoodsQty
  1102. ,"freegiftValArr" : freegiftValArr
  1103. ,"freegiftSqArr" : freegiftSqArr
  1104. ,"freegiftGoodsArr" : freegiftGoodsArr
  1105. ,"freegiftUsePointArr" : freegiftUsePointArr
  1106. ,"giftMsg" : ""
  1107. ,"custPayMeans" : custPayMeans
  1108. ,"cartSqArr" : cartSqArr
  1109. ,"orgGoodsSumAmt" : $("#orderAmtForm .orgGoodsSumAmt").text()
  1110. ,"cpn1DcSumAmt" : $("#orderAmtForm .cpn1DcSumAmt").text()
  1111. ,"tmtb1DcSumAmt" : $("#orderAmtForm .tmtb1DcSumAmt").text()
  1112. ,"tmtb2DcSumAmt" : $("#orderAmtForm .tmtb2DcSumAmt").text()
  1113. ,"goodsCpnDcSumAmt" : $("#orderAmtForm .goodsCpnDcSumAmt").text()
  1114. ,"cartCpnDcSumAmt" : $("#orderAmtForm .cartCpnDcSumAmt").text()
  1115. ,"prePntDcSumAmt" : $("#orderAmtForm .prePntDcSumAmt").text()
  1116. ,"pntDcSumAmt" : $("#orderAmtForm .pntDcSumAmt").text()
  1117. ,"gfcdUseSumAmt" : $("#orderAmtForm .gfcdUseSumAmt").text()
  1118. ,"realOrdSumAmt" : $("#orderAmtForm .realOrdSumAmt").text()
  1119. ,"delvSumAmt" : $("#orderAmtForm .delvSumAmt").text()
  1120. };
  1121. $.ajax( {
  1122. type : "POST",
  1123. url : '/order/create/preOrder',
  1124. data : JSON.stringify(orderData),
  1125. dataType : 'html',
  1126. beforeSend : function(xhr, settings) {
  1127. xhr.setRequestHeader("AJAX" , "true");
  1128. xhr.setRequestHeader('Accept' , 'application/json');
  1129. xhr.setRequestHeader('Content-Type' , 'application/json');
  1130. },
  1131. success : function(result) {
  1132. // 결재정보로드
  1133. $("#order_info").html(result);
  1134. var pgGb = $("#order_info input[name=pgGb]").val();
  1135. if (pgGb == "NAVER") {
  1136. fnNaverPaymentReady();
  1137. } else if (pgGb == "KAKAO") {
  1138. fnKakaoPaymentReady();
  1139. } else if (pgGb == "KCP" || pgGb == "PAYCO") {
  1140. if(payMeans == "G014_70") {
  1141. $("#order_info").submit();
  1142. } else {
  1143. jsf__pay(document.order_info);
  1144. }
  1145. }
  1146. }
  1147. });
  1148. });
  1149. // 1.8 할인영역 설정 (로그인여부일때 동작)
  1150. if (isLogin == true) {
  1151. dcAmtInfoSet();
  1152. } else {
  1153. // 금액계산초기화
  1154. custCpnSumAmtCal();
  1155. }
  1156. }
  1157. }
  1158. });
  1159. }
  1160. // 1.7 프로모션 쿠폰 적용 함수
  1161. var serialCpnApply = function(){
  1162. if (gagajf.isNull($("#serialCpnNm").val())) {
  1163. mcxDialog.alert("할인코드를 입력해주세요.");
  1164. $('#serialCpnNm').focus();
  1165. return false;
  1166. }
  1167. let data = {
  1168. rdCpnNm : $("#serialCpnNm").val()
  1169. }
  1170. $.ajax( {
  1171. type : "POST",
  1172. url : '/cart/list/serialCpnApply',
  1173. contentType : 'application/json',
  1174. dataType : 'json',
  1175. data : JSON.stringify(data),
  1176. success : function(result) {
  1177. // 프로모션쿠폰적용 후 할인영역 노출
  1178. jsonObj.dispYn = "Y";
  1179. // 성공일때는 쿠폰정보 및 포인트 정보 reset
  1180. if (result.serialCpnInfo.result == "SUCCESS") {
  1181. mcxDialog.alert("쿠폰 등록이 되었습니다.");
  1182. // 1.8 할인영역 재로드
  1183. dcAmtInfoSet(jsonData);
  1184. } else {
  1185. mcxDialog.alert(result.serialCpnInfo.result);
  1186. $("#serialCpnNm").val("");
  1187. }
  1188. }
  1189. });
  1190. }
  1191. // 1.8 할인영역 설정 (쿠폰, 선포인트, 포인트, 상품권)
  1192. var dcAmtInfoSet = function() {
  1193. // 1.8.1 할인정보로드
  1194. $.ajax( {
  1195. type : "POST",
  1196. url : '/order/dcAmtInfo',
  1197. data : JSON.stringify(jsonObj),
  1198. dataType : 'html',
  1199. beforeSend : function(xhr, settings) {
  1200. xhr.setRequestHeader("AJAX" , "true");
  1201. xhr.setRequestHeader('Accept' , 'application/json');
  1202. xhr.setRequestHeader('Content-Type' , 'application/json');
  1203. },
  1204. success : function(result) {
  1205. if (result != null) {
  1206. $("#dcAmtInfo").css("display", "block");
  1207. $("#dcAmtInfo").html(result);
  1208. // 쿠폰팝업정보로드
  1209. $.ajax( {
  1210. type : "POST",
  1211. url : '/order/couponApplyPop',
  1212. data : JSON.stringify(jsonObj),
  1213. dataType : 'html',
  1214. beforeSend : function(xhr, settings) {
  1215. xhr.setRequestHeader("AJAX" , "true");
  1216. xhr.setRequestHeader('Accept' , 'application/json');
  1217. xhr.setRequestHeader('Content-Type' , 'application/json');
  1218. },
  1219. success : function(result) {
  1220. $("#couponModifyPop").html(result);
  1221. // 1.8.1 선포인트기능초기화
  1222. prePntDcAmtReset();
  1223. // 1.8.2 쿠폰적용초기화(할인율최고)(상품,장바구니)
  1224. custGoodsCpnInit();
  1225. // 1.8.3 쿠폰적용초기화(할인율최고)(배송비)
  1226. custDelvCpnInit();
  1227. var custCpnCnt = parseInt($("#orderForm input[name=custCpnCnt]").val());
  1228. var custDelvCpnCnt = parseInt($("#orderForm input[name=custDelvCpnCnt]").val());
  1229. var applyCpnCnt = custCpnCnt + custDelvCpnCnt;
  1230. // 2021.04.23 보유쿠폰이 없을때 적용
  1231. if (applyCpnCnt < 1) {
  1232. if ($("#orderForm #chk-maxdisc").is(":checked")) {
  1233. $("#orderForm #chk-maxdisc").trigger("click");
  1234. }
  1235. }
  1236. // 1.8.4 쿠폰적용버튼
  1237. $("#btn_coupon_apply").on("click", function(){
  1238. // 상품쿠폰적용
  1239. $('#couponApplyForm .goodsCpn ul li.selected').each(function(index){
  1240. custCpnApply($(this));
  1241. });
  1242. // 장바구니쿠폰적용
  1243. $('#couponApplyForm .cartCpn').each(function(index){
  1244. if ($(this).find("input[name=rdi-cart-coupon]").is(":checked")) {
  1245. custCpnApply($(this));
  1246. }
  1247. });
  1248. // 최대할인혜택적용 체크해제
  1249. if ($("#chk-maxdisc").is(":checked")) {
  1250. $("#chk-maxdisc").attr("checked", false);
  1251. }
  1252. $(".close-modal").trigger("click"); // 팝업닫기
  1253. });
  1254. // 1.8.5 쿠폰 최대할인금액 초기화 버튼 설정
  1255. $("#chk-maxdisc").on("click", function(){
  1256. // 2021.04.23 보유쿠폰이 없을때 적용
  1257. if (applyCpnCnt < 1) {
  1258. mcxDialog.alert("적용 가능한 쿠폰이 없습니다.");
  1259. return false;
  1260. }
  1261. if ($(this).is(":checked")) {
  1262. // 2021.04.23
  1263. mcxDialog.alert("선택한 쿠폰이 아닌 보유한 쿠폰을 통해 최대할인 혜택을 받을 수 있도록 쿠폰이 자동 적용됩니다.");
  1264. // 상품&장바구니쿠폰 초기화
  1265. custGoodsCpnInit();
  1266. // 배송비쿠폰 초기화
  1267. custDelvCpnInit();
  1268. }
  1269. });
  1270. }
  1271. });
  1272. // 쿠폰변경팝업호출
  1273. $("#btn_couponModify_pop").on("click", function(){
  1274. // 2021.04.23 보유쿠폰이 없을때 적용
  1275. var custCpnCnt = parseInt($("#orderForm input[name=custCpnCnt]").val());
  1276. if (custCpnCnt < 1) {
  1277. mcxDialog.alert("적용 가능한 쿠폰이 없습니다.");
  1278. return false;
  1279. }
  1280. // 쿠폰초기화
  1281. custGoodsCpnInit();
  1282. $("#couponModifyPop").modal("show");
  1283. });
  1284. // 1.8.7 포인트 적용버튼 기능
  1285. $("#btn_point_apply").on("click", function(){
  1286. var rmPntAmt = parseInt($("#orderForm input[name='rmPntAmt']").val());
  1287. var freegiftUsePnt = parseInt($("#orderAmtForm .freegiftUsePnt").text());
  1288. var pntDcAmt = parseInt(uncomma($("#orderForm input[name='pntDcAmtStr']").val()));
  1289. var realOrdAmt = parseInt($("#orderAmtForm .realOrdSumAmt").text());
  1290. var pointUseMaxLimit = parseInt($("#orderForm input[name='pointUseMaxLimit']").val());
  1291. var applyPntDcAmt = (realOrdAmt * pointUseMaxLimit) / 100;
  1292. rmPntAmt = rmPntAmt - freegiftUsePnt;
  1293. if (gagajf.isNull($("#orderForm input[name=pntDcAmtStr]").val())) {
  1294. mcxDialog.alert("포인트를 입력한 후 다시 시도해주세요.");
  1295. $('#orderForm input[name=pntDcAmtStr]').focus();
  1296. return false;
  1297. }
  1298. // 입력여부체크
  1299. if (pntDcAmt < 1) {
  1300. mcxDialog.alert("포인트를 입력한 후 다시 시도해주세요.");
  1301. // 포인트리셋기능
  1302. pntDcAmtReset();
  1303. return false;
  1304. }
  1305. // 10원단위부터 입력가능
  1306. if (pntDcAmt % 10 > 0) {
  1307. mcxDialog.alert("포인트는 10P단위로 사용이 가능합니다.");
  1308. // 포인트리셋기능
  1309. pntDcAmtReset();
  1310. return false;
  1311. }
  1312. // 결제금액을 초과 할 수 없습니다.
  1313. if (pntDcAmt > realOrdAmt) {
  1314. mcxDialog.alert("입력한 포인트가 결제 금액보다 많습니다.");
  1315. // 포인트리셋기능
  1316. pntDcAmtReset();
  1317. return false;
  1318. }
  1319. // 보유포인트보다 초과 사용 불가
  1320. if (pntDcAmt > rmPntAmt) {
  1321. mcxDialog.alert("입력한 포인트가 보유한 포인트보다 많습니다.");
  1322. // 포인트리셋기능
  1323. pntDcAmtReset();
  1324. return false;
  1325. }
  1326. // TODO 포인트 사용금액 1000P 이상 사용
  1327. if (pntDcAmt < 1000) {
  1328. mcxDialog.alert("포인트는 최소 1,000P이상 사용해야 합니다.");
  1329. // 포인트리셋기능
  1330. pntDcAmtReset();
  1331. return false;
  1332. }
  1333. // 실결제금액보다 크게 적용 되었을때 적용 불가능
  1334. if (pntDcAmt > applyPntDcAmt) {
  1335. mcxDialog.alert("결제금액의 최대 " + pointUseMaxLimit +"%를 초과 사용 할 수 없습니다.");
  1336. // 포인트리셋기능
  1337. pntDcAmtReset();
  1338. return false;
  1339. }
  1340. // 2021.04.23 추가
  1341. mcxDialog.alert("총 " + pntDcAmt + " P를 차감 결제 합니다.");
  1342. // 포인트 적용
  1343. $("#orderAmtForm .pntDcSumAmt").text(pntDcAmt);
  1344. $("#pntDcAmt").text(getZeroMinusDelAmt(pntDcAmt)+" 원");
  1345. // 상품권리렛기능
  1346. gfcdUseAmtReset();
  1347. });
  1348. // 1.8.8 상품권 적용버튼 기능
  1349. $("#btn_gfcd_apply").on("click", function(){
  1350. var rmGfcdAmt = parseInt($("#orderForm input[name='rmGfcdAmt']").val());
  1351. var gfcdUseAmt = parseInt(uncomma($("#orderForm input[name='gfcdUseAmtStr']").val()));
  1352. var realOrdAmt = parseInt($("#orderAmtForm .realOrdSumAmt").text());
  1353. if (gagajf.isNull($("#orderForm input[name=gfcdUseAmtStr]").val())) {
  1354. mcxDialog.alert("금액을 입력한 후 다시 시도해주세요.");
  1355. $('#orderForm input[name=gfcdUseAmtStr]').focus();
  1356. return false;
  1357. }
  1358. // 입력여부체크
  1359. if (gfcdUseAmt < 1 || $("#orderForm input[name='gfcdUseAmtStr']").val() == "") {
  1360. mcxDialog.alert("금액을 입력한 후 다시 시도해주세요.");
  1361. // 상품권리셋기능
  1362. gfcdUseAmtReset();
  1363. return false;
  1364. }
  1365. // 결제금액을 초과 할 수 없습니다.
  1366. if (gfcdUseAmt > realOrdAmt) {
  1367. mcxDialog.alert("입력한 금액이 결제할 금액보다 많습니다.");
  1368. // 포인트리셋기능
  1369. gfcdUseAmtReset();
  1370. return false;
  1371. }
  1372. // 보유금액보다 초과 사용 불가
  1373. if (gfcdUseAmt > rmGfcdAmt) {
  1374. mcxDialog.alert("보유금액 보다 초과 사용 할 수 없습니다.");
  1375. // 상품권리셋기능
  1376. gfcdUseAmtReset();
  1377. return false;
  1378. }
  1379. // 보유금액보다 초과 사용 불가
  1380. if (gfcdUseAmt > rmGfcdAmt) {
  1381. mcxDialog.alert("보유금액 보다 초과 사용 할 수 없습니다.");
  1382. // 상품권리셋기능
  1383. gfcdUseAmtReset();
  1384. return false;
  1385. }
  1386. // TODO 포인트 사용금액 1000원 이상 사용
  1387. if (gfcdUseAmt < 1000) {
  1388. mcxDialog.alert("상품권 사용금액은 최소 1,000원 이상 사용해야 합니다.");
  1389. // 상품권리셋기능
  1390. gfcdUseAmtReset();
  1391. return false;
  1392. }
  1393. // 2021.04.23 추가
  1394. mcxDialog.alert("총 " + gfcdUseAmt.addComma() + " 원을 상품권 금액에서 차감 결제 합니다.");
  1395. // 상품권 적용
  1396. $("#orderAmtForm .gfcdUseSumAmt").text(gfcdUseAmt);
  1397. $("#gfcdUseAmt").text(getZeroMinusDelAmt(gfcdUseAmt)+" 원");
  1398. // 금액전체계산
  1399. custCpnSumAmtCal();
  1400. });
  1401. // 금액계산초기화
  1402. custCpnSumAmtCal();
  1403. }
  1404. }
  1405. });
  1406. }
  1407. // 1.9.1 상품쿠폰초기화
  1408. var custGoodsCpnInit = function() {
  1409. // 쿠폰최대할인 적용
  1410. $("#chk-maxdisc").attr("checked", true);
  1411. // 쿠폰초기화
  1412. $(".goodsCpn").each(function(index){
  1413. // select box 쿠폰 적용
  1414. var cpnCartSq = $(this).find("input[name='cpnCartSq']").val();
  1415. // 장바구니시퀀스 체크
  1416. $("#orderAmtForm .cartSq").each(function(){
  1417. if (cpnCartSq == $(this).text()) {
  1418. $(this).parent().find(".goodsCpnSq").text("0"); // 상품쿠폰시퀀스
  1419. $(this).parent().find(".goodsCpnDcAmt").text("0"); // 상품쿠폰할인금액
  1420. }
  1421. });
  1422. $(this).find("input[name='custCpnSq']").val("0");
  1423. $(this).find("input[name='cpnDcAmt']").val("0");
  1424. // 적용안함 적용
  1425. var emptyHtml = $(this).find("ul li .item_coupon.empty").html();
  1426. $(this).find(".select .item_coupon").html(emptyHtml);
  1427. $(this).find("ul li").removeClass("selected");
  1428. });
  1429. // 최대할인율 쿠폰적용
  1430. $('.goodsCpn').each(function(index){
  1431. cpnIndex = 0;
  1432. cpnApplyTemp = false;
  1433. // select 박스 반복문 실행
  1434. $(this).find("ul li").each(function(i){
  1435. cpnIndex++;
  1436. if (cpnApplyTemp == false) {
  1437. if (custCpnDuplicationCheck($(this).attr("value"), cpnIndex)) {
  1438. // 쿠폰적용
  1439. custCpnApply($(this));
  1440. // 쿠폰할인적용
  1441. cpnApplyTemp = true;
  1442. }
  1443. }
  1444. // 쿠폰 select 버튼기능
  1445. $(this).on("click", function(){
  1446. if (custCpnDuplicationCheck($(this).attr("value"), cpnIndex)) {
  1447. // 쿠폰적용
  1448. custCpnApplyTemp($(this));
  1449. // 쿠폰할인적용
  1450. cpnApplyTemp = true;
  1451. } else {
  1452. custCpnNotApply($(this));
  1453. }
  1454. });
  1455. });
  1456. });
  1457. // 장바구니쿠폰초기화
  1458. custCartCpnInit();
  1459. }
  1460. // 1.9.2 장바구니쿠폰초기화
  1461. var custCartCpnInit = function() {
  1462. // 장바구니쿠폰 초기화 적용
  1463. $(".cartCpn").each(function(index) {
  1464. if (index == 0) {
  1465. custCpnApply($(this)); // 쿠폰적용
  1466. }
  1467. // 쿠폰 select 버튼기능
  1468. $(this).on("click", function(){
  1469. custCpnApplyTemp($(this)); // 쿠폰적용
  1470. // 최대할인혜택적용 체크해제
  1471. if ($("#chk-maxdisc").is(":checked")) {
  1472. $("#chk-maxdisc").attr("checked", false);
  1473. }
  1474. });
  1475. });
  1476. // 포인트기능 리셋
  1477. pntDcAmtReset();
  1478. }
  1479. // 1.9.3 배송비쿠폰초기화
  1480. var custDelvCpnInit = function() {
  1481. // 배송비쿠폰 초기화 적용
  1482. $(".delvCpn").each(function(index) {
  1483. if (index == 0) {
  1484. // 쿠폰적용
  1485. custCpnApply($(this));
  1486. }
  1487. // 쿠폰 select 버튼기능
  1488. $(this).on("click", function(){
  1489. // 쿠폰적용
  1490. custCpnApply($(this));
  1491. // 최대할인혜택적용 체크해제
  1492. if ($("#chk-maxdisc").is(":checked")) {
  1493. $("#chk-maxdisc").trigger("click");
  1494. }
  1495. });
  1496. });
  1497. }
  1498. // 1.10 쿠폰중복사용체크
  1499. var custCpnDuplicationCheck = function(custCpnSq, index) {
  1500. var selCustSq = 0;
  1501. var cnt = 0;
  1502. // 쿠폰적용가능
  1503. if (custCpnSq == 0) {
  1504. return true;
  1505. }
  1506. // 쿠폰중본사용체크
  1507. $(".goodsCpn input[name='custCpnSq']").each(function(i){
  1508. if (index != i) {
  1509. selCustSq = $(this).val();
  1510. if (selCustSq == custCpnSq) {
  1511. cnt++;
  1512. }
  1513. }
  1514. });
  1515. // 쿠폰적용불가
  1516. if (cnt > 0) {
  1517. return false;
  1518. }
  1519. // 쿠폰적용가능
  1520. else {
  1521. return true;
  1522. }
  1523. }
  1524. // 1.11.0 임시로 쿠폰적용
  1525. var custCpnApplyTemp = function(obj) {
  1526. // select box 쿠폰 적용
  1527. var cpnType = obj.parent().find("input[name='cpnType']").val();
  1528. // 상품쿠폰적용
  1529. if (cpnType == "goodsCpn") {
  1530. var itemHtml = obj.find(".item_coupon").html();
  1531. obj.parent().parent().find(".select .item_coupon").html(itemHtml);
  1532. obj.parent().find("input[name='cpnDcAmt']").val(obj.attr("data"));
  1533. obj.parent().find("input[name='custCpnSq']").val(obj.attr("value"));
  1534. // 장바구니쿠폰 초기화 적용
  1535. $("#couponApplyForm .cartCpn").each(function(index) {
  1536. if (index == 0) {
  1537. custCpnApplyTemp($(this)); // 쿠폰적용
  1538. }
  1539. });
  1540. //상품쿠폰 선택불가 처리
  1541. custCpnSqLiDisabled();
  1542. }
  1543. // 장바구니쿠폰적용
  1544. else if (cpnType == "cartCpn") {
  1545. var dcWay = obj.find("input[name='dcWay']").val();
  1546. var dcVal = obj.find("input[name='dcVal']").val();
  1547. var maxDcAmt = obj.find("input[name='maxDcAmt']").val();
  1548. var buyLimitAmt = obj.find("input[name='buyLimitAmt']").val();
  1549. var cartCpnDcSumAmt = 0;
  1550. var tempSumAmt = 0;
  1551. var cartSqLen = $(".cartSq").length;
  1552. var leftAmt = 0;
  1553. var index = 1;
  1554. // 장바구니쿠폰 해당 장바구니상품들 할인가 적용
  1555. obj.find("input[name='cartCpnCartSq']").each(function(){
  1556. var cartCpnCartSq = $(this).val();
  1557. var cartCpnDcAmt = 0;
  1558. // 장바구니시퀀스 체크
  1559. $("#orderAmtForm .cartSq").each(function(){
  1560. if (cartCpnCartSq == $(this).text()) {
  1561. var orgCurrPrice = parseInt($(this).parent().find(".orgCurrPrice").text());
  1562. var cpn1DcAmt = parseInt($(this).parent().find(".cpn1DcAmt").text());
  1563. var goodsQty = parseInt($(this).parent().find(".goodsQty").text());
  1564. var tmtb1DcAmt = parseInt($(this).parent().find(".tmtb1DcAmt").text());
  1565. var tmtb2DcAmt = parseInt($(this).parent().find(".tmtb2DcAmt").text());
  1566. var goodsCpnDcAmt = 0;
  1567. $("#orderForm .goodsCpn input[name=cpnCartSq]").each(function(){
  1568. if ($(this).val() == cartCpnCartSq) {
  1569. goodsCpnDcAmt = parseInt($(this).parent().find("input[name=cpnDcAmt]").val());
  1570. }
  1571. });
  1572. var tempAmt = ((orgCurrPrice - cpn1DcAmt) * goodsQty) - tmtb1DcAmt - tmtb2DcAmt - goodsCpnDcAmt;
  1573. tempSumAmt = tempSumAmt + tempAmt;
  1574. // 할인율일때 할인금액
  1575. if (dcWay == "G240_11") {
  1576. cartCpnDcAmt = (tempAmt * dcVal) / 100;
  1577. cartCpnDcSumAmt = cartCpnDcSumAmt + cartCpnDcAmt;
  1578. }
  1579. }
  1580. });
  1581. });
  1582. // 금액일때 할인금액 적용
  1583. if (dcWay == "G240_10") {
  1584. cartCpnDcSumAmt = dcVal;
  1585. }
  1586. // 2021.04.19 최대금액 체크
  1587. if (maxDcAmt > cartCpnDcSumAmt || maxDcAmt == 0) {
  1588. cartCpnDcSumAmt = cartCpnDcSumAmt;
  1589. } else {
  1590. cartCpnDcSumAmt = maxDcAmt;
  1591. }
  1592. obj.find("input[name=rdi-cart-coupon]").prop("checked", true);
  1593. obj.parent().find("input[name=cpnDcAmt]").val(cartCpnDcSumAmt);
  1594. obj.parent().find("input[name=custCpnSq]").val(obj.attr("value"));
  1595. }
  1596. var cpnDcSumAmt = 0;
  1597. var cpnApplyCnt = 0;
  1598. var goodsCartCpnSumAmt = 0;
  1599. var cpnType = "";
  1600. $("#couponApplyForm input[name='cpnDcAmt']").each(function(){
  1601. cpnType = $(this).parent().find("input[name=cpnType]").val();
  1602. // 상품, 장바구니쿠폰 할인 금액만 합계 적용
  1603. if (cpnType == "goodsCpn" || cpnType == "cartCpn") {
  1604. goodsCartCpnSumAmt = goodsCartCpnSumAmt + parseInt($(this).val());
  1605. }
  1606. });
  1607. // 상품, 장바구니쿠폰 할인 금액만 합계 적용
  1608. $("#couponApplyForm .modal-footer .goodsCartCpnSumAmt").text(getZeroMinusDelAmt(goodsCartCpnSumAmt));
  1609. }
  1610. // 1.11 쿠폰중복체크 후 적용가능
  1611. var custCpnApply = function(obj) {
  1612. // select box 쿠폰 적용
  1613. var cpnType = obj.parent().find("input[name='cpnType']").val();
  1614. // 상품쿠폰적용
  1615. if (cpnType == "goodsCpn") {
  1616. var itemHtml = obj.find(".item_coupon").html();
  1617. obj.parent().parent().find(".select .item_coupon").html(itemHtml);
  1618. obj.parent().find("input[name='cpnDcAmt']").val(obj.attr("data"));
  1619. obj.parent().find("input[name='custCpnSq']").val(obj.attr("value"));
  1620. var cpnCartSq = obj.parent().parent().find("input[name='cpnCartSq']").val();
  1621. // 장바구니시퀀스 체크
  1622. $("#orderAmtForm .cartSq").each(function(){
  1623. if (cpnCartSq == $(this).text()) {
  1624. $(this).parent().find(".goodsCpnSq").text(obj.prop("value")); // 상품쿠폰시퀀스
  1625. $(this).parent().find(".goodsCpnDcAmt").text(obj.attr("data")); // 상품쿠폰할인금액
  1626. }
  1627. });
  1628. // 선택활성화
  1629. $(obj).addClass("selected");
  1630. //상품쿠폰 선택불가 처리
  1631. custCpnSqLiDisabled();
  1632. }
  1633. // 장바구니쿠폰적용
  1634. else if (cpnType == "cartCpn") {
  1635. var dcWay = obj.find("input[name='dcWay']").val();
  1636. var dcVal = obj.find("input[name='dcVal']").val();
  1637. var maxDcAmt = obj.find("input[name='maxDcAmt']").val();
  1638. var buyLimitAmt = obj.find("input[name='buyLimitAmt']").val();
  1639. var cartCpnDcSumAmt = 0;
  1640. var tempSumAmt = 0;
  1641. var cartSqLen = $("#orderAmtForm .cartSq").length;
  1642. var leftAmt = 0;
  1643. var index = 1;
  1644. // 2021.04.19 장바구니시퀀스 값 초기화
  1645. $("#orderAmtForm .cartSq").each(function(){
  1646. $(this).parent().find(".cartCpnSq").text(0);
  1647. $(this).parent().find(".cartCpnDcAmt").text(0);
  1648. });
  1649. // 장바구니쿠폰 해당 장바구니상품들 할인가 적용
  1650. obj.find("input[name='cartCpnCartSq']").each(function(){
  1651. var cartCpnCartSq = $(this).val();
  1652. var cartCpnDcAmt = 0;
  1653. // 장바구니시퀀스 체크
  1654. $("#orderAmtForm .cartSq").each(function(){
  1655. if (cartCpnCartSq == $(this).text()) {
  1656. var orgCurrPrice = parseInt($(this).parent().find(".orgCurrPrice").text());
  1657. var cpn1DcAmt = parseInt($(this).parent().find(".cpn1DcAmt").text());
  1658. var goodsQty = parseInt($(this).parent().find(".goodsQty").text());
  1659. var tmtb1DcAmt = parseInt($(this).parent().find(".tmtb1DcAmt").text());
  1660. var tmtb2DcAmt = parseInt($(this).parent().find(".tmtb2DcAmt").text());
  1661. var goodsCpnDcAmt = parseInt($(this).parent().find(".goodsCpnDcAmt").text());
  1662. var tempAmt = ((orgCurrPrice - cpn1DcAmt) * goodsQty) - tmtb1DcAmt - tmtb2DcAmt - goodsCpnDcAmt;
  1663. tempSumAmt = tempSumAmt + tempAmt;
  1664. // 할인율일때 할인금액
  1665. if (dcWay == "G240_11") {
  1666. cartCpnDcAmt = parseInt((tempAmt * dcVal) / 100);
  1667. cartCpnDcSumAmt = cartCpnDcSumAmt + cartCpnDcAmt;
  1668. $(this).parent().find(".cartCpnSq").text(obj.attr("value"));
  1669. $(this).parent().find(".cartCpnDcAmt").text(cartCpnDcAmt);
  1670. }
  1671. }
  1672. });
  1673. });
  1674. // 장바구니쿠폰 결제가능수단목록조회
  1675. if (obj.find("input[name='payTypeArr']").length > 0) {
  1676. $("#orderForm input[name=rdi-paynormal]").attr("disabled", true);
  1677. $("#orderForm input[name=rdi-paynormal]").attr("checked", false);
  1678. obj.find("input[name='payTypeArr']").each(function(i){
  1679. var payType = $(this).val();
  1680. $('#orderForm .'+payType).attr("disabled", false);
  1681. });
  1682. // 선택안함
  1683. $("#orderForm .payTypeNm").text("선택없음");
  1684. // 2021.06.18 장바구니쿠폰 PG 제어가 있으면 초기화하고 결제타입 펼침
  1685. //paymentInfoDispYn("Y");
  1686. } else {
  1687. $("#orderForm input[name=rdi-paynormal]").attr("disabled", false);
  1688. }
  1689. // 2021.04.25 실시간계좌이체, 무통장입금시 보증보험 신청 약관 노출 감추는기능
  1690. $("#orderForm .insuranceYn").hide();
  1691. // 2021.04.19 최대금액 체크
  1692. if (maxDcAmt > cartCpnDcSumAmt || maxDcAmt == 0) {
  1693. cartCpnDcSumAmt = cartCpnDcSumAmt;
  1694. } else {
  1695. // 최대값 적용 일때는 금액할인 방식을 적용
  1696. cartCpnDcSumAmt = maxDcAmt;
  1697. dcVal = cartCpnDcSumAmt;
  1698. dcWay = "G240_10";
  1699. }
  1700. // 금액일때 할인금액 적용
  1701. if (dcWay == "G240_10") {
  1702. cartCpnDcSumAmt = dcVal;
  1703. leftAmt = dcVal;
  1704. index = 1;
  1705. // 장바구니쿠폰 해당 장바구니상품들 할인가 적용
  1706. obj.find("input[name='cartCpnCartSq']").each(function(){
  1707. var cartCpnCartSq = $(this).val();
  1708. var cartCpnDcAmt = 0;
  1709. // 장바구니시퀀스 체크
  1710. $("#orderAmtForm .cartSq").each(function(){
  1711. if (cartCpnCartSq == $(this).text()) {
  1712. var orgCurrPrice = parseInt($(this).parent().find(".orgCurrPrice").text());
  1713. var cpn1DcAmt = parseInt($(this).parent().find(".cpn1DcAmt").text());
  1714. var goodsQty = parseInt($(this).parent().find(".goodsQty").text());
  1715. var tmtb1DcAmt = parseInt($(this).parent().find(".tmtb1DcAmt").text());
  1716. var tmtb2DcAmt = parseInt($(this).parent().find(".tmtb2DcAmt").text());
  1717. var goodsCpnDcAmt = parseInt($(this).parent().find(".goodsCpnDcAmt").text());
  1718. var tempAmt = ((orgCurrPrice - cpn1DcAmt) * goodsQty) - tmtb1DcAmt - tmtb2DcAmt - goodsCpnDcAmt;
  1719. var tempDiv = parseInt((tempAmt / tempSumAmt) * 100);
  1720. var cartCpnDcAmt = 0;
  1721. if (index == cartSqLen) {
  1722. cartCpnDcAmt = leftAmt;
  1723. } else {
  1724. cartCpnDcAmt = parseInt((cartCpnDcSumAmt * tempDiv) / 100);
  1725. leftAmt = leftAmt - cartCpnDcAmt;
  1726. }
  1727. $(this).parent().find(".cartCpnSq").text(obj.attr("value"));
  1728. $(this).parent().find(".cartCpnDcAmt").text(cartCpnDcAmt);
  1729. index++;
  1730. }
  1731. });
  1732. });
  1733. }
  1734. obj.find("input[name=rdi-cart-coupon]").prop("checked", true);
  1735. obj.parent().find("input[name=cpnDcAmt]").val(cartCpnDcSumAmt);
  1736. obj.parent().find("input[name=custCpnSq]").val(obj.attr("value"));
  1737. }
  1738. // 배송비쿠폰적용
  1739. else if (cpnType == "delvCpn") {
  1740. // 적용안함 적용
  1741. var itemHtml = obj.find(".dlvr_coupon").html();
  1742. obj.parent().parent().find(".select .dlvr_coupon").html(itemHtml);
  1743. obj.parent().find("input[name='cpnDcAmt']").val(obj.attr("data"));
  1744. obj.parent().find("input[name='custCpnSq']").val(obj.attr("value"));
  1745. obj.parent().find("input[name='delvFeeCd']").val(obj.attr("delvfeecd"));
  1746. var delvFeeCd = obj.attr("delvfeecd");
  1747. // 배송비쿠폰 테이블 적용
  1748. $("#orderAmtForm .delvFeeCd").each(function(){
  1749. // 배송비쿠폰적용
  1750. if ($(this).text() == delvFeeCd) {
  1751. $(this).parent().find(".delvCpnSq").text(obj.attr("value"));
  1752. $(this).parent().find(".delvCpnDcAmt").text(obj.attr("data"));
  1753. }
  1754. // 배송비쿠폰적용안함
  1755. else if (delvFeeCd == 0) {
  1756. $(this).parent().find(".delvCpnSq").text(obj.attr("value"));
  1757. $(this).parent().find(".delvCpnDcAmt").text(obj.attr("data"));
  1758. }
  1759. });
  1760. }
  1761. // 포인트기능 리렛
  1762. pntDcAmtReset();
  1763. }
  1764. // 1.11.1 상품쿠폰 선택불가 처리
  1765. var custCpnSqLiDisabled = function() {
  1766. // 상품쿠폰 선택불가 처리
  1767. $(".goodsCpn ul li").each(function(){
  1768. var custCpnSq = $(this).attr("value");
  1769. var liObj = $(this);
  1770. liObj.attr("aria-disabled", false);
  1771. // 선택된 li 제외
  1772. if ($(this).hasClass("selected") == false) {
  1773. // 적용안함 제외
  1774. if (custCpnSq > 0) {
  1775. // 선택된 custCpnSq li와 같으면 선택불가처리
  1776. $(".area_item_coupon input[name=custCpnSq]").each(function(){
  1777. var inputCustCpSq = $(this).val();
  1778. if (custCpnSq == inputCustCpSq) {
  1779. // 선택불가처리
  1780. liObj.attr("aria-disabled", true);
  1781. }
  1782. });
  1783. }
  1784. }
  1785. });
  1786. }
  1787. // 1.12 쿠폰중복체크 후 적용불가
  1788. var custCpnNotApply = function(obj) {
  1789. // 이전에 등록된 쿠폰시퀀스
  1790. var custCpnSq = obj.parent().find("input[name='custCpnSq']").val();
  1791. // 이전에 등록된 쿠폰시퀀스 비교후 데이타 원복
  1792. obj.parent().find("li").each(function(){
  1793. if ($(this).attr("value") == custCpnSq) {
  1794. var itemHtml = $(this).find(".item_coupon").html();
  1795. obj.parent().parent().find(".select .item_coupon").html(itemHtml);
  1796. }
  1797. });
  1798. // 포인트기능 리렛
  1799. pntDcAmtReset();
  1800. }
  1801. // 1.14 선포인트리셋기능 (사용안함)
  1802. var prePntDcAmtReset = function() {
  1803. // 2021.04.29 수정
  1804. var rmPrePntAmt = parseInt($("#orderForm input[name='rmPrePntAmt']").val());
  1805. if (rmPrePntAmt > 0) {
  1806. rmPrePntAmt = parseInt($("#orderForm input[name='rmPrePntAmt']").val());
  1807. $("#orderForm input[name='prePntDcAmt']").val(rmPrePntAmt);
  1808. } else {
  1809. rmPrePntAmt = 0;
  1810. }
  1811. // 선포인트사용여부 체크 후 적용
  1812. $("#orderForm input[name='rdi-beforpoint']").each(function(){
  1813. // 선포인트 초기 설정 사용함
  1814. if ($(this).val() == "Y") {
  1815. $(this).attr("checked", true);
  1816. }
  1817. // 버튼기능 구현
  1818. $(this).on("click", function(){
  1819. var rmPrePntAmt = parseInt($("#orderForm input[name='rmPrePntAmt']").val());
  1820. // 선포인트적용
  1821. if ($(this).val() == "Y") {
  1822. $("#prePntDcAmt").text(getZeroMinusDelAmt(rmPrePntAmt)+" 원");
  1823. } else {
  1824. $("#prePntDcAmt").text("0 원");
  1825. }
  1826. // 쿠폰할인금액 SUM
  1827. custCpnSumAmtCal();
  1828. });
  1829. });
  1830. $("#orderForm #prePntDcAmt").text(getZeroMinusDelAmt(rmPrePntAmt)+" 원");
  1831. // 포인트기능 리렛
  1832. pntDcAmtReset();
  1833. }
  1834. // 1.15 포인트리셋기능
  1835. var pntDcAmtReset = function() {
  1836. $("#orderAmtForm .pntDcSumAmt").text("0");
  1837. $("#orderForm input[name='pntDcAmtStr']").val("");
  1838. $("#pntDcAmt").text("0 원");
  1839. // 상품권리셋기능
  1840. gfcdUseAmtReset();
  1841. }
  1842. // 1.16 상품권리셋기능
  1843. var gfcdUseAmtReset = function() {
  1844. $("#orderAmtForm .gfcdUseSumAmt").text("0");
  1845. $("#orderForm input[name='gfcdUseAmtStr']").val("");
  1846. $("#gfcdUseAmt").text("0 원");
  1847. // 금액전체계산
  1848. custCpnSumAmtCal();
  1849. }
  1850. // 1.17 쿠폰할인금액합계설정(금액전체계산)
  1851. var custCpnSumAmtCal = function() {
  1852. var cpnDcSumAmt = 0;
  1853. var cpnApplyCnt = 0;
  1854. var goodsCartCpnSumAmt = 0;
  1855. var cpnType = "";
  1856. $("input[name='cpnDcAmt']").each(function(){
  1857. cpnType = $(this).parent().find("input[name=cpnType]").val();
  1858. cpnDcSumAmt = cpnDcSumAmt + parseInt($(this).val());
  1859. // 적용된 쿠폰 수량
  1860. if (parseInt($(this).val()) > 0) {
  1861. cpnApplyCnt++;
  1862. }
  1863. // 상품, 장바구니쿠폰 할인 금액만 합계 적용
  1864. if (cpnType == "goodsCpn" || cpnType == "cartCpn") {
  1865. goodsCartCpnSumAmt = goodsCartCpnSumAmt + parseInt($(this).val());
  1866. }
  1867. });
  1868. // 상품, 장바구니쿠폰 할인 금액만 합계 적용
  1869. $(".maxdisc_amount .goodsCartCpnDcAmt").text(getZeroMinusDelAmt(goodsCartCpnSumAmt)); // 쿠폰할인금액합계
  1870. $(".goodsCartCpnSumAmt").text(getZeroMinusDelAmt(goodsCartCpnSumAmt)); // 쿠폰할인금액합계
  1871. // 전체쿠폰 할인 금액 합계 적용
  1872. $(".maxdisc_amount .cpnDcAmt").text(getZeroMinusDelAmt(cpnDcSumAmt)); // 쿠폰할인금액합계
  1873. $("#couponDcSumAmt").text(getZeroMinusDelAmt(goodsCartCpnSumAmt)+ " 원"); // 쿠폰할인금액합계
  1874. $("#orderAmtForm .cpnDcSumAmt").text(cpnDcSumAmt);
  1875. var delvSumAmt = orgSumDelvFee;
  1876. // 배송비할인적용
  1877. $("input[name='cpnType']").each(function(){
  1878. if ($(this).val() == "delvCpn") {
  1879. delvSumAmt = parseInt(orgSumDelvFee) - parseInt($(this).parent().find("input[name='cpnDcAmt']").val());
  1880. // 최종배송비
  1881. $("#delvSumAmt").text(delvSumAmt.addComma() + " 원");
  1882. $("#orderAmtForm .delvSumAmt").text(delvSumAmt);
  1883. }
  1884. });
  1885. // 2021.03.06 주문상세 테이블 적용
  1886. // 포인트금액 상품상세에 포인트금액 분배 작업
  1887. var prePntDcAmtYn = $("#orderForm input[name='rdi-beforpoint']:checked").val();
  1888. var leftPntAmt = parseInt($("#orderAmtForm .pntDcSumAmt").text());
  1889. var leftGfcdAmt = parseInt($("#orderAmtForm .gfcdUseSumAmt").text());
  1890. var cartSqLenght = $("#orderAmtForm .cartSq").length;
  1891. var index = 1;
  1892. var orgGoodsSumAmt = 0;
  1893. var cpn1DcSumAmt = 0;
  1894. var ordSumAmt = 0;
  1895. var tmtb1DcSumAmt = 0;
  1896. var tmtb2DcSumAmt = 0;
  1897. var tmtbDcSumAmt = 0;
  1898. var goodsCpnDcSumAmt = 0;
  1899. var cartCpnDcSumAmt = 0;
  1900. var delvCpnDcSumAmt = 0;
  1901. var cpnDcSumAmt = 0;
  1902. var prePntDcSumAmt = 0;
  1903. var pntDcSumAmt = parseInt($(".pntDcSumAmt").text());
  1904. var gfcdUseSumAmt = parseInt($(".gfcdUseSumAmt").text());
  1905. var realOrdSumAmt = 0;
  1906. var savePntSumAmt = 0;
  1907. $("#orderAmtForm .cartSq").each(function(){
  1908. var orgCurrPrice = parseInt($(this).parent().find(".orgCurrPrice").text());
  1909. var cpn1DcAmt = parseInt($(this).parent().find(".cpn1DcAmt").text());
  1910. var optAddPrice = parseInt($(this).parent().find(".optAddPrice").text());
  1911. var goodsQty = parseInt($(this).parent().find(".goodsQty").text());
  1912. var tmtb1DcAmt = parseInt($(this).parent().find(".tmtb1DcAmt").text());
  1913. var tmtb2DcAmt = parseInt($(this).parent().find(".tmtb2DcAmt").text());
  1914. var goodsCpnDcAmt = parseInt($(this).parent().find(".goodsCpnDcAmt").text());
  1915. var cartCpnDcAmt = parseInt($(this).parent().find(".cartCpnDcAmt").text());
  1916. var prePntDcAmt1 = parseInt($(this).parent().find(".prePntDcAmt1").text());
  1917. var dcSumAmt = 0;
  1918. // 주문금액 = ((판매가 - 즉시할인가) + 옵션추가금액) * 장바구니수량
  1919. orgGoodsSumAmt = orgGoodsSumAmt + (orgCurrPrice + optAddPrice) * goodsQty;
  1920. //orgGoodsSumAmt = orgGoodsSumAmt + orgCurrPrice;
  1921. cpn1DcSumAmt = cpn1DcSumAmt + (cpn1DcAmt * goodsQty);
  1922. tmtb1DcSumAmt = tmtb1DcSumAmt + tmtb1DcAmt;
  1923. tmtb2DcSumAmt = tmtb2DcSumAmt + tmtb2DcAmt;
  1924. tmtbDcSumAmt = tmtbDcSumAmt + (tmtb1DcAmt + tmtb2DcAmt);
  1925. goodsCpnDcSumAmt = goodsCpnDcSumAmt + goodsCpnDcAmt;
  1926. cartCpnDcSumAmt = cartCpnDcSumAmt + cartCpnDcAmt;
  1927. cpnDcSumAmt = cpnDcSumAmt + (goodsCpnDcAmt + cartCpnDcAmt);
  1928. prePntDcSumAmt = prePntDcSumAmt + prePntDcAmt1;
  1929. var ordAmt = ((orgCurrPrice - cpn1DcAmt) + optAddPrice) * goodsQty;
  1930. ordSumAmt = ordSumAmt + ordAmt;
  1931. // 선포인트사용여부
  1932. // 할인금액합계 = 다다익선수량금액 + 다다익선금액금액 + 상품쿠폰금액 + 장바구니금액 + 선포인트금액
  1933. if (prePntDcAmtYn == "Y") {
  1934. dcSumAmt = tmtb1DcAmt + tmtb2DcAmt + goodsCpnDcAmt + cartCpnDcAmt + prePntDcAmt1;
  1935. } else {
  1936. dcSumAmt = tmtb1DcAmt + tmtb2DcAmt + goodsCpnDcAmt + cartCpnDcAmt;
  1937. }
  1938. // 주문금액설정
  1939. $(this).parent().find(".ordAmt").text(ordAmt);
  1940. $(this).parent().find(".dcSumAmt").text(dcSumAmt);
  1941. });
  1942. // 포인트, 상품권 금액 분배
  1943. $("#orderAmtForm .cartSq").each(function(){
  1944. var pntPrate = parseInt($(this).parent().find(".pntPrate").text());
  1945. var pntMrate = parseInt($(this).parent().find(".pntMrate").text());
  1946. var ordAmt = parseInt($(this).parent().find(".ordAmt").text());
  1947. var dcSumAmt = parseInt($(this).parent().find(".dcSumAmt").text());
  1948. var prePntDcAmt1 = parseInt($(this).parent().find(".prePntDcAmt1").text());
  1949. var tempDiv = parseInt((ordAmt / ordSumAmt) * 100);
  1950. var pntDcAmt1 = 0;
  1951. var gfcdUseAmt1 = 0;
  1952. var savePntAmt1 = 0;
  1953. if (index == cartSqLenght) {
  1954. pntDcAmt1 = leftPntAmt;
  1955. gfcdUseAmt1 = leftGfcdAmt;
  1956. } else {
  1957. pntDcAmt1 = parseInt((pntDcSumAmt * tempDiv) / 100);
  1958. gfcdUseAmt1 = parseInt((gfcdUseSumAmt * tempDiv) / 100);
  1959. leftPntAmt = leftPntAmt - pntDcAmt1;
  1960. leftGfcdAmt = leftGfcdAmt - gfcdUseAmt1;
  1961. }
  1962. var realOrdAmt1 = ordAmt - dcSumAmt - pntDcAmt1 - gfcdUseAmt1;
  1963. var realOrdAmt2 = ordAmt - dcSumAmt - pntDcAmt1;
  1964. realOrdSumAmt = realOrdSumAmt + realOrdAmt1;
  1965. // 2021.05.11 최종할인금액으로 적립포인트 적용
  1966. if (frontGb == 'P') {
  1967. savePntAmt1 = parseInt(realOrdAmt2 * (pntPrate/100));
  1968. } else {
  1969. savePntAmt1 = parseInt(realOrdAmt2 * (pntMrate/100));
  1970. }
  1971. // 선포인트사용여부
  1972. if (prePntDcAmtYn == "Y") {
  1973. if (prePntDcAmt1 < 1) {
  1974. savePntSumAmt = savePntSumAmt + savePntAmt1;
  1975. }
  1976. } else {
  1977. savePntSumAmt = savePntSumAmt + savePntAmt1;
  1978. }
  1979. $(this).parent().find(".pntDcAmt1").text(pntDcAmt1);
  1980. $(this).parent().find(".gfcdUseAmt1").text(gfcdUseAmt1);
  1981. $(this).parent().find(".realOrdAmt1").text(realOrdAmt1);
  1982. $(this).parent().find(".savePntAmt1").text(savePntAmt1);
  1983. index++;
  1984. });
  1985. realOrdSumAmt = realOrdSumAmt + delvSumAmt;
  1986. $("#orderAmtForm .orgGoodsSumAmt").text(orgGoodsSumAmt);
  1987. $("#orderAmtForm .cpn1DcSumAmt").text(cpn1DcSumAmt);
  1988. $("#orderAmtForm .ordSumAmt").text(ordSumAmt);
  1989. $("#orderAmtForm .tmtb1DcSumAmt").text(tmtb1DcSumAmt);
  1990. $("#orderAmtForm .tmtb2DcSumAmt").text(tmtb2DcSumAmt);
  1991. $("#orderAmtForm .tmtbDcSumAmt").text(tmtbDcSumAmt);
  1992. $("#orderAmtForm .goodsCpnDcSumAmt").text(goodsCpnDcSumAmt);
  1993. $("#orderAmtForm .cartCpnDcSumAmt").text(cartCpnDcSumAmt);
  1994. $("#orderAmtForm .cpnDcSumAmt").text(cpnDcSumAmt);
  1995. $("#orderAmtForm .prePntDcSumAmt").text(prePntDcSumAmt);
  1996. $("#orderAmtForm .realOrdSumAmt").text(realOrdSumAmt);
  1997. $("#orderAmtForm .savePntSumAmt").text(savePntSumAmt);
  1998. $("#realOrdAmt").text(realOrdSumAmt.addComma()); // 총 결제 예정 금액
  1999. $("#orderForm .realOrdAmt").text(realOrdSumAmt.addComma() + " 원"); // 총 결제 예정 금액
  2000. // 2021.04.29 적립포인트금액 선포인트 사용시 사용금액제외
  2001. $("#orderForm #savePntSumAmt").text(savePntSumAmt.addComma() + " P");
  2002. var tempSavePnt = savePntSumAmt - prePntDcAmt;
  2003. // 사은품사용 후 보유포인트
  2004. var rmPntAmt = parseInt($("#orderForm input[name='rmPntAmt']").val());
  2005. var freegiftUsePnt = parseInt($("#orderAmtForm .freegiftUsePnt").text());
  2006. rmPntAmt = rmPntAmt - freegiftUsePnt;
  2007. $("#orderForm .rmPntAmt").text(rmPntAmt.addComma());
  2008. // 걸제영역
  2009. //$("#btn_payment").text("동의 후 "+realOrdSumAmt.addComma()+" 원 결제하기");
  2010. // 적립포인트
  2011. $("#savePntSumAmt").text(savePntSumAmt.addComma()+" P");
  2012. // 사은품정보 설정
  2013. var freegiftValArr = [];
  2014. var freegiftUsePointArr = [];
  2015. $("#orderForm .gift_box").each(function(){
  2016. $(this).find(".freegiftRdo").each(function(){
  2017. // 사은품필수
  2018. if ($(this).attr("allYn") == "Y" ) {
  2019. freegiftValArr.push($(this).val());
  2020. freegiftUsePointArr.push($(this).attr("usepoint"));
  2021. } else {
  2022. // 라디오버튼 선택 사은품 체크
  2023. if ($(this).is(":checked")) {
  2024. // 수령거부가 아닐때 체크
  2025. if ($(this).val() != "noSel") {
  2026. freegiftValArr.push($(this).val());
  2027. freegiftUsePointArr.push($(this).attr("usepoint"));
  2028. }
  2029. }
  2030. }
  2031. });
  2032. });
  2033. $("#orderAmtForm .freegiftValArr").text(freegiftValArr); // 사은품시퀀스배열
  2034. $("#orderAmtForm .freegiftUsePointArr").text(freegiftUsePointArr); // 사은품사용포인트배열
  2035. };
  2036. // 1.18 배송지정보 설정
  2037. var delvAddrSet = function(delvObj) {
  2038. var rtnStr = "";
  2039. rtnStr += "| recipNm ::: " + delvObj.recipNm;
  2040. rtnStr += "| recipPhnno ::: " + delvObj.recipPhnno;
  2041. rtnStr += "| recipZipcode ::: " + delvObj.recipZipcode;
  2042. rtnStr += "| recipBaseAddr ::: " + delvObj.recipBaseAddr;
  2043. rtnStr += "| recipDtlAddr ::: " + delvObj.recipDtlAddr;
  2044. rtnStr += "| delvMemo ::: " + delvObj.delvMemo;
  2045. // 배송지정보로드실행
  2046. deliveryAddrInfoSet(delvObj, false);
  2047. }
  2048. // 1.19 배송메모설정
  2049. var delvMemoSet = function(delvMemoObj) {
  2050. var rtnStr = "";
  2051. rtnStr += "| delvMemo ::: " + delvMemoObj.delvMemo;
  2052. $("#orderForm input[name=delvMemo]").val(delvMemoObj.delvMemo); // input 값에 설정
  2053. $("#delvMemo").text(delvMemoObj.delvMemo); // 메모 text 설정
  2054. $("#orderAmtForm .delvMemo").text(delvMemoObj.delvMemo); // 메모 text 설정
  2055. }
  2056. </script>
  2057. <script th:inline="javascript">
  2058. $(document).ready( function() {
  2059. //해외배송 입력
  2060. $(document).on('change','.odPayment .area_overseas #rdi-overs1',function(e){
  2061. $('.info_box.overs2').hide();
  2062. $('.info_box.overs1').show();
  2063. return false;
  2064. }).on('change','.odPayment .area_overseas #rdi-overs2',function(e){
  2065. $('.info_box.overs1').hide();
  2066. $('.info_box.overs2').show();
  2067. return false;
  2068. });
  2069. //할인쿠폰 확인
  2070. $(document).on('click','.odPayment .area_seldiscount .btn_coupon_toggle',function(e){
  2071. $('.coupon_list').toggle();
  2072. $(this).toggleClass('on');
  2073. return false;
  2074. });
  2075. //결제수단 선택
  2076. /*
  2077. $(document).on('change','.odPayment .area_paymethod .paymethod_radio input',function(e){
  2078. $('.radio_blk').removeClass('on');
  2079. $(this).parents('.radio_blk').addClass('on');
  2080. $(this).parents('.radio_blk').find('.paymethod_box').show();
  2081. $(this).parents('.radio_blk').siblings('div').find('.paymethod_box').hide();
  2082. var paymethodlabel = $(this).prop('labels');
  2083. $(this).parents('li').find('.fold_head .data span').text($(paymethodlabel).text());
  2084. //간편결제 카드추가 슬라이드
  2085. var swiper = new Swiper('.paymethod_box .card_quickpay .list_card.swiper-container', {
  2086. slidesPerView: 'auto',
  2087. spaceBetween: 160,
  2088. centeredSlides: true,
  2089. navigation: {
  2090. nextEl: '.list_card .swiper-button-next',
  2091. prevEl: '.list_card .swiper-button-prev',
  2092. },
  2093. });
  2094. return false;
  2095. });
  2096. */
  2097. //STYLE24 간편결제 배너닫기
  2098. $(document).on('click','.odPayment .area_paymethod .quickpay_bnr .btn_close_bnr',function(e){
  2099. $('.quickpay_bnr').hide();
  2100. });
  2101. //결제수단 선택 > 즐겨찾기 추가시
  2102. $(document).on('click','.odPayment .area_paymethod .paymethod_box .card .etc .btn_favorcard',function(e){
  2103. $(this).toggleClass('active');
  2104. return false;
  2105. });
  2106. //결제수단 > 일반결제> 실시간계좌이체 선택시
  2107. /*
  2108. $(document).on('change','.odPayment input:radio[name=rdi-paynormal]',function(e){
  2109. var paynormalValue = $(this).attr('id');
  2110. if (paynormalValue == 'rdi-paynormal2') {
  2111. $('.area_paymethod .agree_insurance').show();
  2112. } else {
  2113. $('.area_paymethod .agree_insurance').hide();
  2114. }
  2115. return false;
  2116. });
  2117. */
  2118. // 개인정보동의 열고닫기
  2119. $(document).on('click','.area_paymentinfo .payinfo_blk a',function(e){
  2120. e.preventDefault();
  2121. $(this).parents('.payinfo_blk').toggleClass('on');
  2122. var privacyToggle = $(this).find('span');
  2123. $(privacyToggle).text($(privacyToggle).text() == '보기' ? '닫기' : '보기');
  2124. return false;
  2125. });
  2126. //배송지수정 팝업열기
  2127. /*
  2128. $(document).on('click','#btn_addrModify_pop',function(e){
  2129. $("#adrsModifyPop").modal("show");
  2130. return false;
  2131. });
  2132. */
  2133. //배송요청사항 팝업열기
  2134. /*
  2135. $(document).on('click','#btn_rqstModify_pop',function(e){
  2136. $("#rqstModifyPop").modal("show");
  2137. return false;
  2138. });
  2139. */
  2140. //사은품지급안내 팝업열기
  2141. $(document).on('click','#btn_infoGift_pop',function(e){
  2142. $("#infoGiftPop").modal("show");
  2143. return false;
  2144. });
  2145. //간편결제등록 > STEP1.이용약관 팝업열기
  2146. $(document).on('click','.btn_addcard',function(e){
  2147. $("#qPayAgree_pop").modal("show");
  2148. return false;
  2149. });
  2150. //간편결제등록 > STEP1.이용약관 체크
  2151. $(document).on('click','.area_QpayCk .agr_select button',function(e){
  2152. $(this).parents('.area_QpayCk').find('.info_agrQpay').toggle();
  2153. var payagrToggle = $(this).find('span');
  2154. $(payagrToggle).text($(payagrToggle).text() == '약관열기' ? '약관닫기' : '약관열기');
  2155. return false;
  2156. });
  2157. //간편결제등록 > STEP1.이용약관 체크박스 전체선택
  2158. $(document).on('click','#chk-Qpay-agrAll',function(e){
  2159. $(this).parents(".qPayAgree_pop").find('.agree_Qpay input').prop("checked", $(this).is(":checked"));
  2160. });
  2161. //간편결제등록 > STEP1.이용약관 체크박스 개별선택
  2162. $(document).on("click", ".agree_Qpay input",function(e){
  2163. var is_checked = true;
  2164. $(".agree_Qpay input").each(function(){
  2165. is_checked = is_checked && $(this).is(":checked");
  2166. });
  2167. $("#chk-Qpay-agrAll").prop("checked", is_checked);
  2168. });
  2169. //간편결제등록 > 본인인증 팝업열기
  2170. $(document).on('click','#btn_qPayidConfirm_pop',function(e){
  2171. $("#qPayidConfirm_pop").modal("show");
  2172. return false;
  2173. });
  2174. });
  2175. // PG 카카오페이 결제준비 처리
  2176. var fnKakaoPaymentReady = function() {
  2177. let nextRedirectUrl = $('#order_info input[name=nextRedirectPcUrl]').val();
  2178. let option = 'width=420, height=520';
  2179. window.open(nextRedirectUrl, 'kakaoPaymentPopup', option);
  2180. }
  2181. // PG 카카오페이 결제 승인 요청
  2182. var fnKakaoPaymentRequest = function(pgToken) {
  2183. // Token 값 설정
  2184. $('#order_info input[name=pgToken]').val(pgToken);
  2185. // Form Submit
  2186. document.order_info.submit();
  2187. return true;
  2188. }
  2189. // PG 네이버페이 결제준비 처리
  2190. var fnNaverPaymentReady = function() {
  2191. let naverPayUrl = 'https://' + [[${@environment.getProperty('naverPay.payUrl.web')}]];
  2192. let reserveId = $('#order_info input[name=reserveId]').val();
  2193. let url = naverPayUrl + '/payments/' + reserveId;
  2194. let option = 'width=750, height=' + $(window).height();
  2195. window.open(url, 'naverPaymentPopup', option);
  2196. }
  2197. // PG 네이버페이 결제 승인 요청
  2198. var fnNaverPaymentRequest = function(paymentId) {
  2199. // TID 설정
  2200. $('#order_info input[name=pgTid]').val(paymentId);
  2201. // Form Submit
  2202. document.order_info.submit();
  2203. return true;
  2204. }
  2205. // 0원이하이면 '-' 처리 삭제 함수
  2206. var getZeroMinusDelAmt = function(tempAmt) {
  2207. var rtnAmtStr = "";
  2208. if (tempAmt > 0) {
  2209. rtnAmtStr = "-" + tempAmt.addComma();
  2210. } else {
  2211. rtnAmtStr = tempAmt.addComma();
  2212. }
  2213. return rtnAmtStr;
  2214. }
  2215. //START ::: 2021.04.09 숫자입려 천단위 찍기
  2216. var inputNumberFormat = function(obj) {
  2217. obj.value = comma(uncomma(obj.value));
  2218. }
  2219. var comma = function(str) {
  2220. str = String(str);
  2221. return str.replace(/(\d)(?=(?:\d{3})+(?!\d))/g, '$1,');
  2222. }
  2223. var uncomma = function(str) {
  2224. str = String(str);
  2225. return str.replace(/[^\d]+/g, '');
  2226. }
  2227. // 2021.04.09 숫자입려 천단위 찍기 ::: END
  2228. </script>
  2229. </th:block>
  2230. </body>
  2231. </html>