+++ src/main/java/itn/let/kakao/user/kakaoFt/service/KakaoFriendsTalkService.java
... | ... | @@ -0,0 +1,12 @@ |
| 1 | +package itn.let.kakao.user.kakaoFt.service; | |
| 2 | + | |
| 3 | +import javax.servlet.http.HttpServletRequest; | |
| 4 | + | |
| 5 | +import itn.let.kakao.kakaoComm.KakaoVO; | |
| 6 | +import itn.let.mail.service.StatusResponse; | |
| 7 | + | |
| 8 | +public interface KakaoFriendsTalkService { | |
| 9 | + | |
| 10 | + StatusResponse insertKakaoFtSandAjax_advc(KakaoVO kakaoVO, HttpServletRequest request); | |
| 11 | + | |
| 12 | +} |
+++ src/main/java/itn/let/kakao/user/kakaoFt/service/impl/KakaoFriendsTalkServiceImpl.java
... | ... | @@ -0,0 +1,37 @@ |
| 1 | +package itn.let.kakao.user.kakaoFt.service.impl; | |
| 2 | + | |
| 3 | +import javax.annotation.Resource; | |
| 4 | +import javax.servlet.http.HttpServletRequest; | |
| 5 | + | |
| 6 | +import org.springframework.http.HttpStatus; | |
| 7 | +import org.springframework.stereotype.Service; | |
| 8 | + | |
| 9 | +import egovframework.rte.fdl.cmmn.EgovAbstractServiceImpl; | |
| 10 | +import egovframework.rte.fdl.idgnr.EgovIdGnrService; | |
| 11 | +import itn.let.kakao.kakaoComm.KakaoVO; | |
| 12 | +import itn.let.kakao.user.kakaoFt.service.KakaoFriendsTalkService; | |
| 13 | +import itn.let.mail.service.StatusResponse; | |
| 14 | + | |
| 15 | +@Service("kakaoFriendsTalkTemplateService") | |
| 16 | +public class KakaoFriendsTalkServiceImpl extends EgovAbstractServiceImpl implements KakaoFriendsTalkService{ | |
| 17 | + | |
| 18 | + @Resource(name = "egovFriendstalkTemplateIdService") | |
| 19 | + private EgovIdGnrService idgenFriendTalkTmpId; | |
| 20 | + | |
| 21 | + @Resource(name="kakaoFriendsTalkTemplateDAO") | |
| 22 | + private KakaoFriendsTalkTemplateDAO kakaoFriendsTalkTemplateDAO; | |
| 23 | + | |
| 24 | + @Override | |
| 25 | + public StatusResponse insertKakaoFtSandAjax_advc(KakaoVO kakaoVO, HttpServletRequest request) { | |
| 26 | + StatusResponse statusResponse = new StatusResponse(); | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + statusResponse.setStatus(HttpStatus.OK); | |
| 33 | +// statusResponse.setObject(returnMap); | |
| 34 | + return statusResponse; | |
| 35 | + } | |
| 36 | + | |
| 37 | +} |
--- src/main/java/itn/let/kakao/user/kakaoFt/web/KakaoFriendsTalkSendController.java
+++ src/main/java/itn/let/kakao/user/kakaoFt/web/KakaoFriendsTalkSendController.java
... | ... | @@ -13,9 +13,11 @@ |
| 13 | 13 |
import javax.servlet.http.HttpServletRequest; |
| 14 | 14 |
|
| 15 | 15 |
import org.springframework.beans.factory.annotation.Autowired; |
| 16 |
+import org.springframework.http.ResponseEntity; |
|
| 16 | 17 |
import org.springframework.stereotype.Controller; |
| 17 | 18 |
import org.springframework.ui.ModelMap; |
| 18 | 19 |
import org.springframework.web.bind.annotation.ModelAttribute; |
| 20 |
+import org.springframework.web.bind.annotation.RequestBody; |
|
| 19 | 21 |
import org.springframework.web.bind.annotation.RequestMapping; |
| 20 | 22 |
import org.springframework.web.servlet.ModelAndView; |
| 21 | 23 |
|
... | ... | @@ -29,7 +31,9 @@ |
| 29 | 31 |
import itn.let.kakao.kakaoComm.KakaoVO; |
| 30 | 32 |
import itn.let.kakao.kakaoComm.kakaoApi.service.KakaoApiService; |
| 31 | 33 |
import itn.let.kakao.user.kakaoAt.service.KakaoAlimTalkService; |
| 34 |
+import itn.let.kakao.user.kakaoFt.service.KakaoFriendsTalkService; |
|
| 32 | 35 |
import itn.let.kakao.user.kakaoFt.service.KakaoFriendsTalkTemplateService; |
| 36 |
+import itn.let.mail.service.StatusResponse; |
|
| 33 | 37 |
import itn.let.mjo.mjocommon.MjonCommon; |
| 34 | 38 |
import itn.let.mjo.mjocommon.MjonHolidayApi; |
| 35 | 39 |
import itn.let.mjo.msgdata.service.MjonMsgDataService; |
... | ... | @@ -67,6 +71,9 @@ |
| 67 | 71 |
|
| 68 | 72 |
@Resource(name = "kakaoFriendsTalkTemplateService") |
| 69 | 73 |
private KakaoFriendsTalkTemplateService kakaoFtTemplateService; |
| 74 |
+ |
|
| 75 |
+ @Resource(name = "kakaoFriendsTalkService") |
|
| 76 |
+ private KakaoFriendsTalkService kakaoFriendsTalkService; |
|
| 70 | 77 |
|
| 71 | 78 |
/** userManageService */ |
| 72 | 79 |
@Resource(name = "userManageService") |
... | ... | @@ -313,7 +320,30 @@ |
| 313 | 320 |
return modelAndView; |
| 314 | 321 |
} |
| 315 | 322 |
|
| 323 |
+ |
|
| 324 |
+ /** |
|
| 325 |
+ * 문자 발송 기능 |
|
| 326 |
+ * @param searchVO |
|
| 327 |
+ * @param model |
|
| 328 |
+ * @return "/web/mjon/msgdata/sendMsgDataAjax.do" |
|
| 329 |
+ * @throws Exception |
|
| 330 |
+ */ |
|
| 316 | 331 |
|
| 332 |
+ @RequestMapping(value = "/web/mjon/kakao/friendstalk/kakaoFriendsTalkMsgSendAjax_advc.do") |
|
| 333 |
+ public ResponseEntity<StatusResponse> sendMsgData_ft_advc( |
|
| 334 |
+ @RequestBody KakaoVO kakaoVO, |
|
| 335 |
+ HttpServletRequest request, |
|
| 336 |
+ ModelMap model) throws Exception {
|
|
| 337 |
+ System.out.println(" :: sendMsgData_ft_advc :: ");
|
|
| 338 |
+ |
|
| 339 |
+ |
|
| 340 |
+ // 디버깅 출력 |
|
| 341 |
+// System.out.println("mjonMsgVO : " + mjonMsgVO.getMjonMsgSendVOList().toString());
|
|
| 342 |
+// System.out.println("mjonMsgVO : " + mjonMsgVO.getMjonMsgSendVOList().size());
|
|
| 343 |
+ |
|
| 344 |
+ return ResponseEntity.ok().body(kakaoFriendsTalkService.insertKakaoFtSandAjax_advc(kakaoVO, request)) ; |
|
| 345 |
+ |
|
| 346 |
+ } |
|
| 317 | 347 |
|
| 318 | 348 |
/** |
| 319 | 349 |
* @Method Name : kakaoFriendsTalkMsgSendAjax |
--- src/main/webapp/WEB-INF/jsp/web/kakao/msgdata/ft/KakaoFriendsTalkMsgDataView.jsp
+++ src/main/webapp/WEB-INF/jsp/web/kakao/msgdata/ft/KakaoFriendsTalkMsgDataView.jsp
... | ... | @@ -1191,14 +1191,19 @@ |
| 1191 | 1191 |
var data = new FormData(document.bizForm); |
| 1192 | 1192 |
$.ajax({
|
| 1193 | 1193 |
type: "POST" |
| 1194 |
- , url: "/web/mjon/kakao/friendstalk/kakaoFriendsTalkMsgSendAjax.do" |
|
| 1194 |
+// , url: "/web/mjon/kakao/friendstalk/kakaoFriendsTalkMsgSendAjax.do" |
|
| 1195 |
+ , url: "/web/mjon/kakao/friendstalk/kakaoFriendsTalkMsgSendAjax_advc.do" |
|
| 1195 | 1196 |
, data: data |
| 1196 | 1197 |
, dataType: 'json' |
| 1197 | 1198 |
, async: true |
| 1198 | 1199 |
, processData: false |
| 1199 | 1200 |
, contentType: false |
| 1200 | 1201 |
, cache: false |
| 1201 |
- , success: function (returnData, status) {
|
|
| 1202 |
+ , success: function (returnData) {
|
|
| 1203 |
+ |
|
| 1204 |
+ console.log('returnData : ', returnData);
|
|
| 1205 |
+ |
|
| 1206 |
+ /* |
|
| 1202 | 1207 |
if(status == 'success'){
|
| 1203 | 1208 |
if("loginFail" == returnData.result){
|
| 1204 | 1209 |
|
... | ... | @@ -1230,7 +1235,7 @@ |
| 1230 | 1235 |
|
| 1231 | 1236 |
$('.mask').addClass('on');
|
| 1232 | 1237 |
} |
| 1233 |
- } |
|
| 1238 |
+ } */ |
|
| 1234 | 1239 |
} |
| 1235 | 1240 |
,beforeSend : function(xmlHttpRequest) {
|
| 1236 | 1241 |
//로딩창 show |
+++ src/main/webapp/WEB-INF/jsp/web/kakao/msgdata/ft/KakaoFriendsTalkMsgDataView_advcbackup_20250414.jsp
... | ... | @@ -0,0 +1,2549 @@ |
| 1 | +<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> | |
| 2 | +<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%> | |
| 3 | +<%@ taglib prefix="fn" uri="http://java.sun.com/jsp/jstl/functions"%> | |
| 4 | +<%@ taglib prefix="form" uri="http://www.springframework.org/tags/form" %> | |
| 5 | +<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %> | |
| 6 | +<%@ taglib prefix="ec" uri="/WEB-INF/tld/ecnet_tld.tld"%> | |
| 7 | +<%@ page import="itn.com.cmm.LoginVO" %> | |
| 8 | +<script src="/js/kakao/templateComm.js"></script> | |
| 9 | + | |
| 10 | +<script type="text/javascript" src="<c:out value='/js/MJUtill.js' />"></script> | |
| 11 | +<script type="text/javascript" src="<c:out value='/js/kakao/ft/ftPriceClclt.js' />"></script> | |
| 12 | +<script type="text/javascript" src="<c:out value='/js/kakao/ft/ftTabulator.js' />"></script> | |
| 13 | +<script type="text/javascript" src="<c:out value='/js/txtSpecialReplace.js' />"></script> | |
| 14 | +<script type="text/javascript" src="<c:out value='/js/kakao/at/addr.js' />"></script> | |
| 15 | +<script type="text/javascript" src="<c:out value='/js/common/popup.js' />"></script> | |
| 16 | +<script type="text/javascript" src="<c:out value='/js/kakao/ft/friendstalkExcel.js' />"></script> | |
| 17 | + | |
| 18 | + | |
| 19 | +<script type="text/javascript"> | |
| 20 | + | |
| 21 | +var loginVO = '${loginVO}'; | |
| 22 | +/* 파일등록 */ | |
| 23 | +var _fileIdx = 0; | |
| 24 | +var _fileForm2 = new Array(); | |
| 25 | +var fileExt = ""; // 첨부파일 확장자 | |
| 26 | +var excelAddr = []; //엑셀 불러오기에서 내용 저장하는 배열 변수 | |
| 27 | + | |
| 28 | +$(document).ready(function (){ | |
| 29 | + | |
| 30 | + //화면 초기 로딩시 화면 처리해주기 - 템플릿 불러오기 했을 경우를 위함 | |
| 31 | + initFormChk(); | |
| 32 | + | |
| 33 | + //이모티콘 삽입 기능 처리 | |
| 34 | + $(".symbolButton, .changeWord").on('click', function(){ | |
| 35 | + | |
| 36 | + // 커서 위치에 삽입 | |
| 37 | + setCursorInsertText("inputTemplateContent", $(this).attr("value")); | |
| 38 | + setContentsLeng($('#inputTemplateContent').val()); | |
| 39 | + }); | |
| 40 | + | |
| 41 | + | |
| 42 | + //즉시 발송 라디오 버튼 선택시 숨김처리 | |
| 43 | + $("#reserYnN").on('click', function(){ | |
| 44 | + $('.rev_selected').hide(); | |
| 45 | + $('.send_rev .send_content').css('padding-bottom','108px'); | |
| 46 | + $('.send_btn .btnType:first-child').html('발송하기'); | |
| 47 | + $('#bizForm #reserveYn').val($(this).val()); | |
| 48 | + }); | |
| 49 | + | |
| 50 | + //예약 발송 라디오 버튼 선택시 숨김 해제처리 | |
| 51 | + $("#reserYnY").on('click', function(){ | |
| 52 | + $('.rev_selected').show(); | |
| 53 | + $('.send_rev .send_content').css('padding-bottom','0'); | |
| 54 | + $('.send_btn .btnType:first-child').html('예약하기'); | |
| 55 | + $('#bizForm #reserveYn').val($(this).val()); | |
| 56 | + }); | |
| 57 | + | |
| 58 | + //템플릿 내용 입력 글자수 체크 해주기 | |
| 59 | + $("#inputTemplateContent").keyup(function(e){ | |
| 60 | + | |
| 61 | + var contents = $('#inputTemplateContent').val(); | |
| 62 | + setContentsLengForFriends(contents); | |
| 63 | + | |
| 64 | + }); | |
| 65 | + | |
| 66 | + $("#excelAdd").click(function(){ | |
| 67 | + | |
| 68 | + if(excelAddr.length > 0){ | |
| 69 | + | |
| 70 | + //첨부파일로 불러온 데이터를 받는사람 목록에 추가해 준다. | |
| 71 | + addPhoneInfo(excelAddr); | |
| 72 | + | |
| 73 | + //첨부파일 초기화 시켜주기 | |
| 74 | + $("#excelFile").val(""); | |
| 75 | + $("#excelNm").val(""); | |
| 76 | + | |
| 77 | + }else{ | |
| 78 | + | |
| 79 | + alert("추가 엑셀 데이터가 없습니다."); | |
| 80 | + return false; | |
| 81 | + | |
| 82 | + } | |
| 83 | + | |
| 84 | + }); | |
| 85 | + | |
| 86 | + | |
| 87 | + $("#send_fail_check").change(function(){ | |
| 88 | + if($("#send_fail_check").is(":checked")){ | |
| 89 | + | |
| 90 | + | |
| 91 | + if(loginVO == "" || loginVO == null){ | |
| 92 | + alert("로그인 후 사용 가능한 기능입니다."); | |
| 93 | + location.href="<c:url value='/web/user/login/login.do'/>"; | |
| 94 | + return false; | |
| 95 | + | |
| 96 | + $("#send_fail_check").prop("checked", false); | |
| 97 | + } | |
| 98 | + | |
| 99 | + if($('#callFromList').val() === ''){ | |
| 100 | + | |
| 101 | + if(confirm('대체문자 전송을 위한 발신번호가 등록되지 않았습니다. \n대체문자 발신번호를 지금 등록하시겠습니까?')){ | |
| 102 | + window.location="<c:out value='/web/user/sendNumberManage.do' />"; | |
| 103 | + } | |
| 104 | + $("#send_fail_check").prop("checked", false); | |
| 105 | + | |
| 106 | + }else{ | |
| 107 | + // 에러버튼 체크 초기화 | |
| 108 | + fn_insertErrorYN('N'); | |
| 109 | + | |
| 110 | + $('#smsTxtArea').val(''); | |
| 111 | +// // 미리보기 텍스트를 가져와 줄바꿈 처리 후 대체문자 내용으로 입력 | |
| 112 | + $('#smsTxtArea').val( | |
| 113 | + $('.template_text').html().trim().replace(/(<br>|<br\/>|<br \/>)/g, '\r\n') | |
| 114 | + ); | |
| 115 | + | |
| 116 | +// //문자 내용 입력시 바이트수 계산하기 | |
| 117 | + | |
| 118 | + $(".replace_send_wrap").slideDown(400); | |
| 119 | + thisFnByteString($('#smsTxtArea').val()); | |
| 120 | + } | |
| 121 | + }else{ | |
| 122 | + $(".replace_send_wrap").slideUp(400); | |
| 123 | + // 초기화 버튼 클릭 | |
| 124 | + $('#failCheckInit').click(); | |
| 125 | + $('.send_top .send_right .phone').css({'top': '0','transition': 'top .4s linear'}); | |
| 126 | + } | |
| 127 | + | |
| 128 | + // 금액 계산 fn 호출 | |
| 129 | + totalFtPriceSum(tableL.getRows().length); | |
| 130 | + //fn_priceClclt(); | |
| 131 | + }); | |
| 132 | + | |
| 133 | + // 대체문자 내용 수정 | |
| 134 | + $('#smsTxtArea').keyup(function(){ | |
| 135 | + // 금액 계산 fn 호출 | |
| 136 | + totalFtPriceSum(tableL.getRows().length); | |
| 137 | + //fn_priceClclt(); | |
| 138 | + // 문자 바이트수 체크 | |
| 139 | + thisFnByteString($('#smsTxtArea').val()); | |
| 140 | + // 에러버튼 체크 초기화 | |
| 141 | + fn_insertErrorYN('N'); | |
| 142 | + | |
| 143 | + }); | |
| 144 | + | |
| 145 | + | |
| 146 | + //대체문자 초기화 버튼 선택 처리 | |
| 147 | + $("#failCheckInit").click(function(){ | |
| 148 | + | |
| 149 | + $('#smsTxtArea').val(""); | |
| 150 | + | |
| 151 | + // 금액 계산 fn 호출 | |
| 152 | + totalFtPriceSum(tableL.getRows().length); | |
| 153 | + //fn_priceClclt(); | |
| 154 | + // 문자 바이트수 체크 | |
| 155 | + thisFnByteString($('#smsTxtArea').val()); | |
| 156 | + // 에러버튼 체크 초기화 | |
| 157 | + fn_insertErrorYN('N'); | |
| 158 | + | |
| 159 | + }); | |
| 160 | + | |
| 161 | + | |
| 162 | +}); | |
| 163 | + | |
| 164 | +function initFormChk(){ | |
| 165 | + | |
| 166 | + //첫로딩시 우측 미리보기 화면 숨김처리 | |
| 167 | + $('.emphasis_title_text').hide(); //강조유형 타이틀 | |
| 168 | + $('.emphasis_side_text').hide(); //강조유형 보조문구 | |
| 169 | + //$('.template_text').hide(); //내용 미리보기 | |
| 170 | + $('.side_info_text').hide(); //부가정보 내용 | |
| 171 | + $('.channel_info_text').hide(); //채널추가 텍스트 내용 | |
| 172 | + $('.btnAd').hide(); //샘플 채널추가 버튼 | |
| 173 | + //$('.btnEmpty').hide(); //샘플 버튼 | |
| 174 | + | |
| 175 | + //채널ID 정보 미리보기에 표시해주기 | |
| 176 | + fnAgentCodeChg(); | |
| 177 | + | |
| 178 | + //템플릿 등록 이미지가 있는 경우 이미지 정보 표시해 주기 | |
| 179 | + var imgType = $("input[name=img_file_add]:checked").val(); | |
| 180 | + | |
| 181 | + if(!imgType == ''){ | |
| 182 | + | |
| 183 | + if($("input[name='img_file_add']:checked").attr("id")=="img_file_1"){ | |
| 184 | + $(".basic_img_add_wrap").show().siblings(".img_add_info_wrap").hide(); | |
| 185 | + $(".img_file_add_wrap").show(); | |
| 186 | + }else if($("input[name='img_file_add']:checked").attr("id")=="img_file_2"){ | |
| 187 | + $(".wide_img_add_wrap").show().siblings(".img_add_info_wrap").hide(); | |
| 188 | + $(".img_file_add_wrap").show(); | |
| 189 | + } else{ | |
| 190 | + $(".img_add_info_wrap, .img_file_add_wrap").hide(); | |
| 191 | + } | |
| 192 | + | |
| 193 | + }else{ | |
| 194 | + | |
| 195 | + $("#img_file_0").prop('checked',true); | |
| 196 | + | |
| 197 | + } | |
| 198 | + var imageFileName = '${resultTemplateVO.imageFileName}'; | |
| 199 | + $("#imgNm").text(imageFileName); | |
| 200 | + | |
| 201 | + //미리보기에 이미지 표시해주기 | |
| 202 | + var imgUrl = '${resultTemplateVO.templateImageUrl}'; | |
| 203 | + | |
| 204 | + if(imgUrl != ''){ | |
| 205 | + $('.kakao_image').css("display", "block"); | |
| 206 | + $("#kakaoImg").attr("src", imgUrl); | |
| 207 | + } | |
| 208 | + | |
| 209 | + //초기 템플릿 내용 글자수 처리해주기 | |
| 210 | + var tmpContents = $('#inputTemplateContent').val(); | |
| 211 | + setContentsLengForFriends(tmpContents); | |
| 212 | + | |
| 213 | + //초기 광고포함 여부 처리 | |
| 214 | + var adFlagVal = $("input[name=ad_flag]:checked").val(); | |
| 215 | + advTextChange(adFlagVal); | |
| 216 | + | |
| 217 | + var reserYn = $("input[name=reserYn]:checked").val(); | |
| 218 | + if(reserYn == 'N'){ | |
| 219 | + | |
| 220 | + $('.rev_selected').hide(); | |
| 221 | + $('.send_rev .send_content').css('padding-bottom','108px'); | |
| 222 | + $('.send_btn .btnType:first-child').html('발송하기'); | |
| 223 | + $('#bizForm #reserveYn').val('N'); | |
| 224 | + | |
| 225 | + } | |
| 226 | + | |
| 227 | +} | |
| 228 | + | |
| 229 | +//우측 미리보기 화면 채널 아이디 정보 변경해 주기 | |
| 230 | +function fnAgentCodeChg(){ | |
| 231 | + var yellowIdVal = $("#selectAgentCode option:checked").val(); | |
| 232 | + var yellowId = $("#selectAgentCode option:checked").text(); | |
| 233 | + var yellowIdAt = yellowId.replaceAll('@',''); | |
| 234 | + if(yellowIdVal != ''){ | |
| 235 | + | |
| 236 | + $('#spnYellowid').text(yellowId); //미리보기화면 채널ID | |
| 237 | + $('#spnYellowidAt').text(yellowIdAt); //미리보기화면 채널ID @제거 | |
| 238 | + $('#yellowIdCon').text(yellowIdAt); //내용 입력 부분 채널ID | |
| 239 | + }else{ | |
| 240 | + | |
| 241 | + $('#spnYellowid').text("채널ID"); //미리보기화면 채널ID | |
| 242 | + $('#spnYellowidAt').text("채널ID"); //미리보기화면 채널ID @제거 | |
| 243 | + $('#yellowIdCon').text("채널ID"); //내용 입력 부분 채널ID | |
| 244 | + } | |
| 245 | +} | |
| 246 | + | |
| 247 | +//파일첨부 버튼 클릭시 파일 첨부 실행 | |
| 248 | +function upImgClick(){ | |
| 249 | + var selectChennelID = $("select[name='selectAgentCode']").val(); //채널ID 정보 | |
| 250 | + var imageType = $("input[name=img_file_add]:checked").val(); //이미지 종류 정보(일반, 와이드) | |
| 251 | + var title = $("#imgTitle").val(); | |
| 252 | + var link = $("#imgLink").val(); | |
| 253 | + | |
| 254 | + if(selectChennelID == ''){ | |
| 255 | + | |
| 256 | + $("#imgNm").text(""); | |
| 257 | + $("#imgFile").val(""); | |
| 258 | + alert("채널ID를 선택해 주세요."); | |
| 259 | + return false; | |
| 260 | + | |
| 261 | + } | |
| 262 | + | |
| 263 | + if(imageType != ''){ | |
| 264 | + | |
| 265 | + bizForm.imageType.value = imageType; | |
| 266 | + | |
| 267 | + }else{ | |
| 268 | + | |
| 269 | + $("#imgNm").text(""); | |
| 270 | + $("#imgFile").val(""); | |
| 271 | + alert("이미지 종류를 선택해 주세요."); | |
| 272 | + return false; | |
| 273 | + | |
| 274 | + } | |
| 275 | + | |
| 276 | + if(title == ''){ | |
| 277 | + | |
| 278 | + $("#imgNm").text(""); | |
| 279 | + $("#imgFile").val(""); | |
| 280 | + alert("이미지 제목을 입력해 주세요."); | |
| 281 | + return false; | |
| 282 | + | |
| 283 | + } | |
| 284 | + | |
| 285 | + //이미지 선택시 링크 정보 및 url 패턴 검사 | |
| 286 | + if(link == ''){ | |
| 287 | + | |
| 288 | + $("#imgNm").text(""); | |
| 289 | + $("#imgFile").val(""); | |
| 290 | + alert("이미지 클릭시 이동할 URL 주소를 http:// 또는 https:// 포함하여 입력해 주세요."); | |
| 291 | + return false; | |
| 292 | + | |
| 293 | + }else{ | |
| 294 | + | |
| 295 | + if(link.search("http://") == -1 && link.search("https://") == -1){ | |
| 296 | + | |
| 297 | + $("#imgNm").text(""); | |
| 298 | + $("#imgFile").val(""); | |
| 299 | + alert("이미지 URL 주소에는 http:// 또는 https://를 포함하여 입력해야 합니다."); | |
| 300 | + return false; | |
| 301 | + | |
| 302 | + } | |
| 303 | + | |
| 304 | + } | |
| 305 | + | |
| 306 | + //첨부파일 선택 팝업 호출해주기 | |
| 307 | + $("#imgFile").click(); | |
| 308 | +} | |
| 309 | + | |
| 310 | +//첨부 이미지 정보 확인 처리 해주기(이미지 리사이징 전단계) | |
| 311 | +function imgResizeInfo(event){ | |
| 312 | + | |
| 313 | + var fileValue = $("#imgFile").val().split("\\"); | |
| 314 | + var fileName = fileValue[fileValue.length-1]; | |
| 315 | + | |
| 316 | + var fileExt = fileName.split('.').pop().toLowerCase(); | |
| 317 | + | |
| 318 | + if(fileExt.length > 0){ | |
| 319 | + if($.inArray(fileExt, ['jpg','jpeg','png']) == -1) { | |
| 320 | + alert('jpg, jpeg, png 파일만 업로드 할수 있습니다.'); | |
| 321 | + return false; | |
| 322 | + } | |
| 323 | + | |
| 324 | + $("#imgNm").text(fileName); | |
| 325 | + } | |
| 326 | + | |
| 327 | + //알림톡 이미지 등록 요청하기 | |
| 328 | + getTemplateImagUrl(); | |
| 329 | +} | |
| 330 | + | |
| 331 | +//카카오 친구톡 이미지 등록 요청 API 호출해주기 | |
| 332 | +function getTemplateImagUrl(){ | |
| 333 | + | |
| 334 | + var bizForm = document.bizForm; | |
| 335 | + | |
| 336 | + var data = new FormData(bizForm); | |
| 337 | + var atchFileSts = true; //첨부파일 갯수 상태 값1 | |
| 338 | + | |
| 339 | + data.append("file0", $('#imgFile').prop('files')[0]); | |
| 340 | + | |
| 341 | + var fileValue = $("#imgFile").val().split("\\"); | |
| 342 | + var fileName = fileValue[fileValue.length-1]; | |
| 343 | + | |
| 344 | + var fileExt = fileName.split('.').pop().toLowerCase(); | |
| 345 | + | |
| 346 | + if($.inArray(fileExt, ['jpg','jpeg', 'png']) == -1) { | |
| 347 | + | |
| 348 | + alert('jpg, jpeg 파일만 업로드 할수 있습니다.'); | |
| 349 | + return false; | |
| 350 | + | |
| 351 | + } | |
| 352 | + | |
| 353 | + var url = ""; | |
| 354 | + | |
| 355 | + if(fileExt == "jpg" || fileExt == "jpeg" || fileExt == "png"){ | |
| 356 | + | |
| 357 | + url = "/web/mjon/kakao/template/sendKakaoFriendsTemplateImageUploadAjax.do"; | |
| 358 | + | |
| 359 | + }else{ | |
| 360 | + | |
| 361 | + alert('jpg, jpeg 파일만 업로드 할수 있습니다.'); | |
| 362 | + return; | |
| 363 | + | |
| 364 | + } | |
| 365 | + | |
| 366 | + $.ajax({ | |
| 367 | + type : 'POST' | |
| 368 | + , enctype : 'multipart/form-data' | |
| 369 | + , url : url | |
| 370 | + , data : data | |
| 371 | + , dataType:'json' | |
| 372 | + , async:true | |
| 373 | + , processData: false | |
| 374 | + , contentType: false | |
| 375 | + , cache : false | |
| 376 | + , success : function(returnData, status){ | |
| 377 | + if(returnData.result == "success") { | |
| 378 | + | |
| 379 | + var code = returnData.code; | |
| 380 | + var msg = returnData.msg; | |
| 381 | + var imgUrl = returnData.imgUrl; | |
| 382 | + | |
| 383 | + if(code == "200"){//등록 성공시 메시지 및 이미지 표시 처리 | |
| 384 | + alert("이미지 등록이 완료 되었습니다."); | |
| 385 | + $("#templateImageName").val(fileName); | |
| 386 | + $("#templateImageUrl").val(imgUrl); | |
| 387 | + | |
| 388 | + $('.kakao_image').css("display", "block"); | |
| 389 | + $("#kakaoImg").attr("src", imgUrl); | |
| 390 | + $("#imageFileName").val(fileName); | |
| 391 | + | |
| 392 | + }else if(code == "2002"){//일반 이미지 가로 세로 크기 오류 발생 | |
| 393 | + | |
| 394 | + alert("권장 이미지 사이즈는 가로 720px 세로 720px(가로:세로 비율이 2:1 아닐 경우, 가로 500px, 세로 250px 이하일 경우 업로드 불가), 최대용량 500KB 입니다."); | |
| 395 | + | |
| 396 | + //첨부파일 정보를 지워준다. | |
| 397 | + $("#imgFile").val(""); | |
| 398 | + $("#imgNm").text(""); | |
| 399 | + return false; | |
| 400 | + | |
| 401 | + }else if(code == "405"){ | |
| 402 | + | |
| 403 | + alert("권장 이미지 사이즈는 가로 800px 세로 600px(가로:세로 비율이 2:1 아닐 경우, 가로 500px, 세로 250px 이하일 경우 업로드 불가), 최대용량 2MB 입니다."); | |
| 404 | + | |
| 405 | + //첨부파일 정보를 지워준다. | |
| 406 | + $("#imgFile").val(""); | |
| 407 | + $("#imgNm").text(""); | |
| 408 | + return false; | |
| 409 | + | |
| 410 | + }else{ | |
| 411 | + | |
| 412 | + alert(msg); | |
| 413 | + | |
| 414 | + //첨부파일 정보를 지워준다. | |
| 415 | + $("#imgFile").val(""); | |
| 416 | + $("#imgNm").text(""); | |
| 417 | + return false; | |
| 418 | + } | |
| 419 | + | |
| 420 | + }else if(returnData.result == "loginFail"){ | |
| 421 | + location.href="/web/user/login/login.do"; | |
| 422 | + }else{ | |
| 423 | + alert("이미지 등록 중 오류가 발생하였습니다.!!!"); | |
| 424 | + return false; | |
| 425 | + } | |
| 426 | + }, | |
| 427 | + beforeSend : function(xmlHttpRequest) { | |
| 428 | + //로딩창 show | |
| 429 | + $('.loading_layer').addClass('active'); | |
| 430 | + }, | |
| 431 | + complete : function(xhr, textStatus) { | |
| 432 | + //로딩창 hide | |
| 433 | + $('.loading_layer').removeClass('active'); | |
| 434 | + }, | |
| 435 | + error : function(request , status, error){ | |
| 436 | + alert("code:"+request.status+"\n"+"message:"+request.responseText+"\n"+"error:"+error); | |
| 437 | + } | |
| 438 | + }); | |
| 439 | + | |
| 440 | + //첨부파일 이름 및 데이터 지워주기 - 완료 후 팝업이 자동으로 닫힘. | |
| 441 | + $("#imgFile").val(""); | |
| 442 | +} | |
| 443 | + | |
| 444 | +function fnImageDel(){ | |
| 445 | + | |
| 446 | + var selectAgentCode = $("select[name='selectAgentCode']").val(); // 선택 채널ID | |
| 447 | + var imageUrl = $("#templateImageUrl").val(); | |
| 448 | + var bizForm = document.bizForm; | |
| 449 | + | |
| 450 | + bizForm.senderKey.value = selectAgentCode; | |
| 451 | + | |
| 452 | + if(imageUrl == ''){ | |
| 453 | + | |
| 454 | + alert("등록된 이미지가 없습니다."); | |
| 455 | + return false; | |
| 456 | + | |
| 457 | + } | |
| 458 | + | |
| 459 | + var tmpFriendId = $("#tmpFriendId").val(); | |
| 460 | + | |
| 461 | + if(tmpFriendId != ''){ | |
| 462 | + | |
| 463 | + if(!confirm("불러온 템플릿의 이미지도 함께 삭제 됩니다. 계속하시겠습니까?")){ | |
| 464 | + return false; | |
| 465 | + } | |
| 466 | + | |
| 467 | + } | |
| 468 | + | |
| 469 | + var data = new FormData(bizForm); | |
| 470 | + | |
| 471 | + if(confirm("등록된 이미지를 삭제하시겠습니까?")){ | |
| 472 | + | |
| 473 | + $.ajax({ | |
| 474 | + type: "POST" | |
| 475 | + , url: "/web/mjon/kakao/template/deleteKakaoFriendsImageDataAjax.do" | |
| 476 | + , data: data | |
| 477 | + , dataType: 'json' | |
| 478 | + , async: false | |
| 479 | + , processData: false | |
| 480 | + , contentType: false | |
| 481 | + , cache: false | |
| 482 | + , success: function (returnData, status) { | |
| 483 | + | |
| 484 | + var result = returnData.result; | |
| 485 | + var code = returnData.code; | |
| 486 | + var msg = returnData.msg; | |
| 487 | + | |
| 488 | + if(result == "notLogin") {//차단 발신번호인 경우 등록 불가 | |
| 489 | + alert("로그인후 진행이 가능합니다."); | |
| 490 | + }else if(returnData.result == "success") { | |
| 491 | + | |
| 492 | + if(code == "200"){ | |
| 493 | + alert("등록된 이미지가 삭제되었습니다."); | |
| 494 | + $("#imgTitle").val(""); | |
| 495 | + $("#imgLink").val(""); | |
| 496 | + $("#imgFile").val(""); | |
| 497 | + $("#imgNm").text("첨부파일 이미지"); | |
| 498 | + $("#templateImageUrl").val(""); | |
| 499 | + $('.kakao_image').css("display", "none"); | |
| 500 | + $("#kakaoImg").attr("src", ""); | |
| 501 | + $("#imageFileName").val(""); //이미지 파일명 삭제 | |
| 502 | + $("#img_file_0").click(); //이미지 첨부 안함 선택 | |
| 503 | + return false; | |
| 504 | + | |
| 505 | + }else{ | |
| 506 | + alert(msg); | |
| 507 | + return false; | |
| 508 | + } | |
| 509 | + }else{ | |
| 510 | + alert("이미지 삭제에 오류가 발생하였습니다."); | |
| 511 | + return false; | |
| 512 | + } | |
| 513 | + } | |
| 514 | + ,error: function (e) { | |
| 515 | + console.log("ERROR : ", e); | |
| 516 | + alert("이미지 삭제에 오류가 발생하였습니다."); | |
| 517 | + } | |
| 518 | + }); | |
| 519 | + } | |
| 520 | +} | |
| 521 | + | |
| 522 | +//알림톡 내용 초기화 해주기 | |
| 523 | +function fnContentsReset(){ | |
| 524 | + $("#inputTemplateContent").val(""); | |
| 525 | + $(".template_text").text("내용 미리보기"); | |
| 526 | + $('.nowChar').text("0 /"); | |
| 527 | +} | |
| 528 | + | |
| 529 | +//저장 템플릿 불러오기 선택시 | |
| 530 | +function myTemplateSelect(ftId){ | |
| 531 | + | |
| 532 | + var form = document.templateForm; | |
| 533 | + | |
| 534 | + form.friendId.value = ftId; | |
| 535 | + | |
| 536 | + form.action="/web/mjon/kakao/friendstalk/kakaoFriendsTalkMsgDataView.do"; | |
| 537 | + form.submit(); | |
| 538 | + | |
| 539 | + | |
| 540 | +} | |
| 541 | + | |
| 542 | +//광고성 정보 포함 선택에 따른 텍스트 표시 부분 처리 | |
| 543 | +$(document).on('change', '.inputAdFlag', function(){ | |
| 544 | + | |
| 545 | + var adFlagVal = $(this).val(); | |
| 546 | + advTextChange(adFlagVal); | |
| 547 | + | |
| 548 | +}); | |
| 549 | + | |
| 550 | +function advTextChange(adFlagVal){ | |
| 551 | + | |
| 552 | + if(typeof adFlagVal == "undefined" || adFlagVal == null || adFlagVal == ""){ | |
| 553 | + | |
| 554 | + $("#ad_Y").prop('checked',true); | |
| 555 | + | |
| 556 | + }else if(adFlagVal == 'N'){//광고 표시 숨김처리 | |
| 557 | + | |
| 558 | + $('.adFlag').hide(); | |
| 559 | + $('.kakao_block_text').hide(); | |
| 560 | + $('#adFlagFront').hide(); | |
| 561 | + $('.adFlagAfter').hide(); | |
| 562 | + | |
| 563 | + }else{ | |
| 564 | + $('.adFlag').show(); | |
| 565 | + $('.kakao_block_text').show(); | |
| 566 | + $('#adFlagFront').show(); | |
| 567 | + $('.adFlagAfter').show(); | |
| 568 | + } | |
| 569 | + | |
| 570 | +} | |
| 571 | + | |
| 572 | + | |
| 573 | +//친구톡 내용 템플릿으로 저장하기 - 내용 저장하기 | |
| 574 | +function myTemplateSave(){ | |
| 575 | + | |
| 576 | + var selectAgentCode = $("select[name='selectAgentCode']").val(); // 선택 채널ID | |
| 577 | + var yellowId = $("select[name='selectAgentCode'] option:selected").text().replaceAll('@',''); // 선택 채널명 | |
| 578 | + var inputTemplateName = $("#inputTemplateName").val(); // 입력 템플릿 이름 | |
| 579 | + var imageType = $("input[name=img_file_add]:checked").val(); // 첨부 이미지 종류(없음, 일반, 와이드 이미지) | |
| 580 | + var imageTitle = $("#imgTitle").val(); //첨부이미지 제목 | |
| 581 | + var imageLink = $("#imgLink").val(); //첨부이미지 클릭시 이동 링크 주소 | |
| 582 | + var inputTemplateAd = $("input[name=ad_flag]:checked").val(); // 광고성메시지 선택 여부 | |
| 583 | + var inputTemplateContent = $("#inputTemplateContent").val(); // 템플릿 내용 | |
| 584 | + | |
| 585 | + var inputTemplateImageName = $("#templateImageName").val(); // 템플릿 이미지 파일명 | |
| 586 | + var inputTemplateImageUrl = $("#templateImageUrl").val(); // 템플릿 이미지 링크 | |
| 587 | + | |
| 588 | + // 공통 유효성 검사 조회 | |
| 589 | + if(selectAgentCode == null || selectAgentCode == ""){ | |
| 590 | + alert("채널ID를 선택해 주세요"); | |
| 591 | + return; | |
| 592 | + }; | |
| 593 | + | |
| 594 | + if(inputTemplateName == null || inputTemplateName == ""){ | |
| 595 | + alert("템플릿 명을 입력해 주세요"); | |
| 596 | + $("#inputTemplateName").focus(); | |
| 597 | + return; | |
| 598 | + }; | |
| 599 | + | |
| 600 | + if(imageType == 'I' || imageType == 'W'){ | |
| 601 | + | |
| 602 | + if(imageTitle == ''){ | |
| 603 | + | |
| 604 | + alert("이미지 제목을 입력해 주세요."); | |
| 605 | + return false; | |
| 606 | + | |
| 607 | + } | |
| 608 | + | |
| 609 | + if(imageLink == ''){ | |
| 610 | + | |
| 611 | + alert("이미지 클릭시 이동할 URL을 입력해 주세요."); | |
| 612 | + return false; | |
| 613 | + | |
| 614 | + }else{ | |
| 615 | + | |
| 616 | + if(imageLink.search("http://") == -1 && imageLink.search("https://") == -1){ | |
| 617 | + | |
| 618 | + alert("이미지 URL 주소에는 http:// 또는 https://를 포함하여 입력해야 합니다."); | |
| 619 | + return false; | |
| 620 | + | |
| 621 | + } | |
| 622 | + | |
| 623 | + } | |
| 624 | + | |
| 625 | + if(inputTemplateImageUrl == ''){ | |
| 626 | + | |
| 627 | + alert("이미지를 선택해 주세요."); | |
| 628 | + return false; | |
| 629 | + | |
| 630 | + } | |
| 631 | + | |
| 632 | + } | |
| 633 | + | |
| 634 | + | |
| 635 | + if(inputTemplateContent == null || inputTemplateContent == ""){ | |
| 636 | + alert("템플릿 내용을 입력해 주세요."); | |
| 637 | + return; | |
| 638 | + }; | |
| 639 | + | |
| 640 | + var bizForm = document.bizForm; | |
| 641 | + bizForm.senderKey.value = selectAgentCode; | |
| 642 | + //bizForm.yellowId.value = yellowId; | |
| 643 | + bizForm.templateName.value = inputTemplateName; | |
| 644 | + //bizForm.imageType.value = imageType; | |
| 645 | + //bizForm.imgTitle.value = imageTitle; | |
| 646 | + //bizForm.imgLink.value = imageLink; | |
| 647 | + bizForm.adFlag.value = inputTemplateAd; | |
| 648 | + bizForm.templateContent.value = inputTemplateContent; | |
| 649 | + | |
| 650 | + var data = new FormData(bizForm); | |
| 651 | + | |
| 652 | + if(confirm("템플릿을 저장하시겠습니까?")){ | |
| 653 | + | |
| 654 | + $.ajax({ | |
| 655 | + type: "POST" | |
| 656 | + , url: "/web/mjon/kakao/template/insertKakaoFriendsTemplateDataAjax.do" | |
| 657 | + , data: data | |
| 658 | + , dataType: 'json' | |
| 659 | + , async: false | |
| 660 | + , processData: false | |
| 661 | + , contentType: false | |
| 662 | + , cache: false | |
| 663 | + , success: function (returnData, status) { | |
| 664 | + | |
| 665 | + var result = returnData.result; | |
| 666 | + | |
| 667 | + if(result == "loginFail") {//차단 발신번호인 경우 등록 불가 | |
| 668 | + alert("로그인후 진행이 가능합니다."); | |
| 669 | + }else if(returnData.result == "success") { | |
| 670 | + alert("템플릿 저장이 완료되었습니다."); | |
| 671 | + return false; | |
| 672 | + }else{ | |
| 673 | + | |
| 674 | + alert("템플릿 저장에 오류가 발생하였습니다."); | |
| 675 | + return false; | |
| 676 | + | |
| 677 | + } | |
| 678 | + } | |
| 679 | + ,error: function (e) { | |
| 680 | + console.log("ERROR : ", e); | |
| 681 | + alert("템플릿 저장에 오류가 발생하였습니다."); | |
| 682 | + } | |
| 683 | + }); | |
| 684 | + | |
| 685 | + } | |
| 686 | + | |
| 687 | +} | |
| 688 | + | |
| 689 | +//주소록 불러오기 버튼 클릭시 | |
| 690 | +$('.popupAddr').click(function(){ | |
| 691 | + | |
| 692 | + if(loginVO == "" || loginVO == null){ | |
| 693 | + alert("주소록 불러오기 서비스는 로그인 후 이용 가능합니다."); | |
| 694 | + location.href="<c:url value='/web/user/login/login.do'/>"; | |
| 695 | + return false; | |
| 696 | + } | |
| 697 | + | |
| 698 | + $("#addrGroupLoad").load("/web/mjon/msgdata/selectAddrGroupListAjax.do", "" ,function(response, status, xhr){ | |
| 699 | + //리스트 스크롤 처리해주기 | |
| 700 | + $(".adr_pop_list").mCustomScrollbar({ | |
| 701 | + axis: 'y', | |
| 702 | + scrollbarPosition: "outside", | |
| 703 | + theme: "dark", | |
| 704 | + autoHideScrollbar: false | |
| 705 | + }); | |
| 706 | + }); | |
| 707 | + | |
| 708 | +}); | |
| 709 | + | |
| 710 | +function fnEmptyId(){ | |
| 711 | + | |
| 712 | + alert("로그인 후 이용이 가능합니다."); | |
| 713 | + return false; | |
| 714 | + | |
| 715 | +} | |
| 716 | + | |
| 717 | +//분할전송 건수 데이터 체크 | |
| 718 | +function checkNumber(event) { | |
| 719 | + var divideCnt = $('#frmDivideCnt').val(); | |
| 720 | + if(!(event.key >= 0 && event.key <= 9)) { | |
| 721 | + return false; | |
| 722 | + } | |
| 723 | + | |
| 724 | + var totCnt = divideCnt + "" + event.key; | |
| 725 | + if(Number(totCnt) > 5000){ | |
| 726 | + alert("분할전송 건수는 5,000건을 초과할 수 없습니다."); | |
| 727 | + $('#frmDivideCnt').val("20"); | |
| 728 | + return false; | |
| 729 | + } | |
| 730 | + | |
| 731 | + return true; | |
| 732 | +} | |
| 733 | + | |
| 734 | +function fnSelectMinChk(){ | |
| 735 | + | |
| 736 | + var resHour = $("#msgResHour option:selected").val(); | |
| 737 | + var resMin = $("#msgResMin option:selected").val(); | |
| 738 | + | |
| 739 | + if(resHour == '20'){ | |
| 740 | + | |
| 741 | + if(resMin >= 50 && resMin <= 59){ | |
| 742 | + | |
| 743 | + alert("친구톡은 20:50 ~ 익일 08:00까지 발송할 수 없습니다."); | |
| 744 | + $("#msgResMin").val("40").prop("selected", true); | |
| 745 | + | |
| 746 | + } | |
| 747 | + | |
| 748 | + } | |
| 749 | + | |
| 750 | +} | |
| 751 | + | |
| 752 | + | |
| 753 | +//친구톡 발송 금지 시간 처리 | |
| 754 | +function fn_noTimeSend(){ | |
| 755 | + | |
| 756 | + var id = '${loginVO.id}'; | |
| 757 | + | |
| 758 | + if(id == ""){ | |
| 759 | + | |
| 760 | + alert("로그인 후 이용이 가능합니다."); | |
| 761 | + return false; | |
| 762 | + | |
| 763 | + } | |
| 764 | + | |
| 765 | + alert("친구톡은 20:50 ~ 익일 08:00까지 발송할 수 없습니다."); | |
| 766 | + return false; | |
| 767 | + | |
| 768 | +} | |
| 769 | + | |
| 770 | +//친구톡 데이터 전송 처리 | |
| 771 | +function fn_sendMsgData(){ | |
| 772 | + | |
| 773 | + var senderKey = $("#selectAgentCode option:checked").val(); | |
| 774 | + | |
| 775 | + if(senderKey == ''){ | |
| 776 | + | |
| 777 | + alert("채널ID를 선택해 주세요."); | |
| 778 | + return false; | |
| 779 | + | |
| 780 | + }else{ | |
| 781 | + | |
| 782 | + $("#inputSenderKey").val(senderKey); | |
| 783 | + | |
| 784 | + } | |
| 785 | + | |
| 786 | + //이미지 첨부 체크 | |
| 787 | + var imgChk = $("input[name=img_file_add]:checked").val(); | |
| 788 | + if(!getFtImageType(imgChk)){ | |
| 789 | + return false; | |
| 790 | + } | |
| 791 | + | |
| 792 | + //템플릿 버튼 갯수 체크 | |
| 793 | + var buttonCnt = $(".btn_kakao_type").length; | |
| 794 | + | |
| 795 | + if(buttonCnt > 0){ | |
| 796 | + //json 파일 필요 유무 셋팅 | |
| 797 | + $("#bizJsonYn").val("Y"); | |
| 798 | + } | |
| 799 | + | |
| 800 | + //친구톡 내용 체크 | |
| 801 | + var tmpContents = $('#inputTemplateContent').val(); | |
| 802 | + | |
| 803 | + if(tmpContents == ""){ | |
| 804 | + | |
| 805 | + alert("친구톡 내용을 입력해 주세요."); | |
| 806 | + return false; | |
| 807 | + | |
| 808 | + } | |
| 809 | + | |
| 810 | + var rtnStr = strChinJpnCheck(tmpContents); | |
| 811 | + | |
| 812 | + //문자내용에 이모지가 있는지 체크 | |
| 813 | + if(!emojiCheck(tmpContents)) return false; | |
| 814 | + | |
| 815 | + if(rtnStr.length > 0){ | |
| 816 | + | |
| 817 | + alert("입력하신 문구 중 \" " + rtnStr + " \" 는 일부 휴대폰에서 표기되지 않을 수 있습니다."); | |
| 818 | + | |
| 819 | + } | |
| 820 | + | |
| 821 | + | |
| 822 | + //수신번호 리스트 체크하기 | |
| 823 | + var numCnt = 0; | |
| 824 | + var nameList = []; //치환문자 이름 | |
| 825 | + var phoneNum = []; //받는사람 | |
| 826 | + var rep1List = []; //치환문자1 | |
| 827 | + var rep2List = []; //치환문자2 | |
| 828 | + var rep3List = []; //치환문자3 | |
| 829 | + var rep4List = []; //치환문자4 | |
| 830 | + | |
| 831 | + var varValList = []; //치환문자 연결시킬 변수 셋팅 | |
| 832 | + | |
| 833 | + var selectedData = tableL.getRows(); | |
| 834 | + | |
| 835 | + var varValStatus = true; //치환분자 데이터 체크용 | |
| 836 | + | |
| 837 | + if(selectedData == "" || selectedData == null){ | |
| 838 | + | |
| 839 | + alert("받는사람 주소를 한 건 이상 입력해주세요."); | |
| 840 | + return false; | |
| 841 | + | |
| 842 | + }else{ // 선택한 Row '-' 문자 삭제하기 | |
| 843 | + | |
| 844 | + var txtReplYn = $("#txtReplYn").val(); | |
| 845 | + | |
| 846 | + if(txtReplYn == 'Y'){//치환문자가 있는 경우 변수 치환 처리 | |
| 847 | + | |
| 848 | + for(var i=0; i < selectedData.length; i++){ | |
| 849 | + | |
| 850 | + var nmStatus = false; | |
| 851 | + var rep1Status = false; | |
| 852 | + var rep2Status = false; | |
| 853 | + var rep3Status = false; | |
| 854 | + var rep4Status = false; | |
| 855 | + | |
| 856 | + | |
| 857 | + if(tmpContents.indexOf("\#{이름}") > -1){ | |
| 858 | + | |
| 859 | + nmStatus = true; | |
| 860 | + } | |
| 861 | + | |
| 862 | + if(tmpContents.indexOf("\#{1}") > -1){ | |
| 863 | + | |
| 864 | + rep1Status = true; | |
| 865 | + } | |
| 866 | + | |
| 867 | + if(tmpContents.indexOf("\#{2}") > -1){ | |
| 868 | + | |
| 869 | + rep2Status = true; | |
| 870 | + } | |
| 871 | + | |
| 872 | + if(tmpContents.indexOf("\#{3}") > -1){ | |
| 873 | + | |
| 874 | + rep3Status = true; | |
| 875 | + } | |
| 876 | + | |
| 877 | + if(tmpContents.indexOf("\#{4}") > -1){ | |
| 878 | + | |
| 879 | + rep4Status = true; | |
| 880 | + } | |
| 881 | + | |
| 882 | + //일괄변환 문자에 콤마(,)가 들어가있으면 배열로 넘길때 문제가 발생하여 특수문자(§)로 치환하여 넘겨주도록 한다. | |
| 883 | + var name = tableL.getRows()[i].getData().name; | |
| 884 | + var phone = removeDash(tableL.getRows()[i].getData().phone); | |
| 885 | + var rep1 = tableL.getRows()[i].getData().rep1; | |
| 886 | + var rep2 = tableL.getRows()[i].getData().rep2; | |
| 887 | + var rep3 = tableL.getRows()[i].getData().rep3; | |
| 888 | + var rep4 = tableL.getRows()[i].getData().rep4; | |
| 889 | + var varValStr = ""; //¶ 구분자 | |
| 890 | + | |
| 891 | + if(phone == ""){ | |
| 892 | + | |
| 893 | + alert("수신 목록에 핸드폰 번호가 없는 항목이 있습니다."); | |
| 894 | + return false; | |
| 895 | + | |
| 896 | + }else if(!checkHpNum(phone)){ | |
| 897 | + | |
| 898 | + alert("수신 목록에 잘 못된 핸드폰 번호가 있습니다. 핸드폰 번호 : " + phone + " 입니다."); | |
| 899 | + return false; | |
| 900 | + | |
| 901 | + }else{ | |
| 902 | + | |
| 903 | + if(typeof(name) != 'undefined' && name != null && name !=""){ | |
| 904 | + if(!emojiCheck(name)){//이모지 체크 해주기 | |
| 905 | + return false; | |
| 906 | + } | |
| 907 | + | |
| 908 | + //이름 치환변수가 있으면 저장 | |
| 909 | + if(nmStatus){ | |
| 910 | + //nameList[i] = name.replaceAll(",","§"); | |
| 911 | + if(varValStr == ''){ | |
| 912 | + | |
| 913 | + varValStr = name.replaceAll(",","§"); | |
| 914 | + }else{ | |
| 915 | + | |
| 916 | + varValStr = varValStr + "¶" + name.replaceAll(",","§"); | |
| 917 | + | |
| 918 | + } | |
| 919 | + } | |
| 920 | + }else{ | |
| 921 | + if(nmStatus){ | |
| 922 | + varValStatus = false; | |
| 923 | + } | |
| 924 | + } | |
| 925 | + | |
| 926 | + | |
| 927 | + if(phone != '' && phone != null){ | |
| 928 | + //연락처 변수 저장하기 | |
| 929 | + phoneNum[i] = phone; | |
| 930 | + if(varValStr == ''){ | |
| 931 | + varValStr = phone; | |
| 932 | + }else{ | |
| 933 | + varValStr = varValStr + "¶" + phone; | |
| 934 | + } | |
| 935 | + }else{ | |
| 936 | + varValStatus = false; | |
| 937 | + } | |
| 938 | + | |
| 939 | + if(typeof(rep1) != 'undefined' && rep1 != null && rep1 !=""){ | |
| 940 | + if(!emojiCheck(rep1)){//이모지 체크 해주기 | |
| 941 | + return false; | |
| 942 | + } | |
| 943 | + | |
| 944 | + if(rep1Status){ | |
| 945 | + | |
| 946 | + if(varValStr == ''){ | |
| 947 | + //rep1List[i] = rep1.replaceAll(",","§"); | |
| 948 | + varValStr = rep1.replaceAll(",","§"); | |
| 949 | + }else{ | |
| 950 | + //rep1List[i] = rep1.replaceAll(",","§"); | |
| 951 | + varValStr = varValStr + "¶" + rep1.replaceAll(",","§"); | |
| 952 | + } | |
| 953 | + } | |
| 954 | + }else{ | |
| 955 | + if(rep1Status){ | |
| 956 | + varValStatus = false; | |
| 957 | + } | |
| 958 | + } | |
| 959 | + | |
| 960 | + if(typeof(rep2) != 'undefined' && rep2 != null && rep2 !=""){ | |
| 961 | + if(!emojiCheck(rep2)){//이모지 체크 해주기 | |
| 962 | + return false; | |
| 963 | + } | |
| 964 | + | |
| 965 | + if(rep2Status){ | |
| 966 | + | |
| 967 | + if(varValStr == ''){ | |
| 968 | + varValStr = rep2.replaceAll(",","§"); | |
| 969 | + }else{ | |
| 970 | + //rep2List[i] = rep2.replaceAll(",","§"); | |
| 971 | + varValStr = varValStr + "¶" + rep2.replaceAll(",","§"); | |
| 972 | + } | |
| 973 | + } | |
| 974 | + }else{ | |
| 975 | + if(rep2Status){ | |
| 976 | + varValStatus = false; | |
| 977 | + } | |
| 978 | + } | |
| 979 | + | |
| 980 | + | |
| 981 | + if(typeof(rep3) != 'undefined' && rep3 != null && rep3 !=""){ | |
| 982 | + if(!emojiCheck(rep3)){//이모지 체크 해주기 | |
| 983 | + return false; | |
| 984 | + } | |
| 985 | + | |
| 986 | + if(rep3Status){ | |
| 987 | + | |
| 988 | + if(varValStr == ''){ | |
| 989 | + varValStr = rep3.replaceAll(",","§"); | |
| 990 | + }else{ | |
| 991 | + //rep3List[i] = rep3.replaceAll(",","§"); | |
| 992 | + varValStr = varValStr + "¶" + rep3.replaceAll(",","§"); | |
| 993 | + } | |
| 994 | + } | |
| 995 | + }else{ | |
| 996 | + if(rep3Status){ | |
| 997 | + varValStatus = false; | |
| 998 | + } | |
| 999 | + } | |
| 1000 | + | |
| 1001 | + | |
| 1002 | + if(typeof(rep4) != 'undefined' && rep4 != null && rep4 !=""){ | |
| 1003 | + if(!emojiCheck(rep4)){//이모지 체크 해주기 | |
| 1004 | + return false; | |
| 1005 | + } | |
| 1006 | + | |
| 1007 | + if(rep4Status){ | |
| 1008 | + | |
| 1009 | + if(varValStr == ''){ | |
| 1010 | + varValStr = rep4.replaceAll(",","§"); | |
| 1011 | + }else{ | |
| 1012 | + //rep4List[i] = rep4.replaceAll(",","§"); | |
| 1013 | + varValStr = varValStr + "¶" + rep4.replaceAll(",","§"); | |
| 1014 | + } | |
| 1015 | + } | |
| 1016 | + }else{ | |
| 1017 | + if(rep4Status){ | |
| 1018 | + varValStatus = false; | |
| 1019 | + } | |
| 1020 | + } | |
| 1021 | + | |
| 1022 | + } | |
| 1023 | + | |
| 1024 | + varValList[i] = varValStr; | |
| 1025 | + | |
| 1026 | + } | |
| 1027 | + | |
| 1028 | + }else{//치환문자가 없는 경우 휴대폰 번호만 입력 | |
| 1029 | + | |
| 1030 | + for(var i=0; i < selectedData.length; i++){ | |
| 1031 | + | |
| 1032 | + //일괄변환 문자에 콤마(,)가 들어가있으면 배열로 넘길때 문제가 발생하여 특수문자(§)로 치환하여 넘겨주도록 한다. | |
| 1033 | + var phone = removeDash(tableL.getRows()[i].getData().phone); | |
| 1034 | + | |
| 1035 | + if(phone == ""){ | |
| 1036 | + | |
| 1037 | + alert("수신 목록에 핸드폰 번호가 없는 항목이 있습니다."); | |
| 1038 | + return false; | |
| 1039 | + | |
| 1040 | + }else if(!checkHpNum(phone)){ | |
| 1041 | + | |
| 1042 | + alert("수신 목록에 잘 못된 핸드폰 번호가 있습니다. 핸드폰 번호 : " + phone + " 입니다."); | |
| 1043 | + return false; | |
| 1044 | + | |
| 1045 | + }else{ | |
| 1046 | + | |
| 1047 | + phoneNum[i] = phone; | |
| 1048 | + | |
| 1049 | + } | |
| 1050 | + | |
| 1051 | + } | |
| 1052 | + | |
| 1053 | + } | |
| 1054 | + | |
| 1055 | + } | |
| 1056 | + | |
| 1057 | + //예약문자 시간 체크 | |
| 1058 | + var reserYn = $("input[name=reserYn]:checked").val(); // 예약 발송 여부 확인 | |
| 1059 | + | |
| 1060 | + if(reserYn == 'Y'){ | |
| 1061 | + | |
| 1062 | + var date = $(".resDate").val();//form.msgResDate.value; | |
| 1063 | + var hour = $("#msgResHour option:selected").val(); | |
| 1064 | + var min = $("#msgResMin option:selected").val(); | |
| 1065 | + | |
| 1066 | + if(date == ""){ | |
| 1067 | + | |
| 1068 | + alert("예약전송 날짜를 선택해 주세요."); | |
| 1069 | + return false; | |
| 1070 | + | |
| 1071 | + }else{ | |
| 1072 | + | |
| 1073 | + var now = new Date(); | |
| 1074 | + var reqDate = date + " " + hour + ":" + min + ":00"; | |
| 1075 | + var gapDate = getGapDayTime(date, hour, min); | |
| 1076 | + | |
| 1077 | + if(gapDate < 0){ // 음수이면 이전날짜, 크면 이후 날짜. | |
| 1078 | + alert("예약 날짜는 현재 시간 이후의 날짜 및 시간을 선택해 주세요."); | |
| 1079 | + return false; | |
| 1080 | + }else{ | |
| 1081 | + $("#reqDate").val(reqDate); //예약일자 파라미터 저장 | |
| 1082 | + } | |
| 1083 | + } | |
| 1084 | + | |
| 1085 | + }else{ | |
| 1086 | + | |
| 1087 | + $("#reqDate").val(""); //예약일자 파라미터 저장 | |
| 1088 | + | |
| 1089 | + } | |
| 1090 | + | |
| 1091 | + | |
| 1092 | + //대체문자 선택 및 내용 체크 | |
| 1093 | + var subMsgSendYn = "N"; | |
| 1094 | + | |
| 1095 | + if($("#send_fail_check").is(":checked")){ | |
| 1096 | + | |
| 1097 | + subMsgSendYn = "Y"; | |
| 1098 | + $("#subMsgSendYn").val("Y"); | |
| 1099 | + | |
| 1100 | + //대체문자 체크사항 함수 호출 | |
| 1101 | + if(!fn_subMsgCheck()){ | |
| 1102 | + | |
| 1103 | + /* $("#send_fail_check").prop("checked", false); | |
| 1104 | + $(".replace_send_wrap").slideUp(400); | |
| 1105 | + // 초기화 버튼 클릭 | |
| 1106 | + $('#failCheckInit').click(); | |
| 1107 | + $('.send_top .send_right .phone').css({'top': '0','transition': 'top .4s linear'}); */ | |
| 1108 | + return false; | |
| 1109 | + | |
| 1110 | + } | |
| 1111 | + | |
| 1112 | + }else{ | |
| 1113 | + | |
| 1114 | + subMsgSendYn = "N"; | |
| 1115 | + $("#subMsgSendYn").val("N"); | |
| 1116 | + | |
| 1117 | + } | |
| 1118 | + | |
| 1119 | + //수신전화번호 목록 | |
| 1120 | + $("#callToList").val(phoneNum); | |
| 1121 | + | |
| 1122 | + //치환변수 데이터 정보 목록(수신번호 포함, tabulator 정보 모두 ) | |
| 1123 | + $("#varValList").val(varValList); | |
| 1124 | + | |
| 1125 | + //템플릿 내용 입력 | |
| 1126 | + $("#templateContent").val(tmpContents); | |
| 1127 | + | |
| 1128 | + //광고포함 여부 | |
| 1129 | + var adFlag = $("input[name=ad_flag]:checked").val(); | |
| 1130 | + $("#adFlag").val(adFlag); | |
| 1131 | + | |
| 1132 | + //치환문자에 대한 데이터 누락 체크 | |
| 1133 | + if(!varValStatus){ | |
| 1134 | + | |
| 1135 | + alert("특정문구 일괄변환에 대한 일부 데이터가 누락된 부분이 있습니다. 데이터를 확인해 주세요."); | |
| 1136 | + return false; | |
| 1137 | + | |
| 1138 | + } | |
| 1139 | + | |
| 1140 | + if(!confirm("친구톡을 발송하시겠습니까?")){ | |
| 1141 | + | |
| 1142 | + return false; | |
| 1143 | + | |
| 1144 | + } | |
| 1145 | + | |
| 1146 | + var spamChk = true; | |
| 1147 | + | |
| 1148 | + var spmData = new FormData(document.bizForm); | |
| 1149 | + $.ajax({ | |
| 1150 | + type: "POST" | |
| 1151 | + , url: "/web/mjon/kakao/friendstalk/selectSpamKakaoFriendsTalkMsgChkAjax.do" | |
| 1152 | + , data: spmData | |
| 1153 | + , dataType:'json' | |
| 1154 | + , async: false | |
| 1155 | + , processData: false | |
| 1156 | + , contentType: false | |
| 1157 | + , cache: false | |
| 1158 | + , success: function (returnData, status) { | |
| 1159 | + if(status == 'success'){ // status 확인 필요한가. 석세스 안뜨면 에러 가지 않나 | |
| 1160 | + | |
| 1161 | + if("fail" == returnData.result){ | |
| 1162 | + alert(returnData.message); | |
| 1163 | + spamChk = false; | |
| 1164 | + return false; | |
| 1165 | + }else if("loginFail" == returnData.result){ | |
| 1166 | + alert(returnData.message); | |
| 1167 | + spamChk = false; | |
| 1168 | + return false; | |
| 1169 | + }else if("spams" == returnData.result){ | |
| 1170 | + //alert("전송 내용에 스팸문구가 포함되어 있습니다.") | |
| 1171 | + $("#spamStatus").val("Y"); | |
| 1172 | + return false; | |
| 1173 | + }else{ | |
| 1174 | + spamChk = true; | |
| 1175 | + return false; | |
| 1176 | + } | |
| 1177 | + | |
| 1178 | + } else if(status== 'fail'){ | |
| 1179 | + alert(returnData.message); | |
| 1180 | + return false; | |
| 1181 | + } | |
| 1182 | + } | |
| 1183 | + , error: function (e) { | |
| 1184 | + alert("문자 발송에 실패하였습니다."); | |
| 1185 | + console.log("ERROR : ", e); | |
| 1186 | + return false; | |
| 1187 | + } | |
| 1188 | + }); | |
| 1189 | + | |
| 1190 | + if(spamChk){ | |
| 1191 | + var data = new FormData(document.bizForm); | |
| 1192 | + $.ajax({ | |
| 1193 | + type: "POST" | |
| 1194 | + , url: "/web/mjon/kakao/friendstalk/kakaoFriendsTalkMsgSendAjax.do" | |
| 1195 | + , data: data | |
| 1196 | + , dataType: 'json' | |
| 1197 | + , async: true | |
| 1198 | + , processData: false | |
| 1199 | + , contentType: false | |
| 1200 | + , cache: false | |
| 1201 | + , success: function (returnData, status) { | |
| 1202 | + if(status == 'success'){ | |
| 1203 | + if("loginFail" == returnData.result){ | |
| 1204 | + | |
| 1205 | + alert(returnData.message); | |
| 1206 | + return false; | |
| 1207 | + | |
| 1208 | + }else if('fail' == returnData.result){ | |
| 1209 | + | |
| 1210 | + alert(returnData.message); | |
| 1211 | + return false; | |
| 1212 | + | |
| 1213 | + }else if('authFail' == returnData.result){ | |
| 1214 | + | |
| 1215 | + alert(returnData.message); | |
| 1216 | + location.reload(); | |
| 1217 | + | |
| 1218 | + } else if(status == 'success'){ | |
| 1219 | + | |
| 1220 | + var kakaoSendCnt = returnData.resultSts; | |
| 1221 | + | |
| 1222 | + $('.pop_msg_success').css({'display':'block','opacity':'1','left':'50%','top':'50%','transform':'translate(-50%,-50%)'}); | |
| 1223 | + | |
| 1224 | + //예약발송 건의 경우 결과 팝업 문구 변경 | |
| 1225 | + if(reserYn == 'Y'){ | |
| 1226 | + $('.pop_msg_success .msg_text').html("예약 성공 : <strong>"+ kakaoSendCnt + "</strong>건의<br>친구톡이 예약 되었습니다."); | |
| 1227 | + }else{ | |
| 1228 | + $('.pop_msg_success .msg_text').html("발송 성공 : <strong>"+ kakaoSendCnt + "</strong>건의<br>친구톡이 발송 되었습니다."); | |
| 1229 | + } | |
| 1230 | + | |
| 1231 | + $('.mask').addClass('on'); | |
| 1232 | + } | |
| 1233 | + } | |
| 1234 | + } | |
| 1235 | + ,beforeSend : function(xmlHttpRequest) { | |
| 1236 | + //로딩창 show | |
| 1237 | + $('.loading_layer').addClass('active'); | |
| 1238 | + } | |
| 1239 | + ,complete : function(xhr, textStatus) { | |
| 1240 | + //로딩창 hide | |
| 1241 | + $('.loading_layer').removeClass('active'); | |
| 1242 | + } | |
| 1243 | + ,error: function (e) { | |
| 1244 | + console.log("ERROR : ", e); | |
| 1245 | + alert("카카오 친구톡 전송에 실패하였습니다."); | |
| 1246 | + } | |
| 1247 | + }); | |
| 1248 | + } | |
| 1249 | + | |
| 1250 | +} | |
| 1251 | + | |
| 1252 | + | |
| 1253 | +/** | |
| 1254 | + * @description 대체문자 오류체크 funciton | |
| 1255 | + */ | |
| 1256 | +function fn_errorChk(){ | |
| 1257 | + | |
| 1258 | + // 대체문자가 없을 시 return false; | |
| 1259 | + if($('#txtReplYn').val() === 'N') | |
| 1260 | + { | |
| 1261 | + alert('오류가 없습니다.'); | |
| 1262 | + return false; | |
| 1263 | + } | |
| 1264 | + | |
| 1265 | + // 치환 부분 변수명만 추출 = 배열 | |
| 1266 | + var varList = $("#inputTemplateContent").val().match(/#\{([^}]+)\}/g); | |
| 1267 | + | |
| 1268 | + var smsTxt = $('#smsTxtArea').val(); | |
| 1269 | + for(var i=0; i < varList.length; i++){ | |
| 1270 | + if(smsTxt.indexOf(varList[i]) < 0){ | |
| 1271 | + if(confirm(varList[i] + '값이 없습니다. 치환문자 없이 진행하시겠습니까?')){ | |
| 1272 | + fn_insertErrorYN('Y'); | |
| 1273 | + }; | |
| 1274 | + return false; | |
| 1275 | + } | |
| 1276 | + smsTxt = smsTxt.replace(varList[i], ''); | |
| 1277 | + }; | |
| 1278 | + alert('오류가 없습니다.'); | |
| 1279 | + fn_insertErrorYN('Y'); | |
| 1280 | +} | |
| 1281 | + | |
| 1282 | + | |
| 1283 | +function fn_insertErrorYN(val){ | |
| 1284 | + $('#errorChk').val(val); | |
| 1285 | +} | |
| 1286 | + | |
| 1287 | +/* | |
| 1288 | + *대체문자 필수 항목 체크 | |
| 1289 | + * | |
| 1290 | + **/ | |
| 1291 | + | |
| 1292 | +function fn_subMsgCheck(){ | |
| 1293 | + | |
| 1294 | + if($('#callFromList').val() === ''){ | |
| 1295 | + | |
| 1296 | + if(confirm('대체문자 전송을 위한 발신번호가 등록되지 않았습니다. \n대체문자 발신번호를 지금 등록하시겠습니까?')){ | |
| 1297 | + window.location="<c:out value='/web/user/sendNumberManage.do' />"; | |
| 1298 | + } | |
| 1299 | + $("#send_fail_check").prop("checked", false); | |
| 1300 | + | |
| 1301 | + return false; | |
| 1302 | + | |
| 1303 | + }else{ | |
| 1304 | + | |
| 1305 | + //발신번호 입력 처리 | |
| 1306 | + $("#callFrom").val(removeDash($('#callFromList').val())); | |
| 1307 | + | |
| 1308 | + } | |
| 1309 | + | |
| 1310 | + if($("#smsTxtArea").val() === ''){ | |
| 1311 | + | |
| 1312 | + alert("대체문자 내용을 입력해 주세요."); | |
| 1313 | + return false; | |
| 1314 | + | |
| 1315 | + }else{//대체문자에 치환문자 여부 체크 | |
| 1316 | + | |
| 1317 | + var smsTxtArea = $("#smsTxtArea").val(); | |
| 1318 | + var replStatus = false; | |
| 1319 | + | |
| 1320 | + if(smsTxtArea.indexOf("\#{이름}") > -1){ | |
| 1321 | + replStatus = true; | |
| 1322 | + } | |
| 1323 | + | |
| 1324 | + if(smsTxtArea.indexOf("\#{1}") > -1){ | |
| 1325 | + replStatus = true; | |
| 1326 | + } | |
| 1327 | + | |
| 1328 | + if(smsTxtArea.indexOf("\#{2}") > -1){ | |
| 1329 | + replStatus = true; | |
| 1330 | + } | |
| 1331 | + | |
| 1332 | + if(smsTxtArea.indexOf("\#{3}") > -1){ | |
| 1333 | + replStatus = true; | |
| 1334 | + } | |
| 1335 | + | |
| 1336 | + if(smsTxtArea.indexOf("\#{4}") > -1){ | |
| 1337 | + replStatus = true; | |
| 1338 | + } | |
| 1339 | + | |
| 1340 | + if(replStatus){ | |
| 1341 | + $("#subMsgTxtReplYn").val("Y"); | |
| 1342 | + }else{ | |
| 1343 | + $("#subMsgTxtReplYn").val("N"); | |
| 1344 | + } | |
| 1345 | + | |
| 1346 | + $("#subMsgTxt").val(smsTxtArea); | |
| 1347 | + | |
| 1348 | + } | |
| 1349 | + | |
| 1350 | + | |
| 1351 | + | |
| 1352 | + return true; | |
| 1353 | + | |
| 1354 | +} | |
| 1355 | + | |
| 1356 | +//문자 바이트수 계산하기 함수 | |
| 1357 | +function thisFnByteString(contents){ | |
| 1358 | + var totalByte = 0; | |
| 1359 | + //var content = contents; | |
| 1360 | + var adverYn = $("input[name='send_adYn']:checked").val(); | |
| 1361 | + var adTxtLeng = 0; | |
| 1362 | + var denyTxtLeng = 0; | |
| 1363 | + | |
| 1364 | + $('#msgLeng').html(""); | |
| 1365 | + $('#limitLeng').html(""); | |
| 1366 | + var conLeng = conByteLeng(contents); // 내용 문자 입력 바이트 수 계산하기 | |
| 1367 | + | |
| 1368 | + | |
| 1369 | + $('#msgLeng').text(conLeng); | |
| 1370 | + | |
| 1371 | + //문자 길이 변수에 저장해주기 | |
| 1372 | + $('#smsLen').val(conLeng); | |
| 1373 | + | |
| 1374 | + | |
| 1375 | + if(conLeng > 90){ | |
| 1376 | + | |
| 1377 | + $('#msgLeng').html(conLeng + " / "); | |
| 1378 | + $('#limitLeng').html("2000"); | |
| 1379 | + $('.msg_com').html("장문"); | |
| 1380 | + $('#msgType').val("6"); // 메세지 타입 설정 | |
| 1381 | + | |
| 1382 | + $('.msg_com').removeClass("msg_short"); //단문 클래스 삭제하고 | |
| 1383 | + $('.put_left').removeClass("short"); //내용 입력 박스 클래스 삭제 | |
| 1384 | + $('.msg_com').addClass("msg_long"); // 장문 클래스 삽입 | |
| 1385 | + $("#subMsgType").val("LMS"); | |
| 1386 | + | |
| 1387 | + }else{ | |
| 1388 | + | |
| 1389 | + $('#msgLeng').html(conLeng + " / "); | |
| 1390 | + $('#limitLeng').html("90"); | |
| 1391 | + $('.msg_com').html("단문"); | |
| 1392 | + $('#msgType').val("4"); // 메세지 타입 설정 | |
| 1393 | + $('.msg_com').removeClass("msg_long"); //단문 클래스 삭제하고 | |
| 1394 | + $('.put_left').removeClass("long"); //내용 입력 박스 클래스 삭제 | |
| 1395 | + $('.msg_com').addClass("msg_short"); // 장문 클래스 삽입 | |
| 1396 | + $("#subMsgType").val("SMS"); | |
| 1397 | + | |
| 1398 | + } | |
| 1399 | + | |
| 1400 | +} | |
| 1401 | + | |
| 1402 | +function msgSuccessClose(obj){ | |
| 1403 | + $(obj).closest('.pop_msg_success').attr('style',''); | |
| 1404 | + location.reload(true); | |
| 1405 | + $('html').scrollTop(0); | |
| 1406 | +} | |
| 1407 | + | |
| 1408 | +function getFtImageType(imgChk){ | |
| 1409 | + | |
| 1410 | + if(imgChk == 'I' || imgChk == 'W'){ | |
| 1411 | + | |
| 1412 | + var imgTitle = $("#imgTitle").val(); | |
| 1413 | + var imgLink = $("#imgLink").val(); | |
| 1414 | + var imgFileName = $("#imageFileName").val(); | |
| 1415 | + | |
| 1416 | + if(imgTitle == ''){ | |
| 1417 | + | |
| 1418 | + alert("친구톡 이미지 제목정보를 입력해 주세요."); | |
| 1419 | + return false; | |
| 1420 | + | |
| 1421 | + } | |
| 1422 | + | |
| 1423 | + if(imgLink == ''){ | |
| 1424 | + | |
| 1425 | + alert("친구톡 이미지 선택시 이동할 링크 주소를 입력해 주세요."); | |
| 1426 | + return false; | |
| 1427 | + | |
| 1428 | + } | |
| 1429 | + | |
| 1430 | + if(imgFileName == ''){ | |
| 1431 | + | |
| 1432 | + alert("친구톡 이미지를 등록해 주세요."); | |
| 1433 | + return false; | |
| 1434 | + | |
| 1435 | + } | |
| 1436 | + | |
| 1437 | + $("#imageType").val(imgChk); | |
| 1438 | + | |
| 1439 | + //json 파일 필요 유무 셋팅 | |
| 1440 | + $("#bizJsonYn").val("Y"); | |
| 1441 | + } | |
| 1442 | + | |
| 1443 | + return true; | |
| 1444 | + | |
| 1445 | +} | |
| 1446 | + | |
| 1447 | + | |
| 1448 | +function goToKakaoTestPopUp(){ | |
| 1449 | + | |
| 1450 | + if(loginVO == "" || loginVO == null){ | |
| 1451 | + alert("테스트 발송 서비스는 로그인 후 이용 가능합니다."); | |
| 1452 | + location.href="<c:url value='/web/user/login/login.do'/>"; | |
| 1453 | + return false; | |
| 1454 | + } | |
| 1455 | + | |
| 1456 | + //기업회원 체크 | |
| 1457 | + if(!usrDeptChk()){ | |
| 1458 | + return false; | |
| 1459 | + } | |
| 1460 | + | |
| 1461 | + var form = document.bizForm; | |
| 1462 | + var senderKey = $("#selectAgentCode option:checked").val(); | |
| 1463 | + var yellowId = $("#selectAgentCode option:checked").text(); | |
| 1464 | + | |
| 1465 | + if(senderKey == ''){ | |
| 1466 | + alert("채널ID를 선택해 주세요."); | |
| 1467 | + return false; | |
| 1468 | + }else{ | |
| 1469 | + $("#inputSenderKey").val(senderKey); | |
| 1470 | + $("#yellowId").val(yellowId); | |
| 1471 | + } | |
| 1472 | + | |
| 1473 | + var imgChk = $("input[name=img_file_add]:checked").val(); | |
| 1474 | + if(!getFtImageType(imgChk)){ | |
| 1475 | + return false; | |
| 1476 | + } | |
| 1477 | + | |
| 1478 | + //템플릿 버튼 갯수 체크 | |
| 1479 | + var buttonCnt = $(".btn_kakao_type").length; | |
| 1480 | + | |
| 1481 | + if(buttonCnt > 0){ | |
| 1482 | + //json 파일 필요 유무 셋팅 | |
| 1483 | + $("#bizJsonYn").val("Y"); | |
| 1484 | + } | |
| 1485 | + | |
| 1486 | + //친구톡 내용 체크 | |
| 1487 | + var tmpContents = $('#inputTemplateContent').val(); | |
| 1488 | + | |
| 1489 | + if(tmpContents == ""){ | |
| 1490 | + | |
| 1491 | + alert("친구톡 내용을 입력해 주세요."); | |
| 1492 | + return false; | |
| 1493 | + | |
| 1494 | + }else{ | |
| 1495 | + | |
| 1496 | + //템플릿 내용 입력 | |
| 1497 | + $("#templateContent").val(tmpContents); | |
| 1498 | + | |
| 1499 | + } | |
| 1500 | + | |
| 1501 | + var rtnStr = strChinJpnCheck(tmpContents); | |
| 1502 | + | |
| 1503 | + //문자내용에 이모지가 있는지 체크 | |
| 1504 | + if(!emojiCheck(tmpContents)) return false; | |
| 1505 | + | |
| 1506 | + if(rtnStr.length > 0){ | |
| 1507 | + | |
| 1508 | + alert("입력하신 문구 중 \" " + rtnStr + " \" 는 일부 휴대폰에서 표기되지 않을 수 있습니다."); | |
| 1509 | + | |
| 1510 | + } | |
| 1511 | + | |
| 1512 | + | |
| 1513 | + var selectedData = tableL.getRows(); | |
| 1514 | + | |
| 1515 | + if(selectedData == "" || selectedData == null){ | |
| 1516 | + | |
| 1517 | + alert("받는사람 주소를 한 건 이상 입력해주세요."); | |
| 1518 | + return false; | |
| 1519 | + | |
| 1520 | + }else{ | |
| 1521 | + | |
| 1522 | + //치환문구 변환 | |
| 1523 | + var txtReplYn = $("#txtReplYn").val(); | |
| 1524 | + | |
| 1525 | + if(txtReplYn == 'Y'){ | |
| 1526 | + | |
| 1527 | + var name = tableL.getRows()[0].getData().name; | |
| 1528 | + var phone = removeDash(tableL.getRows()[0].getData().phone); | |
| 1529 | + var rep1 = tableL.getRows()[0].getData().rep1; | |
| 1530 | + var rep2 = tableL.getRows()[0].getData().rep2; | |
| 1531 | + var rep3 = tableL.getRows()[0].getData().rep3; | |
| 1532 | + var rep4 = tableL.getRows()[0].getData().rep4; | |
| 1533 | + | |
| 1534 | + var varValList = []; //치환문자 연결시킬 변수 셋팅 | |
| 1535 | + | |
| 1536 | + | |
| 1537 | + var nmStatus = false; | |
| 1538 | + var rep1Status = false; | |
| 1539 | + var rep2Status = false; | |
| 1540 | + var rep3Status = false; | |
| 1541 | + var rep4Status = false; | |
| 1542 | + | |
| 1543 | + var varValStr = ""; | |
| 1544 | + var varValStatus = true; | |
| 1545 | + | |
| 1546 | + | |
| 1547 | + if(tmpContents.indexOf("\#{이름}") > -1){ | |
| 1548 | + nmStatus = true; | |
| 1549 | + } | |
| 1550 | + | |
| 1551 | + if(tmpContents.indexOf("\#{1}") > -1){ | |
| 1552 | + rep1Status = true; | |
| 1553 | + } | |
| 1554 | + | |
| 1555 | + if(tmpContents.indexOf("\#{2}") > -1){ | |
| 1556 | + rep2Status = true; | |
| 1557 | + } | |
| 1558 | + | |
| 1559 | + if(tmpContents.indexOf("\#{3}") > -1){ | |
| 1560 | + rep3Status = true; | |
| 1561 | + } | |
| 1562 | + | |
| 1563 | + if(tmpContents.indexOf("\#{4}") > -1){ | |
| 1564 | + rep4Status = true; | |
| 1565 | + } | |
| 1566 | + | |
| 1567 | + | |
| 1568 | + if(nmStatus && (typeof(name) != 'undefined' && name != null && name !="")){ | |
| 1569 | + | |
| 1570 | + if(varValStr == ''){ | |
| 1571 | + varValStr = name.replaceAll(",","§"); | |
| 1572 | + }else{ | |
| 1573 | + varValStr = varValStr + "¶" + name.replaceAll(",","§"); | |
| 1574 | + } | |
| 1575 | + | |
| 1576 | + }else{ | |
| 1577 | + | |
| 1578 | + if(nmStatus){ | |
| 1579 | + varValStatus = false; | |
| 1580 | + } | |
| 1581 | + | |
| 1582 | + } | |
| 1583 | + | |
| 1584 | + if(varValStr == ''){ | |
| 1585 | + varValStr = phone; | |
| 1586 | + }else{ | |
| 1587 | + varValStr = varValStr + "¶" + phone; | |
| 1588 | + } | |
| 1589 | + | |
| 1590 | + if(rep1Status && (typeof(rep1) != 'undefined' && rep1 != null && rep1 !="")){ | |
| 1591 | + | |
| 1592 | + if(varValStr == ''){ | |
| 1593 | + varValStr = rep1.replaceAll(",","§"); | |
| 1594 | + }else{ | |
| 1595 | + varValStr = varValStr + "¶" + rep1.replaceAll(",","§"); | |
| 1596 | + } | |
| 1597 | + | |
| 1598 | + }else{ | |
| 1599 | + | |
| 1600 | + if(rep1Status){ | |
| 1601 | + varValStatus = false; | |
| 1602 | + } | |
| 1603 | + | |
| 1604 | + } | |
| 1605 | + | |
| 1606 | + | |
| 1607 | + if(rep2Status && (typeof(rep2) != 'undefined' && rep2 != null && rep2 !="")){ | |
| 1608 | + | |
| 1609 | + if(varValStr == ''){ | |
| 1610 | + varValStr = rep2.replaceAll(",","§"); | |
| 1611 | + }else{ | |
| 1612 | + varValStr = varValStr + "¶" + rep2.replaceAll(",","§"); | |
| 1613 | + } | |
| 1614 | + | |
| 1615 | + }else{ | |
| 1616 | + | |
| 1617 | + if(rep2Status){ | |
| 1618 | + varValStatus = false; | |
| 1619 | + } | |
| 1620 | + | |
| 1621 | + } | |
| 1622 | + | |
| 1623 | + if(rep3Status && (typeof(rep3) != 'undefined' && rep3 != null && rep3 !="")){ | |
| 1624 | + | |
| 1625 | + if(varValStr == ''){ | |
| 1626 | + varValStr = rep3.replaceAll(",","§"); | |
| 1627 | + }else{ | |
| 1628 | + varValStr = varValStr + "¶" + rep3.replaceAll(",","§"); | |
| 1629 | + } | |
| 1630 | + | |
| 1631 | + }else{ | |
| 1632 | + | |
| 1633 | + if(rep3Status){ | |
| 1634 | + varValStatus = false; | |
| 1635 | + } | |
| 1636 | + | |
| 1637 | + } | |
| 1638 | + | |
| 1639 | + if(rep4Status && (typeof(rep4) != 'undefined' && rep4 != null && rep4 !="")){ | |
| 1640 | + | |
| 1641 | + if(varValStr == ''){ | |
| 1642 | + varValStr = rep4.replaceAll(",","§"); | |
| 1643 | + }else{ | |
| 1644 | + varValStr = varValStr + "¶" + rep4.replaceAll(",","§"); | |
| 1645 | + } | |
| 1646 | + | |
| 1647 | + }else{ | |
| 1648 | + | |
| 1649 | + if(rep4Status){ | |
| 1650 | + varValStatus = false; | |
| 1651 | + } | |
| 1652 | + | |
| 1653 | + } | |
| 1654 | + | |
| 1655 | + if(!varValStatus){ | |
| 1656 | + | |
| 1657 | + alert("특정문구 일괄변환에 대한 일부 데이터가 누락된 부분이 있습니다. 데이터를 확인해 주세요."); | |
| 1658 | + return false; | |
| 1659 | + | |
| 1660 | + } | |
| 1661 | + | |
| 1662 | + varValList[0] = varValStr; | |
| 1663 | + | |
| 1664 | + $("#varValList").val(varValList); | |
| 1665 | + } | |
| 1666 | + | |
| 1667 | + } | |
| 1668 | + | |
| 1669 | + form.method = "post"; | |
| 1670 | + window.open("about:blank", 'testSendPop', 'width=770, height=850, top=100, left=100, fullscreen=no, menubar=no, status=no, toolbar=no, titlebar=yes, location=no, scrollbars=1'); | |
| 1671 | + form.target = "testSendPop"; | |
| 1672 | + form.action = "/web/mjon/kakao/friendstalk/selectKakaoFriendsTalkTestSendPopup.do"; | |
| 1673 | + form.submit(); | |
| 1674 | +} | |
| 1675 | + | |
| 1676 | + | |
| 1677 | +function msgResultLink(){ | |
| 1678 | + var reserYn = $("input[name=reserYn]:checked").val(); // 예약 발송 여부 확인 | |
| 1679 | + if(reserYn == 'Y'){ | |
| 1680 | + | |
| 1681 | + location.href="/web/mjon/reservmsg/selectReservKaKaoView.do"; | |
| 1682 | + | |
| 1683 | + }else{ | |
| 1684 | + location.href="/web/kakao/sent/selectKakaoSentView.do"; | |
| 1685 | + } | |
| 1686 | +} | |
| 1687 | + | |
| 1688 | +</script> | |
| 1689 | + | |
| 1690 | +<!-- 로딩바 --> | |
| 1691 | +<div class="loading_layer"> | |
| 1692 | + <div class="loading_container"> | |
| 1693 | + <div class="bar"></div> | |
| 1694 | + <div class="text">Loading</div> | |
| 1695 | + </div> | |
| 1696 | +</div> | |
| 1697 | + | |
| 1698 | +<div class="inner"> | |
| 1699 | + <div class="send_top"> | |
| 1700 | + <!-- tab button --> | |
| 1701 | + <%@include file="/WEB-INF/jsp/web/kakao/include/KaKaoAlimtalkTopMenuTap.jsp" %> | |
| 1702 | + <!-- // tab button --> | |
| 1703 | + <div class="top_content kakaotalksend_cont current pay_tab_wrap"> | |
| 1704 | + <div class="heading"> | |
| 1705 | + <h2>친구톡 전송</h2> | |
| 1706 | + <button type="button" class="button info">친구톡 사용방법</button> | |
| 1707 | + </div> | |
| 1708 | + | |
| 1709 | + <!-- 유저 보유잔액 --> | |
| 1710 | + <input type="hidden" id="oriUserMoney" value="<c:out value='${userMoney}' />"> | |
| 1711 | + | |
| 1712 | + <!-- 각 금액 단가 --> | |
| 1713 | + <input type="hidden" id="kakaoFtPrice" value="<c:out value='${sendPrice.kakaoFtPrice}' />"> <!-- 친구톡 단가 --> | |
| 1714 | + <input type="hidden" id="longPrice" value="<c:out value='${sendPrice.longPrice}' />"> <!-- mms 단가 --> | |
| 1715 | + <input type="hidden" id="shortPrice" value="<c:out value='${sendPrice.shortPrice}' />"> <!-- sms 단가 --> | |
| 1716 | + | |
| 1717 | + <form id="bizForm" name="bizForm" method="multipart/form-data"> | |
| 1718 | + <input type="hidden" id="menuTopTab" name="menuTopTab" value="tabFriend"> | |
| 1719 | + <input type="hidden" id="imageType" name="imageType" value="<c:out value='${resultTemplateVO.imageType}'/>"/> | |
| 1720 | + <input type="hidden" id="inputSenderKey" name="senderKey" value="<c:out value='${resultTemplateVO.senderKey}'/>"/> | |
| 1721 | + <input type="hidden" id="imageFileName" name="imageFileName" value="<c:out value='${resultTemplateVO.imageFileName}'/>"> | |
| 1722 | + <input type="hidden" id="templateImageUrl" name="templateImageUrl" value="<c:out value='${resultTemplateVO.templateImageUrl}'/>"> | |
| 1723 | + <input type="hidden" id="tmpFriendId" name="friendId" value="<c:out value='${resultTemplateVO.friendId}'/>"> | |
| 1724 | + <input type="hidden" id="templateName" name="templateName" value=""/> | |
| 1725 | + <input type="hidden" id="adFlag" name="adFlag" value="N"/> | |
| 1726 | + <input type="hidden" id="templateContent" name="templateContent" value=""/> | |
| 1727 | + | |
| 1728 | + <!-- 예약발송 여부 --> | |
| 1729 | + <input type="hidden" id="reserveYn" name="reserveYn" value="N"/> | |
| 1730 | + <input type="hidden" id="reqDate" name="reqDate" value=""/> | |
| 1731 | + | |
| 1732 | + <!-- 변환문자 유무 --> | |
| 1733 | + <input type="hidden" id="txtReplYn" name="txtReplYn" value="N"/> | |
| 1734 | + <input type="hidden" id="varValList" name="varValList" value=""/> | |
| 1735 | + | |
| 1736 | + <!-- 수신목록 --> | |
| 1737 | + <input type="hidden" id="callToList" name="callToList" value=""/> | |
| 1738 | + | |
| 1739 | + <!-- 스팸 문구 유무 --> | |
| 1740 | + <input type="hidden" id="spamStatus" name="spamStatus" value="N"/> | |
| 1741 | + <input type="hidden" id="atSmishingYn" name="atSmishingYn" value="<c:out value='${atSmishingYn}' />"/> | |
| 1742 | + | |
| 1743 | + <!-- 오류 체크 --> | |
| 1744 | + <input type="hidden" id="errorChk" name="errorChk" value="N"/> | |
| 1745 | + | |
| 1746 | + <!-- 대체문자 여부 --> | |
| 1747 | + <input type="hidden" id="subMsgSendYn" name="subMsgSendYn" value="N"/> | |
| 1748 | + <input type="hidden" id="subMsgType" name="subMsgType" value="SMS"/> | |
| 1749 | + <input type="hidden" id="subMsgTxtReplYn" name="subMsgTxtReplYn" value="N"/> | |
| 1750 | + <input type="hidden" id="subMsgTxt" name="subMsgTxt" value=""/> | |
| 1751 | + | |
| 1752 | + <!-- 발신번호정보 --> | |
| 1753 | + <input type="hidden" id="callFrom" name="callFrom" value=""/> | |
| 1754 | + | |
| 1755 | + <!-- 친구톡 발송 단가 정보 --> | |
| 1756 | + <input type="hidden" id="kakaoFtPrice" name="kakaoFtPrice" value="<c:out value='${sendPrice.kakaoFtPrice}' />"/> | |
| 1757 | + <input type="hidden" id="eachPrice" name="eachPrice" value="0"/> | |
| 1758 | + <input type="hidden" id="totPrice" name="totalPrice" value="0"/> | |
| 1759 | + | |
| 1760 | + <!-- 친구톡 발송 json 파일 필요 유무 --> | |
| 1761 | + <input type="hidden" id="bizJsonYn" name="bizJsonYn" value="N"/> | |
| 1762 | + | |
| 1763 | + <input type="hidden" id="yellowId" name="yellowId" value=""/> | |
| 1764 | + | |
| 1765 | + | |
| 1766 | + <div class="send_general friend_talk_wrap kakao_wrap"> | |
| 1767 | + <div class="send_left"> | |
| 1768 | + <table class="tType1"> | |
| 1769 | + <colgroup> | |
| 1770 | + <col style="width: 130px;"> | |
| 1771 | + <col style="width: auto;"> | |
| 1772 | + </colgroup> | |
| 1773 | + <tbody> | |
| 1774 | + <tr> | |
| 1775 | + <th>채널ID</th> | |
| 1776 | + <td> | |
| 1777 | + <label for="selectAgentCode" class="채널ID 선택"></label> | |
| 1778 | + <select class="select_gray_type" name="selectAgentCode" id="selectAgentCode" onchange="javascript:fnAgentCodeChg();"> | |
| 1779 | + <option value="">채널ID 선택</option> | |
| 1780 | + <c:forEach var="kakaoProfileInfo" items="${resultProfileList}" varStatus="status"> | |
| 1781 | + <option value="${kakaoProfileInfo.senderKey}" <c:if test="${kakaoProfileInfo.senderKey eq resultTemplateVO.senderKey}">selected</c:if> ><c:out value='${kakaoProfileInfo.yellowId}'/></option> | |
| 1782 | + </c:forEach> | |
| 1783 | + </select> | |
| 1784 | + </td> | |
| 1785 | + </tr> | |
| 1786 | + <tr> | |
| 1787 | + <th>템플릿명</th> | |
| 1788 | + <td> | |
| 1789 | + <input type="text" class="template_name" id="inputTemplateName" name="inputTemplateName" value="<c:out value='${resultTemplateVO.templateName}'/>" placeholder="템플릿명을 입력해주세요. (최대 50자)"> | |
| 1790 | + <p class="template_name_cf">최대 50자, 템플릿 관리용</p> | |
| 1791 | + </td> | |
| 1792 | + </tr> | |
| 1793 | + <tr> | |
| 1794 | + <th>이미지 첨부</th> | |
| 1795 | + <td> | |
| 1796 | + <div class="img_sort_wrap"> | |
| 1797 | + <input type="radio" name="img_file_add" id="img_file_0" value="" <c:if test="${resultTemplateVO.imageType eq ''}">checked</c:if> > <label for="img_file_0">첨부안함</label> | |
| 1798 | + <input type="radio" name="img_file_add" id="img_file_1" value="I" <c:if test="${resultTemplateVO.imageType eq 'I'}">checked</c:if> > <label for="img_file_1">이미지 첨부</label> | |
| 1799 | + <input type="radio" name="img_file_add" id="img_file_2" value="W" <c:if test="${resultTemplateVO.imageType eq 'W'}">checked</c:if> > <label for="img_file_2">와이드 이미지 첨부</label> | |
| 1800 | + <div class="img_add_info_wrap basic_img_add_wrap"> | |
| 1801 | + <p class="info_title_text"><span class="c_e40000">*</span> 이미지 첨부 안내</p> | |
| 1802 | + <ul class="info_text"> | |
| 1803 | + <li>- 권장사이즈 : 720px * 720px</li> | |
| 1804 | + <li>- 제한사이즈 : 가로 500px 미만, 가로:세로 비율이 2:1 미만 또는 3:4 초과시 업로드 불가</li> | |
| 1805 | + <li>- 파일형식 : jpg, png (최대 500kb)</li> | |
| 1806 | + <li>- 이미지 첨부시 메시지 내용은 최대 400자까지 입력할 수 있습니다.</li> | |
| 1807 | + </ul> | |
| 1808 | + </div> | |
| 1809 | + <div class="img_add_info_wrap wide_img_add_wrap"> | |
| 1810 | + <p class="info_title_text"><span class="c_e40000">*</span> 와이드 이미지 첨부 안내</p> | |
| 1811 | + <ul class="info_text"> | |
| 1812 | + <li>- 권장사이즈 : 800px * 600px</li> | |
| 1813 | + <!-- <li>- 제한사이즈 : 가로 500px 미만, 가로:세로 비율이 2:1 미만 또는 3:4 초과시 업로드 불가</li> --> | |
| 1814 | + <li>- 파일형식 : jpg, png (최대 2mb)</li> | |
| 1815 | + <li>- 와이드 이미지 첨부시 메시지 내용은 최대 76자, 버튼 1개까지 입력할 수 있습니다.</li> | |
| 1816 | + </ul> | |
| 1817 | + </div> | |
| 1818 | + </div> | |
| 1819 | + <div class="img_file_add_wrap"> | |
| 1820 | + <ul class="img_file_info_wrap"> | |
| 1821 | + <li> | |
| 1822 | + <p>이미지 제목</p> | |
| 1823 | + <input type="text" id="imgTitle" name="imgTitle" value="<c:out value='${resultTemplateVO.imgTitle}'/>" class="img_url" maxLength="50"> | |
| 1824 | + </li> | |
| 1825 | + <li> | |
| 1826 | + <p>이미지 클릭시 이동할 URL</p> | |
| 1827 | + <input type="text" id="imgLink" name="imgLink" value="<c:out value='${resultTemplateVO.imgLink}'/>" placeholder="http://" class="img_url" maxLength="1000"> | |
| 1828 | + </li> | |
| 1829 | + <li> | |
| 1830 | + <p class="file_name" id="imgNm" name="imgNm">첨부파일 이미지</p> | |
| 1831 | + <button type="button" class="btn_del btnImgDel" onclick="buttonTypeDel(this);"> | |
| 1832 | + <img src="/publish/images/btn_delete.png" id="imgDel" alt="이미지 삭제" onclick="fnImageDel();"> | |
| 1833 | + </button> | |
| 1834 | + </li> | |
| 1835 | + </ul> | |
| 1836 | + <button type="button" class="btnType btnType8 btn_img_upload" title="이미지 불러오기" onclick="javascript:upImgClick(); return false;">이미지 불러오기</button> | |
| 1837 | + <input type="file" id="imgFile" accept=".jpg, .jpeg, .png" onchange="imgResizeInfo(event); return false;" style="display:none"/> | |
| 1838 | + </div> | |
| 1839 | + </td> | |
| 1840 | + </tr> | |
| 1841 | + <tr> | |
| 1842 | + <th>광고포함 여부</th> | |
| 1843 | + <td> | |
| 1844 | + <input type="radio" class="inputAdFlag" name="ad_flag" id="ad_Y" value="Y" <c:if test="${resultTemplateVO.adFlag eq 'Y'}">checked</c:if> ><label for="ad_Y">광고성 정보 포함</label> | |
| 1845 | + <%-- <input type="radio" class="inputAdFlag" name="ad_flag" id="ad_N" value="N" <c:if test="${resultTemplateVO.adFlag eq 'N'}">checked</c:if> ><label for="ad_N">포함 안함</label> --%> | |
| 1846 | + </td> | |
| 1847 | + </tr> | |
| 1848 | + <tr> | |
| 1849 | + <th>내용</th> | |
| 1850 | + <td class="kakao_template_text"> | |
| 1851 | + <div class="put_left short"> | |
| 1852 | + <div class="put_text_wrap"> | |
| 1853 | + <div class="ad_txt"> | |
| 1854 | + <p><span id="adFlagFront">(광고)</span> <span id="yellowIdCon" >채널ID</span></p> | |
| 1855 | + </div> | |
| 1856 | + <label for="inputTemplateContent" class="label"></label> | |
| 1857 | + <textarea id="inputTemplateContent" name="inputTemplateContent" class="put_text" placeholder="내용을 입력해주세요."><c:out value="${resultTemplateVO.templateContent}"/></textarea> | |
| 1858 | + <div class="text_length"> | |
| 1859 | + <div> | |
| 1860 | + <p class="adFlagAfter">수신거부 : 홈 > 채널차단</p> | |
| 1861 | + </div> | |
| 1862 | + <div> | |
| 1863 | + <p><span class="fwMd nowChar">0 /</span><span class="c_002c9a fwMd totChar">1000</span>자</p> | |
| 1864 | + </div> | |
| 1865 | + </div> | |
| 1866 | + </div> | |
| 1867 | + </div> | |
| 1868 | + <div class="put_right"> | |
| 1869 | + <div class="btn_popup_wrap"> | |
| 1870 | + <button type="button" class="btnType btnType7" onclick="miniPopup(this)">특수문자</button> | |
| 1871 | + <div class="send_miniPop spc_character"> | |
| 1872 | + <div class="tab_character"> | |
| 1873 | + <a href="#none" class="on">특수문자</a> | |
| 1874 | + <a href="#none">웃음</a> | |
| 1875 | + <a href="#none">슬픔</a> | |
| 1876 | + <a href="#none">분노</a> | |
| 1877 | + <a href="#none">사랑</a> | |
| 1878 | + <a href="#none">그외</a> | |
| 1879 | + </div> | |
| 1880 | + <!-- 특수문자 --> | |
| 1881 | + <div class="cnt_character on"> | |
| 1882 | + <div class="box_character"> | |
| 1883 | + <c:forEach var="symbolList" items="${symbolList}" varStatus="status"> | |
| 1884 | + <c:if test="${symbolList.symbolType == 'D'}"> | |
| 1885 | + <a href="javascript:void(0)" class="symbolButton" value="${symbolList.symbol}"><c:out value="${symbolList.symbol}"/></a> | |
| 1886 | + </c:if> | |
| 1887 | + </c:forEach> | |
| 1888 | + </div> | |
| 1889 | + </div> | |
| 1890 | + <!-- //특수문자 --> | |
| 1891 | + | |
| 1892 | + <!-- 웃음 --> | |
| 1893 | + <div class="cnt_character emt_character"> | |
| 1894 | + <div class="box_character"> | |
| 1895 | + <c:forEach var="symbolList" items="${symbolList}" varStatus="status"> | |
| 1896 | + <c:if test="${symbolList.symbolType == 'S'}"> | |
| 1897 | + <a href="javascript:void(0)" class="symbolButton" value="${symbolList.symbol}">${symbolList.symbol}</a> | |
| 1898 | + </c:if> | |
| 1899 | + </c:forEach> | |
| 1900 | + </div> | |
| 1901 | + </div> | |
| 1902 | + <!-- //웃음 --> | |
| 1903 | + | |
| 1904 | + <!-- 슬픔 --> | |
| 1905 | + <div class="cnt_character emt_character"> | |
| 1906 | + <div class="box_character"> | |
| 1907 | + <c:forEach var="symbolList" items="${symbolList}" varStatus="status"> | |
| 1908 | + <c:if test="${symbolList.symbolType == 'C'}"> | |
| 1909 | + <a href="javascript:void(0)" class="symbolButton" value="${symbolList.symbol}">${symbolList.symbol}</a> | |
| 1910 | + </c:if> | |
| 1911 | + </c:forEach> | |
| 1912 | + </div> | |
| 1913 | + </div> | |
| 1914 | + <!-- //슬픔 --> | |
| 1915 | + | |
| 1916 | + <!-- 분노 --> | |
| 1917 | + <div class="cnt_character emt_character"> | |
| 1918 | + <div class="box_character"> | |
| 1919 | + <c:forEach var="symbolList" items="${symbolList}" varStatus="status"> | |
| 1920 | + <c:if test="${symbolList.symbolType == 'A'}"> | |
| 1921 | + <a href="javascript:void(0)" class="symbolButton" value="${symbolList.symbol}">${symbolList.symbol}</a> | |
| 1922 | + </c:if> | |
| 1923 | + </c:forEach> | |
| 1924 | + </div> | |
| 1925 | + </div> | |
| 1926 | + <!-- //분노 --> | |
| 1927 | + | |
| 1928 | + <!-- 사랑 --> | |
| 1929 | + <div class="cnt_character emt_character"> | |
| 1930 | + <div class="box_character"> | |
| 1931 | + <c:forEach var="symbolList" items="${symbolList}" varStatus="status"> | |
| 1932 | + <c:if test="${symbolList.symbolType == 'L'}"> | |
| 1933 | + <a href="javascript:void(0)" class="symbolButton" value="${symbolList.symbol}">${symbolList.symbol}</a> | |
| 1934 | + </c:if> | |
| 1935 | + </c:forEach> | |
| 1936 | + </div> | |
| 1937 | + </div> | |
| 1938 | + <!-- //사랑 --> | |
| 1939 | + | |
| 1940 | + <!-- 그외 --> | |
| 1941 | + <div class="cnt_character emt_character emt_etc "> | |
| 1942 | + <div class="box_character"> | |
| 1943 | + <c:forEach var="symbolList" items="${symbolList}" varStatus="status"> | |
| 1944 | + <c:if test="${symbolList.symbolType == 'E'}"> | |
| 1945 | + <a href="javascript:void(0)" class="symbolButton" value="${symbolList.symbol}">${symbolList.symbol}</a> | |
| 1946 | + </c:if> | |
| 1947 | + </c:forEach> | |
| 1948 | + </div> | |
| 1949 | + </div> | |
| 1950 | + <!-- //그외 --> | |
| 1951 | + <button type="button" class="btn_close" onclick="miniPopup(this)">닫기</button> | |
| 1952 | + </div> | |
| 1953 | + </div> | |
| 1954 | + <div class="btn_popup_wrap convers_wrap"> | |
| 1955 | + <button type="button" class="btnType btnType7" onclick="miniPopup(this)">특정문구 일괄변환<i class="qmMark"></i></button> | |
| 1956 | + <div class="send_miniPop convers"> | |
| 1957 | + <div> | |
| 1958 | + <div class="convers_top"> | |
| 1959 | + <span>특정문구 일괄변환이란?</span> | |
| 1960 | + <p>주소록, 엑셀에 입력된 내용을 이용해 수신자마다 다른 내용의 메시지를 발송하는 기능</p> | |
| 1961 | + </div> | |
| 1962 | + <div class="convers_middle"> | |
| 1963 | + <a href="javascript:void(0)" class="changeWord" value="\#{이름}"><c:out value="\#{이름}"/></a> | |
| 1964 | + </div> | |
| 1965 | + <div class="convers_bottom"> | |
| 1966 | + <a href="javascript:void(0)" class="changeWord" value="\#{1}"><c:out value="\#{1}"/></a> | |
| 1967 | + <a href="javascript:void(0)" class="changeWord" value="\#{2}"><c:out value="\#{2}"/></a> | |
| 1968 | + <a href="javascript:void(0)" class="changeWord" value="\#{3}"><c:out value="\#{3}"/></a> | |
| 1969 | + <a href="javascript:void(0)" class="changeWord" value="\#{4}"><c:out value="\#{4}"/></a> | |
| 1970 | + </div> | |
| 1971 | + </div> | |
| 1972 | + <button type="button" class="btn_close" onclick="miniPopup(this)">닫기</button> | |
| 1973 | + </div> | |
| 1974 | + </div> | |
| 1975 | + <div class="btn_popup_wrap spc_wrap"> | |
| 1976 | + <button type="button" class="btnType btnType7" onclick="miniPopup(this)">이모티콘</button> | |
| 1977 | + <div class="send_miniPop spc_character kakao_emoticon"> | |
| 1978 | + <%@include file="/WEB-INF/jsp/web/kakao/include/KakaoSentImoticonInfo.jsp" %> | |
| 1979 | + <button type="button" class="btn_close" onclick="miniPopup(this)">닫기</button> | |
| 1980 | + </div> | |
| 1981 | + </div> | |
| 1982 | + <div class="btn_popup_wrap template_call_wrap"> | |
| 1983 | + <c:choose> | |
| 1984 | + <c:when test="${not empty loginVO.id}"> | |
| 1985 | + <button type="button" class="btnType btnType8" onclick="window.open('/web/mjon/kakao/template/selectKakaoFriendsTemplateListPopupAjax.do','_blank','width=930, height=780, top=100, left=100, fullscreen=no, menubar=no, status=no, toolbar=no, titlebar=yes, location=no, scrollbars=yes')">템플릿 불러오기</button> | |
| 1986 | + </c:when> | |
| 1987 | + <c:otherwise> | |
| 1988 | + <button type="button" class="btnType btnType8" onclick="javascript:fnEmptyId();">템플릿 불러오기</button> | |
| 1989 | + </c:otherwise> | |
| 1990 | + </c:choose> | |
| 1991 | + </div> | |
| 1992 | + <div class="send_btnWrap"> | |
| 1993 | + <c:choose> | |
| 1994 | + <c:when test="${not empty loginVO.id}"> | |
| 1995 | + <button type="button" class="btnType btn_text_save" onclick="javascript:myTemplateSave();">내용 저장하기</button> | |
| 1996 | + </c:when> | |
| 1997 | + <c:otherwise> | |
| 1998 | + <button type="button" class="btnType btn_text_save" onclick="javascript:fnEmptyId();">내용 저장하기</button> | |
| 1999 | + </c:otherwise> | |
| 2000 | + </c:choose> | |
| 2001 | + | |
| 2002 | + <button type="button" class="btnType btnType9" onclick="javascript:fnContentsReset();">초기화</button> | |
| 2003 | + </div> | |
| 2004 | + </div> | |
| 2005 | + </td> | |
| 2006 | + </tr> | |
| 2007 | + <tr> | |
| 2008 | + <th>버튼</th> | |
| 2009 | + <td class="template_button"> | |
| 2010 | + <select name="tmpBtnSelect" id="tmpBtnSelect" class="select_gray_type template_button_select"> | |
| 2011 | + <option value="button_type_0">버튼타입 선택</option> | |
| 2012 | + <option value="button_type_1">배송조회</option> | |
| 2013 | + <option value="button_type_2">웹링크</option> | |
| 2014 | + <option value="button_type_3">앱링크</option> | |
| 2015 | + <option value="button_type_5">메시지전달</option> | |
| 2016 | + </select> | |
| 2017 | + <button type="button" class="btnType btnType6" onclick="friendTemplateButtonAdd();">추가</button> | |
| 2018 | + <p class="cf_text fwRg"> | |
| 2019 | + <span class="c_e40000 fwBold">*</span> 버튼 타입중 <span class="c_e40000">봇키워드, 메시지전달</span>은 <span class="c_222">카카오톡 채널 관리자센터(https://center-pf.kakao.com)</span>에서 설정을 직접 한 후 이용하셔야 동작합니다. (최대 5개까지 등록가능) | |
| 2020 | + </p> | |
| 2021 | + <div class="button_add_wrap"> | |
| 2022 | + <c:forEach var="buttonList" items="${resultTemplateVO.buttonVOList}" varStatus="status"> | |
| 2023 | + | |
| 2024 | + <c:if test="${buttonList.linkType eq 'DS'}"> | |
| 2025 | + <!-- 배송조회 버튼 --> | |
| 2026 | + <dl class="button_type_wrap type1"> | |
| 2027 | + <dt>배송조회</dt> | |
| 2028 | + <dd class="button_type_input"> | |
| 2029 | + <input type="hidden" id="buttonLikeTypeDeliv" name="buttonVOList[${status.index}].linkType" value="DS"/> | |
| 2030 | + <input type="text" id="btnNmDeliv" name="buttonVOList[${status.index}].name" value="<c:out value='${buttonList.name}'/>" placeholder="버튼명 입력(최대 14자)"> | |
| 2031 | + <p class="cf_text">*이용가능 택배사 : KG로지스, 우체국택배,일양로지스, GTX로지스, FedEx, 경동택배, 합동택배, 롯데택배</p> | |
| 2032 | + </dd> | |
| 2033 | + <dd> | |
| 2034 | + <button type="button" class="btn_del" onclick="buttonTypeDel(this);"><img src="/publish/images/btn_delete.png" alt=""></button> | |
| 2035 | + </dd> | |
| 2036 | + </dl> | |
| 2037 | + </c:if> | |
| 2038 | + | |
| 2039 | + <c:if test="${buttonList.linkType eq 'WL'}"> | |
| 2040 | + <!-- 웹링크 버튼 --> | |
| 2041 | + <dl class="button_type_wrap type2"> | |
| 2042 | + <dt>웹링크</dt> | |
| 2043 | + <dd class="button_type_input"> | |
| 2044 | + <ul> | |
| 2045 | + <li> | |
| 2046 | + <input type="hidden" id="buttonLikeTypeWeb" name="buttonVOList[${status.index}].linkType" value="WL"/> | |
| 2047 | + <input type="text" id="btnNmWeb" name="buttonVOList[${status.index}].name" value="<c:out value='${buttonList.name}'/>" placeholder="버튼명 입력(최대 14자)"> | |
| 2048 | + </li> | |
| 2049 | + <li> | |
| 2050 | + <input type="text" id="buttonLinkMo" name="buttonVOList[${status.index}].linkMo" value="<c:out value='${buttonList.linkMo}'/>" placeholder="모바일 링크 입력"> | |
| 2051 | + </li> | |
| 2052 | + <li> | |
| 2053 | + <input type="text" id="buttonLinkPc" name="buttonVOList[${status.index}].linkPc" value="<c:out value='${buttonList.linkPc}'/>" placeholder="PC 링크 입력"> | |
| 2054 | + </li> | |
| 2055 | + </ul> | |
| 2056 | + </dd> | |
| 2057 | + <dd> | |
| 2058 | + <button type="button" class="btn_del" onclick="buttonTypeDel(this);"><img src="/publish/images/btn_delete.png" alt=""></button> | |
| 2059 | + </dd> | |
| 2060 | + </dl> | |
| 2061 | + </c:if> | |
| 2062 | + | |
| 2063 | + <c:if test="${buttonList.linkType eq 'AL'}"> | |
| 2064 | + <!-- 앱링크 버튼 --> | |
| 2065 | + <dl class="button_type_wrap type3"> | |
| 2066 | + <dt>앱링크</dt> | |
| 2067 | + <dd class="button_type_input"> | |
| 2068 | + <ul> | |
| 2069 | + <li> | |
| 2070 | + <input type="hidden" id="buttonLikeTypeApp" name="buttonVOList[${status.index}].linkType" value="AL"/> | |
| 2071 | + <input type="text" id="btnNmApp" name="buttonVOList[${status.index}].name" value="<c:out value='${buttonList.name}'/>" placeholder="버튼명 입력(최대 14자)"> | |
| 2072 | + </li> | |
| 2073 | + <li> | |
| 2074 | + <input type="text" id="buttonLinkAnd" name="buttonVOList[${status.index}].linkAnd" value="<c:out value='${buttonList.linkAnd}'/>" placeholder="Android 링크 입력"> | |
| 2075 | + </li> | |
| 2076 | + <li> | |
| 2077 | + <input type="text" id="buttonLinkIos" name="buttonVOList[${status.index}].linkIos" value="<c:out value='${buttonList.linkIos}'/>" placeholder="IOS 링크 입력"> | |
| 2078 | + </li> | |
| 2079 | + </ul> | |
| 2080 | + </dd> | |
| 2081 | + <dd> | |
| 2082 | + <button type="button" class="btn_del" onclick="buttonTypeDel(this);"><img src="/publish/images/btn_delete.png" alt=""></button> | |
| 2083 | + </dd> | |
| 2084 | + </dl> | |
| 2085 | + </c:if> | |
| 2086 | + | |
| 2087 | + <c:if test="${buttonList.linkType eq 'BK'}"> | |
| 2088 | + <!-- 봇키워드 --> | |
| 2089 | + <dl class="button_type_wrap type4"> | |
| 2090 | + <dt>봇키워드</dt> | |
| 2091 | + <dd class="button_type_input"> | |
| 2092 | + <input type="hidden" id="buttonLikeTypeBot" name="buttonVOList[${status.index}].linkType" value="BK"/> | |
| 2093 | + <input type="text" id="btnNmBot" name="buttonVOList[${status.index}].name" value="<c:out value='${buttonList.name}'/>" placeholder="버튼명 입력(최대 14자)"> | |
| 2094 | + </dd> | |
| 2095 | + <dd><button type="button" class="btn_del" onclick="buttonTypeDel(this);"><img src="/publish/images/btn_delete.png" alt=""></button></dd> | |
| 2096 | + </dl> | |
| 2097 | + </c:if> | |
| 2098 | + | |
| 2099 | + <c:if test="${buttonList.linkType eq 'MD'}"> | |
| 2100 | + <!-- 메시지 전달 --> | |
| 2101 | + <dl class="button_type_wrap type5"> | |
| 2102 | + <dt>메시지전달</dt> | |
| 2103 | + <dd class="button_type_input"> | |
| 2104 | + <input type="hidden" id="buttonLikeTypeMsg" name="buttonVOList[${status.index}].linkType" value="MD" /> | |
| 2105 | + <input type="text" id="btnNmMsg" name="buttonVOList[${status.index}].name" value="<c:out value='${buttonList.name}'/>" placeholder="버튼명 입력(최대 14자)"> | |
| 2106 | + </dd> | |
| 2107 | + <dd> | |
| 2108 | + <button type="button" class="btn_del" onclick="buttonTypeDel(this);"> | |
| 2109 | + <img src="/publish/images/btn_delete.png" alt=""> | |
| 2110 | + </button> | |
| 2111 | + </dd> | |
| 2112 | + </dl> | |
| 2113 | + </c:if> | |
| 2114 | + | |
| 2115 | + <c:if test="${buttonList.linkType eq 'BC'}"> | |
| 2116 | + <!-- 상담톡 전환 --> | |
| 2117 | + <dl class="button_type_wrap type6"> | |
| 2118 | + <dt>상담톡전환</dt> | |
| 2119 | + <dd class="button_type_input"> | |
| 2120 | + <input type="hidden" id="buttonLikeTypeCons" name="buttonVOList[${status.index}].linkType" value="BC" /> | |
| 2121 | + <input type="text" id="btnNmCons" name="buttonVOList[${status.index}].name" value="<c:out value='${buttonList.name}'/>" placeholder="버튼명 입력(최대 14자)"> | |
| 2122 | + </dd> | |
| 2123 | + <dd> | |
| 2124 | + <button type="button" class="btn_del" onclick="buttonTypeDel(this);"> | |
| 2125 | + <img src="/publish/images/btn_delete.png" alt=""> | |
| 2126 | + </button> | |
| 2127 | + </dd> | |
| 2128 | + </dl> | |
| 2129 | + </c:if> | |
| 2130 | + | |
| 2131 | + <c:if test="${buttonList.linkType eq 'BT'}"> | |
| 2132 | + <!-- 챗봇전환 --> | |
| 2133 | + <dl class="button_type_wrap type7"> | |
| 2134 | + <dt>챗봇전환</dt> | |
| 2135 | + <dd class="button_type_input"> | |
| 2136 | + <input type="hidden" id="buttonLikeTypeBotChg" name="buttonVOList[${status.index}].linkType" value="BT" /> | |
| 2137 | + <input type="text" id="btnNmBotChg" name="buttonVOList[${status.index}].name" value="" placeholder="버튼명 입력(최대 14자)"> | |
| 2138 | + </dd> | |
| 2139 | + <dd> | |
| 2140 | + <button type="button" class="btn_del" onclick="buttonTypeDel(this);"> | |
| 2141 | + <img src="/publish/images/btn_delete.png" alt=""> | |
| 2142 | + </button> | |
| 2143 | + </dd> | |
| 2144 | + </dl> | |
| 2145 | + </c:if> | |
| 2146 | + </c:forEach> | |
| 2147 | + </div> | |
| 2148 | + </td> | |
| 2149 | + </tr> | |
| 2150 | + <tr> | |
| 2151 | + <th>받는사람</th> | |
| 2152 | + <td class="putText"> | |
| 2153 | + <div class="clearfix receipt_num"> | |
| 2154 | + <div class="receipt_num_top"> | |
| 2155 | + <label for="callTo" class="label">받는 번호입력</label> | |
| 2156 | + <input type="text" placeholder="번호를 입력하세요" id="callTo" name="callTo" onfocus="this.placeholder=''" onblur="this.placeholder='번호를 입력하세요'" style="width:340px;"> | |
| 2157 | + <button type="button" class="btnType btnType6 addCallToF">번호추가</button> | |
| 2158 | + <span><span class="vMiddle">*</span> 중복번호는 한번만 발송됩니다.</span> | |
| 2159 | + </div> | |
| 2160 | + <div class="receipt_num_midde"> | |
| 2161 | + <div class="listType list01 callList_box" id="callList_box"> | |
| 2162 | + <div class="list_table list_head"> | |
| 2163 | + <div class="cb_wrap"> | |
| 2164 | + <label for="select_all" class="label"></label> | |
| 2165 | + <input type="checkbox" id="select_all"> | |
| 2166 | + </div> | |
| 2167 | + <div class="list_table_num"> | |
| 2168 | + <p>휴대폰</p> | |
| 2169 | + <img src="/publish/images/sortUp.png"> | |
| 2170 | + <img src="/publish/images/sortDown.png"> | |
| 2171 | + </div> | |
| 2172 | + <div class="list_table_name"> | |
| 2173 | + <p>이름</p> | |
| 2174 | + <img src="/publish/images/sortUp.png"> | |
| 2175 | + <img src="/publish/images/sortDown.png"> | |
| 2176 | + </div> | |
| 2177 | + </div> | |
| 2178 | + <div class="list_body_wrap" id="wrap01_body"> | |
| 2179 | + </div> | |
| 2180 | + </div> | |
| 2181 | + <div class="put_right"> | |
| 2182 | + <div class="btn_popup_wrap spc_wrap"> | |
| 2183 | + <button type="button" data-tooltip="popup06" class="btnType btnType7 popupAddr">주소록 불러오기</button> | |
| 2184 | + </div> | |
| 2185 | + <div class="btn_popup_wrap"> | |
| 2186 | + <button type="button" data-tooltip="popup02" class="btnType btnType7">엑셀 불러오기</button> | |
| 2187 | + </div> | |
| 2188 | + <div class="btn_popup_wrap"> | |
| 2189 | + <button type="button" data-tooltip="popup03" class="btnType btnType7 tab1">최근 전송내역</button> | |
| 2190 | + </div> | |
| 2191 | + <div class="btn_popup_wrap"> | |
| 2192 | + <button type="button" data-tooltip="popup03" class="btnType btnType7 tab2">자주보내는 번호</button> | |
| 2193 | + </div> | |
| 2194 | + <div class="btn_popup_wrap check_validity_wrap"> | |
| 2195 | + <button type="button" class="btnType btnType7 check_validity">오류 검사<i class="qmMark error_qm"></i></button> | |
| 2196 | + <div class="error_hover_cont send_hover_cont"> | |
| 2197 | + <p>휴대폰 번호 입력 시 해당 휴대폰 번호에 대한 형식이 어긋나거나 휴대폰 번호에 오류가 있는지 등을 검사하는 기능</p> | |
| 2198 | + <span>(예시) 010-1234-0001(O) / 010-12345-0001(X)</span> | |
| 2199 | + </div> | |
| 2200 | + </div> | |
| 2201 | + </div> | |
| 2202 | + </div> | |
| 2203 | + <div class="list_bottom clearfix"> | |
| 2204 | + <div class="remove_btnWrap"> | |
| 2205 | + <button type="button" class="btnType15 all_del"><i class="remove_img"></i>전체삭제</button> | |
| 2206 | + <button type="button" class="btnType15 select_del"><i class="remove_img"></i>선택삭제</button> | |
| 2207 | + </div> | |
| 2208 | + <div class="list_bottom_right"> | |
| 2209 | + <p>총 <span class="c_e40000" id="rowTotCnt">0</span>건 / 중복 <span class="c_002c9a" id="rowDupCnt">0</span>건</p> | |
| 2210 | +<!-- <button type="button" class="address_reg2">주소록에 등록</button> --> | |
| 2211 | + </div> | |
| 2212 | + </div> | |
| 2213 | + </div> | |
| 2214 | + </td> | |
| 2215 | + </tr> | |
| 2216 | + <tr> | |
| 2217 | + <th colspan="2" class="billingAmount"> | |
| 2218 | + <div> | |
| 2219 | + <div class="final_pay"> | |
| 2220 | + <div class="pay_info_list"> | |
| 2221 | + <p>발송금액 :</p> | |
| 2222 | + <div class="info" id="repPriceTxt" style="display: none;"> | |
| 2223 | + 단문 : <strong>20</strong>건<span>/</span>장문 : | |
| 2224 | + <strong>150</strong>건<span>/</span>그림문자 : | |
| 2225 | + <strong>30</strong>건 | |
| 2226 | + </div> | |
| 2227 | + </div> | |
| 2228 | + <p class="price"><span id="repPriceTxt"></span><span id="totalPriceTxt">0</span> 원<span></span></p> | |
| 2229 | + </div> | |
| 2230 | + <div class="pay_type clearfix"> | |
| 2231 | + <div> | |
| 2232 | + <input type="radio" id="radio_bill_1" name="radio_bill" checked="checked"> | |
| 2233 | + <label for="radio_bill_1">보유잔액</label> | |
| 2234 | + <label for="userMoney" class="label">보유잔액</label> | |
| 2235 | + <fmt:formatNumber type="number" maxFractionDigits="3" value="${sendPrice.userMoney}" var="commaPrice" /> | |
| 2236 | + <input type="text" id="userMoney" name="userMoney" value="<c:out value='${commaPrice}'/>" readonly=""> | |
| 2237 | + <span class="won">원</span> | |
| 2238 | + <button type="button" class="btnType btnType21" onclick="location.href='/web/member/pay/PayView.do'">충전</button> | |
| 2239 | + </div> | |
| 2240 | + <div></div> | |
| 2241 | + </div> | |
| 2242 | + </div> | |
| 2243 | + </th> | |
| 2244 | + </tr> | |
| 2245 | + <tr> | |
| 2246 | + <th colspan="2" class="replace_send_th"> | |
| 2247 | + <div class="title_th"><p>대체문자</p> | |
| 2248 | + <input type="checkbox" id="send_fail_check" name="send_fail_check" class="send_fail_check"> | |
| 2249 | + <label for="send_fail_check">친구톡 전송 실패 시 문자 전송</label> | |
| 2250 | + </div> | |
| 2251 | + <div class="replace_send_wrap"> | |
| 2252 | + <table class="tType1"> | |
| 2253 | + <colgroup> | |
| 2254 | + <col style="width: 90px;"> | |
| 2255 | + <col style="width: auto;"> | |
| 2256 | + </colgroup> | |
| 2257 | + <tbody> | |
| 2258 | + <tr> | |
| 2259 | + <th>발신번호</th> | |
| 2260 | + <td> | |
| 2261 | + <label for="callFromList" class="label"></label> | |
| 2262 | + <select id="callFromList" name="callFromList" class="sel_number"> | |
| 2263 | + <c:choose> | |
| 2264 | + <c:when test="${not empty resultPhonList}"> | |
| 2265 | + <c:forEach var="phonList" items="${resultPhonList}" varStatus="status"> | |
| 2266 | + <option value="${phonList}">${phonList}</option> | |
| 2267 | + </c:forEach> | |
| 2268 | + </c:when> | |
| 2269 | + <c:otherwise> | |
| 2270 | + <option value="">등록된 발신 번호가 없습니다.</option> | |
| 2271 | + </c:otherwise> | |
| 2272 | + </c:choose> | |
| 2273 | + </select> | |
| 2274 | + <button type="button" class="btnType btnType6" onclick="location.href='/web/user/sendNumberManage.do'">번호등록</button> | |
| 2275 | + </td> | |
| 2276 | + </tr> | |
| 2277 | + <tr> | |
| 2278 | + <th>내용</th> | |
| 2279 | + <td class="putText"> | |
| 2280 | + <div class="clearfix"> | |
| 2281 | + <div class="put_left short"> | |
| 2282 | + <!-- 업로드한 이미지의 썸네일 영역 --> | |
| 2283 | + <ul class="thumb_wrap liOnImg ui-sortable"></ul> | |
| 2284 | + <!-- //업로드한 이미지의 썸네일 영역 --> | |
| 2285 | + <label for="smsTxtArea" class="label"></label> | |
| 2286 | + <textarea id="smsTxtArea" name="smsTxtArea" class="put_text"></textarea> | |
| 2287 | + <div class="text_length"> | |
| 2288 | + <div name="afterDeny"> | |
| 2289 | + <p> | |
| 2290 | + <span class="fwMd" id="msgLeng">0 /</span> | |
| 2291 | + <span class="c_002c9a fwMd" id="limitLeng">90</span>byte | |
| 2292 | + </p> | |
| 2293 | + <span class="msg_com msg_short">단문</span> | |
| 2294 | + </div> | |
| 2295 | + </div> | |
| 2296 | + </div> | |
| 2297 | + <div class="put_right"> | |
| 2298 | + <button type="button" class="btnType btnType9" id="failCheckInit">초기화</button> | |
| 2299 | + <button type="button" class="btnType btnType7" onclick="javascript:fn_errorChk(); return false;">오류검사<i class="qmMark"></i></button> | |
| 2300 | + </div> | |
| 2301 | + </div> | |
| 2302 | + </td> | |
| 2303 | + </tr> | |
| 2304 | + </tbody> | |
| 2305 | + </table> | |
| 2306 | + </div> | |
| 2307 | + </th> | |
| 2308 | + </tr> | |
| 2309 | + </tbody> | |
| 2310 | + </table> | |
| 2311 | + </div> | |
| 2312 | + <div class="send_right"> | |
| 2313 | + <div class="phone" style="top: 201px;"> | |
| 2314 | + <div class="phoneIn"> | |
| 2315 | + <p class="prev_p"> | |
| 2316 | + <img src="/publish/images/content/kakao_prev_icon.png" alt=""> | |
| 2317 | + <span id="spnYellowid">@채널ID</span> | |
| 2318 | + </p> | |
| 2319 | + <!-- 텍스트 미리보기 --> | |
| 2320 | + <div class="text_preview"> | |
| 2321 | + <p class="friend_talk_title"> | |
| 2322 | + <span class="adFlag">(광고)</span> | |
| 2323 | + <span id="spnYellowidAt">채널ID</span> | |
| 2324 | + </p> | |
| 2325 | + <div class="allimtalk_content"> | |
| 2326 | + <div class="kakao_image" style="display:none;"> | |
| 2327 | + <img src="" id="kakaoImg" alt=""> | |
| 2328 | + </div> | |
| 2329 | + <p class="template_text">내용 미리보기</p> | |
| 2330 | + <div class="btnViewArea"> | |
| 2331 | + <c:forEach var="buttonList" items="${resultTemplateVO.buttonVOList}" varStatus="status"> | |
| 2332 | + <button type="button" class="btn_kakao_type btnEmpty" style="display:block;"><c:out value="${buttonList.name}"/></button> | |
| 2333 | + </c:forEach> | |
| 2334 | + </div> | |
| 2335 | + </div> | |
| 2336 | + <p class="kakao_block_text">수신거부 : 홈 > 채널차단</p> | |
| 2337 | + </div> | |
| 2338 | + <!-- //텍스트 미리보기 --> | |
| 2339 | + </div> | |
| 2340 | + <p class="addText">※ 단말기 설정에 따라 다르게 보일 수 있습니다<p> | |
| 2341 | + </div> | |
| 2342 | + <div class="phone_bottom"> | |
| 2343 | + <div class="send_rev"> | |
| 2344 | + <div class="send_content" style="padding-bottom: 0;"> | |
| 2345 | + <div class="rev_radio"> | |
| 2346 | + <ul> | |
| 2347 | + <li> | |
| 2348 | + <input type="radio" id="reserYnN" name="reserYn" value="N" checked="checked"><label for="reserYnN">즉시</label> | |
| 2349 | + </li> | |
| 2350 | + <li> | |
| 2351 | + <input type="radio" id="reserYnY" name="reserYn" value="Y"><label for="reserYnY">예약</label> | |
| 2352 | + </li> | |
| 2353 | + </ul> | |
| 2354 | + </div> | |
| 2355 | + <div class="send_btn"> | |
| 2356 | + <%-- 친구톡 발송시간 체크 하기 - 20:50 ~ 익일 08:00 사이에는 발송 금지 --%> | |
| 2357 | + <c:choose> | |
| 2358 | + <c:when test="${sendStatus eq 'true'}"> | |
| 2359 | + <button type="button" class="btnType btnType11" onclick="javascript:fn_sendMsgData(); return false;">발송하기</button> | |
| 2360 | + </c:when> | |
| 2361 | + <c:otherwise> | |
| 2362 | + <button type="button" class="btnType btnType11" onclick="javascript:fn_noTimeSend(); return false;">발송하기</button> | |
| 2363 | + </c:otherwise> | |
| 2364 | + </c:choose> | |
| 2365 | + <button type="button" class="btnType btnType10" onclick="javascript:goToKakaoTestPopUp(); return false;">테스트발송</button> | |
| 2366 | + </div> | |
| 2367 | + </div> | |
| 2368 | + <div class="rev_selected" > | |
| 2369 | + <div class="rev_top"> | |
| 2370 | + <span>날짜 :</span> | |
| 2371 | + <div class="calendar_wrap"> | |
| 2372 | + <input type="text" class="startDate2 inp resDate calendar picker__input picker__input--active" title="검색 시작일" id="startDate2" name="startDate2" value="" data-datecontrol="true" readonly="" aria-haspopup="true" aria-expanded="true" aria-readonly="false" aria-owns="startDate2_root"> | |
| 2373 | + </div> | |
| 2374 | + <div class="selBox"> | |
| 2375 | + <label for="msgResHour" class="label">시 선택</label> | |
| 2376 | + <select class="selType1" id="msgResHour" name="msgResHour"> | |
| 2377 | + <c:forEach var="hour" begin="8" end="20" step="1" varStatus="status"> | |
| 2378 | + <c:choose> | |
| 2379 | + <c:when test="${hour < 10}"> | |
| 2380 | + <option value="0${hour}">0${hour}시</option> | |
| 2381 | + </c:when> | |
| 2382 | + <c:otherwise> | |
| 2383 | + <option value="${hour}">${hour}시</option> | |
| 2384 | + </c:otherwise> | |
| 2385 | + </c:choose> | |
| 2386 | + </c:forEach> | |
| 2387 | + </select> | |
| 2388 | + <label for="msgResMin" class="label">분 선택</label> | |
| 2389 | + <select class="selType1" id="msgResMin" name="msgResMin" onChange="fnSelectMinChk();"> | |
| 2390 | + <c:forEach var="min" begin="0" end="59" step="1"> | |
| 2391 | + <c:choose> | |
| 2392 | + <c:when test="${min < 10}"> | |
| 2393 | + <option value="0${min}">0${min}분</option> | |
| 2394 | + </c:when> | |
| 2395 | + <c:otherwise> | |
| 2396 | + <option value="${min}">${min}분</option> | |
| 2397 | + </c:otherwise> | |
| 2398 | + </c:choose> | |
| 2399 | + </c:forEach> | |
| 2400 | + </select> | |
| 2401 | + </div> | |
| 2402 | + </div> | |
| 2403 | + <%-- <div class="rev_bottom"> | |
| 2404 | + <input type="checkbox" id="inputDivideChk" name="inputDivideChk"> | |
| 2405 | + <label for="inputDivideChk">분할전송</label> | |
| 2406 | + <input type="text" class="dividType1" id="frmDivideCnt" name="frmDivideCnt" value="20" onkeypress='return checkNumber(event)' maxlength="4"/> | |
| 2407 | + <label for="divideCnt">건</label> | |
| 2408 | + <select class="selType1" id="divideTime" name="divideTime"> | |
| 2409 | + <option value="5">05분</option> | |
| 2410 | + <option value="10">10분</option> | |
| 2411 | + <option value="15">15분</option> | |
| 2412 | + <option value="20">20분</option> | |
| 2413 | + <option value="30">30분</option> | |
| 2414 | + </select> | |
| 2415 | + <label for="divideTime">간격</label> | |
| 2416 | + </div> --%> | |
| 2417 | + </div> | |
| 2418 | + </div> | |
| 2419 | + </div> | |
| 2420 | + </div> | |
| 2421 | + </div> | |
| 2422 | + </form> | |
| 2423 | + </div> | |
| 2424 | + </div> | |
| 2425 | +</div> | |
| 2426 | + | |
| 2427 | +<!-- 문자발송 성공 레이어팝업 --> | |
| 2428 | +<div class="tooltip-wrap"> | |
| 2429 | + <div class="popup-com pop_msg_success"> | |
| 2430 | + <div class="popup_heading"> | |
| 2431 | + <p>친구톡 전송 결과</p> | |
| 2432 | + <button type="button" class="tooltip-close" onclick="msgSuccessClose(this);"><img src="/publish/images/content/layerPopup_close.png" alt="팝업 닫기"></button> | |
| 2433 | + </div> | |
| 2434 | + <div class="layer_in"> | |
| 2435 | + <div class="msg_text">발송 성공 : <strong>1</strong> 건,수신거부 : <span>0</span>건의<br>문자가 발송 되었습니다.</div> | |
| 2436 | + </div> | |
| 2437 | + <div class="popup_btn"> | |
| 2438 | + <button type="button" onclick="msgResultLink(); return false;">친구톡 발송결과 바로가기</button> | |
| 2439 | + <button type="button" class="tooltip-close" onclick="msgSuccessClose(this);">확인</button> | |
| 2440 | + </div> | |
| 2441 | + </div> | |
| 2442 | +</div> | |
| 2443 | + | |
| 2444 | +<!-- 주소록 불러오기 --> | |
| 2445 | +<div class="tooltip-wrap"> | |
| 2446 | + <div class="popup-com import_layer popup06" tabindex="0" data-tooltip-con="popup06" data-focus="popup06" data-focus-prev="popup06-close" style="width: 1000px"> | |
| 2447 | + <div class="popup_heading"> | |
| 2448 | + <p><span>주소록 불러오기</p> | |
| 2449 | + <button type="button" onClick="javascript:addrClose(); return false;"> | |
| 2450 | + <img src="/publish/images/content/layerPopup_close.png" alt="팝업 닫기"></button> | |
| 2451 | + </div> | |
| 2452 | + <div class="layer_in"> | |
| 2453 | + <div class="titBox titBox_pad"> | |
| 2454 | + <p>- 주소록 수정 및 변경은 <span>[주소록 관리]</span>에서만 가능합니다.</p> | |
| 2455 | + <button type="button" class="adr_admin" onClick="location.href='/web/mjon/addr/selectAddrList.do'">주소록 관리</button> | |
| 2456 | + </div> | |
| 2457 | + <div class="adr_wrap"> | |
| 2458 | + <form id="searchAddrGrpForm" name="searchAddrGrpForm" method="post" style="display: flex; justify-content: space-between;"> | |
| 2459 | + <input type="hidden" id="searchAddrGrpId" name="searchAddrGrpId" value=""/> | |
| 2460 | + <input type="hidden" id="type" name="type" value="all"/> | |
| 2461 | + <input type="hidden" id="searchKeyword" name="searchKeyword" value=""/> | |
| 2462 | + <input type="hidden" name="searchCondition" id="searchCondition" value="0" /> | |
| 2463 | + <div class="adr_pop_left"> | |
| 2464 | + <div class="adr_left_search"> | |
| 2465 | + <label for="searchGrpKeyword" class="label">그룹명 검색</label> | |
| 2466 | + <input type="text" name="searchGrpKeyword" id="searchGrpKeyword" placeholder="그룹명 검색" onfocus="this.placeholder=''" onblur="this.placeholder='그룹명 검색'" class="inputLight"> | |
| 2467 | + <button type="button" onClick="javascrit:fnAddrGrpSearch(); return false;"><img src="/publish/images/popup/search.png" alt="검색"></button> | |
| 2468 | + </div> | |
| 2469 | + <div class="adr_pop_box"> | |
| 2470 | + <div id="addrGroupLoad"> | |
| 2471 | + </div> | |
| 2472 | + </div> | |
| 2473 | + <!-- <div class="popup_btn"> | |
| 2474 | + <button type="button" class="btnType" onClick="javascript:fnSelectAddrGrpList(); return false;">선택 그룹 추가</button> | |
| 2475 | + </div> --> | |
| 2476 | + </div> | |
| 2477 | + <div class="adr_pop_right"> | |
| 2478 | + <div class="clearfix"> | |
| 2479 | + <div class="btnWrap_last"> | |
| 2480 | + <label for="searchAddrCondition" class="label">카테고리 선택</label> | |
| 2481 | + <select id="searchAddrCondition" name="searchAddrCondition" class="selType2"> | |
| 2482 | + <option value='0'>전체</option> | |
| 2483 | + <option value='1'>그룹명</option> | |
| 2484 | + <option value='2'>이름</option> | |
| 2485 | + <option value='3'>핸드폰번호</option> | |
| 2486 | + </select> | |
| 2487 | + <label for="searchAddrKeyword" class="label">검색어 입력</label> | |
| 2488 | + <input type="text" id="searchAddrKeyword" name="searchAddrKeyword" placeholder="검색어를 입력하세요" onfocus="this.placeholder=''" onblur="this.placeholder='검색어를 입력하세요'" > | |
| 2489 | + <button type="button" class="btnType btnType17" onClick="javascrit:fnAddrSearch(); return false;">검색</button> | |
| 2490 | + </div> | |
| 2491 | + <!-- table --> | |
| 2492 | + <div class="adr_excel adr_pop_list2 callAddr_box"> | |
| 2493 | + </div> | |
| 2494 | + <!--// table --> | |
| 2495 | + </div> | |
| 2496 | + <div class="popup_btn_wrap2"> | |
| 2497 | + <button type="button" onClick="javascript:addrToList(); return false;">추가</button> | |
| 2498 | + <button type="button" onClick="javascript:addrClose(); return false;">닫기</button> | |
| 2499 | + </div> | |
| 2500 | + <%-- 주소록 레이어 팝업 닫기 실행 코드 --%> | |
| 2501 | + <input type="hidden" name="btnAddrClose" id="btnAddrClose" class="tooltip-close closeAddr" data-focus="popup06-close" /> | |
| 2502 | + </div> | |
| 2503 | + </form> | |
| 2504 | + </div> | |
| 2505 | + </div> | |
| 2506 | + </div> | |
| 2507 | +</div> | |
| 2508 | +<!--// 주소록 불러오기 --> | |
| 2509 | + | |
| 2510 | +<!-- 엑셀 불러오기 --> | |
| 2511 | +<form id="excelToolTipForm" name="excelToolTipForm" method="post"> | |
| 2512 | + <div class="tooltip-wrap"> | |
| 2513 | + <div class="popup-com import_layer popup02" tabindex="0" data-tooltip-con="popup02" data-focus="popup02" data-focus-prev="popup02-close"> | |
| 2514 | + <div class="popup_heading"> | |
| 2515 | + <p><span>엑셀</span> 불러오기</p> | |
| 2516 | + <button type="button" class="tooltip-close" data-focus="popup02-close"><img src="/publish/images/content/layerPopup_close.png" alt="팝업 닫기"></button> | |
| 2517 | + </div> | |
| 2518 | + <div class="layer_in"> | |
| 2519 | + <!-- 엑셀파일 불러오기 --> | |
| 2520 | + <div class="hascont"> | |
| 2521 | + <div class="titBox"> | |
| 2522 | + <p>- 최대 2만 건까지 등록할 수 있습니다.</p> | |
| 2523 | + <p>- [엑셀 불러오기]시 문서의 A, B열을 불러옵니다.(지원하는 파일 형식 : xls, xlsx)</p> | |
| 2524 | + <p>- 휴대폰 항목은 숫자, 하이픈(-)만 인식하며, 번호 앞에 0이 생략되어도 정상 등록됩니다. | |
| 2525 | + </p> | |
| 2526 | + <!-- <button type="button" class="excel_btn" onclick="location.href='/cmm/fms/FileDown.do?atchFileId=FILE_000000000011651&fileSn=1'"><i></i>샘플파일 다운로드</button> --> | |
| 2527 | + <button type="button" class="excel_btn" onclick="location.href='/download/msg/엑셀주소록_등록양식.xlsx'"><i class="downroad"></i>샘플파일 다운로드</button> | |
| 2528 | + </div> | |
| 2529 | + <div class="attachedFile"> | |
| 2530 | + <label for="excelNm" class="attachedFile_label">첨부파일</label> | |
| 2531 | + <input type="text" id="excelNm" value="" readonly> | |
| 2532 | + <input type="file" id="excelFile" accept=".xls, .xlsx" onchange="excelExport(event); return false;" style="display:none"/> | |
| 2533 | + <button type="button" class="btnType btnType6 c1">찾아보기</button> | |
| 2534 | +<!-- <p><span class="vMiddle">*</span> 첨부된 파일은 <span class="c_e40000">[추가]버튼을 클릭</span>하셔야 받는 사람에 등록됩니다.</p> --> | |
| 2535 | + <p><span class="vMiddle">*</span> 첨부된 파일은 <span class="c_e40000">[추가]버튼을 클릭</span>하셔야 받는 사람에 등록됩니다.</p> | |
| 2536 | + </div> | |
| 2537 | + </div><!--// 엑셀파일 불러오기 --> | |
| 2538 | + <div class="popup_btn_wrap2"> | |
| 2539 | + <button type="button" class="tooltip-close" data-focus="popup02-close" data-focus-next="popup02" id="excelAdd">추가</button> | |
| 2540 | + <button type="button" class="tooltip-close" data-focus="popup02-close" data-focus-next="popup02">닫기</button> | |
| 2541 | + </div> | |
| 2542 | + </div> | |
| 2543 | + </div> | |
| 2544 | + </div><!--// 엑셀 불러오기 --> | |
| 2545 | +</form> | |
| 2546 | + | |
| 2547 | +<form id="templateForm" name="templateForm" method="post"> | |
| 2548 | + <input type="hidden" id="friendId" name="friendId" value="<c:out value='${resultTemplateVO.friendId}'/>"/> | |
| 2549 | +</form>(No newline at end of file) |
Add a comment
Delete comment
Once you delete this comment, you won't be able to recover it. Are you sure you want to delete this comment?