1. 공시송달 현황 수정.

2. 기타 수정.
main
jjh 5 months ago
parent b2f544bbea
commit 20ec46ad64

@ -342,11 +342,7 @@ public class OpnnSbmsnBean extends AbstractBean {
String rtnMsg = ""; // 처리 결과 메시지
// 의견제출(TB_OPNN_SBMSN) 정보를 조회한다.
LevyExclQuery req = new LevyExclQuery();
req.setOpnnId(opnnSbmsn.getOpnnId());
req.setDelYn("N");
DataObject opnnSbmsnInfo = opnnSbmsnMapper.selectOpnnSbmsnInfo(req);
DataObject opnnSbmsnInfo = opnnSbmsnMapper.selectOpnnSbmsnInfo(new LevyExclQuery().setOpnnId(opnnSbmsn.getOpnnId()));
// 의견제출 ID가 조회되지 않았다면 종료..
if (opnnSbmsnInfo.string("OPNN_ID").equals("")) {

@ -276,12 +276,14 @@ public class Excl01Controller extends ApplicationController {
if (levyExcl.getLevyExclIds() == null || levyExcl.getLevyExclIds().length < 1) {
rtnMsg = levyExclService.removeLevyExcl(levyExcl);
} else {
// 부과제외 Ids 만큼 반복..
for (int iLoop = 0; iLoop < levyExcl.getLevyExclIds().length; iLoop++) {
levyExcl.setLevyExclId(levyExcl.getLevyExclIds()[iLoop]); // 부과제외 ID 설정
// 부과제외 삭제 호출
rtnMsg = levyExclService.removeLevyExcl(levyExcl);
// 부과제외 Ids 만큼 삭제 반복..
for (String levyExclId : levyExcl.getLevyExclIds()) {
LevyExcl deltLevyExcl = new LevyExcl();
deltLevyExcl.setLevyExclId(levyExclId);
deltLevyExcl.setDelRsn(levyExcl.getDelRsn());
// 공시송달 삭제 호출
rtnMsg = levyExclService.removeLevyExcl(deltLevyExcl);
if (!rtnMsg.contains("[S]")) // 오류가 발생하였으면 종료..
break;
}

@ -31,6 +31,7 @@ import cokr.xit.fims.cmmn.hwp.format.DlbrDecsnList;
import cokr.xit.fims.cmmn.service.bean.StngBean;
import cokr.xit.fims.cmmn.xls.FormatMaker;
import cokr.xit.fims.cmmn.xls.StyleMaker;
import cokr.xit.fims.excl.LevyExcl;
import cokr.xit.fims.excl.LevyExclQuery;
import cokr.xit.fims.excl.OpnnDlbrMbr;
import cokr.xit.fims.excl.OpnnSbmsn;
@ -411,12 +412,14 @@ public class Excl02Controller extends ApplicationController {
if (opnnSbmsn.getOpnnIds() == null || opnnSbmsn.getOpnnIds().length < 1) {
rtnMsg = opnnSbmsnService.removeOpnnSbmsn(opnnSbmsn);
} else {
// 의견제출 Ids 만큼 반복..
for (int iLoop = 0; iLoop < opnnSbmsn.getOpnnIds().length; iLoop++) {
opnnSbmsn.setOpnnId(opnnSbmsn.getOpnnIds()[iLoop]); // 의견제출 ID 설정
// 의견제출 Ids 만큼 삭제 반복..
for (String opnnId : opnnSbmsn.getOpnnIds()) {
OpnnSbmsn deltOpnnSbmsn = new OpnnSbmsn();
deltOpnnSbmsn.setOpnnId(opnnId);
deltOpnnSbmsn.setDelRsn(opnnSbmsn.getDelRsn());
// 의견제출 삭제 호출
rtnMsg = opnnSbmsnService.removeOpnnSbmsn(opnnSbmsn);
rtnMsg = opnnSbmsnService.removeOpnnSbmsn(deltOpnnSbmsn);
if (!rtnMsg.contains("[S]")) // 오류가 발생하였으면 종료..
break;
}

@ -56,30 +56,30 @@ public class SndbQuery extends CmmnQuery {
// 상세 검색 조건
// 동적 검색 조건
private String levyExclSeCd; // 부과제외_부과 제외 구분 코드
private String levyExclSeNm; // 부과제외_부과 제외 구분 명
private String vltnCd; // 위반 코드
private String vhrno; // 단속(TB_CRDN)_차량번호
private String rtpyrNm; // 납부자(TB_PAYER)_납부자 명
private String crdnSttsCd; // 단속(TB_CRDN)_단속 상태 코드
private String crdnSttsCdFrom; // 단속(TB_CRDN)_단속 상태 코드 시작
private String crdnSttsCdTo; // 단속(TB_CRDN)_단속 상태 코드 종료
private String sndngSeCd; // 발송 구분 코드
private String sndngSeCdFrom; // 발송 구분 코드 시작
private String sndngSeCdTo; // 발송 구분 코드 종료
private String sndngDtlSttsCd; // 발송 상세 상태 코드
private String levyExclSeCd; // 부과제외_부과 제외 구분 코드
private String levyExclSeNm; // 부과제외_부과 제외 구분 명
private String vltnCd; // 위반 코드
private String vhrno; // 단속(TB_CRDN)_차량번호
private String rtpyrNm; // 납부자(TB_PAYER)_납부자 명
private String crdnSttsCd; // 단속(TB_CRDN)_단속 상태 코드
private String crdnSttsCdFrom; // 단속(TB_CRDN)_단속 상태 코드 시작
private String crdnSttsCdTo; // 단속(TB_CRDN)_단속 상태 코드 종료
private String sndngSeCd; // 발송 구분 코드
private String sndngSeCdFrom; // 발송 구분 코드 시작
private String sndngSeCdTo; // 발송 구분 코드 종료
private String sndngDtlSttsCd; // 발송 상세 상태 코드
private String rcpnRelNm1;
private String rcpnRelNm2;
private String rcpnRelNm3;
private String rcpnRelNm4;
private String tnocs; // 총건수
private String printDocNo; // 출력 문서 번호
private String printTtlNm; // 출력 제목 명
private String printSvbtcDate; // 출력 공고 기한
private String tnocs; // 총건수
private String printDocNo; // 출력 문서 번호
private String printTtlNm; // 출력 제목 명
private String printSvbtcDate; // 출력 공고 기한
// ETC
private String callPurpose; // infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정, refresh 재조회).
private String delRsn; // 삭제 사유
private String crdnDelYn; // 단속 삭제 여부
private String callPurpose; // infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정, refresh 재조회).
private String delRsn; // 삭제 사유
private String crdnDelYn; // 단속 삭제 여부
public String[] getCrdnIds() {
return ifEmpty(crdnIds, () -> null);

@ -17,6 +17,16 @@ public class Svbtc extends AbstractEntity {
*/
private String svbtcId;
/**
*
*/
private String sggCd;
/**
*
*/
private String taskSeCd;
/**
*
*/
@ -78,9 +88,4 @@ public class Svbtc extends AbstractEntity {
*/
private String sndngDtlId;
/**
*
*/
private String sggCd;
}

@ -6,7 +6,6 @@ import cokr.xit.foundation.data.DataObject;
import cokr.xit.fims.sndb.SndbQuery;
import cokr.xit.fims.sndb.SndngDtl;
import cokr.xit.fims.sndb.Svbtc;
/** .
*
@ -98,13 +97,4 @@ public interface SndngDtlService {
*/
String removeSndbk(SndngDtl sndngDtl);
/** .
* @param svbtc
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
String removeSvbtcEach(Svbtc svbtc);
}

@ -75,4 +75,13 @@ public interface SvbtcService {
*/
String removeSvbtc(Svbtc svbtc);
/** .
* @param svbtc
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
String removeSvbtcEach(Svbtc svbtc);
}

@ -173,9 +173,8 @@ public class SndngBean extends AbstractBean {
// 발송 상세 대장을 등록한다.
for (int iLoop = 0; iLoop < trgtList.size(); iLoop++) {
rtnMsg = createWrngSndngDtl(sndng, trgtList.get(iLoop).string("CRDN_ID"));
// 메시지 확인
if (!rtnMsg.contains("[S]")) {
throw new RuntimeException(rtnMsg); // 예외를 발생시켜서 DB Rollback
if (!rtnMsg.contains("[S]")) { // 오류가 발생하였으면 종료..
throw new RuntimeException(rtnMsg.replace("[F]", "")); // 예외를 발생시켜서 DB Rollback
}
}
@ -351,8 +350,8 @@ public class SndngBean extends AbstractBean {
for (int iLoop = 0; iLoop < advntceTrgtList.size(); iLoop++) {
rtnMsg = createAdvntceSndngDtl(sndng, advntceTrgtList.get(iLoop).string("CRDN_ID"));
// 메시지 확인
if (!rtnMsg.contains("[S]")) {
throw new RuntimeException(rtnMsg.replace("[F]", "사전통지")); // 예외를 발생시켜서 DB Rollback
if (!rtnMsg.contains("[S]")) { // 오류가 발생하였으면 종료..
throw new RuntimeException(rtnMsg.replace("[F]", "")); // 예외를 발생시켜서 DB Rollback
}
}
@ -449,8 +448,8 @@ public class SndngBean extends AbstractBean {
// 부과(TB_LEVY) 대장에 부과일자, 최초납기일자, 납기일자를 수정한다.
rtnMsg = levyBean.updateRductLevyYmd(levy);
if (!rtnMsg.contains("[S]")) {
throw new RuntimeException(rtnMsg.replace("[F]", "사전통지 발송상세 등록 작업중 ")); // 예외를 발생시켜서 DB Rollback
if (!rtnMsg.contains("[S]")) { // 오류가 발생하였으면 종료..
throw new RuntimeException(rtnMsg.replace("[F]", "")); // 예외를 발생시켜서 DB Rollback
}
}
}
@ -665,9 +664,8 @@ public class SndngBean extends AbstractBean {
// 발송 상세 대장에 등록한다.
for (int iLoop = 0; iLoop < nhtTrgtList.size(); iLoop++) {
rtnMsg = createNhtSndngDtl(sndng, nhtTrgtList.get(iLoop).string("CRDN_ID"));
// 메시지 확인
if (!rtnMsg.contains("[S]")) {
throw new RuntimeException(rtnMsg.replace("[F]", "고지서")); // 예외를 발생시켜서 DB Rollback
if (!rtnMsg.contains("[S]")) { // 오류가 발생하였으면 종료..
throw new RuntimeException(rtnMsg.replace("[F]", "")); // 예외를 발생시켜서 DB Rollback
}
}

@ -643,7 +643,7 @@ public class SndngDtlBean extends AbstractBean {
// 발송상세(TB_SNDNG_DTL)에 반송 정보를 등록한다.
int rtnNocs = sndngDtlMapper.createSndbk(sndngDtl);
if (rtnNocs != 1) {
throw new RuntimeException("[F] 발송상세의 반송 정보 등록에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
throw new RuntimeException("발송상세의 반송 정보 등록에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
return "[S] 작업이 정상 처리 되었습니다.";
@ -660,7 +660,7 @@ public class SndngDtlBean extends AbstractBean {
// 발송상세(TB_SNDNG_DTL)에 반송 정보를 등록한다.
int rtnNocs = sndngDtlMapper.updateSndbk(sndngDtl);
if (rtnNocs != 1) {
throw new RuntimeException("[F] 발송상세의 반송 정보 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
throw new RuntimeException("발송상세의 반송 정보 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
return "[S] 작업이 정상 처리 되었습니다.";

@ -11,7 +11,6 @@ import cokr.xit.foundation.data.DataObject;
import cokr.xit.fims.sndb.SndbQuery;
import cokr.xit.fims.sndb.SndngDtl;
import cokr.xit.fims.sndb.Svbtc;
import cokr.xit.fims.sndb.service.SndngDtlService;
/** .
@ -90,57 +89,4 @@ public class SndngDtlServiceBean extends AbstractServiceBean implements SndngDtl
return sndngDtlBean.removeSndbk(sndngDtl);
}
@Override
public String removeSvbtcEach(Svbtc svbtc) {
// 변수 선언
String rtnMsg = ""; // 처리 결과 메시지
// 공시송달 Ids 건수를 확인하여 1건이하면.. 종료
if (svbtc.getSndngDtlIds().length < 1) {
rtnMsg = "작업 중 선택 자료가 존재하지 않습니다.";
return rtnMsg;
}
// 공시송달 Ids 만큼 반복..
for (int iLoop = 0; iLoop < svbtc.getSndngDtlIds().length; iLoop++) {
// 발송 상세(TB_SNDNG_DTL) 대장에서 공시송달 정보를 삭제한다.
SndngDtl sndngDtl = new SndngDtl();
sndngDtl.setSndngDtlId(svbtc.getSndngDtlIds()[iLoop]);
sndngDtl.setSvbtcId(svbtc.getSvbtcId());
sndngDtl.setSndngDtlSttsCd("05");
rtnMsg = sndngDtlBean.removeSndngDtlSvbtc(sndngDtl);
if (!rtnMsg.contains("[S]")) {
throw new RuntimeException("발송상세 대장에 공시송달 정보 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
}
// 공시송달 총건수 수정 호출
int svbtcTnocs = sndngDtlBean.selectTnocsSndngDtlSvbtc(svbtc.getSvbtcId());
if (svbtcTnocs == 0) { // 총건수가 0건이라면 공시송달 대장에서 삭제
rtnMsg = svbtcBean.removeSvbtc(svbtc);
} else { // 총건수를 확인하여 공시송달 대장에서 수정
// 공시송달 정보 호출
DataObject svbtcInfo = svbtcBean.getSvbtcInfo(new SndbQuery().setSvbtcId(svbtc.getSvbtcId()));
Svbtc updtSvbtc = new Svbtc();
updtSvbtc.setSvbtcYmd(svbtcInfo.string("SVBTC_YMD"));
updtSvbtc.setTtlNm(svbtcInfo.string("TTL_NM"));
updtSvbtc.setDocNo(svbtcInfo.string("DOC_NO"));
updtSvbtc.setEtcCn(svbtcInfo.string("ETC_CN"));
updtSvbtc.setTnocs(svbtcTnocs);
updtSvbtc.setSvbtcId(svbtc.getSvbtcId());
rtnMsg = svbtcBean.updateSvbtc(updtSvbtc);
}
// 오류가 발생하였으면 종료..
if (!rtnMsg.contains("[S]")) {
throw new RuntimeException(rtnMsg); // 예외를 발생시켜서 DB Rollback
}
return "[S] 작업이 정상 처리 되었습니다.";
}
}

@ -193,6 +193,16 @@ public class SvbtcBean extends AbstractBean {
public String removeSvbtc(Svbtc svbtc) {
// 변수 선언
int rtnNocs = -1; // 처리 결과 건수
String rtnMsg = ""; // 처리 결과 메시지
// 공시송달(TB_SVBTC) 정보를 조회한다.
DataObject svbtcInfo = svbtcMapper.selectSvbtcInfo(new SndbQuery().setSvbtcId(svbtc.getSvbtcId()));
// 삭제 대상 자료 ID 확인
if (svbtcInfo.string("SVBTC_ID").equals("")) {
rtnMsg = "[F] 작업 중 오류가 발생하였습니다.<br>공시송달 대장 자료가 존재하지 않습니다.";
return rtnMsg;
}
// 공시송달(TB_SVBTC) 대장을 삭제한다.
rtnNocs = svbtcMapper.deleteSvbtc(svbtc);
@ -200,17 +210,80 @@ public class SvbtcBean extends AbstractBean {
throw new RuntimeException("공시송달 대장 삭제에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
// 발송 상세(TB_SNDNG_DTL) 대장에서 공시송달 정보를 삭제한다.
SndngDtl sndngDtl = new SndngDtl();
sndngDtl.setSndngDtlIds(svbtc.getSndngDtlIds());
sndngDtl.setSvbtcId(svbtc.getSvbtcId());
sndngDtl.setSndngDtlSttsCd("05");
// 발송 상세(TB_SNDNG_DTL) 대장에서 공시송달 정보를 삭제한다.
rtnNocs = sndngDtlMapper.deleteSndngDtlSvbtc(sndngDtl);
if (rtnNocs != 1) {
if (rtnNocs < 1) {
throw new RuntimeException("발송상세 대장에 공시송달 정보 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
return "[S] 작업이 정상 처리 되었습니다.";
}
/** .
* @param svbtc
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
public String removeSvbtcEach(Svbtc svbtc) {
// 변수 선언
int rtnNocs = -1; // 처리 결과 건수
String rtnMsg = ""; // 처리 결과 메시지
// 공시송달(TB_SVBTC) 정보를 조회한다.
DataObject svbtcInfo = svbtcMapper.selectSvbtcInfo(new SndbQuery().setSvbtcId(svbtc.getSvbtcId()));
// 삭제 대상 자료 ID 확인
if (svbtcInfo.string("SVBTC_ID").equals("")) {
rtnMsg = "[F] 작업 중 오류가 발생하였습니다.<br>공시송달 대장 자료가 존재하지 않습니다.";
return rtnMsg;
}
// 총건수
int trgtNocs = svbtcInfo.number("TNOCS").intValue() - svbtc.getSndngDtlIds().length;
if (trgtNocs == 0) { // 전체 삭제
rtnMsg = removeSvbtc(svbtc);
if (!rtnMsg.contains("[S]")) { // 오류가 발생하였으면 종료..
throw new RuntimeException(rtnMsg.replace("[F]", "")); // 예외를 발생시켜서 DB Rollback
}
} else if (trgtNocs >= 1) { // 일부 삭제
SndngDtl sndngDtl = new SndngDtl();
sndngDtl.setSndngDtlIds(svbtc.getSndngDtlIds());
sndngDtl.setSvbtcId(svbtc.getSvbtcId());
sndngDtl.setSndngDtlSttsCd("05");
// 발송 상세(TB_SNDNG_DTL) 대장에서 공시송달 정보를 삭제한다.
rtnNocs = sndngDtlMapper.deleteSndngDtlSvbtc(sndngDtl);
if (rtnNocs < 1) {
throw new RuntimeException("발송 상세 대장에 공시송달 정보 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
Svbtc updtSvbtc = new Svbtc();
updtSvbtc.setSvbtcYmd(svbtcInfo.string("SVBTC_YMD")); // 공시송달 일자
updtSvbtc.setSvbtcEndYmd(svbtcInfo.string("SVBTC_END_YMD")); // 공시송달 종료 일자
updtSvbtc.setTtlNm(svbtcInfo.string("TTL_NM")); // 제목 명
updtSvbtc.setDocNo(svbtcInfo.string("DOC_NO")); // 문서 번호
updtSvbtc.setEtcCn(svbtcInfo.string("ETC_CN")); // 기타 내용
updtSvbtc.setTnocs(trgtNocs); // 총건수
updtSvbtc.setSvbtcId(svbtc.getSvbtcId());
// 공시송달(TB_SVBTC) 정보를 수정한다.
rtnMsg = updateSvbtc(updtSvbtc);
if (!rtnMsg.contains("[S]")) { // 오류가 발생하였으면 종료..
throw new RuntimeException(rtnMsg.replace("[F]", "")); // 예외를 발생시켜서 DB Rollback
}
} else {
throw new RuntimeException("공시송달 총건수 보다 선택건수가 많이 조회됩니다.");
}
return "[S] 작업이 정상 처리 되었습니다.";
}
}

@ -66,40 +66,12 @@ public class SvbtcServiceBean extends AbstractServiceBean implements SvbtcServic
@Override
public String removeSvbtc(Svbtc svbtc) {
// 변수 선언
String rtnMsg = ""; // 처리 결과 메시지
// 공시송달 Id 및 공시송달 Ids 확인하여 null이면 종료
if (svbtc.getSvbtcId() == null && svbtc.getSvbtcIds() == null) {
rtnMsg = "[F] 작업 중 선택 자료가 존재하지 않습니다.";
return rtnMsg;
}
// 공시송달 삭제 처리
if (svbtc.getSvbtcId() != null) {
rtnMsg = svbtcBean.removeSvbtc(svbtc);
} else {
// 공시송달 Ids 를 확인하여 건수가 1보다 작다면 종료..
if (svbtc.getSvbtcIds().length < 1) {
rtnMsg = "[F] 작업 중 선택 자료가 존재하지 않습니다.";
return rtnMsg;
}
// 공시송달 Ids 만큼 반복..
for (int iLoop = 0; iLoop < svbtc.getSvbtcIds().length; iLoop++) {
// 부과제외 ID 설정
svbtc.setSvbtcId(svbtc.getSvbtcIds()[iLoop]);
// 공시송달 삭제 호출
rtnMsg = svbtcBean.removeSvbtc(svbtc);
// 오류가 발생하였으면 종료..
if (!rtnMsg.contains("[S]")) {
return rtnMsg;
}
}
}
return rtnMsg;
return svbtcBean.removeSvbtc(svbtc);
}
@Override
public String removeSvbtcEach(Svbtc svbtc) {
return svbtcBean.removeSvbtcEach(svbtc);
}
}

@ -841,6 +841,23 @@ public class Sndb01Controller extends ApplicationController {
}
}
/** (sndb/sndb01/090-main) .
* @return /sndb/sndb01/090-main
*/
@ -1492,6 +1509,7 @@ public class Sndb01Controller extends ApplicationController {
return mav.addObject("pageName", "sndb01240") // View(jsp)에서 사용할 id 뒤에 붙일 suffix
.addObject("infoPrefix", "svbtc") // prefix
.addObject("infoPrefixUrl", CLASS_URL) // prefixUrl
.addObject("sggCd", managedUser.getOrgID()) // 시군구 코드(SGG_CD)
.addObject("taskListForSgg", stngBean.filterTaskSectionCodeForSgg(commonCodes.get("FIM054"))) // 시군구에서 사용하는 업무 목록
.addObject("FIM047List", commonCodes.get("FIM047")) // 발송 구분 코드(SNDNG_SE_CD)
@ -1564,17 +1582,18 @@ public class Sndb01Controller extends ApplicationController {
*/
@Task
@RequestMapping(name="공시송달 상세 화면", value=METHOD_URL.getServiceByPublicNoticeDetailInfo)
public ModelAndView getServiceByPublicNoticeDetailInfo(SndbQuery req) {
//
public ModelAndView getServiceByPublicNoticeDetailInfo(HttpServletRequest hReq, SndbQuery req) {
ModelAndView mav = getServiceByPublicNoticeDetailList(req);
mav.setViewName("fims/sndb/sndb01250-info");
return mav
.addObject("pageName", "sndb01250") // View(jsp)에서 사용할 id 뒤에 붙일 suffix
.addObject("infoPrefix", "svbtcDtl") // prefix
.addObject("callPurpose", req.getCallPurpose()) // 호출 용도
.addObject("mainQuery", toJson(req)) // 검색 조건
.addObject("openerPageName", hReq.getParameter("openerPageName")) // 호출한 Jsp PageName
.addObject("callPurpose", req.getCallPurpose()) // 호출 용도
.addObject("pageName", "sndb01250") // View(jsp)에서 사용할 id 뒤에 붙일 suffix
.addObject("infoPrefix", "svbtcDtl") // prefix
.addObject("infoPrefixUrl", CLASS_URL) // prefixUrl
.addObject("mainQuery", toJson(req)) // 검색 조건
.addObject("svbtcDtlList", toJson(mav.getModel().get("svbtcDtlList"))) // 자료
;
}
@ -1660,8 +1679,6 @@ public class Sndb01Controller extends ApplicationController {
@Task
@RequestMapping(name="공시송달 한글 저장", value=METHOD_URL.makeSvbtcFileFromHwpFormat)
public ModelAndView makeSvbtcFileFromHwpFormat(SndbQuery req) {
UserInfo userInfo = currentUser();
fimsOgdpBean.initUserInfo(userInfo);
Print print = new Print();
@ -1678,6 +1695,7 @@ public class Sndb01Controller extends ApplicationController {
HashMap<String, Object> result = hwpFormat.makeFile().andDownload();
ModelAndView mav = new ModelAndView("downloadView");
mav.addAllObjects(result);
return mav;
}
@ -1690,18 +1708,17 @@ public class Sndb01Controller extends ApplicationController {
*/
@Task
@RequestMapping(name="공시송달 정보", value=METHOD_URL.getServiceByPublicNoticeInfo)
public ModelAndView getServiceByPublicNoticeInfo(SndbQuery req) {
public ModelAndView getServiceByPublicNoticeInfo(HttpServletRequest hReq, SndbQuery req) {
// 공시송달 정보 조회
DataObject svbtcInfo = svbtcService.getSvbtcInfo(req);
DataObject info = svbtcService.getSvbtcInfo(req);
// 등록을 호출하였지만 등록된 공시송달 ID가 있는지 확인.
if (req.getCallPurpose().equals("create") && !svbtcInfo.string("SVBTC_ID").equals("")) {
if (req.getCallPurpose().equals("create") && !info.string("SVBTC_ID").equals("")) {
ModelAndView mav = new ModelAndView("jsonView");
return mav.addObject("rtnMsg", "이미 등록된 공시송달 정보가 있습니다.");
} else {
boolean json = jsonResponse();
ModelAndView mav = new ModelAndView(json ? "jsonView" : "fims/sndb/sndb01260-info");
// View(jsp)에서 사용할 공통코드를 조회
@ -1710,11 +1727,13 @@ public class Sndb01Controller extends ApplicationController {
addCodes(commonCodes, mav, "FIM047", "FIM054");
return mav
.addObject("pageName", "sndb01260") // View(jsp)에서 사용할 id 뒤에 붙일 suffix
.addObject("infoPrefix", "svbtc") // prefix
.addObject("callPurpose", req.getCallPurpose()) // 호출 용도
.addObject("mainQuery", json ? req : toJson(req)) // Query
.addObject("svbtcInfo", json ? svbtcInfo : toJson(svbtcInfo)) // 공시송달 정보
.addObject("openerPageName", hReq.getParameter("openerPageName")) // 호출한 Jsp PageName
.addObject("callPurpose", req.getCallPurpose()) // 호출 용도
.addObject("pageName", "sndb01260") // View(jsp)에서 사용할 id 뒤에 붙일 suffix
.addObject("infoPrefix", "svbtc") // prefix
.addObject("infoPrefixUrl", CLASS_URL) // prefixUrl
.addObject("mainQuery", json ? req : toJson(req)) // Query
.addObject("svbtcInfo", json ? info : toJson(info)) // 공시송달 정보
;
}
}
@ -1779,7 +1798,23 @@ public class Sndb01Controller extends ApplicationController {
@RequestMapping(name="공시송달 삭제", value=METHOD_URL.removeServiceByPublicNotice)
public ModelAndView removeServiceByPublicNotice(Svbtc svbtc) {
boolean saved = false;
String rtnMsg = svbtcService.removeSvbtc(svbtc);
String rtnMsg = "";
if (svbtc.getSvbtcIds() == null || svbtc.getSvbtcIds().length < 1) {
rtnMsg = svbtcService.removeSvbtc(svbtc);
} else {
// 공시송달 Ids 만큼 삭제 반복..
for (String svbtcId : svbtc.getSvbtcIds()) {
Svbtc deltSvbtc = new Svbtc();
deltSvbtc.setSvbtcId(svbtcId);
deltSvbtc.setDelRsn(svbtc.getDelRsn());
// 공시송달 삭제 호출
rtnMsg = svbtcService.removeSvbtc(deltSvbtc);
if (!rtnMsg.contains("[S]")) // 오류가 발생하였으면 종료..
break;
}
}
if (rtnMsg.contains("[S]")) {
saved = true;
@ -1804,7 +1839,7 @@ public class Sndb01Controller extends ApplicationController {
@RequestMapping(name="공시송달 개별 삭제", value=METHOD_URL.removeServiceByPublicNoticeEach)
public ModelAndView removeServiceByPublicNoticeEach(Svbtc svbtc) {
boolean saved = false;
String rtnMsg = sndngDtlService.removeSvbtcEach(svbtc);
String rtnMsg = svbtcService.removeSvbtcEach(svbtc);
if (rtnMsg.contains("[S]")) {
saved = true;
@ -1869,7 +1904,6 @@ public class Sndb01Controller extends ApplicationController {
}
}
Print print = new Print();
UserInfo userInfo = currentUser();
fimsOgdpBean.initUserInfo(userInfo);

@ -103,127 +103,124 @@
</resultMap>
<sql id="selectList">
SELECT SD.SNDNG_DTL_ID <!-- 발송 상세 ID -->
, SD.CRDN_ID <!-- 단속 ID -->
, SD.SVBTC_ID <!-- 공시송달 ID -->
, SD.LINK_TRGT_CD <!-- 연계 대상 코드 -->
, SD.LINK_MNG_KEY <!-- 연계 관리 키 -->
, SD.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, SD.SNDNG_YMD <!-- 발송 일자 -->
, SD.SNDNG_END_YMD <!-- 발송 종료 일자 -->
, SD.RCPN_NM <!-- 수령인 명 -->
, SD.RCPN_BRDT <!-- 수령인 생년월일 -->
, SD.RCPN_ADDR <!-- 수령인 주소 -->
, SD.RCPN_DTL_ADDR <!-- 수령인 상세 주소 -->
, SD.RCPN_ZIP <!-- 수령인 우편번호 -->
, SD.CON_KEY <!-- 외부연계식별키 -->
, SD.RG_NO <!-- 등기 번호 -->
, SD.DLVR_YMD <!-- 배달 일자 -->
, SD.DLVR_TM <!-- 배달 시각 -->
, SD.UNDLVR_RSN_CD <!-- 미배달 사유 코드 -->
, SD.UNDLVR_RSN_NM <!-- 미배달 사유 명 -->
, SD.ACTL_RCPN_NM <!-- 실제 수령인 명 -->
, SD.RCPN_REL_NM <!-- 수령인 관계 명 -->
, SD.SNDNG_DTL_STTS_CD <!-- 발송 상세 상태 코드 -->
, SD.BFR_SNDNG_DTL_STTS_CD <!-- 전 발송 상세 상태 코드 -->
, SD.BFR_DLVR_YMD <!-- 전 배달 일자 -->
, SD.BFR_DLVR_HR <!-- 전 배달 시간 -->
, SD.SNDNG_RCVMT_CD <!-- 발송 수납 코드 -->
, SD.ADDR_CHG_CD <!-- 주소 변경 코드 -->
, SD.CRDN_DT <!-- 단속 일시 -->
, SD.VHRNO <!-- 차량번호 -->
, SD.CRDN_STDG_NM <!-- 단속 법정동 명 -->
, SD.CRDN_PLC <!-- 단속 장소 -->
, SD.FYR <!-- 회계연도 -->
, SD.LEVY_NO <!-- 부과 번호 -->
, SD.LEVY_YMD <!-- 부과 일자 -->
, SD.DUDT_YMD <!-- 납기 일자 -->
, SD.DUDT_AFTR_YMD <!-- 납기 후 일자 -->
, SD.FFNLG_AMT <!-- 과태료 금액 -->
, SD.PCPTAX <!-- 본세 -->
, SD.ADAMT <!-- 가산금 -->
, SD.SUM_AMT <!-- 합계 금액 -->
, SD.DUDT_AFTR_AMT <!-- 납기 후 금액 -->
, SD.TAX_NO <!-- 납세 번호 -->
, SD.EPAYNO <!-- 전자납부번호 -->
, SD.BANK_NM <!-- 은행 명 -->
, SD.VR_ACTNO <!-- 가상 계좌번호 -->
, SD.BANK_NM2 <!-- 은행 명 2 -->
, SD.VR_ACTNO2 <!-- 가상 계좌번호 2 -->
, SD.BANK_NM3 <!-- 은행 명 3 -->
, SD.VR_ACTNO3 <!-- 가상 계좌번호 3 -->
, SD.BANK_NM4 <!-- 은행 명 4 -->
, SD.VR_ACTNO4 <!-- 가상 계좌번호 4 -->
, SD.BANK_NM5 <!-- 은행 명 5 -->
, SD.VR_ACTNO5 <!-- 가상 계좌번호 5 -->
, SD.BANK_NM6 <!-- 은행 명 6 -->
, SD.VR_ACTNO6 <!-- 가상 계좌번호 6 -->
, SD.BANK_NM7 <!-- 은행 명 7 -->
, SD.VR_ACTNO7 <!-- 가상 계좌번호 7 -->
, SD.BANK_NM8 <!-- 은행 명 8 -->
, SD.VR_ACTNO8 <!-- 가상 계좌번호 8 -->
, SD.BANK_NM9 <!-- 은행 명 9 -->
, SD.VR_ACTNO9 <!-- 가상 계좌번호 9 -->
, SD.BANK_NM10 <!-- 은행 명 10 -->
, SD.VR_ACTNO10 <!-- 가상 계좌번호 10 -->
, SD.BANK_NM11 <!-- 은행 명 11 -->
, SD.VR_ACTNO11 <!-- 가상 계좌번호 11 -->
, SD.BANK_NM12 <!-- 은행 명 12 -->
, SD.VR_ACTNO12 <!-- 가상 계좌번호 12 -->
, SD.BANK_NM13 <!-- 은행 명 13 -->
, SD.VR_ACTNO13 <!-- 가상 계좌번호 13 -->
, SD.BANK_NM14 <!-- 은행 명 14 -->
, SD.VR_ACTNO14 <!-- 가상 계좌번호 14 -->
, SD.BANK_NM15 <!-- 은행 명 15 -->
, SD.VR_ACTNO15 <!-- 가상 계좌번호 15 -->
, SD.BANK_NM16 <!-- 은행 명 16 -->
, SD.VR_ACTNO16 <!-- 가상 계좌번호 16 -->
, SD.BANK_NM17 <!-- 은행 명 17 -->
, SD.VR_ACTNO17 <!-- 가상 계좌번호 17 -->
, SD.BANK_NM18 <!-- 은행 명 18 -->
, SD.VR_ACTNO18 <!-- 가상 계좌번호 18 -->
, SD.BANK_NM19 <!-- 은행 명 19 -->
, SD.VR_ACTNO19 <!-- 가상 계좌번호 19 -->
, SD.BANK_NM20 <!-- 은행 명 20 -->
, SD.VR_ACTNO20 <!-- 가상 계좌번호 20 -->
, SD.REG_DT <!-- 등록 일시 -->
, SD.RGTR <!-- 등록자 -->
, SD.MDFCN_DT <!-- 수정 일시 -->
, SD.MDFR <!-- 수정자 -->
, SD.DEL_DT <!-- 삭제 일시 -->
, SD.DLTR <!-- 삭제자 -->
, (GET_BRDT_FORMAT(SD.RCPN_BRDT, '.')) AS RCPN_BRDT_MASK <!-- 수령인 생년월일 마스크 -->
, (GET_MASK_DATE(SD.SNDNG_YMD, '-')) AS SNDNG_YMD_MASK <!-- 부과 일자 -->
, (GET_MASK_DATE(SD.SNDNG_END_YMD, '-')) AS SNDNG_END_YMD_MASK <!-- 부과 일자 -->
, (GET_MASK_DATE(SD.LEVY_YMD, '.')) AS LEVY_YMD_MASK <!-- 부과 일자 -->
, (GET_MASK_DATE(SD.DUDT_YMD, 'K')) AS DUDT_YMD_MASK_KOR <!-- 납기 일자(한글표기) -->
, (GET_MASK_DATE(SD.DUDT_YMD, '.')) AS DUDT_YMD_MASK <!-- 납기 일자 -->
, (GET_MASK_DATE(SD.DUDT_AFTR_YMD, '.')) AS DUDT_AFTR_YMD_MASK <!-- 납기 후 일자 -->
, (GET_MASK_EPAYNO(SD.EPAYNO)) AS EPAYNO_MASK <!-- 전자납부번호 -->
, (SELECT GET_CODE_NM('FIM047', SD.SNDNG_SE_CD) FROM DUAL) AS SNDNG_SE_NM <!-- 발송 구분 명 -->
SELECT SD.SNDNG_DTL_ID <!-- 발송 상세 ID -->
, SD.CRDN_ID <!-- 단속 ID -->
, SD.SVBTC_ID <!-- 공시송달 ID -->
, SD.LINK_TRGT_CD <!-- 연계 대상 코드 -->
, SD.LINK_MNG_KEY <!-- 연계 관리 키 -->
, SD.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, (SELECT GET_CODE_NM('FIM047', SD.SNDNG_SE_CD) FROM DUAL) AS SNDNG_SE_NM <!-- 발송 구분 명 -->
, SD.SNDNG_YMD <!-- 발송 일자 -->
, (SELECT GET_MASK_DATE(SD.SNDNG_YMD, '-') FROM DUAL) AS SNDNG_YMD_MASK <!-- 발송 일자 -->
, SD.SNDNG_END_YMD <!-- 발송 종료 일자 -->
, (SELECT GET_MASK_DATE(SD.SNDNG_END_YMD, '-') FROM DUAL) AS SNDNG_END_YMD_MASK <!-- 발송 종료 일자 -->
, SD.RCPN_NM <!-- 수령인 명 -->
, SD.RCPN_BRDT <!-- 수령인 생년월일 -->
, (SELECT GET_BRDT_FORMAT(SD.RCPN_BRDT, '.') FROM DUAL) AS RCPN_BRDT_MASK <!-- 수령인 생년월일 마스크 -->
, SD.RCPN_ADDR <!-- 수령인 주소 -->
, SD.RCPN_DTL_ADDR <!-- 수령인 상세 주소 -->
, SD.RCPN_ZIP <!-- 수령인 우편번호 -->
, SD.CON_KEY <!-- 외부연계식별키 -->
, SD.RG_NO <!-- 등기 번호 -->
, SD.DLVR_YMD <!-- 배달 일자 -->
, SD.DLVR_TM <!-- 배달 시각 -->
, SD.UNDLVR_RSN_CD <!-- 미배달 사유 코드 -->
, SD.UNDLVR_RSN_NM <!-- 미배달 사유 명 -->
, SD.ACTL_RCPN_NM <!-- 실제 수령인 명 -->
, SD.RCPN_REL_NM <!-- 수령인 관계 명 -->
, SD.SNDNG_DTL_STTS_CD <!-- 발송 상세 상태 코드 -->
, (SELECT GET_CODE_NM('FIM050', SD.SNDNG_DTL_STTS_CD) FROM DUAL) AS SNDNG_DTL_STTS_NM <!-- 발송 상세 상태 명 -->
, (SELECT GET_CODE_NM('FIM050', SD.BFR_SNDNG_DTL_STTS_CD) FROM DUAL) AS BFR_SNDNG_DTL_STTS_NM <!-- 전 발송 상세 상태 명 -->
, (SELECT GET_CODE_NM('FIM051', SD.SNDNG_RCVMT_CD) FROM DUAL) AS SNDNG_RCVMT_NM <!-- 발송 수납 명 -->
, SD.BFR_SNDNG_DTL_STTS_CD <!-- 전 발송 상세 상태 코드 -->
, (SELECT GET_CODE_NM('FIM050', SD.BFR_SNDNG_DTL_STTS_CD) FROM DUAL) AS BFR_SNDNG_DTL_STTS_NM <!-- 전 발송 상세 상태 명 -->
, SD.BFR_DLVR_YMD <!-- 전 배달 일자 -->
, SD.BFR_DLVR_HR <!-- 전 배달 시간 -->
, SD.SNDNG_RCVMT_CD <!-- 발송 수납 코드 -->
, (SELECT GET_CODE_NM('FIM051', SD.SNDNG_RCVMT_CD) FROM DUAL) AS SNDNG_RCVMT_NM <!-- 발송 수납 명 -->
, SD.ADDR_CHG_CD <!-- 주소 변경 코드 -->
, SD.CRDN_DT <!-- 단속 일시 -->
, SD.VHRNO <!-- 차량번호 -->
, SD.CRDN_STDG_NM <!-- 단속 법정동 명 -->
, SD.CRDN_PLC <!-- 단속 장소 -->
, SD.FYR <!-- 회계연도 -->
, SD.LEVY_NO <!-- 부과 번호 -->
, SD.LEVY_YMD <!-- 부과 일자 -->
, (SELECT GET_MASK_DATE(SD.LEVY_YMD, '.') FROM DUAL) AS LEVY_YMD_MASK <!-- 부과 일자 -->
, SD.DUDT_YMD <!-- 납기 일자 -->
, (SELECT GET_MASK_DATE(SD.DUDT_YMD, '.') FROM DUAL) AS DUDT_YMD_MASK <!-- 납기 일자 -->
, (SELECT GET_MASK_DATE(SD.DUDT_YMD, 'K') FROM DUAL) AS DUDT_YMD_MASK_KOR <!-- 납기 일자(한글표기) -->
, SD.DUDT_AFTR_YMD <!-- 납기 후 일자 -->
, (SELECT GET_MASK_DATE(SD.DUDT_AFTR_YMD, '.') FROM DUAL) AS DUDT_AFTR_YMD_MASK <!-- 납기 후 일자 -->
, SD.FFNLG_AMT <!-- 과태료 금액 -->
, SD.PCPTAX <!-- 본세 -->
, SD.ADAMT <!-- 가산금 -->
, SD.SUM_AMT <!-- 합계 금액 -->
, SD.DUDT_AFTR_AMT <!-- 납기 후 금액 -->
, SD.TAX_NO <!-- 납세 번호 -->
, SD.EPAYNO <!-- 전자납부번호 -->
, (SELECT GET_MASK_EPAYNO(SD.EPAYNO) FROM DUAL) AS EPAYNO_MASK <!-- 전자납부번호 -->
, SD.BANK_NM <!-- 은행 명 -->
, SD.VR_ACTNO <!-- 가상 계좌번호 -->
, SD.BANK_NM2 <!-- 은행 명 2 -->
, SD.VR_ACTNO2 <!-- 가상 계좌번호 2 -->
, SD.BANK_NM3 <!-- 은행 명 3 -->
, SD.VR_ACTNO3 <!-- 가상 계좌번호 3 -->
, SD.BANK_NM4 <!-- 은행 명 4 -->
, SD.VR_ACTNO4 <!-- 가상 계좌번호 4 -->
, SD.BANK_NM5 <!-- 은행 명 5 -->
, SD.VR_ACTNO5 <!-- 가상 계좌번호 5 -->
, SD.BANK_NM6 <!-- 은행 명 6 -->
, SD.VR_ACTNO6 <!-- 가상 계좌번호 6 -->
, SD.BANK_NM7 <!-- 은행 명 7 -->
, SD.VR_ACTNO7 <!-- 가상 계좌번호 7 -->
, SD.BANK_NM8 <!-- 은행 명 8 -->
, SD.VR_ACTNO8 <!-- 가상 계좌번호 8 -->
, SD.BANK_NM9 <!-- 은행 명 9 -->
, SD.VR_ACTNO9 <!-- 가상 계좌번호 9 -->
, SD.BANK_NM10 <!-- 은행 명 10 -->
, SD.VR_ACTNO10 <!-- 가상 계좌번호 10 -->
, SD.BANK_NM11 <!-- 은행 명 11 -->
, SD.VR_ACTNO11 <!-- 가상 계좌번호 11 -->
, SD.BANK_NM12 <!-- 은행 명 12 -->
, SD.VR_ACTNO12 <!-- 가상 계좌번호 12 -->
, SD.BANK_NM13 <!-- 은행 명 13 -->
, SD.VR_ACTNO13 <!-- 가상 계좌번호 13 -->
, SD.BANK_NM14 <!-- 은행 명 14 -->
, SD.VR_ACTNO14 <!-- 가상 계좌번호 14 -->
, SD.BANK_NM15 <!-- 은행 명 15 -->
, SD.VR_ACTNO15 <!-- 가상 계좌번호 15 -->
, SD.BANK_NM16 <!-- 은행 명 16 -->
, SD.VR_ACTNO16 <!-- 가상 계좌번호 16 -->
, SD.BANK_NM17 <!-- 은행 명 17 -->
, SD.VR_ACTNO17 <!-- 가상 계좌번호 17 -->
, SD.BANK_NM18 <!-- 은행 명 18 -->
, SD.VR_ACTNO18 <!-- 가상 계좌번호 18 -->
, SD.BANK_NM19 <!-- 은행 명 19 -->
, SD.VR_ACTNO19 <!-- 가상 계좌번호 19 -->
, SD.BANK_NM20 <!-- 은행 명 20 -->
, SD.VR_ACTNO20 <!-- 가상 계좌번호 20 -->
, SD.REG_DT <!-- 등록 일시 -->
, SD.RGTR <!-- 등록자 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SD.RGTR) AS RGTR_NM <!-- 등록자 명 -->
, SD.MDFCN_DT <!-- 수정 일시 -->
, SD.MDFR <!-- 수정자 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SD.MDFR) AS MDFR_NM <!-- 수정자 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SD.DLTR) AS DLTR_NM <!-- 삭제자 명 -->
, S.SNDNG_ID <!-- 발송 ID -->
, S.SGG_CD <!-- 시군구 코드 -->
, S.DEPT_CD <!-- 부서 코드 -->
, S.TASK_SE_CD <!-- 업무 구분 코드 -->
, S.SNDNG_REG_SE_CD <!-- 발송 등록 구분 코드 -->
, S.LEVY_BGNG_YMD <!-- 부과 시작 일자 -->
, S.LEVY_END_YMD <!-- 부과 종료 일자 -->
, S.TTL_NM <!-- 제목 명 -->
, S.DOC_NO <!-- 문서 번호 -->
, S.ETC_CN <!-- 기타 내용 -->
, S.TNOCS <!-- 총건수 -->
, S.GRAMT <!-- 총금액 -->
, S.DIV_KB <!-- 취급 구분 -->
, S.EPOST_NOTICE_ID <!-- 전자우편 안내문 ID -->
, S.SNDNG_STTS_CD <!-- 발송 상태 코드 -->
, S.RESND_YN <!-- 재발송 여부 -->
, (SELECT GET_CODE_NM('EGP002', S.DIV_KB) FROM DUAL) AS DIV_KB_NM <!-- 취급 구분 명 -->
, S.SNDNG_ID <!-- 발송 ID -->
, S.SGG_CD <!-- 시군구 코드 -->
, S.DEPT_CD <!-- 부서 코드 -->
, S.TASK_SE_CD <!-- 업무 구분 코드 -->
, S.SNDNG_REG_SE_CD <!-- 발송 등록 구분 코드 -->
, S.LEVY_BGNG_YMD <!-- 부과 시작 일자 -->
, S.LEVY_END_YMD <!-- 부과 종료 일자 -->
, S.TTL_NM <!-- 제목 명 -->
, S.DOC_NO <!-- 문서 번호 -->
, S.ETC_CN <!-- 기타 내용 -->
, S.TNOCS <!-- 총건수 -->
, S.GRAMT <!-- 총금액 -->
, S.DIV_KB <!-- 취급 구분 -->
, (SELECT GET_CODE_NM('EGP002', S.DIV_KB) FROM DUAL) AS DIV_KB_NM <!-- 취급 구분 명 -->
, S.EPOST_NOTICE_ID <!-- 전자우편 안내문 ID -->
, S.SNDNG_STTS_CD <!-- 발송 상태 코드 -->
, S.RESND_YN <!-- 재발송 여부 -->
FROM TB_SNDNG_DTL SD
LEFT OUTER JOIN TB_SNDNG S ON (SD.SNDNG_ID = S.SNDNG_ID)
</sql>
@ -233,21 +230,21 @@
<include refid="selectList" />
<where>
<if test="sndngId != null">
AND SD.SNDNG_ID = #{sndngId} <!-- 발송 Id -->
AND SD.SNDNG_ID = #{sndngId} <!-- 발송 Id -->
</if>
<if test="sndngDtlIds != null">
AND SD.SNDNG_DTL_ID IN ( <!-- 발송 상세 Ids -->
AND SD.SNDNG_DTL_ID IN ( <!-- 발송 상세 Ids -->
<foreach collection="sndngDtlIds" item="sndngDtlId" separator=","> #{sndngDtlId} </foreach>
)
</if>
<if test="sndngDtlId != null">
AND SD.SNDNG_DTL_ID = #{sndngDtlId} <!-- 발송 상세 Id -->
AND SD.SNDNG_DTL_ID = #{sndngDtlId} <!-- 발송 상세 Id -->
</if>
<if test="crdnId != null">
AND SD.CRDN_ID = #{crdnId} <!-- 단속 Id -->
AND SD.CRDN_ID = #{crdnId} <!-- 단속 Id -->
</if>
<if test="delYn != null">
AND SD.DEL_YN = #{delYn} <!-- 삭제 여부 -->
AND SD.DEL_YN = #{delYn} <!-- 삭제 여부 -->
</if>
</where>
<include refid="utility.orderBy" />
@ -1044,8 +1041,10 @@
, MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 -->
, MDFR = #{modifiedBy} <!-- 수정자 -->
WHERE SVBTC_ID = #{svbtcId} <!-- 공시송달 ID -->
<if test="sndngDtlId != null">
AND SNDNG_DTL_ID = #{sndngDtlId} <!-- 발송 상세 ID -->
<if test="sndngDtlIds != null">
AND SNDNG_DTL_ID IN ( <!-- 발송 상세 Ids -->
<foreach collection="sndngDtlIds" item="sndngDtlId" separator=","> #{sndngDtlId} </foreach>
)
</if>
AND DEL_YN = 'N'
</update>

@ -8,7 +8,9 @@
============================ -->
<resultMap id="svbtcRow" type="cokr.xit.fims.sndb.Svbtc">
<result property="svbtcId" column="SVBTC_ID" /> <!-- 공시송달 ID -->
<result property="svbtcId" column="SVBTC_ID" /> <!-- 공시송달 ID -->
<result property="sggCd" column="SGG_CD" /> <!-- 시군구 코드 -->
<result property="taskSeCd" column="TASK_SE_CD" /> <!-- 업무 구분 코드 -->
<result property="sndngSeCd" column="SNDNG_SE_CD" /> <!-- 발송 구분 코드 -->
<result property="svbtcYmd" column="SVBTC_YMD" /> <!-- 공시송달 일자 -->
<result property="svbtcEndYmd" column="SVBTC_END_YMD" /> <!-- 공시송달 종료 일자 -->
@ -28,8 +30,11 @@
<sql id="select">
SELECT SV.SVBTC_ID <!-- 공시송달 ID -->
, SV.SGG_CD <!-- 시군구 코드 -->
, SV.TASK_SE_CD <!-- 업무 구분 코드 -->
, (GET_CODE_NM('FIM054', SV.TASK_SE_CD)) AS TASK_SE_NM <!-- 업무 구분 명 -->
, SV.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, (SELECT GET_CODE_NM('FIM047', SV.SNDNG_SE_CD) FROM DUAL) AS SNDNG_SE_NM <!-- 발송 구분 명 -->
, (GET_CODE_NM('FIM047', SV.SNDNG_SE_CD)) AS SNDNG_SE_NM <!-- 발송 구분 명 -->
, SV.SVBTC_YMD <!-- 공시송달 일자 -->
, SV.SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
, SV.TTL_NM <!-- 제목 명 -->
@ -43,7 +48,7 @@
, SV.MDFCN_DT <!-- 수정 일시 -->
, SV.MDFR <!-- 수정자 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.MDFR) AS MDFR_NM <!-- 등록자 명 -->
FROM TB_SVBTC SV
FROM TB_SVBTC SV
</sql>
<select id="selectSvbtcList" parameterType="map" resultType="dataobject">/* 공시송달 대장 목록 조회(svbtcMapper.selectSvbtcList) */
@ -138,8 +143,10 @@
<sql id="selectDtl">
SELECT SV.SVBTC_ID <!-- 공시송달 ID -->
, SV.SGG_CD <!-- 시군구 코드 -->
, SV.TASK_SE_CD <!-- 업무 구분 코드 -->
, SV.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, (SELECT GET_CODE_NM('FIM047', SV.SNDNG_SE_CD) FROM DUAL) AS SNDNG_SE_NM <!-- 발송 구분 명 -->
, (GET_CODE_NM('FIM047', SV.SNDNG_SE_CD)) AS SNDNG_SE_NM <!-- 발송 구분 명 -->
, SV.SVBTC_YMD <!-- 공시송달 일자 -->
, SV.SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
, SV.DOC_NO <!-- 문서 번호 -->
@ -165,10 +172,10 @@
, SD.SNDNG_YMD <!-- 발송 일자 -->
, SD.SNDNG_END_YMD <!-- 발송 종료 일자 -->
, SD.LEVY_YMD <!-- 부과 일자 -->
, (SELECT GET_MASK_DATE(SD.LEVY_YMD, '.') FROM DUAL) AS LEVY_YMD_MASK <!-- 부과 일자 -->
, (GET_MASK_DATE(SD.LEVY_YMD, '.')) AS LEVY_YMD_MASK <!-- 부과 일자 -->
, SD.DUDT_YMD <!-- 납기 일자 -->
, (SELECT GET_MASK_DATE(SD.DUDT_YMD, '.') FROM DUAL) AS DUDT_YMD_MASK <!-- 납기 일자 -->
, (SELECT GET_MASK_DATE(SD.DUDT_YMD, 'K') FROM DUAL) AS DUDT_YMD_MASK_KOR <!-- 납기 일자(한글표기) -->
, (GET_MASK_DATE(SD.DUDT_YMD, '.')) AS DUDT_YMD_MASK <!-- 납기 일자 -->
, (GET_MASK_DATE(SD.DUDT_YMD, 'K')) AS DUDT_YMD_MASK_KOR <!-- 납기 일자(한글표기) -->
, SD.FFNLG_AMT <!-- 과태료 금액 -->
, SD.PCPTAX <!-- 본세 -->
, SD.ADAMT <!-- 가산금 -->
@ -183,13 +190,13 @@
, SD.DLVR_YMD <!-- 배달 일자 -->
, SD.DLVR_TM <!-- 배달 시각 -->
, SD.UNDLVR_RSN_NM <!-- 미배달 사유 명 -->
, (SELECT GET_CODE('EGP010', SD.UNDLVR_RSN_NM) FROM DUAL) AS UNDLVR_RSN_CD <!-- 미배달 사유 코드 -->
, (GET_CODE('EGP010', SD.UNDLVR_RSN_NM)) AS UNDLVR_RSN_CD <!-- 미배달 사유 코드 -->
, SD.ACTL_RCPN_NM <!-- 실제 수령인 명 -->
, SD.RCPN_REL_NM <!-- 수령인 관계 명 -->
, SD.SNDNG_DTL_STTS_CD <!-- 발송 상세 상태 코드 -->
, (SELECT GET_CODE_NM('FIM050', SD.SNDNG_DTL_STTS_CD) FROM DUAL) AS SNDNG_DTL_STTS_NM <!-- 발송 상세 상태 명 -->
, (GET_CODE_NM('FIM050', SD.SNDNG_DTL_STTS_CD)) AS SNDNG_DTL_STTS_NM <!-- 발송 상세 상태 명 -->
, SD.SNDNG_RCVMT_CD <!-- 발송 수납 코드 -->
, (SELECT GET_CODE_NM('FIM051', SD.SNDNG_RCVMT_CD) FROM DUAL) AS SNDNG_RCVMT_NM <!-- 발송 수납 명 -->
, (GET_CODE_NM('FIM051', SD.SNDNG_RCVMT_CD)) AS SNDNG_RCVMT_NM <!-- 발송 수납 명 -->
, SD.ADDR_CHG_CD <!-- 주소 변경 코드 -->
FROM TB_SVBTC SV
INNER JOIN TB_SNDNG_DTL SD ON (SV.SVBTC_ID = SD.SVBTC_ID)
@ -243,9 +250,9 @@
<select id="selectSvbtcPrint" parameterType="map" resultType="dataobject">/* 공시송달 상세 객체 가져오기(svbtcMapper.selectSvbtcDtls) */
SELECT SV.SVBTC_ID <!-- 공시송달 ID -->
, SV.SVBTC_YMD <!-- 공시송달 일자 -->
, (SELECT GET_MASK_DATE(SV.SVBTC_YMD, '-') FROM DUAL) AS SVBTC_YMD <!-- 공시송달 일자 -->
, (GET_MASK_DATE(SV.SVBTC_YMD, '-')) AS SVBTC_YMD <!-- 공시송달 일자 -->
, SV.SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
, (SELECT GET_MASK_DATE(SV.SVBTC_END_YMD, '-') FROM DUAL) AS SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
, (GET_MASK_DATE(SV.SVBTC_END_YMD, '-')) AS SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
, SV.DOC_NO <!-- 문서 번호 -->
, SV.TTL_NM <!-- 제목 명 -->
, SV.ETC_CN <!-- 기타 내용 -->
@ -265,13 +272,14 @@
, SD.RCPN_ZIP <!-- 수령인 우편번호 -->
, SD.RG_NO <!-- 등기 번호 -->
, SD.DLVR_YMD <!-- 배달 일자 -->
, (SELECT GET_MASK_DATE(SD.DLVR_YMD, '-') FROM DUAL) AS DLVR_YMD_MASK <!-- 배달일자 마스크 -->
, (GET_MASK_DATE(SD.DLVR_YMD, '-')) AS DLVR_YMD_MASK <!-- 배달일자 마스크 -->
, SD.DLVR_TM <!-- 배달 시각 -->
, SD.UNDLVR_RSN_NM <!-- 미배달 사유 명 -->
, SD.ACTL_RCPN_NM <!-- 실제 수령인 명 -->
, SD.RCPN_REL_NM <!-- 수령인 관계 명 -->
, (SELECT GET_MASK_NAME(SD.RCPN_NM, 'MIDDLE', 2, '*') FROM DUAL) AS RCPN_NM_MASK <!-- 수령인 명 마스크 -->
, (SELECT GET_INST_LEADER(S.INST_NM, S.INST_SE_CD) FROM DUAL) AS INST_LEADER <!-- 기관 장 -->
, (GET_MASK_NAME(SD.RCPN_NM, 'MIDDLE', 2, '*')) AS RCPN_NM_MASK <!-- 수령인 명 마스크 -->
, SGG.INST_NM <!-- 기관 명 -->
, (GET_INST_LEADER(SGG.INST_NM, SGG.INST_SE_CD)) AS INST_LEADER <!-- 기관 장 -->
, SGG.OFFCS_FILE_PATH <!-- 직인 파일 경로 -->
, DPT.DEPT_TELNO <!-- 부서 전화번호 -->
, (CONCAT(SGG.SGG_NM, ' ', DPT.DEPT_NM)) AS SGG_DEPT_NM <!-- 부서 명 -->
@ -281,14 +289,9 @@
FROM TB_SVBTC SV
INNER JOIN TB_SNDNG_DTL SD ON (SV.SVBTC_ID = SD.SVBTC_ID)
INNER JOIN TB_SNDNG S ON (SD.SNDNG_ID = S.SNDNG_ID)
INNER JOIN TB_SGG SGG ON (S.SGG_CD = SGG.SGG_CD AND SGG.SGG_CD = #{sggCd})
INNER JOIN TB_DEPT DPT ON (SGG.SGG_CD = DPT.SGG_CD AND DPT.DEPT_CD = #{deptCd})
INNER JOIN TB_SGG SGG ON (S.SGG_CD = SGG.SGG_CD)
INNER JOIN TB_DEPT DPT ON (S.SGG_CD = DPT.SGG_CD AND S.DEPT_CD = DPT.DEPT_CD)
<where>
<if test="svbtcIds != null">
AND SV.SVBTC_ID IN ( <!-- 공시송달 IDs -->
<foreach collection="svbtcIds" item="svbtcId" separator=","> #{svbtcId} </foreach>
)
</if>
<if test="svbtcId != null">
AND SV.SVBTC_ID = #{svbtcId} <!-- 공시송달 ID -->
</if>
@ -332,6 +335,8 @@
INSERT
INTO TB_SVBTC (
SVBTC_ID <!-- 공시송달 ID -->
, SGG_CD <!-- 시군구 코드 -->
, TASK_SE_CD <!-- 업무 구분 코드 -->
, SNDNG_SE_CD <!-- 발송 구분 코드 -->
, SVBTC_YMD <!-- 공시송달 일자 -->
, SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
@ -347,6 +352,8 @@
)
VALUES (
#{svbtcId} <!-- 공시송달 ID -->
, #{sggCd} <!-- 시군구 코드 -->
, #{taskSeCd} <!-- 업무 구분 코드 -->
, #{sndngSeCd} <!-- 발송 구분 코드 -->
, #{svbtcYmd} <!-- 공시송달 일자 -->
, #{svbtcEndYmd} <!-- 공시송달 종료 일자 -->

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">우편통합 안내문 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
@ -60,7 +60,7 @@
</div> <!-- <div class="container flex-grow-1 px-0"> -->
<!-- Content -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">우편통합 발송 내역</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
@ -99,7 +99,7 @@
</div> <!-- <div class="container flex-grow-1 px-0"> -->
<!-- Content -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -452,7 +452,6 @@
foundTr.appendChild(this.cloneNode(true));
});
//
let replacer = (str, dataItem) => str
.replace(/{onclick}/gi, "pageObject['${pageName}'].control.setCurrent('" + dataItem.getValue("LEVY_EXCL_ID") + "');")
.replace(/{ondblclick}/gi, "pageObject['${pageName}'].getTotalInfo('" + dataItem.getValue("CRDN_ID") + "');");
@ -535,9 +534,9 @@
let params = {};
let selected = $P.control.dataset.getKeys("selected");
params[$P.control.prefixed("Ids")] = selected.join(","); // IDs
params.sggCd = $("#sggCd--${pageName}").val(); // 시군구 코드
params.taskSeCd = $("input[name=taskSeCd]:checked").val(); // 업무 구분 코드
params[$P.control.prefixed("Ids")] = selected.join(","); // 부과 제외 IDs
params.delRsn = obj.reason; // 삭제 사유
$P.control.remove(params);

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">부과제외 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
@ -61,24 +61,24 @@
</form>
<!-- 입력 영역 -->
<!-- 업무 버튼 표시 -->
<!-- 업무 버튼 및 건수 표시 -->
<div>
<span class="container-page-btn">
<!-- 업무 버튼 -->
<span class="container-window-btn-right">
<!-- 업무 버튼 -->
<button type="button" class="btn btn-primary w-px-80" id="btnSave--${pageName}" title="저장">
저장
</button>
</span>
</span>
</div> <!-- 업무 버튼 표시 -->
</div> <!-- 업무 버튼 및 건수 표시 -->
</div> <!-- <div class="card"> -->
<!-- Page Body -->
</div> <!-- <div class="container flex-grow-1 px-0"> -->
<!-- Content -->
</div>
<!-- / inner page html <div class="content-wrapper"> -->
<!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -200,12 +200,12 @@
<button type="button" class="btn btn-primary w-px-120" id="btnUpdateOpnnDlbr--${pageName}" title="의견제출 심의">
의견제출 심의
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnPrintDlbrDecsn--${pageName}" title="심의의결서 출력">
심의의결서 출력
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnRemove--${pageName}" title="의견제출 삭제">
의견제출 삭제
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnPrintDlbrDecsn--${pageName}" title="심의의결서 출력">
심의의결서 출력
</button>
</span>
</span>
</div> <!-- 업무 버튼 및 건수 표시 -->
@ -426,10 +426,10 @@
checkbox.prop("checked", keys.includes(checkbox.val()));
});
// 심의의결서 출력 버튼
$("#btnPrintDlbrDecsn--${pageName}").prop("disabled", keys.length < 1);
// 삭제 버튼
$("#btnRemove--${pageName}").prop("disabled", keys.length < 1);
// 심의의결서 출력 버튼
$("#btnPrintDlbrDecsn--${pageName}").prop("disabled", keys.length < 1);
// DataTables(그리드) 전체 선택(checkbox)
if (keys.length < 1) {
@ -748,30 +748,6 @@
});
}
// 심의의결서 출력 버튼 클릭 이벤트
$P.fnPrintDlbrDecsn = (title) => {
// 선택 자료
let selected = $P.control.dataset.getKeys("selected");
if (selected.length < 1) {
dialog.alert({
content: "선택하신 의견제출 정보가 없습니다."
, onOK: () => { }
});
return;
}
let params = {
callPurpose: "download"
, title: title
, sggCd: $P.control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd: $P.control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, opnnIds: selected.join(",") // 의견제출 IDs
};
$P.makeHwpFileDlbrDecsn(params);
}
// 의견제출 삭제 버튼 클릭 이벤트
$P.fnRemove = (title) => {
// 선택 자료
@ -779,7 +755,7 @@
if (selected.length < 1) {
dialog.alert({
content: "선택하신 의견제출 정보가 없습니다."
content: "선택하신 " + $P.control.prefixName + " 의견제출 정보가 없습니다."
, onOK: () => { }
});
return;
@ -800,13 +776,37 @@
, content: template
, init: () => { setDialogZindex(); }
, onOK: () => {
$P.callbackRsn({ reason : $("#reason").val() });
$P.callbackRsn({ reason: $("#reason").val() });
}
});
}
});
}
// 심의의결서 출력 버튼 클릭 이벤트
$P.fnPrintDlbrDecsn = (title) => {
// 선택 자료
let selected = $P.control.dataset.getKeys("selected");
if (selected.length < 1) {
dialog.alert({
content: "선택하신 의견제출 정보가 없습니다."
, onOK: () => { }
});
return;
}
let params = {
callPurpose: "download"
, title: title
, sggCd: $P.control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd: $P.control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, opnnIds: selected.join(",") // 의견제출 IDs
};
$P.makeHwpFileDlbrDecsn(params);
}
/**************************************************************************
* 초기 설정
**************************************************************************/
@ -850,14 +850,14 @@
$("#btnUpdateOpnnDlbr--${pageName}").on("click", function() {
$P.fnUpdateOpnnDlbr($(this).attr("title"));
});
// 심의의결서 출력 버튼 이벤트
$("#btnPrintDlbrDecsn--${pageName}").on("click", function() {
$P.fnPrintDlbrDecsn($(this).attr("title"));
});
// 의견제출 삭제 버튼 이벤트
$("#btnRemove--${pageName}").on("click", function() {
$P.fnRemove($(this).attr("title"));
});
// 심의의결서 출력 버튼 이벤트
$("#btnPrintDlbrDecsn--${pageName}").on("click", function() {
$P.fnPrintDlbrDecsn($(this).attr("title"));
});
// DataTables width 변경 조정
fnMakeResizableTable($("#table-responsive--${pageName}")[0]);

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">의견제출 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
@ -174,7 +174,7 @@
</div> <!-- <div class="container flex-grow-1 px-0"> -->
<!-- Content -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">의견제출 심의 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
@ -122,7 +122,7 @@
</div> <!-- <div class="container flex-grow-1 px-0"> -->
<!-- Content -->
</div> <!-- inner page html <div class="content-wrapper"> -->
</div> <!-- inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">의견제출 심의 위원 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
@ -115,7 +115,7 @@
</div> <!-- <div class="container flex-grow-1 px-0"> -->
<!-- Content -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">사전 감경부과 대상 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
<!-- Page Body -->
@ -71,7 +71,7 @@
<!-- / 업무 버튼 표시 -->
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">과태료 감경 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
<!-- Page Body -->
@ -79,7 +79,7 @@
<!-- / 업무 버튼 표시 -->
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">납부자 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
<!-- Page Body -->
@ -135,7 +135,7 @@
<!-- / 업무 버튼 표시 -->
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -2,7 +2,7 @@
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
<c:set var="prefixName" scope="request">수납 정보</c:set>
@ -157,7 +157,7 @@
<!-- / 업무 버튼 표시 -->
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -2,7 +2,7 @@
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
<c:set var="prefixName" scope="request">감액 정보</c:set>
@ -74,7 +74,7 @@
<!-- / 업무 버튼 표시 -->
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

@ -345,13 +345,8 @@
$P.control.defaultFetchSize = $P.mainQuery.fetchSize;
$P.control.query = $P.mainQuery;
// URL 설정
$P.fnSetURL($P.mainQuery.taskSeCd);
}
// 업무구분에 따른 URL 설정
$P.fnSetURL = (taskSeCd) => {
$P.control.urls.load = wctx.url("/" + taskSeCd + "${infoPrefixUrl}" + "/040/list.do"); // 조회
// 업무구분에 따른 URL 설정
$P.control.urls.load = wctx.url("/" + $P.mainQuery.taskSeCd + "${infoPrefixUrl}" + "/040/list.do"); // 조회
}
/**************************************************************************

@ -323,12 +323,12 @@
if (typeof sndngId == "undefined" || sndngId == null || sndngId == "") return;
let params = {
title: $P.control.prefixName + " 상세 정보" // 타이틀
, callPurpose: "view" // 호출 용도
, pageNum: 1 // 페이지 번호
, sggCd: $("#sggCd--${pageName}").val() // 시군구 코드
, taskSeCd: $("input[name=taskSeCd]:checked").val() // 업무 구분 코드
, sndngId: sndngId // 발송 ID
title: $P.control.prefixName + " 상세 정보" // 타이틀
, callPurpose: "view" // 호출 용도
, pageNum: 1 // 페이지 번호
, sggCd: $("#sggCd--${pageName}").val() // 시군구 코드
, taskSeCd: $("input[name=taskSeCd]:checked").val() // 업무 구분 코드
, sndngId: sndngId // 발송 ID
}
ajax.get({
@ -417,7 +417,7 @@
// DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트
$P.scrollDataList = () => {
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 false
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 false
$P.control.load($P.control.query.pageNum + 1);
}
@ -591,7 +591,7 @@
});
});
// 버튼 이벤트
// 업무 버튼 이벤트
$("#btnRemove--${pageName}").on("click", function() {
$P.fnRemove($(this).attr("title")); // 사전통지 발송 삭제
});
@ -622,7 +622,6 @@
});
// 기본 데이터 설정
$("#sggCd--${pageName}").val("${sggCd}"); // 시군구 코드
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + taskSeCd + "']").prop("checked", true); // 업무 구분 코드
initDatepicker("frmSearch--${pageName}"); // 달력 초기화

@ -13,7 +13,8 @@
<!-- 입력 영역 -->
<form id="frmEdit--${pageName}" name="frmEdit">
<input type="hidden" id="sndngId--${pageName}" name="sndngId" />
</form> <!-- 입력 영역 -->
</form>
<!-- 입력 영역 -->
<!-- 업무 버튼 및 건수 표시 -->
<div>
@ -47,7 +48,7 @@
<button type="button" class="btn btn-primary w-px-120" id="btnPrintAdvntceOutsourcing--${pageName}" title="사전통지 출력(외주파일)">
사전통보서출력(외주파일)
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnCreateSndbk--${pageName}" title="반송 등록">
<button type="button" class="btn btn-primary w-px-120" id="btnCreateSndbk--${pageName}" title="반송 확인">
반송 확인
</button>
</span>
@ -261,7 +262,7 @@
// DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트
$P.scrollDataList = () => {
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 false
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 false
$P.control.load($P.control.query.pageNum + 1);
}
@ -631,13 +632,8 @@
$P.control.defaultFetchSize = $P.mainQuery.fetchSize;
$P.control.query = $P.mainQuery;
// URL 설정
$P.fnSetURL($P.mainQuery.taskSeCd);
}
// 업무구분에 따른 URL 설정
$P.fnSetURL = (taskSeCd) => {
$P.control.urls.load = wctx.url("/" + taskSeCd +"${infoPrefixUrl}" + "/080/list.do"); // 조회
// 업무구분에 따른 URL 설정
$P.control.urls.load = wctx.url("/" + $P.mainQuery.taskSeCd + "${infoPrefixUrl}" + "/080/list.do"); // 조회
}
/**************************************************************************

@ -1,11 +1,12 @@
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
<c:set var="prefixName" scope="request">공시송달 현황</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<!-- Content -->
<div class="container-xxl flex-grow-1 px-0">
<c:set var="prefixName" scope="request">공시송달 현황</c:set>
<!-- Page Body -->
<div class="card">
@ -23,8 +24,7 @@
엑셀
</button>
</span>
</div>
<!-- / 상단 버튼 -->
</div> <!-- 상단 버튼 -->
<!-- 검색 조건 영역 -->
<form id="frmSearch--${pageName}" name="frmSearch">
@ -36,12 +36,12 @@
<div class="row g-1">
<!-- 업무구분 -->
<div class="col-12">
<span class="form-label fw-bold form-search-title text-end">업무구분</span>
<span class="form-label fw-bold form-search-title w-px-120 text-end">업무구분</span>
<span class="form-search-linebox">
<c:forEach items="${taskListForSgg}" var="item">
<label>
<input type="radio" class="form-check-input" name="taskSeCd" alt="업무구분"
value="${item.code}" onchange="fnResetAndChangeBiz${pageName}(this.value);">
value="${item.code}" onchange="pageObject['${pageName}'].fnResetAndChangeBiz(this.value);">
${item.value}
</label>
</c:forEach>
@ -49,7 +49,7 @@
</div>
<!-- 공시송달 일자 -->
<div class="col-6">
<span class="form-label fw-bold form-search-title text-end">송달일자</span>
<label class="form-label fw-bold form-search-title w-px-120 text-end" for="schSvbtcYmdFrom--${pageName}">송달일자</label>
<span class="form-search-linebox">
<input type="text" class="form-control form-date" id="schSvbtcYmdFrom--${pageName}" name="schSvbtcYmdFrom"
data-fmt-type="day" title="시작 날짜 선택" />
@ -62,26 +62,24 @@
</div>
<!-- 발송구분 -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end" for="schSndngSeCd--${pageName}">발송구분</label>
<select class="form-select w-px-150" id="schSndngSeCd--${pageName}" name="schSndngSeCd">
<label class="form-label fw-bold form-search-title w-px-120 text-end" for="schSndngSeCd--${pageName}">발송구분</label>
<select class="form-select w-px-160" id="schSndngSeCd--${pageName}" name="schSndngSeCd">
<option value="">전체</option>
<c:forEach items="${FIM047List}" var="item">
<option value="${item.code}">${item.value}</option>
</c:forEach>
</select>
</div>
<!-- 문서 번호 -->
<!-- -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end" for="schDocNo--${pageName}">문서번호</label>
<input type="text" class="form-control w-px-160" id="schDocNo--${pageName}" name="schDocNo" autocomplete="off" />
</div>
<!-- 동적검색 -->
<div class="col-6">
<input type="hidden" id="by--${pageName}" name="by" />
<input type="text" class="form-control" id="byOutput--${pageName}" value="동적 검색" readonly />
<input type="text" class="form-control fw-bold w-px-120 text-end" id="byOutput--${pageName}" value="동적 검색" readonly />
<input type="hidden" id="mainOption--${pageName}" name="mainOption" />
<input type="hidden" id="subOption--${pageName}" name="subOption" />
<input type="text" class="form-control w-px-300" id="term--${pageName}" name="term" />
<input type="text" class="form-control w-px-400" id="term--${pageName}" name="term" autocomplete="off" />
<!-- 상세 검색조건 버튼 -->
<span class="flr">
<button type="button" class="btn btn-open-detail" data-bs-toggle="collapse" data-bs-target="#searchDetail--${pageName}">
@ -91,15 +89,14 @@
</span>
</div>
</div>
</div>
<!-- / 메인 조건 -->
</div> <!-- 메인 조건 -->
<!-- 상세 조건 -->
<div id="searchDetail--${pageName}" class="container-search container-search-detail collapse">
<div class="row g-1">
<!-- 등록일자, 수정일자 -->
<div class="col-6">
<select class="form-select text-center" id="schRegDateOpt--${pageName}" name="schRegDateOpt">
<select class="form-select w-px-120 text-center" id="schRegDateOpt--${pageName}" name="schRegDateOpt">
<option value="regDt">등록일자</option>
<option value="mdfcnDt">수정일자</option>
</select>
@ -115,20 +112,18 @@
</div>
<!-- 등록자명, 수정자명 -->
<div class="col-6">
<select class="form-select text-center" id="schRgtrOpt--${pageName}" name="schRgtrOpt">
<select class="form-select w-px-120 text-center" id="schRgtrOpt--${pageName}" name="schRgtrOpt">
<option value="rgtr">등록자</option>
<option value="mdfr">수정자</option>
</select>
<input type="hidden" id="schRgtrCd--${pageName}" name="schRgtrCd" />
<input type="text" class="form-control" id="schRgtrNm--${pageName}" name="schRgtrNm" />
<button type="button" class="btn btn-sm btn-outline-dark" id="btnFindUser--${pageName}" title="사용자 검색">
검색
</button>
<input type="text" class="form-control w-px-160" id="schRgtrNm--${pageName}" name="schRgtrNm" />
<button type="button" class="btn btn-sm btn-outline-dark" id="btnFindUser--${pageName}" title="사용자 검색">검색</button>
</div>
</div>
</div> <!-- / 상세 조건 -->
</div> <!-- 상세 조건 -->
</form>
<!-- / 검색 조건 영역 -->
<!-- 검색 조건 영역 -->
<!-- 업무 버튼 및 건수 표시 -->
<div>
@ -139,21 +134,20 @@
<ul class="pagination pagination-primary" id="paging--${pageName}">
</ul>
</div>
<!-- 업무 버튼 -->
<span class="container-window-btn-right">
<!-- 업무 버튼 -->
<button type="button" class="btn btn-primary w-px-120" id="btnHwpSvbtc--${pageName}" title="한글파일 출력">
<button type="button" class="btn btn-primary w-px-120" id="btnPrintHwp--${pageName}" title="한글파일 출력">
한글파일 출력
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnUpdateSvbtc--${pageName}" title="공시송달 수정">
<button type="button" class="btn btn-primary w-px-120" id="btnUpdate--${pageName}" title="공시송달 수정">
공시송달 수정
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnRemoveSvbtc--${pageName}" title="공시송달 삭제">
<button type="button" class="btn btn-primary w-px-120" id="btnRemove--${pageName}" title="공시송달 삭제">
공시송달 삭제
</button>
</span>
</span>
</div>
<!-- / 업무 버튼 및 건수 표시 -->
</div> <!-- 업무 버튼 및 건수 표시 -->
<!-- DataTables(그리드) -->
<div class="card-datatable text-nowrap">
@ -207,12 +201,14 @@
</table>
</div>
</div>
</div> <!-- / DataTables(그리드) -->
</div> <!-- / Wrapper-list -->
</div> <!-- / Card -->
</div> <!-- DataTables(그리드) -->
</div> <!-- <div class="wrapper-list"> -->
</div> <!-- <div class="card"> -->
<!-- Page Body -->
<span id="tempArea--${pageName}" hidden></span>
</div> <!-- / Content -->
</div> <!-- <div class="container-xxl flex-grow-1 px-0"> -->
<!-- Content -->
<div class="content-backdrop fade"></div>
</div>
@ -229,10 +225,8 @@
**************************************************************************/
$(document).ready(function() {
// pageObject
var $P = pageObject["${pageName}"];
let $P = pageObject["${pageName}"];
// URL
$P.PrefixUrl = "/sndb/sndb01";
// FormFields
$P.formFields = new FimsFormFields("#frmSearch--${pageName}");
@ -240,47 +234,47 @@
* DatasetControl
**************************************************************************/
$P.control = new DatasetControl({
prefix : "svbtc"
, prefixName : "공시송달"
, infoSize : "xxl"
, keymapper : info => info ? info.SVBTC_ID : ""
, dataGetter : obj => obj.${infoPrefix}List
, appendData : true
, formats : {
SVBTC_YMD : dateFormat
, TNOCS : numberFormat
, GRAMT : numberFormat
, REG_DT : datetimeFormat
, MDFCN_DT : datetimeFormat
prefix: "svbtc"
, prefixName: "공시송달"
, keymapper: info => info ? info.SVBTC_ID : ""
, dataGetter: obj => obj.${infoPrefix}List
, appendData: true
, infoSize: "xxl"
, formats: {
SVBTC_YMD: dateFormat
, TNOCS: numberFormat
, GRAMT: numberFormat
, REG_DT: datetimeFormat
, MDFCN_DT: datetimeFormat
}
});
// $P.control 설정
$P.control.defaultFetchSize = FETCH_XS; // 1 페이지당 조회되는 자료 건수 index.jsp에서 확인 FETCH_XS = 30
$P.control.untilPageNum = 0; // 현재 페이지 번호
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 완료 여부
$P.control.defaultFetchSize = FETCH_XS; // 1 페이지당 조회되는 자료 건수 index.jsp에서 확인 FETCH_XS = 30
$P.control.untilPageNum = 0; // 현재 페이지 번호
$P.control.beforeCurrent = null;
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 완료 여부
/**************************************************************************
* DatasetControl 이벤트
**************************************************************************/
// Dataset 변경
$P.control.onDatasetChange = obj => {
$P.control.onDatasetChange = (obj) => {
$P.renderList(obj.${infoPrefix}Total);
$("#paging--${pageName}").setPagingInfo({
list : $P.control.dataset
, prefix : "paging--${pageName}"
, start : obj.${infoPrefix}Start
, totalSize : obj.${infoPrefix}Total
, fetchSize : obj.${infoPrefix}Fetch
, func : "pageObject['${pageName}'].control.load({index})"
list: $P.control.dataset
, prefix: "paging--${pageName}"
, start: obj.${infoPrefix}Start
, totalSize: obj.${infoPrefix}Total
, fetchSize: obj.${infoPrefix}Fetch
, func: "pageObject['${pageName}'].control.load({index})"
});
$P.control.tableRenderComplete = true; // dataTables 에 자료 추가 완료
$P.control.tableRenderComplete = true; // dataTables 에 자료 추가 완료
};
// 현재 선택 자료 변경 이벤트
$P.control.onCurrentChange = item => {
$P.control.onCurrentChange = (item) => {
if (!item) return;
let key = item.data.SVBTC_ID;
@ -295,40 +289,44 @@
$("#tbody--${pageName} input[type='checkbox']").each(function() {
let checkbox = $(this);
checkbox.prop("checked", keys.includes(checkbox.val()));
});
$("#btnRemoveSvbtc--${pageName}").prop("disabled", keys.length < 1);
// 삭제 버튼
$("#btnRemove--${pageName}").prop("disabled", keys.length < 1);
// DataTables(그리드) 전체 선택(checkbox)
if (keys.length < 1) {
$("th input[type='checkbox']").prop("checked", false); // 체크 해제
$("th input[type='checkbox']").prop("checked", false); // 체크 해제
} else if (keys.length == ${infoPrefix}List.length) {
$("th input[type='checkbox']").prop("checked", true); // 체크 설정
$("th input[type='checkbox']").prop("checked", true); // 체크 설정
} else {
$("th input[type='checkbox']").prop("checked", false); // 체크 해제
$("th input[type='checkbox']").prop("checked", false); // 체크 해제
}
};
// 공시송달 상세 Info
// 상세정보 Info
$P.control.getInfo = (svbtcId) => {
if (typeof svbtcId == "undefined" || svbtcId == null || svbtcId == "") return;
let params = $P.control.query;
params.callPurpose = "view"; // 호출 용도
params.pageNum = 1; // 페이지 번호
params.svbtcId = svbtcId; // 공시송달 ID
let params = {
title: $P.control.prefixName + " 상세 정보" // 타이틀
, callPurpose: "view" // 호출 용도
, pageNum: 1 // 페이지 번호
, sggCd: $("#sggCd--${pageName}").val() // 시군구 코드
, taskSeCd: $("input[name=taskSeCd]:checked").val() // 업무 구분 코드
, svbtcId: svbtcId // 공시송달 ID
}
ajax.get({
url : $P.control.urls.getInfo
, data : params || {}
, success : resp => {
url: wctx.url("/" + params.taskSeCd + "${infoPrefixUrl}" + "/250/info.do") + "?openerPageName=${pageName}"
, data: params || {}
, success: resp => {
dialog.open({
id : $P.control.prefixed("DtlDialog")
, title : "공시송달 상세 정보"
, content : resp
, size : $P.control.infoSize
id: $P.control.prefixed("DtlDialog--${pageName}")
, title: params.title
, content: resp
, size: $P.control.infoSize
});
}
});
@ -336,18 +334,17 @@
// 삭제 callback
$P.control.onRemove = (resp) => {
let btnTitle = $("#btnRemoveSvbtc--${pageName}").attr("title");
let btnTitle = $("#btnRemove--${pageName}").attr("title");
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, btnTitle);
// 메시지 출력
dialog.alert({
content : showMessage
, onOK : () => { }
content: showMessage
, init: () => { setDialogZindex(); }
, onOK: () => { }
});
if (resp.saved) {
refreshList${pageName}(); // 자료 재조회
}
if (resp.saved) { $P.fnRefreshList(); } // 자료 재조회
}
// 삭제
@ -355,9 +352,9 @@
if (!params) return;
ajax.post({
url : $P.control.urls.remove
, data : params
, success : resp => $P.control.onRemove(resp)
url: wctx.url("/" + params.taskSeCd + "${infoPrefixUrl}" + "/240/remove.do")
, data: params
, success: resp => $P.control.onRemove(resp)
});
}
@ -368,6 +365,7 @@
$P.renderList = (totalSize) => {
let ${infoPrefix}List = $P.control.dataset;
let empty = ${infoPrefix}List.empty;
let clsForTask = $("#frmSearch--${pageName} input[name='taskSeCd']:checked").val().toLowerCase(); // 소문자
let trs = empty ?
[document.getElementById("${infoPrefix}NotFound--${pageName}").innerHTML] <%-- from template#${infoPrefix}NotFound --%>
@ -398,7 +396,7 @@
// DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트
$P.scrollDataList = () => {
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 false
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 false
$P.control.load($P.control.query.pageNum + 1);
}
@ -406,91 +404,53 @@
/**************************************************************************
* 사용자 함수(function)
**************************************************************************/
// callback 사용자 검색
$P.callbackFindUser = (userId, userNm) => {
$("#schRgtrCd--${pageName}").val(userId); // 사용자 ID
$("#schRgtrNm--${pageName}").val(userNm); // 사용자 명
}
// 검색 자료 재조회
$P.fnRefreshList = () => {
$P.control.untilPageNum = $P.control.query.pageNum;
$P.control.query.fetchSize = $P.control.defaultFetchSize * $P.control.query.pageNum;
// 사용자 검색
$P.getFindUser = () => {
let params = {
openerPageName : "${pageName}"
, callbackFuncName : "pageObject['${pageName}']['callbackFindUser']"
}
$P.control.load(1);
}
ajax.get({
url : wctx.url("/user/user02/010/main.do")
, data : params || {}
, success : resp => {
dialog.open({
id : "userDialog"
, title : "사용자 검색"
, content : resp
, size : "lg"
});
}
});
// 사용자검색 callback
$P.callbackFindUser = (userId, userNm) => {
$("#schRgtrCd--${pageName}").val(userId); // 사용자 ID
$("#schRgtrNm--${pageName}").val(userNm); // 사용자 명
}
// 한글파일 출력
// 한글파일 출력 callback
$P.callbackDocNoTtl = (obj) => {
// 서버에 전송할 data(파라미터) 생성
let params = {
sggCd : $P.control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd : $P.control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, svbtcId : $P.control.dataset.getValue("SVBTC_ID") // 반송 ID
, sndngSeCd : $P.control.dataset.getValue("SNDNG_SE_CD") // 발송 구분 코드
sggCd: $P.control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd: $P.control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, svbtcId: $P.control.dataset.getValue("SVBTC_ID") // 반송 ID
, sndngSeCd: $P.control.dataset.getValue("SNDNG_SE_CD") // 발송 구분 코드
};
params.printDocNo = obj.docNo; // 문서 번호
params.printTtlNm = obj.ttlNm; // 제목
params.printSvbtcDate = obj.textDate; // 공고 기한
params.printDocNo = obj.docNo; // 문서 번호
params.printTtlNm = obj.ttlNm; // 제목
params.printSvbtcDate = obj.textDate; // 공고 기한
let url = wctx.url("/" + params.taskSeCd + $P.PrefixUrl + "/240/makeSvbtcHwp.do");
let url = wctx.url("/" + params.taskSeCd + "${infoPrefixUrl}" + "/240/makeSvbtcHwp.do");
let parameter = toQuery(params);
document.location.href = url + "?" + parameter;
}
// 공시송달 수정
$P.getSvbtcInfo = (params) => {
if (!params) return;
ajax.get({
url : wctx.url("/" + params.taskSeCd + $P.PrefixUrl + "/260/info.do")
, data : params || {}
, success : resp => {
dialog.open({
id : $P.control.prefixed("Dialog")
, title : params.title
, content : resp
, size : "md"
, onClose : () => { $P.refreshList(); }
});
}
});
}
// 삭제 사유 callback
// 삭제사유 callback
$P.callbackRsn = (obj) => {
// 서버에 전송할 data(파라미터) 생성
let params = {};
params[$P.control.prefixed("IDs")] = selected.join(","); // IDs
params.delRsn = obj.reason; // 삭제 사유
let selected = $P.control.dataset.getKeys("selected");
$P.control.remove(params);
}
params.sggCd = $("#sggCd--${pageName}").val(); // 시군구 코드
params.taskSeCd = $("input[name=taskSeCd]:checked").val(); // 업무 구분 코드
params[$P.control.prefixed("Ids")] = selected.join(","); // 공시송달 IDs
params.delRsn = obj.reason; // 삭제 사유
// 검색 자료 재조회
$P.refreshList = () => {
$P.control.untilPageNum = $P.control.query.pageNum;
$P.control.query.fetchSize = $P.control.defaultFetchSize * $P.control.query.pageNum;
$P.control.load(1);
$P.control.remove(params);
}
/**************************************************************************
@ -504,9 +464,7 @@
}
// 초기 기본 설정
$P.initForm();
// 기본 데이터 설정
$P.initData(taskSeCd);
$P.initForm(taskSeCd);
// 업무 구분별 설정
$P.setTask(taskSeCd);
@ -514,12 +472,34 @@
$P.control.dataset.clear();
}
// 사용자검색 버튼 클릭 이벤트
$P.fnGetFindUser = () => {
let params = {
openerPageName: "${pageName}"
, callbackFuncName: "pageObject['${pageName}']['callbackFindUser']"
}
ajax.get({
url: wctx.url("/user/user02/010/main.do")
, data: params || {}
, success: resp => {
dialog.open({
id: "userDialog"
, title: "사용자 검색"
, content: resp
, size: "lg"
, init: () => { setDialogZindex(); }
});
}
});
}
// 검색 버튼 클릭 이벤트
$P.fnSearchList = () => {
// 검색조건
$P.control.query = $P.formFields.get();
$P.control.query.fetchSize = $P.control.defaultFetchSize; // 한번에 조회되는 자료 건수
$P.control.query.delYn = "N"; // 삭제 여부
$P.control.query = $P.formFields.get(); // 검색 조건
$P.control.query.fetchSize = $P.control.defaultFetchSize; // 한번에 조회되는 자료 건수
$P.control.query.delYn = "N"; // 삭제 여부
$P.control.load(1);
}
@ -528,10 +508,9 @@
$P.fnExcel = () => {
if ($P.control.dataset.empty) {
dialog.alert({
content : "검색된 자료가 없습니다."
, onOK : () => { }
content: "검색된 자료가 없습니다."
, onOK: () => { }
});
return;
}
@ -543,19 +522,13 @@
$P.control.download();
}
// 사용자 조회 버튼 클릭 이벤트
$P.fnFindUser = () => {
$P.getFindUser();
}
// 한글파일 출력 버튼 이벤트
$P.fnHwpSvbtc = async(title) => {
// 한글 파일 출력 버튼 이벤트
$P.fnPrintHwp = async(title) => {
if ($P.control.dataset.empty) {
dialog.alert({
content : "검색된 자료가 없습니다."
, onOK : () => { }
content: "검색된 자료가 없습니다."
, onOK: () => { }
});
return;
}
@ -565,74 +538,91 @@
let textDate = DateUtil.getDateDay(0).date + " ~ " + DateUtil.getDateDay(15).date + " (15일간)";
// 문서번호, 제목, 공고기한 입력
var resp = await fetch(wctx.url("/resources/html/inputDocNoTtlDialog.html"));
var template = await resp.text();
let resp = await fetch(wctx.url("/resources/html/inputDocNoTtlDialog.html"));
let template = await resp.text();
dialog.open({
id : "inputDocNoTtlDialog",
title: title,
size : "lg",
content: template,
init : () => {
id: "inputDocNoTtlDialog"
, title: title
, size: "lg"
, content: template
, init: () => {
setDialogZindex();
$("#docNo").val(docNo);
$("#ttlNm").val(ttlNm);
$("#textDate").val(textDate);
},
onOK : () => {
}
, onOK: () => {
$P.callbackDocNoTtl({
"docNo" : $("#docNo").val(),
"ttlNm" : $("#ttlNm").val(),
"textDate" : $("#textDate").val()
"docNo": $("#docNo").val()
, "ttlNm": $("#ttlNm").val()
, "textDate": $("#textDate").val()
});
}
});
}
// 수정 버튼 이벤트
$P.fnUpdateSvbtc = (title) => {
$P.fnUpdate = (title) => {
// 공시송달 ID
let svbtcId = $P.control.dataset.getValue("SVBTC_ID");
// 공시송달 ID 가 없다면.. return
if (typeof svbtcId == "undefined" || svbtcId == null || svbtcId == "") return;
let params = {
title : title
, callPurpose : "update"
, svbtcId : svbtcId // 공시송달 ID
, sggCd : $P.control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd : $P.control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, sndngSeCd : $P.control.dataset.getValue("SNDNG_SE_CD") // 발송 구분 코드
title: title
, callPurpose: "update"
, sggCd: $P.control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd: $P.control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, sndngSeCd: $P.control.dataset.getValue("SNDNG_SE_CD") // 발송 구분 코드
, svbtcId: svbtcId // 공시송달 ID
};
$P.getSvbtcInfo(params);
ajax.get({
url: wctx.url("/" + params.taskSeCd + "${infoPrefixUrl}" + "/260/info.do") + "?openerPageName=${pageName}"
, data: params
, success: resp => {
dialog.open({
id: $P.control.prefixed("Dialog--${pageName}")
, title: params.title
, content: resp
, size: "md"
, onClose : () => { $P.fnRefreshList(); }
});
}
});
}
// 삭제 버튼 이벤트
$P.fnRemoveSvbtc = (title) => {
$P.fnRemove = (title) => {
// 선택 자료
let selected = $P.control.dataset.getKeys("selected");
if (selected.length < 1) return;
if (selected.length < 1) {
dialog.alert({
content: "선택하신 " + $P.control.prefixName + " 정보가 없습니다."
, onOK: () => { }
});
return;
}
// 삭제 메세지 확인
dialog.alert({
content : "선택하신 " + selected.length + "건의 " + $P.control.prefixName + " 정보를 삭제하시겠습니까?"
, onOK : async() => {
content: "선택하신 " + selected.length + "건의 " + $P.control.prefixName + " 정보를 삭제하시겠습니까?"
, onOK: async() => {
// 삭제 사유 입력
var resp = await fetch(wctx.url("/resources/html/inputRsnDialog.html"));
var template = await resp.text();
let resp = await fetch(wctx.url("/resources/html/inputRsnDialog.html"));
let template = await resp.text();
dialog.open({
id : "inputDelRsnDialog",
title: title,
size : "lg",
content: template,
init : () => {
setDialogZindex();
},
onOK : () => {
$P.callbackRsn({ reason : $("#reason").val() });
id: "inputDelRsnDialog"
, title: title
, size: "lg"
, content: template
, init: () => { setDialogZindex(); }
, onOK: () => {
$P.callbackRsn({ reason: $("#reason").val() });
}
});
}
@ -648,7 +638,7 @@
$("#btnReset--${pageName}").on("click", () => $P.fnResetAndChangeBiz()); // 초기화
$("#btnSearch--${pageName}").on("click", () => $P.fnSearchList()); // 검색
$("#btnExcel--${pageName}").on("click", () => $P.fnExcel()); // 엑셀
$("#btnFindUser--${pageName}").on("click", () => $P.fnFindUser()); // 사용자 검색
$("#btnFindUser--${pageName}").on("click", () => $P.fnGetFindUser()); // 사용자 검색
// 동적검색에서 엔터(Enter) 키를 누르면 검색한다.
$("#term--${pageName}").keypress(function(e) {
@ -670,17 +660,15 @@
});
});
// 한글파일 출력 버튼 이벤트
$("#btnHwpSvbtc--${pageName}").on("click", function() {
$P.fnHwpSvbtc($(this).attr("title"));
// 업무 버튼 이벤트
$("#btnPrintHwp--${pageName}").on("click", function() {
$P.fnPrintHwp($(this).attr("title")); // 한글파일 출력 버튼 이벤트
});
// 공시송달 수정 버튼 이벤트
$("#btnUpdateSvbtc--${pageName}").on("click", function() {
$P.fnUpdateSvbtc($(this).attr("title"));
$("#btnUpdate--${pageName}").on("click", function() {
$P.fnUpdate($(this).attr("title")); // 공시송달 수정 버튼 이벤트
});
// 공시송달 삭제 버튼 이벤트
$("#btnRemoveSvbtc--${pageName}").on("click", function() {
$P.fnRemoveSvbtc($(this).attr("title"));
$("#btnRemove--${pageName}").on("click", function() {
$P.fnRemove($(this).attr("title")); // 공시송달 삭제 버튼 이벤트
});
// DataTables width 변경 조정
@ -691,7 +679,7 @@
}
// 초기 화면 설정
$P.initForm = () => {
$P.initForm = (taskSeCd) => {
// 화면 초기화
$("#frmSearch--${pageName}")[0].reset();
@ -708,41 +696,20 @@
$(this).prop("disabled", "true");
});
// 달력 초기화
initDatepicker("frmSearch--${pageName}");
$("#schSvbtcYmdFrom--${pageName}").datepicker("setDate", new Date());
$("#schSvbtcYmdTo--${pageName}").datepicker("setDate", new Date());
// 동적 검색
$("#byOutput--${pageName}").val("동적 검색");
// 사용자 이름
$("#schRgtrNm--${pageName}").prop("readonly", true);
}
// 기본 데이터 설정
$P.initData = (taskSeCd) => {
// 시군구 코드
$("#sggCd--${pageName}").val("${sggCd}");
// 업무 구분 코드
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + taskSeCd + "']").prop("checked", true);
// 일자
// 기본 데이터 설정
$("#sggCd--${pageName}").val("${sggCd}"); // 시군구 코드
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + taskSeCd + "']").prop("checked", true); // 업무 구분 코드
initDatepicker("frmSearch--${pageName}"); // 달력 초기화
$("#schSvbtcYmdFrom--${pageName}").datepicker("setDate", DateUtil.getDateDay(-7).date);
$("#schSvbtcYmdTo--${pageName}").datepicker("setDate", new Date());
$("#byOutput--${pageName}").val("동적 검색"); // 동적 검색
$("#schRgtrNm--${pageName}").prop("readonly", true); // 사용자 이름
}
// 업무 구분별 설정
$P.setTask = (taskSeCd) => {
// URL 설정
$P.setURL(taskSeCd);
}
// 업무구분에 따른 URL 설정
$P.setURL = (taskSeCd) => {
$P.control.urls.load = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/240/list.do"); // 조회
$P.control.urls.remove = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/240/remove.do"); // 삭제
$P.control.urls.getInfo = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/250/info.do"); // 공시송달 세부내용
// 업무구분에 따른 URL 설정
$P.control.urls.load = wctx.url("/" + taskSeCd + "${infoPrefixUrl}" + "/240/list.do"); // 조회
}
/**************************************************************************

@ -1,139 +1,140 @@
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
<c:set var="prefixName" scope="request">공시송달 상세</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="wrapper-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
<c:set var="prefixName" scope="request">공시송달 상세</c:set>
<!-- Page Body -->
<div class="card">
<div class="wrapper-pop">
<!-- 입력 영역 -->
<form id="frmEdit--${pageName}" name="frmEdit">
<input type="hidden" id="svbtcId--${pageName}" name="svbtcId" />
</form> <!-- /입력 영역 -->
<!-- 업무 버튼 및 건수 표시 -->
<div>
<span class="container-page-btn">
<!-- 건수, 페이지 표시 -->
<div class="d-flex flex-row justify-content-between">
<span class="dataTables_info" id="paging--${pageName}PagingInfo" role="status" aria-live="polite"></span>
<ul class="pagination pagination-primary" id="paging--${pageName}">
</ul>
</div>
<span class="container-window-btn-right">
<!-- 업무 버튼 -->
<button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀">
엑셀
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnHwpSvbtc--${pageName}" title="한글파일 출력">
한글파일 출력
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnRemoveSvbtc--${pageName}" title="공시송달 삭제">
공시송달 삭제
</button>
</span>
</span>
</div> <!-- / 업무 버튼 및 건수 표시 -->
<!-- DataTables(그리드) -->
<div class="card-datatable text-nowrap">
<div class="dataTables_wrapper dt-bootstrap5 no-footer" id="DataTables_Table_0_wrapper--${pageName}">
<div class="table-responsive ox-scroll oy-scroll h-px-400" id="table-responsive--${pageName}">
<table class="table-layout-fixed dataTable datatables-ajax table table-bordered no-footer" id="DataTables_Table_0--${pageName}" aria-describedby="DataTables_Table_0_info">
<thead class="sticky-thead">
<tr id="theadTr--${pageName}"
data-by="by--${pageName}" data-by-output="byOutput--${pageName}" data-main-option="mainOption--${pageName}" data-sub-option="subOption--${pageName}">
<th class="cmn" style="width: 56px;"><input type="checkbox" class="form-check-input" onchange="pageObject['${pageName}'].control.select(this.checked);" /></th>
<th class="cmn" style="width: 120px;">발송상태</th>
<th class="cmn" style="width: 120px;">공시송달일자</th>
<th class="cmn" style="width: 160px;">등기번호</th>
<th class="cmn" style="width: 120px;">발송일자</th>
<th class="cmn" style="width: 120px;">발송종료일자</th>
<th class="cmn" style="width: 200px;">성명</th>
<th class="cmn" style="width: 100px;">우편번호</th>
<th class="cmn" style="width: 280px;">주소</th>
<th class="cmn" style="width: 320px;">상세주소</th>
<th class="cmn" style="width: 120px;">배달일자</th>
<th class="cmn" style="width: 120px;">배달시각</th>
<th class="cmn" style="width: 200px;">미배달사유</th>
<th class="cmn" style="width: 200px;">수령인</th>
<th class="cmn" style="width: 200px;">수령인관계</th>
<th class="cmn" style="width: 180px;">단속일시</th>
<th class="cmn" style="width: 140px;">차량번호</th>
<th class="cmn" style="width: 160px;">법정동</th>
<th class="cmn" style="width: 280px;">단속장소</th>
<th class="cmn" style="width: 100px;">회계연도</th>
<th class="cmn" style="width: 100px;">부과번호</th>
<th class="cmn" style="width: 120px;">부과일자</th>
<th class="cmn" style="width: 120px;">납기일자</th>
<th class="cmn" style="width: 120px;">과태료금액</th>
<th class="cmn" style="width: 120px;">본세</th>
<th class="cmn" style="width: 120px;">가산금</th>
<th class="cmn" style="width: 120px;">미납금액</th>
<th class="cmn" style="width: 180px;">등록일시</th>
<th class="cmn" style="width: 140px;">등록사용자</th>
<th class="cmn" style="width: 180px;">수정일시</th>
<th class="cmn" style="width: 140px;">수정사용자</th>
<th class="cmn dummy-th"></th>
</tr>
</thead>
<tbody id="tbody--${pageName}">
</tbody>
<template id="${infoPrefix}Row--${pageName}">
<tr data-key="{SNDNG_DTL_ID}">
<td class="cmn text-center"><input type="checkbox" class="form-check-input" name="gridCheckbox" value="{SNDNG_DTL_ID}" onchange="pageObject['${pageName}'].control.select('{SNDNG_DTL_ID}', this.checked);"></td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_DTL_STTS_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SVBTC_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RG_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_END_YMD}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_ZIP}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_ADDR}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_DTL_ADDR}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DLVR_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DLVR_TM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{UNDLVR_RSN_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ACTL_RCPN_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_REL_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_DT}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{VHRNO}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_STDG_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_PLC}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{FYR}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DUDT_YMD}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_AMT}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{PCPTAX}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{ADAMT}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{SUM_AMT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{REG_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGTR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFR_NM}</td>
<td class="cmn dummy-td"></td>
</tr>
</template>
<template id="${infoPrefix}NotFound--${pageName}">
<tr class="odd">
<td valign="top" colspan="32" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
</template>
</table>
</div>
<!-- 입력 영역 -->
<form id="frmEdit--${pageName}" name="frmEdit">
<input type="hidden" id="svbtcId--${pageName}" name="svbtcId" />
</form>
<!-- 입력 영역 -->
<!-- 업무 버튼 및 건수 표시 -->
<div>
<span class="container-page-btn">
<!-- 건수, 페이지 표시 -->
<div class="d-flex flex-row justify-content-between">
<span class="dataTables_info" id="paging--${pageName}PagingInfo" role="status" aria-live="polite"></span>
<ul class="pagination pagination-primary" id="paging--${pageName}">
</ul>
</div>
</div> <!-- / DataTables(그리드) -->
</div> <!-- <div class="wrapper-list"> -->
<!-- 업무 버튼 -->
<span class="container-window-btn-right">
<button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀">
엑셀
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnPrintHwp--${pageName}" title="한글파일 출력">
한글파일 출력
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnRemove--${pageName}" title="공시송달 삭제">
공시송달 삭제
</button>
</span>
</span>
</div> <!-- 업무 버튼 및 건수 표시 -->
<!-- DataTables(그리드) -->
<div class="card-datatable text-nowrap">
<div class="dataTables_wrapper dt-bootstrap5 no-footer" id="DataTables_Table_0_wrapper--${pageName}">
<div class="table-responsive ox-scroll oy-scroll h-px-400" id="table-responsive--${pageName}">
<table class="table-layout-fixed dataTable datatables-ajax table table-bordered no-footer" id="DataTables_Table_0--${pageName}" aria-describedby="DataTables_Table_0_info">
<thead class="sticky-thead">
<tr id="theadTr--${pageName}"
data-by="by--${pageName}" data-by-output="byOutput--${pageName}" data-main-option="mainOption--${pageName}" data-sub-option="subOption--${pageName}">
<th class="cmn" style="width: 56px;"><input type="checkbox" class="form-check-input" onchange="pageObject['${pageName}'].control.select(this.checked);" /></th>
<th class="cmn" style="width: 120px;">발송상태</th>
<th class="cmn" style="width: 120px;">공시송달일자</th>
<th class="cmn" style="width: 160px;">등기번호</th>
<th class="cmn" style="width: 120px;">발송일자</th>
<th class="cmn" style="width: 120px;">발송종료일자</th>
<th class="cmn" style="width: 200px;">성명</th>
<th class="cmn" style="width: 100px;">우편번호</th>
<th class="cmn" style="width: 280px;">주소</th>
<th class="cmn" style="width: 320px;">상세주소</th>
<th class="cmn" style="width: 120px;">배달일자</th>
<th class="cmn" style="width: 120px;">배달시각</th>
<th class="cmn" style="width: 200px;">미배달사유</th>
<th class="cmn" style="width: 200px;">수령인</th>
<th class="cmn" style="width: 200px;">수령인관계</th>
<th class="cmn" style="width: 180px;">단속일시</th>
<th class="cmn" style="width: 140px;">차량번호</th>
<th class="cmn" style="width: 160px;">법정동</th>
<th class="cmn" style="width: 280px;">단속장소</th>
<th class="cmn" style="width: 100px;">회계연도</th>
<th class="cmn" style="width: 100px;">부과번호</th>
<th class="cmn" style="width: 120px;">부과일자</th>
<th class="cmn" style="width: 120px;">납기일자</th>
<th class="cmn" style="width: 120px;">과태료금액</th>
<th class="cmn" style="width: 120px;">본세</th>
<th class="cmn" style="width: 120px;">가산금</th>
<th class="cmn" style="width: 120px;">미납금액</th>
<th class="cmn" style="width: 180px;">등록일시</th>
<th class="cmn" style="width: 140px;">등록사용자</th>
<th class="cmn" style="width: 180px;">수정일시</th>
<th class="cmn" style="width: 140px;">수정사용자</th>
<th class="cmn dummy-th"></th>
</tr>
</thead>
<tbody id="tbody--${pageName}">
</tbody>
<template id="${infoPrefix}Row--${pageName}">
<tr data-key="{SNDNG_DTL_ID}">
<td class="cmn text-center"><input type="checkbox" class="form-check-input" name="gridCheckbox" value="{SNDNG_DTL_ID}" onchange="pageObject['${pageName}'].control.select('{SNDNG_DTL_ID}', this.checked);"></td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_DTL_STTS_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SVBTC_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RG_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_END_YMD}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_ZIP}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_ADDR}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_DTL_ADDR}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DLVR_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DLVR_TM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{UNDLVR_RSN_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ACTL_RCPN_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_REL_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_DT}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{VHRNO}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_STDG_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_PLC}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{FYR}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DUDT_YMD}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_AMT}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{PCPTAX}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{ADAMT}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{SUM_AMT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{REG_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGTR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFR_NM}</td>
<td class="cmn dummy-td"></td>
</tr>
</template>
<template id="${infoPrefix}NotFound--${pageName}">
<tr class="odd">
<td valign="top" colspan="32" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
</template>
</table>
</div>
</div>
</div> <!-- DataTables(그리드) -->
</div> <!-- <div class="card"> -->
<!-- Page Body -->
<span id="tempArea--${pageName}" hidden></span>
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
<!-- Content -->
</div>
<!-- / inner page html <div class="content-wrapper"> -->
@ -148,10 +149,8 @@
**************************************************************************/
$(document).ready(function() {
// pageObject
var $P = pageObject["${pageName}"];
let $P = pageObject["${pageName}"];
// URL
$P.PrefixUrl = "/sndb/sndb01";
// infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정)
$P.callPurpose = "${callPurpose}";
// FormFields
@ -163,30 +162,30 @@
* DatasetControl
**************************************************************************/
$P.control = new DatasetControl({
prefix : "svbtcDtl"
, prefixName : "공시송달 상세 정보"
, keymapper : info => info ? info.SNDNG_DTL_ID : ""
, dataGetter : obj => obj.svbtcDtlList
, appendData : true
, formats : {
SVBTC_YMD : dateFormat
, SNDNG_YMD : dateFormat
, SNDNG_END_YMD : dateFormat
, DLVR_YMD : dateFormat
, LEVY_YMD : dateFormat
, DUDT_YMD : dateFormat
, PCPTAX : numberFormat
, ADAMT : numberFormat
, SUM_AMT : numberFormat
, REG_DT : datetimeFormat
, MDFCN_DT : datetimeFormat
prefix: "svbtcDtl"
, prefixName: "공시송달 상세 정보"
, keymapper: info => info ? info.SNDNG_DTL_ID : ""
, dataGetter: obj => obj.${infoPrefix}List
, appendData: true
, formats: {
SVBTC_YMD: dateFormat
, SNDNG_YMD: dateFormat
, SNDNG_END_YMD: dateFormat
, DLVR_YMD: dateFormat
, LEVY_YMD: dateFormat
, DUDT_YMD: dateFormat
, PCPTAX: numberFormat
, ADAMT: numberFormat
, SUM_AMT: numberFormat
, REG_DT: datetimeFormat
, MDFCN_DT: datetimeFormat
}
});
// $P.control 설정
$P.control.defaultFetchSize = FETCH_XS; // 1 페이지당 조회되는 자료 건수 index.jsp에서 확인 FETCH_XS = 30
$P.control.untilPageNum = 0; // 현재 페이지 번호
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 완료 여부
$P.control.defaultFetchSize = FETCH_XS; // 1 페이지당 조회되는 자료 건수 index.jsp에서 확인 FETCH_XS = 30
$P.control.untilPageNum = 0; // 현재 페이지 번호
$P.control.beforeCurrent = null;
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 완료 여부
/**************************************************************************
* DatasetControl 이벤트
@ -196,15 +195,15 @@
$P.renderList(obj.${infoPrefix}Total);
$("#paging--${pageName}").setPagingInfo({
list : $P.control.dataset
, prefix : "paging--${pageName}"
, start : obj.${infoPrefix}Start
, totalSize : obj.${infoPrefix}Total
, fetchSize : obj.${infoPrefix}Fetch
, func : "pageObject['${pageName}'].control.load({index})"
list: $P.control.dataset
, prefix: "paging--${pageName}"
, start: obj.${infoPrefix}Start
, totalSize: obj.${infoPrefix}Total
, fetchSize: obj.${infoPrefix}Fetch
, func: "pageObject['${pageName}'].control.load({index})"
});
$P.control.tableRenderComplete = true; // dataTables 에 자료 추가 완료
$P.control.tableRenderComplete = true; // dataTables 에 자료 추가 완료
};
// 현재 선택 자료 변경 이벤트
@ -223,37 +222,35 @@
$("#tbody--${pageName} input[type='checkbox']").each(function() {
let checkbox = $(this);
checkbox.prop("checked", keys.includes(checkbox.val()));
});
// 선택 대상 등록 버튼
$("#btnRemoveSvbtc--${pageName}").prop("disabled", keys.length < 1);
$("#btnRemove--${pageName}").prop("disabled", keys.length < 1);
// DataTables(그리드) 전체 선택(checkbox)
if (keys.length < 1) {
$("th input[type='checkbox']").prop("checked", false); // 체크 해제
$("th input[type='checkbox']").prop("checked", false); // 체크 해제
} else if (keys.length == ${infoPrefix}List.length) {
$("th input[type='checkbox']").prop("checked", true); // 체크 설정
$("th input[type='checkbox']").prop("checked", true); // 체크 설정
} else {
$("th input[type='checkbox']").prop("checked", false); // 체크 해제
$("th input[type='checkbox']").prop("checked", false); // 체크 해제
}
};
// 삭제 callback
$P.control.onRemove = (resp) => {
let btnTitle = $("#btnRemoveSvbtc--${pageName}").attr("title");
let btnTitle = $("#btnRemove--${pageName}").attr("title");
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, btnTitle);
// 메시지 출력
dialog.alert({
content : showMessage
, onOK : () => { }
content: showMessage
, init: () => { setDialogZindex(); }
, onOK: () => { }
});
if (resp.saved) {
$P.refreshList(); // 자료 재조회
}
if (resp.saved) { $P.fnRefreshList(); } // 자료 재조회
}
// 삭제
@ -261,9 +258,9 @@
if (!params) return;
ajax.post({
url : $P.control.urls.remove
, data : params
, success : resp => $P.control.onRemove(resp)
url: wctx.url("/" + params.taskSeCd + "${infoPrefixUrl}" + "/250/remove.do")
, data: params || {}
, success: resp => $P.control.onRemove(resp)
});
}
@ -274,6 +271,7 @@
$P.renderList = (totalSize) => {
let ${infoPrefix}List = $P.control.dataset;
let empty = ${infoPrefix}List.empty;
let clsForTask = $("input[name=taskSeCd]:checked").val()
let trs = empty ?
[document.getElementById("${infoPrefix}NotFound--${pageName}").innerHTML] : <%-- from template#${infoPrefix}NotFound --%>
@ -295,89 +293,93 @@
$P.control.untilPageNum = 0;
}
// checkbox 체크 해제
$("th input[type='checkbox']").prop("checked", false);
//보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked"));
}
// DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트
$P.scrollDataList = () => {
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 false
$P.control.tableRenderComplete = false; // dataTables 에 자료 추가 false
$P.control.load($P.control.query.pageNum + 1);
}
/**************************************************************************
* 사용자 함수(function)
**************************************************************************/
// 개별총정보 dialog
// DataTables에 더블 클릭시 개별총정보 dialog
$P.getTotalInfo = (crdnId) => {
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return;
let params = {
callControlName : "pageObject['${pageName}'].control"
, callPurpose : "view"
, crdnId : crdnId
, sggCd : $P.control.dataset.getValue("SGG_CD")
, taskSeCd : $P.control.dataset.getValue("TASK_SE_CD")
callControlName: "pageObject['${pageName}'].control"
, sggCd: $P.control.dataset.getValue("SGG_CD")
, taskSeCd: $P.control.dataset.getValue("TASK_SE_CD")
, crdnId: crdnId
}
ajax.get({
url : wctx.url("/" + params.taskSeCd + "/sprt/sprt02/010/main.do")
, data : params
, success : resp => {
url: wctx.url("/" + params.taskSeCd + "/sprt/sprt02/010/main.do")
, data: params
, success: resp => {
dialog.open({
id : "totalInfoMainDialog"
, title : "개별총정보"
, content : resp
, size : "xxl"
id: "totalInfoMainDialog"
, title: "개별총정보"
, content: resp
, size: "xxl"
});
}
});
}
// 한글파일 출력
/**************************************************************************
* 사용자 함수(function)
**************************************************************************/
// 검색 자료 재조회
$P.fnRefreshList = () => {
$P.control.untilPageNum = $P.control.query.pageNum;
$P.control.query.fetchSize = $P.control.defaultFetchSize * $P.control.query.pageNum;
$P.control.load(1);
}
// 한글파일 출력 callback
$P.callbackDocNoTtl = (obj) => {
let selected = $P.control.dataset.getKeys("selected");
// 서버에 전송할 data(파라미터) 생성
let params = {
sggCd : $P.control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd : $P.control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, svbtcId : $P.control.dataset.getValue("SVBTC_ID") // 반송 ID
sggCd: $P.control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd: $P.control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, svbtcId: $P.control.dataset.getValue("SVBTC_ID") // 반송 ID
, sndngSeCd: $P.control.dataset.getValue("SNDNG_SE_CD") // 발송 구분 코드
};
params.sndngDtlIds = selected.join(","); // 발송 상세 Ids
params.printDocNo = obj.docNo; // 문서 번호
params.printTtlNm = obj.ttlNm; // 제목
params.printSvbtcDate = obj.textDate; // 공고 기한
params.sndngDtlIds = selected.join(","); // 발송 상세 Ids
params.printDocNo = obj.docNo; // 문서 번호
params.printTtlNm = obj.ttlNm; // 제목
params.printSvbtcDate = obj.textDate; // 공고 기한
let url = wctx.url("/" + params.taskSeCd + $P.PrefixUrl + "/240/makeSvbtcHwp.do");
let url = wctx.url("/" + params.taskSeCd + "${infoPrefixUrl}" + "/240/makeSvbtcHwp.do");
let parameter = toQuery(params);
document.location.href = url + "?" + parameter;
}
// 삭제 사유 callback
// 삭제사유 callback
$P.callbackRsn = (obj) => {
let selected = $P.control.dataset.getKeys("selected");
// 서버에 전송할 data(파라미터) 생성
let params = {};
params.sndngDtlIds = selected.join(","); // 발송 상세 IDs
params.delRsn = obj.reason; // 삭제 사유
$P.control.remove(params);
}
let selected = $P.control.dataset.getKeys("selected");
// 검색 자료 재조회
$P.refreshList = () => {
$P.control.untilPageNum = $P.control.query.pageNum;
$P.control.query.fetchSize = $P.control.defaultFetchSize * $P.control.query.pageNum;
params.sggCd = $P.mainQuery.sggCd; // 시군구 코드
params.taskSeCd = $P.mainQuery.taskSeCd; // 업무 구분 코드
params.svbtcId = $P.mainQuery.svbtcId // 공시송달 ID
params.sndngDtlIds = selected.join(","); // 발송 상세 IDs
params.delRsn = obj.reason; // 삭제 사유
$P.control.load(1);
$P.control.remove(params);
}
/**************************************************************************
@ -387,10 +389,9 @@
$P.fnExcel = () => {
if ($P.control.dataset.empty) {
dialog.alert({
content : "검색된 자료가 없습니다."
, onOK : () => { }
content: "검색된 자료가 없습니다."
, onOK: () => { }
});
return;
}
@ -403,63 +404,75 @@
}
// 한글파일 출력 버튼 이벤트
$P.fnHwpSvbtc = async(title) => {
$P.fnPrintHwp = async(title) => {
if ($P.control.dataset.empty) {
dialog.alert({
content: "검색된 자료가 없습니다."
, onOK: () => { }
});
return;
}
// 문서번호, 제목, 공고기한 입력
let docNo = $P.control.dataset.getValue("DOC_NO");
let ttlNm = $P.control.dataset.getValue("TASK_SE_NM") + " 과태료 처분에 대한 " + $P.control.dataset.getValue("TTL_NM");
let textDate = DateUtil.getDateDay(0).date + " ~ " + DateUtil.getDateDay(15).date + " (15일간)";
// 문서번호, 제목, 공고기한 입력
var resp = await fetch(wctx.url("/resources/html/inputDocNoTtlDialog.html"));
var template = await resp.text();
let resp = await fetch(wctx.url("/resources/html/inputDocNoTtlDialog.html"));
let template = await resp.text();
dialog.open({
id : "inputDocNoTtlDialog",
title: title,
size : "lg",
content: template,
init : () => {
id: "inputDocNoTtlDialog"
, title: title
, size: "lg"
, content: template
, init: () => {
setDialogZindex();
$("#docNo").val(docNo);
$("#ttlNm").val(ttlNm);
$("#textDate").val(textDate);
},
onOK : () => {
}
, onOK: () => {
$P.callbackDocNoTtl({
"docNo" : $("#docNo").val(),
"ttlNm" : $("#ttlNm").val(),
"textDate" : $("#textDate").val()
"docNo": $("#docNo").val()
, "ttlNm": $("#ttlNm").val()
, "textDate": $("#textDate").val()
});
}
});
}
// 삭제 버튼 이벤트
$P.fnRemoveSvbtc = (title) => {
$P.fnRemove = (title) => {
// 선택 자료
let selected = $P.control.dataset.getKeys("selected");
if (selected.length < 1) return;
if (selected.length < 1) {
dialog.alert({
content: "선택하신 " + $P.control.prefixName + " 정보가 없습니다."
, onOK: () => { }
});
return;
}
// 삭제 메세지 확인
dialog.alert({
content : "선택하신 " + selected.length + "건의 " + $P.control.prefixName + " 정보를 삭제하시겠습니까?"
, onOK : async() => {
content: "선택하신 " + selected.length + "건의 " + $P.control.prefixName + " 정보를 삭제하시겠습니까?"
, onOK: async() => {
// 삭제 사유 입력
var resp = await fetch(wctx.url("/resources/html/inputRsnDialog.html"));
var template = await resp.text();
let resp = await fetch(wctx.url("/resources/html/inputRsnDialog.html"));
let template = await resp.text();
dialog.open({
id : "inputDelRsnDialog",
title: title,
size : "lg",
content: template,
init : () => {
setDialogZindex();
},
onOK : () => {
$P.callbackRsn({ reason : $("#reason").val() });
id: "inputDelRsnDialog"
, title: title
, size: "lg"
, content: template
, init: () => { setDialogZindex(); }
, onOK: () => {
$P.callbackRsn({ reason: $("#reason").val() });
}
});
}
@ -472,15 +485,14 @@
// 이벤트
$P.setEvent = () => {
// 기본 버튼 이벤트
$("#btnExcel--${pageName}").on("click", () => $P.fnExcel()); // 엑셀
$("#btnExcel--${pageName}").on("click", () => $P.fnExcel()); // 엑셀
// 한글파일 출력 버튼 이벤트
$("#btnHwpSvbtc--${pageName}").on("click", function() {
$P.fnHwpSvbtc($(this).attr("title"));
// 업무 버튼 이벤트
$("#btnPrintHwp--${pageName}").on("click", function() {
$P.fnPrintHwp($(this).attr("title")); // 한글파일 출력
});
// 공시송달 삭제 버튼 이벤트
$("#btnRemoveSvbtc--${pageName}").on("click", function() {
$P.fnRemoveSvbtc($(this).attr("title"));
$("#btnRemove--${pageName}").on("click", function() {
$P.fnRemove($(this).attr("title")); // 공시송달 삭제
});
// DataTables width 변경 조정
@ -490,12 +502,12 @@
fnMakeScrollableTable($("#table-responsive--${pageName}")[0], $P.scrollDataList);
// DataTables 스크롤을 위해서 다이얼로그 화면이 생성된 후 Dataset을 설정한다.
$("#${infoPrefix}Dialog").on("shown.bs.modal", function (e) {
$("#${infoPrefix}Dialog--${openerPageName}").on("shown.bs.modal", function (e) {
$P.control.setData({
${infoPrefix}List : ${svbtcDtlList}
, ${infoPrefix}Start : ${svbtcDtlStart}
, ${infoPrefix}Fetch : ${svbtcDtlFetch}
, ${infoPrefix}Total : ${svbtcDtlTotal}
${infoPrefix}List: ${svbtcDtlList}
, ${infoPrefix}Start: ${svbtcDtlStart}
, ${infoPrefix}Fetch: ${svbtcDtlFetch}
, ${infoPrefix}Total: ${svbtcDtlTotal}
});
// 초기 데이터 설정
@ -515,16 +527,11 @@
$("#svbtcId--${pageName}").val($P.control.dataset.getValue("SVBTC_ID"));
// 검색 조건 설정
$P.control.defaultFetchSize = $P.mainQuery.fetchSize;
$P.control.query = $P.mainQuery;
// URL 설정
$P.setURL($P.mainQuery.taskSeCd);
}
// 업무구분에 따른 URL 설정
$P.setURL = (taskSeCd) => {
$P.control.urls.load = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/250/list.do"); // 조회
$P.control.urls.remove = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/250/remove.do"); // 삭제
// 업무구분에 따른 URL 설정
$P.control.urls.load = wctx.url("/" + $P.mainQuery.taskSeCd + "${infoPrefixUrl}" + "/250/list.do"); // 조회
}
/**************************************************************************

@ -1,17 +1,20 @@
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
<c:set var="prefixName" scope="request">공시송달 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
<c:set var="prefixName" scope="request">공시송달 정보</c:set>
<!-- Page Body -->
<div class="card">
<!-- 입력 영역 -->
<form id="frmEdit--${pageName}" name="frmEdit">
<!-- hidden -->
<input type="hidden" id="sggCd--${pageName}" name="sggCd" data-map="SGG_CD" />
<input type="hidden" id="taskSeCd--${pageName}" name="taskSeCd" data-map="TASK_SE_CD" />
<input type="hidden" id="svbtcId--${pageName}" name="svbtcId" data-map="SVBTC_ID" />
<div class="row g-1">
@ -43,24 +46,27 @@
<textarea type="text" class="form-control w-70" id="etcCn--${pageName}" name="etcCn" data-map="ETC_CN" autocomplete="off" rows="3" data-maxlengthb="1000"></textarea>
</div>
</div>
</form> <!-- /입력 영역 -->
</div> <!-- <div class="card"> -->
</form>
<!-- 입력 영역 -->
<!-- 업무 버튼 표시 -->
<div>
<span class="container-page-btn">
<span class="container-window-btn-right">
<!-- 업무 버튼 및 건수 표시 -->
<div>
<span class="container-page-btn">
<!-- 업무 버튼 -->
<button type="button" class="btn btn-primary w-px-80" id="btnSave--${pageName}" title="저장">
저장
</button>
<span class="container-window-btn-right">
<button type="button" class="btn btn-primary w-px-80" id="btnSave--${pageName}" title="저장">
저장
</button>
</span>
</span>
</span>
</div>
<!-- / 업무 버튼 표시 -->
</div> <!-- 업무 버튼 및 건수 표시 -->
</div> <!-- <div class="card"> -->
<!-- Page Body -->
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- <div class="container flex-grow-1 px-0"> -->
<!-- Content -->
</div>
<!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************
@ -77,10 +83,8 @@
**************************************************************************/
$(document).ready(function() {
// pageObject
var $P = pageObject["${pageName}"];
let $P = pageObject["${pageName}"];
// URL
$P.PrefixUrl = "/sndb/sndb01";
// infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정)
$P.callPurpose = "${callPurpose}";
// FormFields
@ -92,10 +96,10 @@
* DatasetControl
**************************************************************************/
$P.control = new DatasetControl({
prefix : "svbtc"
, prefixName : "공시송달"
, keymapper : info => info ? info.SVBTC_ID : ""
, dataGetter : obj => obj.svbtcInfo
prefix: "svbtc"
, prefixName: "공시송달"
, keymapper: info => info ? info.SVBTC_ID : ""
, dataGetter: obj => obj.${infoPrefix}Info
});
/**************************************************************************
@ -105,18 +109,17 @@
if (!item) return;
// Dataset 셋팅
$P.formFields.set($P.control,item);
$P.formFields.set($P.control, item);
// 업무구분에 따른 URL 변경
$P.setURL(item.data.TASK_SE_CD);
$P.fnSetURL(item.data.TASK_SE_CD);
// 호출용도가 등록이라면..
if (${pageName}CallPurpose == "create") {
$("#svbtcYmd--${pageName}").datepicker("setDate", new Date());
if ($P.callPurpose == "create") {
let taskSeCd = item.data.TASK_SE_CD;
let sndngSeCd = item.data.SNDNG_SE_CD;
$("#svbtcYmd--${pageName}").datepicker("setDate", new Date());
if (sndngSeCd == "") {
$("#ttlNm--${pageName}").val(FIM054[taskSeCd].value + " " + "공시송달");
} else {
@ -127,17 +130,18 @@
// 저장 callback
$P.control.onSave = (resp) => {
let dialogTitle = $("#" + $P.control.prefix + "Dialog").find("h5.modal-title").html();
let dialogTitle = $("#" + $P.control.prefix + "Dialog--${openerPageName}").find("h5.modal-title").html();
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, dialogTitle);
// 메시지 출력
dialog.alert({
content : showMessage
, onOK : () => { }
content: showMessage
, init: () => { setDialogZindex(); }
, onOK: () => { }
});
if (resp.saved) {
dialog.close($P.control.prefix + "Dialog");
dialog.close($P.control.prefix + "Dialog--${openerPageName}");
}
}
@ -148,32 +152,36 @@
let create = ($P.callPurpose == "create");
ajax.post({
url : !create ? $P.control.urls.update : $P.control.urls.create
, data : info
, success : resp => $P.control.onSave(resp)
url: !create ? $P.control.urls.update : $P.control.urls.create
, data: info || {}
, success: resp => $P.control.onSave(resp)
});
}
/**************************************************************************
* 사용자 함수(function)
**************************************************************************/
// 업무구분에 따른 URL 설정
$P.fnSetURL = (taskSeCd) => {
$P.control.urls.create = wctx.url("/" + taskSeCd + "${infoPrefixUrl}" + "/260/create.do"); // 등록
$P.control.urls.update = wctx.url("/" + taskSeCd + "${infoPrefixUrl}" + "/260/update.do"); // 수정
}
/**************************************************************************
* 버튼 clickEvent
**************************************************************************/
// 저장 버튼 클릭 이벤트
$P.fnSave = (title) => {
$P.fnSave = () => {
// validate 확인
if (!customValidate($("#frmEdit--${pageName}").find("input, select, textarea"))) return;
// 파리미터 설정
let params = $.extend({}, $P.mainQuery, $P.formFields.get()); // 객체를 합친다.
params.title = title; // 타이틀
dialog.alert({
content : "현재 " + $P.control.prefixName + " 정보를 저장하시겠습니까?"
, onOK : () => {
content: "현재 " + $P.control.prefixName + " 정보를 저장하시겠습니까?"
, init: () => { setDialogZindex(); }
, onOK: () => {
$P.control.save(params);
}
});
@ -197,10 +205,8 @@
});
});
// 저장 버튼 이벤트
$("#btnSave--${pageName}").on("click", function() {
$P.fnSave($(this).attr("title"));
});
// 버튼 이벤트
$("#btnSave--${pageName}").on("click", () => $P.fnSave()); // 저장
}
// 초기 화면 설정
@ -209,21 +215,15 @@
initDatepicker("frmEdit--${pageName}");
$("#svbtcYmd--${pageName}").datepicker("setDate", new Date());
if ($P.callPurpose == "view") { // view
if ($P.callPurpose == "view") { // view
// input 요소들을 disabled
$("#frmEdit--${pageName}").find("input,textarea,select").prop("disabled", true);
// button 요소들을 disabled
$("#btnSvbtcYmd--${pageName}").prop("disabled", true); // 부과제외 일자 달력 버튼
$("#btnSave--${pageName}").prop("disabled", true); // 저장 버튼
$("#btnSvbtcYmd--${pageName}").prop("disabled", true); // 부과제외 일자 달력 버튼
$("#btnSave--${pageName}").prop("disabled", true); // 저장 버튼
}
}
// 업무구분에 따른 URL 설정
$P.setURL = (taskSeCd) => {
$P.control.urls.create = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/260/create.do"); // 등록
$P.control.urls.update = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/260/update.do"); // 수정
}
/**************************************************************************
* 최초 실행 함수
**************************************************************************/

@ -2,7 +2,7 @@
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
<!-- Page Body -->
<div class="content-wrapper">
<div class="content-pop">
<div class="d-flex flex-row justify-content-evenly">
<!-- 민원 상담 정보 -->
<div class="col-xl-12 mx-1">

@ -4,7 +4,7 @@
<c:set var="prefixName" scope="request">민원 상담 내용 정보</c:set>
<!-- inner page html -->
<div class="content-wrapper">
<div class="content-pop">
<!-- Content -->
<div class="container flex-grow-1 px-0">
<!-- Page Body -->
@ -64,7 +64,7 @@
<!-- / 업무 버튼 표시 -->
</div> <!-- / Content <div class="container-xxl flex-grow-1 px-0"> -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
</div> <!-- / inner page html <div class="content-pop"> -->
<script>
/**************************************************************************

Loading…
Cancel
Save