1. 부과 취소 등록 추가.

2. 감액 추가.
main
jjh 10 months ago
parent 075eebc38d
commit 10b7c7fd75

@ -24,6 +24,7 @@ public class LevyExclQuery extends CmmnQuery {
private String opnnId; // 의견제출 ID private String opnnId; // 의견제출 ID
private String[] reRegIDs; // 재등록 IDs private String[] reRegIDs; // 재등록 IDs
private String reRegId; // 재등록 ID private String reRegId; // 재등록 ID
// 검색 조건 // 검색 조건
private String schLevyExclYmdFrom; // 부과제외_부과제외 일자 시작 private String schLevyExclYmdFrom; // 부과제외_부과제외 일자 시작
private String schLevyExclYmdTo; // 부과제외_부과제외 일자 종료 private String schLevyExclYmdTo; // 부과제외_부과제외 일자 종료

@ -75,14 +75,10 @@ public interface CrdnReRegMapper extends AbstractMapper {
return crdnReReg != null && deleteCrdnReReg(params().set("crdnReReg", crdnReReg)) == 1; return crdnReReg != null && deleteCrdnReReg(params().set("crdnReReg", crdnReReg)) == 1;
} }
/** ID . /** ID .
* @param crdnId ID * @param crdnId ID
* @return * @return
*/ */
DataObject selectCrdn(LevyExclQuery req); DataObject selectCrdnInfo(String crdnId);
default DataObject selectCrdnInfo(String crdnId) {
return selectCrdn(new LevyExclQuery().setCrdnId(crdnId));
}
} }

@ -57,18 +57,6 @@ public interface LevyExclMapper extends AbstractMapper {
return !levyExcls.isEmpty() ? levyExcls.get(0) : null; return !levyExcls.isEmpty() ? levyExcls.get(0) : null;
} }
/** .
* @param crdnId ID
* @return
*/
List<DataObject> selectCrdn(LevyExclQuery req);
default DataObject selectCrdnInfo(LevyExclQuery req) {
List<DataObject> crdn = selectCrdn(req);
return !crdn.isEmpty() ? crdn.get(0) : null;
}
/** . /** .
* @param params * @param params
* <ul><li>"excl01" - </li> * <ul><li>"excl01" - </li>
@ -112,6 +100,12 @@ public interface LevyExclMapper extends AbstractMapper {
return levyExcl != null && deleteLevyExcl(params().set("levyExcl", levyExcl)) == 1; return levyExcl != null && deleteLevyExcl(params().set("levyExcl", levyExcl)) == 1;
} }
/** ID .
* @param crdnId ID
* @return
*/
DataObject selectCrdnInfo(String crdnId);
/** . /** .
* @param crdnId ID * @param crdnId ID
* @return , * @return ,
@ -126,10 +120,10 @@ public interface LevyExclMapper extends AbstractMapper {
* @param excl * @param excl
* @return * @return
*/ */
int updateCvlcptPrcsRsltCn(Map<String, Object> params); int updateCrdnCvlcptPrcsRsltCn(Map<String, Object> params);
default boolean updateCvlcptPrcsRsltCn(CrdnCvlcpt crdnCvlcpt) { default boolean updateCrdnCvlcptPrcsRsltCn(CrdnCvlcpt crdnCvlcpt) {
return crdnCvlcpt != null && updateCvlcptPrcsRsltCn(params().set("crdnCvlcpt", crdnCvlcpt)) == 1; return crdnCvlcpt != null && updateCrdnCvlcptPrcsRsltCn(params().set("crdnCvlcpt", crdnCvlcpt)) == 1;
} }
/**(TB_CRDN_CVLCPT) . /**(TB_CRDN_CVLCPT) .

@ -55,18 +55,6 @@ public interface OpnnSbmsnMapper extends AbstractMapper {
return !opnnSbmsns.isEmpty() ? opnnSbmsns.get(0) : null; return !opnnSbmsns.isEmpty() ? opnnSbmsns.get(0) : null;
} }
/** .
* @param crdnId ID
* @return
*/
List<DataObject> selectCrdn(LevyExclQuery req);
default DataObject selectCrdnInfo(LevyExclQuery req) {
List<DataObject> crdn = selectCrdn(req);
return !crdn.isEmpty() ? crdn.get(0) : null;
}
/** . /** .
* @param opnnId ID * @param opnnId ID
* @return * @return
@ -133,44 +121,43 @@ public interface OpnnSbmsnMapper extends AbstractMapper {
return opnnSbmsn != null && updateAnsSttsCd(params().set("opnnSbmsn", opnnSbmsn)) == 1; return opnnSbmsn != null && updateAnsSttsCd(params().set("opnnSbmsn", opnnSbmsn)) == 1;
} }
/** . /** .
* @param params * @param params
* <ul><li>"crdn" - </li> * <ul><li>"opnnSbmsn" - </li>
* <li>"currentUser" - </li> * <li>"currentUser" - </li>
* </ul> * </ul>
* @return * @return
*/ */
int updateCrdnOpnnSbmsnYn(Map<String, Object> params); int deleteOpnnSbmsn(Map<String, ?> params);
/** . /** .
* @param crdn * @param opnnSbmsn
* @return * @return
* <ul><li> true</li> * <ul><li> true</li>
* <li> false</li> * <li> false</li>
* </ul> * </ul>
*/ */
default boolean updateCrdn(Crdn crdn) { default boolean delete(OpnnSbmsn opnnSbmsn) {
return crdn != null && updateCrdnOpnnSbmsnYn(params().set("crdn", crdn)) == 1; return opnnSbmsn != null && deleteOpnnSbmsn(params().set("opnnSbmsn", opnnSbmsn)) == 1;
} }
/** . /** ID .
* @param crdnId ID
* @return
*/
DataObject selectCrdnInfo(String crdnId);
/** .
* @param params * @param params
* <ul><li>"opnnSbmsn" - </li> * <ul><li>"crdn" - </li>
* <li>"currentUser" - </li> * <li>"currentUser" - </li>
* </ul> * </ul>
* @return * @return
*/ */
int deleteOpnnSbmsn(Map<String, ?> params); int updateCrdnOpnnSbmsnYn(Map<String, Object> params);
/** . default boolean updateCrdn(Crdn crdn) {
* @param opnnSbmsn return crdn != null && updateCrdnOpnnSbmsnYn(params().set("crdn", crdn)) == 1;
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
default boolean delete(OpnnSbmsn opnnSbmsn) {
return opnnSbmsn != null && deleteOpnnSbmsn(params().set("opnnSbmsn", opnnSbmsn)) == 1;
} }
} }

@ -96,7 +96,7 @@ public class CrdnReRegBean extends AbstractComponent {
String rtnMsg = "[F] "; // 처리 결과 메시지 String rtnMsg = "[F] "; // 처리 결과 메시지
// 단속 ID로 단속(TB_CRDN) 정보 조회 // 단속 ID로 단속(TB_CRDN) 정보 조회
DataObject crdnInfo = crdnReRegMapper.selectCrdn(new LevyExclQuery().setCrdnId(crdnReReg.getBfrCrdnId())); DataObject crdnInfo = crdnReRegMapper.selectCrdnInfo(crdnReReg.getBfrCrdnId());
// 단속 ID로 파일(TB_FILE) 정보 조회 // 단속 ID로 파일(TB_FILE) 정보 조회
List<DataObject> crdnFileList = fileBean.getFileList(new FileQuery().setInfoType(CrdnReReg.INF_TYPE) List<DataObject> crdnFileList = fileBean.getFileList(new FileQuery().setInfoType(CrdnReReg.INF_TYPE)
@ -203,12 +203,4 @@ public class CrdnReRegBean extends AbstractComponent {
return crdnReRegMapper.delete(crdnReReg); return crdnReRegMapper.delete(crdnReReg);
} }
/** .
* @param req
* @return
*/
public DataObject getCrdnInfo(LevyExclQuery req) {
return crdnReRegMapper.selectCrdn(req);
}
} }

@ -13,6 +13,10 @@ import cokr.xit.fims.crdn.Crdn;
import cokr.xit.fims.excl.LevyExclQuery; import cokr.xit.fims.excl.LevyExclQuery;
import cokr.xit.fims.excl.LevyExcl; import cokr.xit.fims.excl.LevyExcl;
import cokr.xit.fims.excl.dao.LevyExclMapper; import cokr.xit.fims.excl.dao.LevyExclMapper;
import cokr.xit.fims.levy.LevyQuery;
import cokr.xit.fims.levy.dao.LevyMapper;
import cokr.xit.fims.rdca.Rdcamt;
import cokr.xit.fims.rdca.service.bean.RdcamtBean;
import cokr.xit.foundation.AbstractComponent; import cokr.xit.foundation.AbstractComponent;
import cokr.xit.foundation.data.DataObject; import cokr.xit.foundation.data.DataObject;
@ -37,6 +41,14 @@ public class LevyExclBean extends AbstractComponent {
@Resource(name = "crdnSttsHstryBean") @Resource(name = "crdnSttsHstryBean")
private CrdnSttsHstryBean crdnSttsHstryBean; private CrdnSttsHstryBean crdnSttsHstryBean;
/** 부과 대장 정보 DAO */
@Resource(name = "levyMapper")
private LevyMapper levyMapper;
/** 감액 대장 정보 Bean */
@Resource(name = "rdcamtBean")
private RdcamtBean rdcamtBean;
/** . /** .
* @param req * @param req
* @return * @return
@ -67,6 +79,10 @@ public class LevyExclBean extends AbstractComponent {
* @return * @return
*/ */
public List<DataObject> getLevyExcls(LevyExclQuery req) { public List<DataObject> getLevyExcls(LevyExclQuery req) {
// 사용 여부 확인
if (req.getUseYN() == null) {
req.setUseYN("Y");
}
// 삭제 여부 확인 // 삭제 여부 확인
if (req.getDelYN() == null) { if (req.getDelYN() == null) {
req.setDelYN("N"); req.setDelYN("N");
@ -86,7 +102,7 @@ public class LevyExclBean extends AbstractComponent {
DataObject levyExclInfo = new DataObject(); DataObject levyExclInfo = new DataObject();
if (req.getCallPurpose().equals("create")) { if (req.getCallPurpose().equals("create")) {
levyExclInfo = levyExclMapper.selectCrdnInfo(req); levyExclInfo = levyExclMapper.selectCrdnInfo(req.getCrdnId());
levyExclInfo.set("LEVY_EXCL_SE_CD", req.getLevyExclSeCd()); // 부과 제외 구분 코드 levyExclInfo.set("LEVY_EXCL_SE_CD", req.getLevyExclSeCd()); // 부과 제외 구분 코드
} else { } else {
@ -110,7 +126,7 @@ public class LevyExclBean extends AbstractComponent {
String newCrdnSttsCd = ""; // 신규 단속 상태 코드(CRDN_STTS_CD) String newCrdnSttsCd = ""; // 신규 단속 상태 코드(CRDN_STTS_CD)
// 단속 ID로 단속, 부과제외 정보 조회 // 단속 ID로 단속, 부과제외 정보 조회
DataObject crdnInfo = levyExclMapper.selectCrdnInfo(new LevyExclQuery().setCrdnId(levyExcl.getCrdnId())); DataObject crdnInfo = levyExclMapper.selectCrdnInfo(levyExcl.getCrdnId());
// 부과제외 ID가 있다면 이미 부과제외 자료가 존재하므로 종료.. // 부과제외 ID가 있다면 이미 부과제외 자료가 존재하므로 종료..
if (!crdnInfo.string("LEVY_EXCL_ID").equals("")) { if (!crdnInfo.string("LEVY_EXCL_ID").equals("")) {
@ -144,10 +160,31 @@ public class LevyExclBean extends AbstractComponent {
newCrdnSttsCd = "81"; // 비부과(서손) newCrdnSttsCd = "81"; // 비부과(서손)
} else if (levyExcl.getLevyExclSeCd().equals("2")) { // 계고 } else if (levyExcl.getLevyExclSeCd().equals("2")) { // 계고
newCrdnSttsCd = "83"; // 계고 newCrdnSttsCd = "83"; // 계고
} else if (levyExcl.getLevyExclSeCd().equals("5")) { // 전액감액 } else if (levyExcl.getLevyExclSeCd().equals("3")) { // 부과취소(전액감액)
newCrdnSttsCd = "80"; // 부과취소 newCrdnSttsCd = "80"; // 부과취소
} }
// 부과취소(전액감액)일 경우 부과(TB_LEVY)에 감액금액 입력이 필요..
if (levyExcl.getLevyExclSeCd().equals("3")) {
if (crdnInfo.string("LEVY_ID").equals("")) {
rtnMsg = "[F] 작업 중 부과 자료가 존재하지 않습니다.<br>비부과로 처리 하시기 바랍니다.<br>";
return rtnMsg;
}
// 감액 등록
Rdcamt rdcamt = new Rdcamt();
rdcamt.setLevyId(crdnInfo.string("LEVY_ID")); // 부과 ID
rdcamt.setRdcamtYmd(levyExcl.getLevyExclYmd()); // 감액 일자
rdcamt.setRdcamtSeCd("02"); // 감액 구분 코드 FIM085 - 02:부과취소
rdcamt.setRdcamtRsnCd(levyExcl.getLevyExclRsnCd()); // 감액 사유 코드
rtnMsg = rdcamtBean.createRdcamt(rdcamt);
if (rtnMsg.contains("[F]")) {
throw new RuntimeException(rtnMsg.replace("[F]", "")); // 예외를 발생시켜서 DB Rollback
}
}
// 부과제외(TB_LEVY_EXCL) 대장을 등록 한다. // 부과제외(TB_LEVY_EXCL) 대장을 등록 한다.
rtnScs = levyExclMapper.insert(levyExcl); rtnScs = levyExclMapper.insert(levyExcl);
if (!rtnScs) { if (!rtnScs) {
@ -169,11 +206,6 @@ public class LevyExclBean extends AbstractComponent {
throw new RuntimeException("부과제외 등록 작업 중 단속상태 변경에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback throw new RuntimeException("부과제외 등록 작업 중 단속상태 변경에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
} }
// 전액 감액일 경우 부과(TB_LEVY)에 감액금액 입력이 필요..
if (levyExcl.getLevyExclSeCd().equals("5")) {
}
rtnMsg = "[S] 작업이 정상 처리 되었습니다."; rtnMsg = "[S] 작업이 정상 처리 되었습니다.";
return rtnMsg; return rtnMsg;
@ -215,10 +247,11 @@ public class LevyExclBean extends AbstractComponent {
String rtnMsg = "[F] "; // 처리 결과 메시지 String rtnMsg = "[F] "; // 처리 결과 메시지
// 부과제외(TB_LEVY_EXCL) 정보 조회 // 부과제외(TB_LEVY_EXCL) 정보 조회
DataObject levyExclInfo = levyExclMapper.selectLevyExclInfo(new LevyExclQuery() LevyExclQuery req = new LevyExclQuery();
.setLevyExclId(levyExcl.getLevyExclId()) req.setLevyExclId(levyExcl.getLevyExclId());
.setDelYN("N") req.setDelYN("N");
);
DataObject levyExclInfo = levyExclMapper.selectLevyExclInfo(req);
// 부과제외 ID가 조회되지 않았다면 종료.. // 부과제외 ID가 조회되지 않았다면 종료..
if (levyExclInfo.string("LEVY_EXCL_ID").equals("")) { if (levyExclInfo.string("LEVY_EXCL_ID").equals("")) {
@ -232,7 +265,7 @@ public class LevyExclBean extends AbstractComponent {
} else if (levyExclInfo.string("LEVY_EXCL_SE_CD").equals("2") && !("83,84").contains(levyExclInfo.string("CRDN_STTS_CD"))) { // 계고 } else if (levyExclInfo.string("LEVY_EXCL_SE_CD").equals("2") && !("83,84").contains(levyExclInfo.string("CRDN_STTS_CD"))) { // 계고
rtnMsg = "[F] 작업 중 오류가 발생하였습니다.<br>현재 자료의 단속 상태가 " + levyExclInfo.string("CRDN_STTS_NM") + " 이(가) 아닙니다."; rtnMsg = "[F] 작업 중 오류가 발생하였습니다.<br>현재 자료의 단속 상태가 " + levyExclInfo.string("CRDN_STTS_NM") + " 이(가) 아닙니다.";
return rtnMsg; return rtnMsg;
} else if (levyExclInfo.string("LEVY_EXCL_SE_CD").equals("5") && !levyExclInfo.string("CRDN_STTS_CD").equals("80")) { // 부과취소 } else if (levyExclInfo.string("LEVY_EXCL_SE_CD").equals("3") && !levyExclInfo.string("CRDN_STTS_CD").equals("80")) { // 부과취소
rtnMsg = "[F] 작업 중 오류가 발생하였습니다.<br>현재 자료의 단속 상태가 " + levyExclInfo.string("CRDN_STTS_NM") + " 이(가) 아닙니다."; rtnMsg = "[F] 작업 중 오류가 발생하였습니다.<br>현재 자료의 단속 상태가 " + levyExclInfo.string("CRDN_STTS_NM") + " 이(가) 아닙니다.";
return rtnMsg; return rtnMsg;
} }
@ -245,9 +278,11 @@ public class LevyExclBean extends AbstractComponent {
// 단속상태이력(TB_CRDN_STTS_HSTRY) 대장에 부과제외 이력삭제 및 부과제외삭제 이력을 등록 한다. // 단속상태이력(TB_CRDN_STTS_HSTRY) 대장에 부과제외 이력삭제 및 부과제외삭제 이력을 등록 한다.
String deleteCrdnSttsCd = ""; String deleteCrdnSttsCd = "";
if (levyExclInfo.string("CRDN_STTS_CD").equals("81")) { if (levyExclInfo.string("CRDN_STTS_CD").equals("80")) { // 임시
throw new RuntimeException("부과취소는 부과제외 삭제에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
} else if (levyExclInfo.string("CRDN_STTS_CD").equals("81")) {
deleteCrdnSttsCd = "91"; // 비부과(서손) 삭제 deleteCrdnSttsCd = "91"; // 비부과(서손) 삭제
} else if (levyExclInfo.string("CRDN_STTS_CD").equals("83") || levyExclInfo.string("CRDN_STTS_CD").equals("84")) { } else if (("83,84").contains(levyExclInfo.string("CRDN_STTS_CD"))) {
deleteCrdnSttsCd = "93"; // 계고 삭제 deleteCrdnSttsCd = "93"; // 계고 삭제
} }

@ -99,7 +99,7 @@ public class OpnnSbmsnBean extends AbstractComponent {
DataObject opnnSbmsnInfo = new DataObject(); DataObject opnnSbmsnInfo = new DataObject();
if (req.getCallPurpose().equals("create")) { if (req.getCallPurpose().equals("create")) {
opnnSbmsnInfo = opnnSbmsnMapper.selectCrdnInfo(req); opnnSbmsnInfo = opnnSbmsnMapper.selectCrdnInfo(req.getCrdnId());
} else { } else {
opnnSbmsnInfo = opnnSbmsnMapper.selectOpnnSbmsnInfo(req); opnnSbmsnInfo = opnnSbmsnMapper.selectOpnnSbmsnInfo(req);
} }
@ -132,7 +132,7 @@ public class OpnnSbmsnBean extends AbstractComponent {
String rtnMsg = "[F] "; // 처리 결과 메시지 String rtnMsg = "[F] "; // 처리 결과 메시지
// 단속 ID로 단속 정보 조회 // 단속 ID로 단속 정보 조회
DataObject crdnInfo = opnnSbmsnMapper.selectCrdnInfo(new LevyExclQuery().setCrdnId(opnnSbmsn.getCrdnId())); DataObject crdnInfo = opnnSbmsnMapper.selectCrdnInfo(opnnSbmsn.getCrdnId());
// 의견제출ID가 있다면 이미 자료가 존재하므로 종료.. // 의견제출ID가 있다면 이미 자료가 존재하므로 종료..
if (!crdnInfo.string("OPNN_ID").equals("")) { if (!crdnInfo.string("OPNN_ID").equals("")) {

@ -78,9 +78,9 @@ public class Levy extends AbstractEntity {
private String levyNo; private String levyNo;
/** /**
* *
*/ */
private String inspySn; private String inspyNo;
/** /**
* *

@ -59,12 +59,6 @@ public interface LevyMapper extends AbstractMapper {
return !levys.isEmpty() ? levys.get(0) : null; return !levys.isEmpty() ? levys.get(0) : null;
} }
/** ID .
* @param crdnId ID
* @return
*/
DataObject selectCrdn(String crdnId);
/** ID . /** ID .
* @param crdnId ID * @param crdnId ID
* @return * @return
@ -131,10 +125,23 @@ public interface LevyMapper extends AbstractMapper {
* <li> false</li> * <li> false</li>
* </ul> * </ul>
*/ */
int updateRcvmtAmt(Map<String, Object> params); int updateRcvmt(Map<String, Object> params);
default boolean updateRcvmtAmt(Levy levy) { default boolean updateRcvmt(Levy levy) {
return levy != null && updateRcvmtAmt(params().set("levy", levy)) == 1; return levy != null && updateRcvmt(params().set("levy", levy)) == 1;
}
/** .
* @param levy
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
int updateRdcamt(Map<String, Object> params);
default boolean updateRdcamt(Levy levy) {
return levy != null && updateRdcamt(params().set("levy", levy)) == 1;
} }
/** . /** .
@ -157,4 +164,16 @@ public interface LevyMapper extends AbstractMapper {
return levy != null && deleteLevy(params().set("levy", levy)) == 1; return levy != null && deleteLevy(params().set("levy", levy)) == 1;
} }
/** ID .
* @param crdnId ID
* @return
*/
DataObject selectCrdn(String crdnId);
/** .
* @param req
* @return
*/
DataObject selectLevyAmt(LevyQuery req);
} }

@ -178,7 +178,7 @@ public class LevyBean extends AbstractComponent {
levy.setTxitmCd(crdnInfo.string("TXITM_CD")); // 세목 코드 levy.setTxitmCd(crdnInfo.string("TXITM_CD")); // 세목 코드
levy.setOperItemCd(crdnInfo.string("OPER_ITEM_CD")); // 운영 항목 코드 levy.setOperItemCd(crdnInfo.string("OPER_ITEM_CD")); // 운영 항목 코드
levy.setSpclBizCd(crdnInfo.string("SPCL_BIZ_CD")); // 특별회계 사업 코드 levy.setSpclBizCd(crdnInfo.string("SPCL_BIZ_CD")); // 특별회계 사업 코드
levy.setInspySn("00"); // 분납 순번 levy.setInspyNo("00"); // 분납 순번
levy.setLevySeCd("02"); // 부과 구분 코드 FIM040 levy.setLevySeCd("02"); // 부과 구분 코드 FIM040
levy.setUntySeCd("02"); // 통합 구분 코드 FIM072 levy.setUntySeCd("02"); // 통합 구분 코드 FIM072
if (crdnInfo.string("TASK_SE_CD").equals("BPV")) { if (crdnInfo.string("TASK_SE_CD").equals("BPV")) {
@ -321,12 +321,35 @@ public class LevyBean extends AbstractComponent {
* <li> false</li> * <li> false</li>
* </ul> * </ul>
*/ */
public String updateRcvmtAmt(Levy levy) { public String updateRcvmt(Levy levy) {
// 변수 선언 // 변수 선언
boolean rtnScs = false; // DB 처리 결과 boolean rtnScs = false; // DB 처리 결과
String rtnMsg = "[F] "; // 처리 결과 메시지 String rtnMsg = "[F] "; // 처리 결과 메시지
rtnScs = levyMapper.updateRcvmtAmt(levy); rtnScs = levyMapper.updateRcvmt(levy);
if (!rtnScs) {
// 예외를 발생시켜서 오류메세지를 보내고 DB Rollback
throw new RuntimeException("부과 대장에 수납금액 정보 수정에 실패하였습니다.");
}
rtnMsg = "[S] 작업이 정상 처리 되었습니다.";
return rtnMsg;
}
/** .
* @param levy
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
public String updateRdcamt(Levy levy) {
// 변수 선언
boolean rtnScs = false; // DB 처리 결과
String rtnMsg = "[F] "; // 처리 결과 메시지
rtnScs = levyMapper.updateRdcamt(levy);
if (!rtnScs) { if (!rtnScs) {
// 예외를 발생시켜서 오류메세지를 보내고 DB Rollback // 예외를 발생시켜서 오류메세지를 보내고 DB Rollback
throw new RuntimeException("부과 대장에 수납금액 정보 수정에 실패하였습니다."); throw new RuntimeException("부과 대장에 수납금액 정보 수정에 실패하였습니다.");

@ -209,7 +209,7 @@ public class Levy01Controller extends ApplicationController {
.addObject("rtnMsg", rtnMsg); .addObject("rtnMsg", rtnMsg);
} }
/** (levy/levy01030-main) . /** (levy/levy01050-main) .
* @return * @return
*/ */
public ModelAndView levyMain() { public ModelAndView levyMain() {
@ -271,7 +271,7 @@ public class Levy01Controller extends ApplicationController {
, Map.entry("세목코드", xlsx.style("TXITM_CD", center)) , Map.entry("세목코드", xlsx.style("TXITM_CD", center))
, Map.entry("세목명", xlsx.style("TXITM_NM", center)) , Map.entry("세목명", xlsx.style("TXITM_NM", center))
, Map.entry("부과번호", xlsx.style("LEVY_NO", center)) , Map.entry("부과번호", xlsx.style("LEVY_NO", center))
, Map.entry("분납순번", xlsx.style("INSPY_SN", center)) , Map.entry("분납순번", xlsx.style("INSPY_NO", center))
, Map.entry("부과구분", xlsx.style("LEVY_SE_NM", center)) , Map.entry("부과구분", xlsx.style("LEVY_SE_NM", center))
, Map.entry("통합구분", xlsx.style("UNTY_SE_NM", center)) , Map.entry("통합구분", xlsx.style("UNTY_SE_NM", center))
, Map.entry("감경구분", xlsx.style("RDUCT_SE_NM", center)) , Map.entry("감경구분", xlsx.style("RDUCT_SE_NM", center))

@ -63,9 +63,9 @@ public class Rcvmt extends AbstractEntity {
private String levyNo; private String levyNo;
/** /**
* *
*/ */
private String inspySn; private String inspyNo;
/** /**
* *

@ -46,12 +46,6 @@ public interface RcvmtMapper extends AbstractMapper {
return !rcvmts.isEmpty() ? rcvmts.get(0) : null; return !rcvmts.isEmpty() ? rcvmts.get(0) : null;
} }
/** ID .
* @param req
* @return
*/
DataObject selectLevyInfo(RcvmtQuery req);
/** . /** .
* @param rcvmt * @param rcvmt
* @return * @return
@ -125,4 +119,10 @@ public interface RcvmtMapper extends AbstractMapper {
return rcvmt != null && deleteRcvmt(params().set("rcvmt", rcvmt)) == 1; return rcvmt != null && deleteRcvmt(params().set("rcvmt", rcvmt)) == 1;
} }
/** .
* @param req
* @return
*/
DataObject selectLevyInfo(RcvmtQuery req);
} }

@ -12,6 +12,7 @@ import cokr.xit.fims.cmmn.CmmnUtil;
import cokr.xit.fims.cmmn.CrdnSttsHstry; import cokr.xit.fims.cmmn.CrdnSttsHstry;
import cokr.xit.fims.cmmn.service.bean.CrdnSttsHstryBean; import cokr.xit.fims.cmmn.service.bean.CrdnSttsHstryBean;
import cokr.xit.fims.levy.Levy; import cokr.xit.fims.levy.Levy;
import cokr.xit.fims.levy.LevyQuery;
import cokr.xit.fims.levy.dao.LevyMapper; import cokr.xit.fims.levy.dao.LevyMapper;
import cokr.xit.fims.rcvm.Rcvmt; import cokr.xit.fims.rcvm.Rcvmt;
import cokr.xit.fims.rcvm.RcvmtQuery; import cokr.xit.fims.rcvm.RcvmtQuery;
@ -77,20 +78,20 @@ public class RcvmtBean extends AbstractComponent {
return rcvmtMapper.selectRcvmts(req); return rcvmtMapper.selectRcvmts(req);
} }
/** ID .<br /> /** ID .<br />
* @param req * @param req
* @return * @return
*/ */
public DataObject getRcvmtInfo(RcvmtQuery req) { public DataObject getLevyInfo(RcvmtQuery req) {
return rcvmtMapper.selectRcvmtInfo(req); return rcvmtMapper.selectLevyInfo(req);
} }
/** ID .<br /> /** ID .<br />
* @param req * @param req
* @return * @return
*/ */
public DataObject getLevyInfo(RcvmtQuery req) { public DataObject getRcvmtInfo(RcvmtQuery req) {
return rcvmtMapper.selectLevyInfo(req); return rcvmtMapper.selectRcvmtInfo(req);
} }
/** . /** .
@ -105,12 +106,12 @@ public class RcvmtBean extends AbstractComponent {
boolean rtnScs = false; // DB 처리 결과 boolean rtnScs = false; // DB 처리 결과
String rtnMsg = "[F] "; // 처리 결과 메시지 String rtnMsg = "[F] "; // 처리 결과 메시지
// 부과 ID로 단속, 부과 정보 조회 // 부과 ID로 부과 정보 조회
DataObject levyInfo = rcvmtMapper.selectLevyInfo(new RcvmtQuery().setLevyId(rcvmt.getLevyId()).setDelYN("N")); DataObject levyInfo = levyMapper.selectLevyAmt(new LevyQuery().setLevyId(rcvmt.getLevyId()));
String rcvmtSeCd = ""; // 수납 구분 코드(FIM041)
rcvmt.setDeptCd(levyInfo.string("DEPT_CD")); String rcvmtSeCd = ""; // 수납 구분 코드(FIM041)
rcvmt.setDeptCd(levyInfo.string("DEPT_CD")); // 부서 코드
rcvmt.setLastPcptax(levyInfo.number("LAST_PCPTAX").intValue()); // 최종 본세 rcvmt.setLastPcptax(levyInfo.number("LAST_PCPTAX").intValue()); // 최종 본세
rcvmt.setLastAdamt(levyInfo.number("LAST_ADAMT").intValue()); // 최종 가산금 rcvmt.setLastAdamt(levyInfo.number("LAST_ADAMT").intValue()); // 최종 가산금
@ -161,7 +162,7 @@ public class RcvmtBean extends AbstractComponent {
levy.setRcvmtYmd(rcvmt.getRcvmtYmd()); // 수납 일자 levy.setRcvmtYmd(rcvmt.getRcvmtYmd()); // 수납 일자
levy.setPayMthdSeCd(rcvmt.getPayMthdSeCd()); // 납부 방법 구분 코드 levy.setPayMthdSeCd(rcvmt.getPayMthdSeCd()); // 납부 방법 구분 코드
rtnScs = levyMapper.updateRcvmtAmt(levy); // 부과 대장 수정 rtnScs = levyMapper.updateRcvmt(levy); // 부과 대장 수정
if (!rtnScs) { if (!rtnScs) {
throw new RuntimeException("부과 대장에 수납금액 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback throw new RuntimeException("부과 대장에 수납금액 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
} }
@ -283,7 +284,7 @@ public class RcvmtBean extends AbstractComponent {
// 수납구분코드(RCVMT_SE_CD)가 이중 수납이 아니라면.. // 수납구분코드(RCVMT_SE_CD)가 이중 수납이 아니라면..
if (!rcvmtInfo.string("RCVMT_SE_CD").equals("02")) { if (!rcvmtInfo.string("RCVMT_SE_CD").equals("02")) {
// 부과 ID로 단속, 부과 정보 조회 // 부과 ID로 단속, 부과 정보 조회
DataObject levyInfo = rcvmtMapper.selectLevyInfo(new RcvmtQuery().setLevyId(rcvmtInfo.string("LEVY_ID")).setDelYN("N")); DataObject levyInfo = levyMapper.selectLevyAmt(new LevyQuery().setLevyId(rcvmtInfo.string("LEVY_ID")));
int rcvmtPcptax = levyInfo.number("RCVMT_PCPTAX").intValue() - rcvmtInfo.number("RCVMT_PCPTAX").intValue(); // 부과 수납본세 - 수납 수납본세 int rcvmtPcptax = levyInfo.number("RCVMT_PCPTAX").intValue() - rcvmtInfo.number("RCVMT_PCPTAX").intValue(); // 부과 수납본세 - 수납 수납본세
int rcvmtAdamt = levyInfo.number("RCVMT_ADAMT").intValue() - rcvmtInfo.number("RCVMT_ADAMT").intValue(); // 부과 수납가산금 - 수납 수납가산금 int rcvmtAdamt = levyInfo.number("RCVMT_ADAMT").intValue() - rcvmtInfo.number("RCVMT_ADAMT").intValue(); // 부과 수납가산금 - 수납 수납가산금
@ -306,7 +307,7 @@ public class RcvmtBean extends AbstractComponent {
levy.setPayMthdSeCd(levyInfo.string("PAY_MTHD_SE_CD")); // 납부 방법 구분 코드 levy.setPayMthdSeCd(levyInfo.string("PAY_MTHD_SE_CD")); // 납부 방법 구분 코드
} }
rtnScs = levyMapper.updateRcvmtAmt(levy); // 부과 대장 수정 rtnScs = levyMapper.updateRcvmt(levy); // 부과 대장 수정
if (!rtnScs) { if (!rtnScs) {
throw new RuntimeException("부과 대장에 수납금액 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback throw new RuntimeException("부과 대장에 수납금액 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
} }

@ -0,0 +1,85 @@
package cokr.xit.fims.rdca;
import lombok.Getter;
import lombok.Setter;
import cokr.xit.foundation.AbstractEntity;
/**
*
* @author JoJH
*/
@Getter
@Setter
public class Rdcamt extends AbstractEntity {
/**
* ID
*/
private String rdcamtId;
/**
* ID
*/
private String levyId;
/**
*
*/
private Integer lastPcptax;
/**
*
*/
private Integer lastAdamt;
/**
*
*/
private String rdcamtYmd;
/**
*
*/
private String rdcamtSeCd;
/**
*
*/
private String rdcamtRsnCd;
/**
*
*/
private Integer rdcamtPcptax;
/**
*
*/
private Integer rdcamtAdamt;
/**
*
*/
private String rdcamtRtrcnYn;
/**
*
*/
private String rdcamtRtrcnYmd;
/**
*
*/
private String rdcamtRtrcnRsn;
/**
*
*/
private String delYN;
/**
*
*/
private String delRsn;
}

@ -0,0 +1,110 @@
package cokr.xit.fims.rdca;
import cokr.xit.fims.cmmn.CmmnQuery;
/**
*
* <p> :
*
* <pre>
* ============ ============
* 2024-02-01 JoJH
* ================================
* </pre>
*/
public class RdcamtQuery extends CmmnQuery {
private static final long serialVersionUID = 1L;
// ID
private String[] rdcamtIDs; // 감액 IDs
private String rdcamtId; // 감액 ID
private String[] levyIDs; // 부과 IDs
private String levyId; // 부과 ID
// 검색 조건
private String schLevyExclYmdFrom; // 부과제외_부과제외 일자 시작
private String schLevyExclYmdTo; // 부과제외_부과제외 일자 종료
// 상세 검색 조건
// 동적 검색 조건
// ETC
private String callPurpose; // infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정, refresh 재조회).
private String delRsn; // 삭제 사유
public String[] getRdcamtIDs() {
return ifEmpty(rdcamtIDs, () -> null);
}
public <T extends RdcamtQuery> T setRdcamtIDs(String... rdcamtIDs) {
this.rdcamtIDs = rdcamtIDs;
return self();
}
public String getRdcamtId() {
return ifEmpty(rdcamtId, () -> null);
}
public <T extends RdcamtQuery> T setRdcamtId(String rdcamtId) {
this.rdcamtId = rdcamtId;
return self();
}
public String[] getLevyIDs() {
return ifEmpty(levyIDs, () -> null);
}
public <T extends RdcamtQuery> T setLevyIDs(String... levyIDs) {
this.levyIDs = levyIDs;
return self();
}
public String getLevyId() {
return ifEmpty(levyId, () -> null);
}
public <T extends RdcamtQuery> T setLevyId(String levyId) {
this.levyId = levyId;
return self();
}
public String getSchLevyExclYmdFrom() {
return ifEmpty(schLevyExclYmdFrom, () -> null);
}
public <T extends RdcamtQuery> T setSchLevyExclYmdFrom(String schLevyExclYmdFrom) {
this.schLevyExclYmdFrom = schLevyExclYmdFrom;
return self();
}
public String getSchLevyExclYmdTo() {
return ifEmpty(schLevyExclYmdTo, () -> null);
}
public <T extends RdcamtQuery> T setSchLevyExclYmdTo(String schLevyExclYmdTo) {
this.schLevyExclYmdTo = schLevyExclYmdTo;
return self();
}
// ETC /////////////////////////////////////////////////////////////////////
public String getCallPurpose() {
return ifEmpty(callPurpose, () -> null);
}
public <T extends RdcamtQuery> T setCallPurpose(String callPurpose) {
this.callPurpose = callPurpose;
return self();
}
public String getDelRsn() {
return ifEmpty(delRsn, () -> null);
}
public <T extends RdcamtQuery> T setDelRsn(String delRsn) {
this.delRsn = delRsn;
return self();
}
// ETC /////////////////////////////////////////////////////////////////////
}

@ -0,0 +1,117 @@
package cokr.xit.fims.rdca.dao;
import java.util.List;
import java.util.Map;
import org.egovframe.rte.psl.dataaccess.mapper.Mapper;
import cokr.xit.foundation.component.AbstractMapper;
import cokr.xit.foundation.data.DataObject;
import cokr.xit.fims.rdca.Rdcamt;
import cokr.xit.fims.rdca.RdcamtQuery;
/** DAO
*
* <p> :
*
* <pre>
* ============ ============
* 2024-02-01 JoJH
* ================================
* </pre>
*/
@Mapper("rdcamtMapper")
public interface RdcamtMapper extends AbstractMapper {
/** .<br />
* @param req
* @return
*/
List<DataObject> selectRdcamtList(RdcamtQuery req);
/** .
* @param req
* @return
*/
List<DataObject> selectRdcamts(RdcamtQuery req);
/** 1 .
* @param req
* @return
*/
default DataObject selectRdcamtInfo(RdcamtQuery req) {
// 삭제 여부 확인
if (req.getDelYN() == null) {
req.setDelYN("N");
}
// 기본 정렬
if (req.getOrderBy() == null) {
req.setOrderBy("R.RDCAMT_ID DESC");
}
List<DataObject> rdcamts = selectRdcamts(req);
return !rdcamts.isEmpty() ? rdcamts.get(0) : null;
}
/** .
* @param params
* <ul><li>"rdcamt" - </li>
* <li>"currentUser" - </li>
* </ul>
* @return
*/
int insertRdcamt(Map<String, Object> params);
/** .
* @param rdcamt
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
default boolean insert(Rdcamt rdcamt) {
return rdcamt != null && insertRdcamt(params().set("rdcamt", rdcamt)) == 1;
}
/** .
* @param params
* <ul><li>"rdcamt" - </li>
* <li>"currentUser" - </li>
* </ul>
* @return
*/
int updateRdcamt(Map<String, Object> params);
/** .
* @param rdcamt
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
default boolean update(Rdcamt rdcamt) {
return rdcamt != null && updateRdcamt(params().set("rdcamt", rdcamt)) == 1;
}
/** .
* @param params
* <ul><li>"rdcamt" - </li>
* <li>"currentUser" - </li>
* </ul>
* @return
*/
int deleteRdcamt(Map<String, ?> params);
/** .
* @param rdcamt
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
default boolean delete(Rdcamt rdcamt) {
return rdcamt != null && deleteRdcamt(params().set("rdcamt", rdcamt)) == 1;
}
}

@ -0,0 +1,66 @@
package cokr.xit.fims.rdca.service;
import java.util.List;
import cokr.xit.foundation.data.DataObject;
import cokr.xit.fims.rdca.Rdcamt;
import cokr.xit.fims.rdca.RdcamtQuery;
/** .
*
* <p> :
*
* <pre>
* ============ ============
* 2024-02-01 JoJH
* ================================
* </pre>
*/
public interface RdcamtService {
/** .
* @param req
* @return
*/
List<DataObject> getRdcamtList(RdcamtQuery req);
/** .
* @param req
* @return
*/
List<DataObject> getRdcamts(RdcamtQuery req);
/** 1 .<br />
* @param req
* @return
*/
DataObject getRdcamtInfo(RdcamtQuery req);
/** .
* @param rdcamt
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
String createRdcamt(Rdcamt rdcamt);
/** .
* @param rdcamt
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
String updateRdcamt(Rdcamt rdcamt);
/** .
* @param rdcamt
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
String removeRdcamt(Rdcamt rdcamt);
}

@ -0,0 +1,189 @@
package cokr.xit.fims.rdca.service.bean;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.stereotype.Component;
import cokr.xit.foundation.AbstractComponent;
import cokr.xit.foundation.data.DataObject;
import cokr.xit.fims.cmmn.CmmnUtil;
import cokr.xit.fims.levy.Levy;
import cokr.xit.fims.levy.LevyQuery;
import cokr.xit.fims.levy.dao.LevyMapper;
import cokr.xit.fims.rdca.Rdcamt;
import cokr.xit.fims.rdca.RdcamtQuery;
import cokr.xit.fims.rdca.dao.RdcamtMapper;
/** Bean
*
* <p> :
*
* <pre>
* ============ ============
* 2024-02-01 JoJH
* ================================
* </pre>
*/
@Component("rdcamtBean")
public class RdcamtBean extends AbstractComponent {
/** 감액 대장 정보 DAO */
@Resource(name = "rdcamtMapper")
private RdcamtMapper rdcamtMapper;
/** 부과 대장 정보 DAO */
@Resource(name = "levyMapper")
private LevyMapper levyMapper;
/** .
* @param req
* @return
*/
public List<DataObject> getRdcamtList(RdcamtQuery req) {
// 삭제 여부 확인
if (req.getDelYN() == null) {
req.setDelYN("N");
}
// 정렬 확인
if (req.getOrderBy() == null) {
if (req.getBy() == null) {
req.setOrderBy("REG_DT");
} else {
req.setOrderBy(CmmnUtil.convertCamelCaseToSnakeCase(req.getBy()));
}
}
return rdcamtMapper.selectRdcamtList(req);
}
/** .
* @param req
* @return
*/
public List<DataObject> getRdcamts(RdcamtQuery req) {
// 삭제 여부 확인
if (req.getDelYN() == null) {
req.setDelYN("N");
}
if (req.getOrderBy() == null) {
req.setOrderBy("R.RDCAMT_ID DESC");
}
return rdcamtMapper.selectRdcamts(req);
}
/** 1 .
* @param req
* @return
*/
public DataObject getRdcamtInfo(RdcamtQuery req) {
DataObject rdcamtInfo = new DataObject();
// if (req.getCallPurpose().equals("create")) {
// rdcamtInfo = rdcamtMapper.selectCrdnInfo(req);
// } else {
rdcamtInfo = rdcamtMapper.selectRdcamtInfo(req);
// }
return rdcamtInfo;
}
/** .
* @param rdcamt
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
public String createRdcamt(Rdcamt rdcamt) {
// 변수 선언
boolean rtnScs = false; // DB 처리 결과
String rtnMsg = "[F] "; // 처리 결과 메시지
// 부과 ID로 부과 정보 조회
DataObject levyInfo = levyMapper.selectLevyAmt(new LevyQuery().setLevyId(rdcamt.getLevyId()));
// 부과 확인
// 부과(TB_LEVY) 대장 정보를 수정한다.
Levy levy = new Levy();
// 부과 취소(전액감액)
if (rdcamt.getRdcamtSeCd().equals("02")) {
rdcamt.setLastPcptax(levyInfo.number("LAST_PCPTAX").intValue());
rdcamt.setLastAdamt(levyInfo.number("LAST_ADAMT").intValue());
rdcamt.setRdcamtPcptax(levyInfo.number("LAST_PCPTAX").intValue());
rdcamt.setRdcamtAdamt(levyInfo.number("LAST_ADAMT").intValue());
}
levy.setLevyId(levyInfo.string("LEVY_ID")); // 부과 ID
levy.setRdcamtPcptax(levyInfo.number("RDCAMT_PCPTAX").intValue() + rdcamt.getRdcamtPcptax()); // 감액 본세
levy.setRdcamtAdamt(levyInfo.number("RDCAMT_ADAMT").intValue() + rdcamt.getRdcamtAdamt()); // 감액 가산금
levy.setSumAmt(levyInfo.number("SUM_AMT").intValue() - rdcamt.getRdcamtPcptax() - rdcamt.getRdcamtAdamt()); // 합계 금액
levy.setDudtAftrAmt(levyInfo.number("DUDT_AFTR_AMT").intValue() - rdcamt.getRdcamtPcptax() - rdcamt.getRdcamtAdamt()); // 납기 후 금액
rtnScs = levyMapper.updateRdcamt(levy);
if (!rtnScs) {
throw new RuntimeException("부과 대장의 감액 금액 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
// 감액(TB_RDCAMT) 대장 정보를 등록한다.
rtnScs = rdcamtMapper.insert(rdcamt);
if (!rtnScs) {
throw new RuntimeException("감액 대장 등록에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
rtnMsg = "[S] 작업이 정상 처리 되었습니다.";
return rtnMsg;
}
/** .
* @param rdcamt
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
public String updateRdcamt(Rdcamt rdcamt) {
// 변수 선언
boolean rtnScs = false; // DB 처리 결과
String rtnMsg = "[F] "; // 처리 결과 메시지
// 감액(TB_RDCAMT) 대장 정보를 수정한다.
rtnScs = rdcamtMapper.update(rdcamt);
if (!rtnScs) {
throw new RuntimeException("감액 대장 수정에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
rtnMsg = "[S] 작업이 정상 처리 되었습니다.";
return rtnMsg;
}
/** .
* @param rdcamt
* @return
* <ul><li> true</li>
* <li> false</li>
* </ul>
*/
public String removeRdcamt(Rdcamt rdcamt) {
// 변수 선언
boolean rtnScs = false; // DB 처리 결과
String rtnMsg = "[F] "; // 처리 결과 메시지
// 감액(TB_RDCAMT) 대장 정보를 삭제한다.
rtnScs = rdcamtMapper.delete(rdcamt);
if (!rtnScs) {
throw new RuntimeException("감액 정보 삭제에 실패하였습니다."); // 예외를 발생시켜서 DB Rollback
}
rtnMsg = "[S] 작업이 정상 처리 되었습니다.";
return rtnMsg;
}
}

@ -0,0 +1,62 @@
package cokr.xit.fims.rdca.service.bean;
import java.util.List;
import javax.annotation.Resource;
import org.springframework.stereotype.Service;
import cokr.xit.foundation.component.AbstractServiceBean;
import cokr.xit.foundation.data.DataObject;
import cokr.xit.fims.rdca.Rdcamt;
import cokr.xit.fims.rdca.RdcamtQuery;
import cokr.xit.fims.rdca.service.RdcamtService;
/** .
*
* <p> :
*
* <pre>
* ============ ============
* 2024-02-01 JoJH
* ================================
* </pre>
*/
@Service("rdcamtService")
public class RdcamtServiceBean extends AbstractServiceBean implements RdcamtService {
/** 감액 대장 정보 Bean */
@Resource(name = "rdcamtBean")
private RdcamtBean rdcamtBean;
@Override
public List<DataObject> getRdcamtList(RdcamtQuery req) {
return rdcamtBean.getRdcamtList(req);
}
@Override
public List<DataObject> getRdcamts(RdcamtQuery req) {
return rdcamtBean.getRdcamts(req);
}
@Override
public DataObject getRdcamtInfo(RdcamtQuery req) {
return rdcamtBean.getRdcamtInfo(req);
}
@Override
public String createRdcamt(Rdcamt rdcamt) {
return rdcamtBean.createRdcamt(rdcamt);
}
@Override
public String updateRdcamt(Rdcamt rdcamt) {
return rdcamtBean.updateRdcamt(rdcamt);
}
@Override
public String removeRdcamt(Rdcamt rdcamt) {
return rdcamtBean.removeRdcamt(rdcamt);
}
}

@ -0,0 +1,234 @@
package cokr.xit.fims.rdca.web;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import javax.annotation.Resource;
import org.apache.poi.ss.usermodel.CellStyle;
import org.springframework.web.servlet.ModelAndView;
import com.fasterxml.jackson.core.type.TypeReference;
import cokr.xit.base.code.CommonCode;
import cokr.xit.base.file.xls.XLSWriter;
import cokr.xit.base.file.xls.XLSWriter.CellDef;
import cokr.xit.base.file.xls.XLSWriter.Styler;
import cokr.xit.base.user.ManagedUser;
import cokr.xit.base.web.ApplicationController;
import cokr.xit.fims.cmmn.CmmnUtil;
import cokr.xit.fims.cmmn.service.bean.StngBean;
import cokr.xit.fims.rdca.Rdcamt;
import cokr.xit.fims.rdca.RdcamtQuery;
import cokr.xit.fims.rdca.service.RdcamtService;
import cokr.xit.foundation.data.DataObject;
/**
*
* <p> :
*
* <pre>
* ============ ============
* 2024-02-01 JoJH
* ================================
* </pre>
*/
public class Rdca01Controller extends ApplicationController {
public static final String CLASS_URL = "/rdca/rdca01";
public class METHOD_URL {
public static final String
reducedAmountMain = "/010/main.do" // 감액 관리 메인 화면
, getReducedAmountList = "/010/list.do" // 감액 대장 목록 조회
, getReducedAmountInfo = "/020/info.do" // 감액 대장 조회
, createReducedAmount = "/020/create.do" // 감액 대장 등록
, updateReducedAmount = "/020/update.do" // 감액 대장 수정
, removeReducedAmount = "/010/remove.do" // 감액 대장 삭제
;
}
/**감액 대장 서비스*/
@Resource(name = "rdcamtService")
private RdcamtService rdcamtService;
@Resource(name = "stngBean")
private StngBean stngBean;
/** (rdcamt/rdcamt-main) .
* {@link #getRdcamtList(RdcamtQuery) } .
* @return /rdcamt/rdcamt-main
*/
public ModelAndView reducedAmountMain() {
ModelAndView mav = new ModelAndView("fims/rdca/rdca01010-main");
// 사용자 정보
ManagedUser managedUser = (ManagedUser)currentUser().getUser();
// View(jsp)에서 사용할 공통코드를 조회
Map<String, List<CommonCode>> commonCodes = getCodesOf("FIM021", "FIM022", "FIM054", "FIM085");
addCodes(commonCodes, mav, "FIM021", "FIM022", "FIM085");
return mav
.addObject("pageName", "rdca01010") // View(jsp)에서 사용할 id 뒤에 붙일 suffix
.addObject("infoPrefix", "rdcamt") // prefix
.addObject("sggCd", managedUser.getOrgID()) // 시군구 코드(SGG_CD)
.addObject("taskListForSgg", stngBean.filterTaskSectionCodeForSgg(commonCodes.get("FIM054")))
.addObject("FIM021List", commonCodes.get("FIM021")) // 부과 제외 구분 코드(LEVY_EXCL_SE_CD)
.addObject("FIM022List", commonCodes.get("FIM022")) // 부과 제외 사유 코드(LEVY_EXCL_RSN_CD)
.addObject("FIM054List", commonCodes.get("FIM054")) // 업무 구분 코드(TASK_SE_CD)
.addObject("FIM085List", commonCodes.get("FIM085")) // 감액 구분 코드(RDCAMT_SE_CD)
;
}
/** .<br />
* {@link RdcamtService#getRdcamtList(RdcamtQuery)}
* @param req
* @return jsonView
* <pre><code> {
* "rdcamtList": [ ]
* "rdcamtStart":
* "rdcamtFetch":
* "rdcamtTotal":
* }</code></pre>
*/
public ModelAndView getReducedAmountList(RdcamtQuery req) {
if (!"xls".equals(req.getDownload())) {
List<?> result = rdcamtService.getRdcamtList(setFetchSize(req));
return setCollectionInfo(new ModelAndView("jsonView"), result, "rdcamt");
} else {
// 현재 날짜 구하기
SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMddHHmmss");
String dateTime = dateFormat.format(System.currentTimeMillis());
ArrayList<CellDef> cellDefs = fromJson(req.getCellDefs(), new TypeReference<ArrayList<CellDef>>() {});
XLSWriter xlsx = new XLSWriter()
.setFilename("감액" + "_목록_" + dateTime + ".xlsx")
.worksheet(0);
// CellStyle 지정은 여기에서..
CellStyle center = xlsx.cellStyle(Styler.CENTER); // 가운데 정렬
CellStyle numeric = xlsx.n_nn0(); // 숫자 3자리 콤마(,)
CellStyle dateYMD = xlsx.yyyy_mm_dd(); // 연월일
CellStyle dateDT = xlsx.yyyy_mm_dd_hh_mm_ss(); // 연월일+시간
List<DataObject> list = rdcamtService.getRdcamtList(req.setFetchSize(0));
CellDef.setValues(cellDefs, Map.ofEntries(
Map.entry("업무구분", xlsx.style("TASK_SE_NM", center))
, Map.entry("부과제외일자", xlsx.format(o -> xlsx.str2date(o.get("LEVY_EXCL_YMD"))).style(dateYMD))
, Map.entry("부과제외구분", xlsx.style("LEVY_EXCL_SE_NM", center))
, Map.entry("부과제외사유", "LEVY_EXCL_RSN_NM")
, Map.entry("기타내용", "ETC_CN")
, Map.entry("민원신청번호", xlsx.style("CVLCPT_APLY_NO", center))
, Map.entry("민원접수번호", xlsx.style("CVLCPT_RCPT_NO", center))
, Map.entry("민원접수일자", xlsx.format(o -> xlsx.str2date(o.get("CVLCPT_RCPT_YMD"))).style(dateYMD))
, Map.entry("단속일시", xlsx.format(o -> xlsx.str2datetime(o.get("CRDN_YMD_TM"))).style(dateDT))
, Map.entry("차량번호", "VHRNO")
, Map.entry("납부자구분", xlsx.style("RTPYR_SE_NM", center))
, Map.entry("납부자번호", xlsx.style("RTPYR_NO", center))
, Map.entry("납부자명", "RTPYR_NM")
, Map.entry("단속법정동", xlsx.style("CRDN_STDG_NM", center))
, Map.entry("단속장소", "CRDN_PLC")
, Map.entry("상세단속장소", "DTL_CRDN_PLC")
, Map.entry("위반항목", "VLTN_ARTCL")
, Map.entry("최초단속금액", xlsx.style("FFNLG_CRDN_AMT", numeric))
, Map.entry("처리상태", "CRDN_STTS_NM")
, Map.entry("단속특별구역", xlsx.style("CRDN_SPAREA_NM", center))
, Map.entry("사용연료", xlsx.style("USE_FUEL_NM", center))
, Map.entry("주차가능여부", xlsx.style("PARKNG_PSBLTY_RSLT_NM", center))
, Map.entry("우편번호", xlsx.style("ZIP", center))
, Map.entry("주소", "ADDR")
, Map.entry("상세주소", "DTL_ADDR")
, Map.entry("등록일시", xlsx.format(o -> xlsx.str2datetime(o.get("REG_DT"))).style(dateDT))
, Map.entry("등록사용자", xlsx.style("RGTR_NM", center))
, Map.entry("수정일시", xlsx.format(o -> xlsx.str2datetime(o.get("MDFCN_DT"))).style(dateDT))
, Map.entry("수정사용자", xlsx.style("MDFR_NM", center))
)
);
xlsx.cell(0, 0)
.value("감액", center)
.merge(0, cellDefs.size() - 1)
.cell(3, 0)
.rowValues(CellDef.header(cellDefs, () -> CmmnUtil.headerStyle(xlsx)))
.cell(4, 0)
.values(list, CellDef.values(cellDefs));
return new ModelAndView("xlsView")
.addObject("xls", xlsx);
}
}
/** .
* @param rdcamt
* @return jsonView
* <pre><code> {
* "saved": true, false
* }</code></pre>
*/
public ModelAndView createReducedAmount(Rdcamt rdcamt) {
boolean saved = false;
String rtnMsg = rdcamtService.createRdcamt(rdcamt);
if (rtnMsg.contains("[S]")) {
saved = true;
} else {
saved = false;
}
return new ModelAndView("jsonView")
.addObject("saved", saved)
.addObject("rtnMsg", rtnMsg);
}
/** .
* @param rdcamt
* @return jsonView
* <pre><code> {
* "saved": true, false
* }</code></pre>
*/
public ModelAndView updateReducedAmount(Rdcamt rdcamt) {
boolean saved = false;
String rtnMsg = rdcamtService.updateRdcamt(rdcamt);
if (rtnMsg.contains("[S]")) {
saved = true;
} else {
saved = false;
}
return new ModelAndView("jsonView")
.addObject("saved", saved)
.addObject("rtnMsg", rtnMsg);
}
/** .
* @param rdcamtIDs
* @return jsonView
* <pre><code> {
* "affected":
* "saved": true, false
* }</code></pre>
*/
public ModelAndView removeReducedAmount(Rdcamt rdcamt) {
boolean saved = false;
String rtnMsg = rdcamtService.removeRdcamt(rdcamt);
if (rtnMsg.contains("[S]")) {
saved = true;
} else {
saved = false;
}
return new ModelAndView("jsonView")
.addObject("saved", saved)
.addObject("rtnMsg", rtnMsg);
}
}

@ -1164,12 +1164,12 @@ public class SndngBean extends AbstractComponent {
// OCR 1번째 줄 54 // OCR 1번째 줄 54
// band1 = 부서코드 + 회계연도 + 회계구분 + 세목코드 + 고지번호 + 분납순번 // band1 = 부서코드 + 회계연도 + 회계구분 + 세목코드 + 고지번호 + 분납순번
band1 = sndngDtlInfo.string("DEPT_CD") + "0000" band1 = sndngDtlInfo.string("DEPT_CD") + sndngDtlInfo.string("SPCL_BIZ_CD")
+ sndngDtlInfo.string("FYR") + sndngDtlInfo.string("FYR")
+ sndngDtlInfo.string("ACNTG_SE_CD") + sndngDtlInfo.string("ACNTG_SE_CD")
+ sndngDtlInfo.string("TXITM_CD") + sndngDtlInfo.string("TXITM_CD")
+ sndngDtlInfo.string("LEVY_NO") + sndngDtlInfo.string("LEVY_NO")
+ sndngDtlInfo.string("INSPY_SN"); + sndngDtlInfo.string("INSPY_NO");
ocrVrfcCode = getOcrVrfcCode("12357", band1, 31); ocrVrfcCode = getOcrVrfcCode("12357", band1, 31);
band1 = band1 + ocrVrfcCode; band1 = band1 + ocrVrfcCode;

@ -33,7 +33,6 @@
, CRR.DEL_YN <!-- 삭제 여부 --> , CRR.DEL_YN <!-- 삭제 여부 -->
, CRR.REG_DT <!-- 등록 일시 --> , CRR.REG_DT <!-- 등록 일시 -->
, CRR.DEL_DT <!-- 삭제 일시 --> , CRR.DEL_DT <!-- 삭제 일시 -->
, CRR.DEL_RSN <!-- 삭제 사유 -->
, (SELECT GET_CODE_NM('FIM026', CRR.CRDN_REG_SE_CD) FROM DUAL) AS CRDN_REG_SE_NM <!-- 단속 등록 구분 명 --> , (SELECT GET_CODE_NM('FIM026', CRR.CRDN_REG_SE_CD) FROM DUAL) AS CRDN_REG_SE_NM <!-- 단속 등록 구분 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = CRR.RGTR) AS RGTR_NM <!-- 등록자 명 --> , (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = CRR.RGTR) AS RGTR_NM <!-- 등록자 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = CRR.DLTR) AS DLTR_NM <!-- 삭제자 명 --> , (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = CRR.DLTR) AS DLTR_NM <!-- 삭제자 명 -->
@ -66,7 +65,6 @@
, P.RTPYR_SE_CD <!-- 납부자 구분 코드 --> , P.RTPYR_SE_CD <!-- 납부자 구분 코드 -->
, P.RTPYR_NO <!-- 납부자 번호 --> , P.RTPYR_NO <!-- 납부자 번호 -->
, P.RTPYR_NM <!-- 납부자 명 --> , P.RTPYR_NM <!-- 납부자 명 -->
, P.RTPYR_BRDT <!-- 납부자 생년월일 -->
, P.ZIP <!-- 우편번호 --> , P.ZIP <!-- 우편번호 -->
, P.ADDR <!-- 주소 --> , P.ADDR <!-- 주소 -->
, P.DTL_ADDR <!-- 상세 주소 --> , P.DTL_ADDR <!-- 상세 주소 -->
@ -83,16 +81,15 @@
<include refid="utility.paging-prefix" /> <include refid="utility.paging-prefix" />
<include refid="select" /> <include refid="select" />
WHERE CRR.CRDN_REG_SE_CD = '03' <!-- 단속 등록 구분 코드 - FIM026 --> WHERE CRR.CRDN_REG_SE_CD = '03' <!-- 단속 등록 구분 코드 - FIM026 -->
AND C.SGG_CD = #{sggCd} <!-- 시군구 코드 -->
<if test="taskSeCd != null">
AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 -->
</if>
<if test="schReRegYmdFrom != null"> <if test="schReRegYmdFrom != null">
AND CRR.RE_REG_YMD <![CDATA[>=]]> #{schReRegYmdFrom} <!-- 재등록 일자 시작 --> AND CRR.RE_REG_YMD <![CDATA[>=]]> #{schReRegYmdFrom} <!-- 재등록 일자 시작 -->
</if> </if>
<if test="schReRegYmdTo != null"> <if test="schReRegYmdTo != null">
AND CRR.RE_REG_YMD <![CDATA[<=]]> #{schReRegYmdTo} <!-- 재등록 일자 종료 --> AND CRR.RE_REG_YMD <![CDATA[<=]]> #{schReRegYmdTo} <!-- 재등록 일자 종료 -->
</if> </if>
<if test="delYN != null">
AND CRR.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if>
<if test="schCrdnYmdFrom != null"> <if test="schCrdnYmdFrom != null">
AND C.CRDN_YMD <![CDATA[>=]]> #{schCrdnYmdFrom} <!-- 단속 일자 시작 --> AND C.CRDN_YMD <![CDATA[>=]]> #{schCrdnYmdFrom} <!-- 단속 일자 시작 -->
</if> </if>
@ -102,10 +99,12 @@
<if test = "schVhrno != null"> <if test = "schVhrno != null">
AND C.VHRNO = #{schVhrno} <!-- 차량번호 --> AND C.VHRNO = #{schVhrno} <!-- 차량번호 -->
</if> </if>
<if test="delYN != null"> <if test="sggCd != null">
AND CRR.DEL_YN = #{delYN} <!-- 삭제 여부 --> AND C.SGG_CD = #{sggCd} <!-- 시군구 코드 -->
</if>
<if test="taskSeCd != null">
AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 -->
</if> </if>
AND C.DEL_YN = 'N' <!-- 단속 삭제 여부 -->
<choose> <choose>
<when test="schRegDateOpt == 'regDt'"> <when test="schRegDateOpt == 'regDt'">
<if test="schRegDateFrom != null"> <if test="schRegDateFrom != null">
@ -169,10 +168,6 @@
<select id="selectCrdnReRegs" parameterType="map" resultType="dataobject">/* 단속 재등록 객체 가져오기(crdnReRegMapper.selectCrdnReRegs) */ <select id="selectCrdnReRegs" parameterType="map" resultType="dataobject">/* 단속 재등록 객체 가져오기(crdnReRegMapper.selectCrdnReRegs) */
<include refid="select" /> <include refid="select" />
<where> <where>
<if test="crdnId != null">
AND C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
AND C.DEL_YN = 'N' <!-- 단속 삭제 여부 -->
</if>
<if test="reRegIDs != null"> <if test="reRegIDs != null">
AND CRR.RE_REG_ID IN ( <!-- 재등록 ID --> AND CRR.RE_REG_ID IN ( <!-- 재등록 ID -->
<foreach collection="reRegIDs" item="reRegId" separator=","> #{reRegId} </foreach> <foreach collection="reRegIDs" item="reRegId" separator=","> #{reRegId} </foreach>
@ -184,6 +179,9 @@
<if test="delYN != null"> <if test="delYN != null">
AND CRR.DEL_YN = #{delYN} <!-- 삭제 여부 --> AND CRR.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if> </if>
<if test="crdnId != null">
AND C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
</if>
</where> </where>
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
</select> </select>
@ -221,7 +219,7 @@
<update id="deleteCrdnReReg" parameterType="map">/* 단속 재등록 삭제(crdnReRegMapper.deleteCrdnReReg) */ <update id="deleteCrdnReReg" parameterType="map">/* 단속 재등록 삭제(crdnReRegMapper.deleteCrdnReReg) */
UPDATE TB_CRDN_RE_REG UPDATE TB_CRDN_RE_REG
SET DEL_YN = 'Y' <!-- 삭제 여부 --> SET DEL_YN = 'Y'
, DEL_DT = <include refid="utility.now" /> <!-- 삭제 일시 --> , DEL_DT = <include refid="utility.now" /> <!-- 삭제 일시 -->
, DLTR = #{crdnReReg.modifiedBy} <!-- 삭제자 --> , DLTR = #{crdnReReg.modifiedBy} <!-- 삭제자 -->
, DEL_RSN = #{crdnReReg.delRsn} <!-- 삭제 사유 --> , DEL_RSN = #{crdnReReg.delRsn} <!-- 삭제 사유 -->
@ -229,7 +227,7 @@
AND DEL_YN = 'N' AND DEL_YN = 'N'
</update> </update>
<select id="selectCrdn" parameterType="map" resultType="dataobject">/* 단속 재등록 객체 가져오기(crdnReRegMapper.selectCrdn) */ <select id="selectCrdnInfo" parameterType="string" resultType="dataobject">/* 단속 재등록 객체 가져오기(crdnReRegMapper.selectCrdnInfo) */
SELECT C.CRDN_ID SELECT C.CRDN_ID
, C.SGG_CD , C.SGG_CD
, C.TASK_SE_CD , C.TASK_SE_CD

@ -36,7 +36,6 @@
, LE.REG_DT <!-- 등록 일시 --> , LE.REG_DT <!-- 등록 일시 -->
, LE.MDFCN_DT <!-- 수정 일시 --> , LE.MDFCN_DT <!-- 수정 일시 -->
, LE.DEL_DT <!-- 삭제 일시 --> , LE.DEL_DT <!-- 삭제 일시 -->
, LE.DEL_RSN <!-- 삭제 사유 -->
, (SELECT GET_CODE_NM('FIM021', LE.LEVY_EXCL_SE_CD) FROM DUAL) AS LEVY_EXCL_SE_NM <!-- 부과 제외 구분 명 --> , (SELECT GET_CODE_NM('FIM021', LE.LEVY_EXCL_SE_CD) FROM DUAL) AS LEVY_EXCL_SE_NM <!-- 부과 제외 구분 명 -->
, (SELECT GET_CODE_NM('FIM022', LE.LEVY_EXCL_RSN_CD) FROM DUAL) AS LEVY_EXCL_RSN_NM <!-- 부과 제외 사유 명 --> , (SELECT GET_CODE_NM('FIM022', LE.LEVY_EXCL_RSN_CD) FROM DUAL) AS LEVY_EXCL_RSN_NM <!-- 부과 제외 사유 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = LE.RGTR) AS RGTR_NM <!-- 등록자 명 --> , (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = LE.RGTR) AS RGTR_NM <!-- 등록자 명 -->
@ -68,7 +67,6 @@
, P.RTPYR_SE_CD <!-- 납부자 구분 코드 --> , P.RTPYR_SE_CD <!-- 납부자 구분 코드 -->
, P.RTPYR_NO <!-- 납부자 번호 --> , P.RTPYR_NO <!-- 납부자 번호 -->
, P.RTPYR_NM <!-- 납부자 명 --> , P.RTPYR_NM <!-- 납부자 명 -->
, P.RTPYR_BRDT <!-- 납부자 생년월일 -->
, P.ZIP <!-- 우편번호 --> , P.ZIP <!-- 우편번호 -->
, P.ADDR <!-- 주소 --> , P.ADDR <!-- 주소 -->
, P.DTL_ADDR <!-- 상세 주소 --> , P.DTL_ADDR <!-- 상세 주소 -->
@ -79,7 +77,6 @@
, CC.CVLCPT_APLY_NO <!-- 민원 신청 번호 --> , CC.CVLCPT_APLY_NO <!-- 민원 신청 번호 -->
, CC.CVLCPT_RCPT_NO <!-- 민원 접수 번호 --> , CC.CVLCPT_RCPT_NO <!-- 민원 접수 번호 -->
, CC.CVLCPT_PRCS_CD <!-- 민원 처리 코드 --> , CC.CVLCPT_PRCS_CD <!-- 민원 처리 코드 -->
, CC.CVLCPT_PRCS_CMPTN_DT <!-- 민원 처리 완료 일시 -->
, (SELECT GET_CODE_NM('FIM017', CC.CVLCPT_PRCS_CD) FROM DUAL) AS CVLCPT_PRCS_NM <!-- 민원 처리 명 --> , (SELECT GET_CODE_NM('FIM017', CC.CVLCPT_PRCS_CD) FROM DUAL) AS CVLCPT_PRCS_NM <!-- 민원 처리 명 -->
FROM TB_LEVY_EXCL LE FROM TB_LEVY_EXCL LE
INNER JOIN TB_CRDN C ON (LE.CRDN_ID = C.CRDN_ID) INNER JOIN TB_CRDN C ON (LE.CRDN_ID = C.CRDN_ID)
@ -92,10 +89,7 @@
<select id="selectLevyExclList" parameterType="map" resultType="dataobject">/* 부과제외 대장 목록 조회(levyExclMapper.selectLevyExclList) */ <select id="selectLevyExclList" parameterType="map" resultType="dataobject">/* 부과제외 대장 목록 조회(levyExclMapper.selectLevyExclList) */
<include refid="utility.paging-prefix" /> <include refid="utility.paging-prefix" />
<include refid="selectList" /> <include refid="selectList" />
WHERE C.SGG_CD = #{sggCd} <!-- 시군구 코드 --> <where>
<if test="taskSeCd != null">
AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 -->
</if>
<if test="schLevyExclYmdFrom != null"> <if test="schLevyExclYmdFrom != null">
AND LE.LEVY_EXCL_YMD <![CDATA[>=]]> #{schLevyExclYmdFrom} <!-- 부과제외 일자 시작 --> AND LE.LEVY_EXCL_YMD <![CDATA[>=]]> #{schLevyExclYmdFrom} <!-- 부과제외 일자 시작 -->
</if> </if>
@ -104,6 +98,15 @@
</if> </if>
<if test="schLevyExclSeCd != null"> <if test="schLevyExclSeCd != null">
AND LE.LEVY_EXCL_SE_CD = #{schLevyExclSeCd} <!-- 부과 제외 구분 코드 --> AND LE.LEVY_EXCL_SE_CD = #{schLevyExclSeCd} <!-- 부과 제외 구분 코드 -->
</if>
<if test="delYN != null">
AND LE.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if>
<if test="sggCd != null">
AND C.SGG_CD = #{sggCd} <!-- 시군구 코드 -->
</if>
<if test="taskSeCd != null">
AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 -->
</if> </if>
<if test="schCrdnYmdFrom != null"> <if test="schCrdnYmdFrom != null">
AND C.CRDN_YMD <![CDATA[>=]]> #{schCrdnYmdFrom} <!-- 단속 일자 시작 --> AND C.CRDN_YMD <![CDATA[>=]]> #{schCrdnYmdFrom} <!-- 단속 일자 시작 -->
@ -114,13 +117,10 @@
<if test="schVhrno != null"> <if test="schVhrno != null">
AND C.VHRNO = #{schVhrno} <!-- 차량번호 --> AND C.VHRNO = #{schVhrno} <!-- 차량번호 -->
</if> </if>
AND C.DEL_YN = 'N' <!-- 단속 삭제 여부 -->
<if test="schRtpyrNm != null"> <if test="schRtpyrNm != null">
AND P.RTPYR_NM = #{schRtpyrNm} <!-- 납부자 명 --> AND P.RTPYR_NM = #{schRtpyrNm} <!-- 납부자 명 -->
</if> </if>
<if test="delYN != null">
AND LE.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if>
AND C.DEL_YN = 'N' <!-- 단속 삭제 여부 -->
<choose> <choose>
<when test="schRegDateOpt == 'regDt'"> <when test="schRegDateOpt == 'regDt'">
<if test="schRegDateFrom != null"> <if test="schRegDateFrom != null">
@ -187,6 +187,7 @@
</otherwise> </otherwise>
</choose> </choose>
</if> </if>
</where>
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
<include refid="utility.paging-suffix" /> <include refid="utility.paging-suffix" />
</select> </select>
@ -218,10 +219,8 @@
, C.CRDN_STTS_CHG_DT <!-- 단속 상태 변경 일시 --> , C.CRDN_STTS_CHG_DT <!-- 단속 상태 변경 일시 -->
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 --> , (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 -->
, (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 --> , (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, CA.PARKNG_PSBLTY_RSLT_CD <!-- 주차 가능 결과 코드 -->
FROM TB_LEVY_EXCL LE FROM TB_LEVY_EXCL LE
LEFT OUTER JOIN TB_CRDN C ON (LE.CRDN_ID = C.CRDN_ID) INNER JOIN TB_CRDN C ON (LE.CRDN_ID = C.CRDN_ID)
LEFT OUTER JOIN TB_CRDN_ADI CA ON (C.CRDN_ID = CA.CRDN_ID)
</sql> </sql>
<select id="selectLevyExcls" parameterType="map" resultType="dataobject">/* 부과제외 대장 객체 가져오기(levyExclMapper.selectLevyExcls) */ <select id="selectLevyExcls" parameterType="map" resultType="dataobject">/* 부과제외 대장 객체 가져오기(levyExclMapper.selectLevyExcls) */
@ -234,41 +233,18 @@
</if> </if>
<if test="levyExclId != null"> <if test="levyExclId != null">
AND LE.LEVY_EXCL_ID = #{levyExclId} <!-- 부과 제외 ID --> AND LE.LEVY_EXCL_ID = #{levyExclId} <!-- 부과 제외 ID -->
</if>
<if test="delYN != null">
AND LE.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if> </if>
<if test="crdnId != null"> <if test="crdnId != null">
AND C.CRDN_ID = #{crdnId} <!-- 단속 ID --> AND C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
AND C.DEL_YN = 'N' <!-- 삭제 여부 --> AND C.DEL_YN = 'N' <!-- 삭제 여부 -->
</if> </if>
<if test="delYN != null">
AND LE.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if>
</where> </where>
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
</select> </select>
<select id="selectCrdn" parameterType="map" resultType="dataobject">/* 단속 대장 객체 가져오기(levyExclMapper.selectCrdn) */
SELECT C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.VHRNO <!-- 차량번호 -->
, C.CRDN_STDG_NM <!-- 단속 법정동 명 -->
, C.CRDN_ROAD_NM <!-- 단속 도로 명 -->
, C.CRDN_PLC <!-- 단속 장소 -->
, C.CRDN_STTS_CD <!-- 단속 상태 코드 -->
, C.CRDN_STTS_CHG_DT <!-- 단속 상태 변경 일시 -->
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 -->
, (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, CC.CVLCPT_LINK_ID <!-- 민원 연계 ID -->
, CC.CVLCPT_PRCS_CD <!-- 민원 처리 코드 -->
, CC.CVLCPT_TRSM_CD <!-- 민원 전송 코드 -->
, LE.LEVY_EXCL_ID <!-- 부과제외 ID -->
FROM TB_CRDN C
LEFT OUTER JOIN TB_CRDN_CVLCPT CC ON (C.LINK_ID = CC.CVLCPT_LINK_ID AND C.CVLCPT_LINK_YN = 'Y' AND CC.DEL_YN = 'N')
LEFT OUTER JOIN TB_LEVY_EXCL LE ON (C.CRDN_ID = LE.CRDN_ID AND LE.DEL_YN = 'N')
WHERE C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
AND C.DEL_YN = 'N' <!-- 삭제 여부 -->
</select>
<insert id="insertLevyExcl" parameterType="map">/* 부과제외 대장 등록(levyExclMapper.insertLevyExcl) */ <insert id="insertLevyExcl" parameterType="map">/* 부과제외 대장 등록(levyExclMapper.insertLevyExcl) */
<selectKey resultType="string" keyProperty="levyExcl.levyExclId" keyColumn="NEW_ID" order="BEFORE"> <selectKey resultType="string" keyProperty="levyExcl.levyExclId" keyColumn="NEW_ID" order="BEFORE">
SELECT CONCAT(DATE_FORMAT(CURRENT_DATE, '%Y'), LPAD(CAST(IFNULL(MAX(SUBSTRING(LEVY_EXCL_ID, 5)) + 1, 1) AS INT), 16, '0')) AS NEW_ID SELECT CONCAT(DATE_FORMAT(CURRENT_DATE, '%Y'), LPAD(CAST(IFNULL(MAX(SUBSTRING(LEVY_EXCL_ID, 5)) + 1, 1) AS INT), 16, '0')) AS NEW_ID
@ -317,7 +293,7 @@
<update id="deleteLevyExcl" parameterType="map">/* 부과제외 대장 삭제(levyExclMapper.deleteLevyExcl) */ <update id="deleteLevyExcl" parameterType="map">/* 부과제외 대장 삭제(levyExclMapper.deleteLevyExcl) */
UPDATE TB_LEVY_EXCL UPDATE TB_LEVY_EXCL
SET DEL_YN = 'Y' <!-- 삭제 여부 --> SET DEL_YN = 'Y'
, DEL_DT = <include refid="utility.now" /> <!-- 삭제 일시 --> , DEL_DT = <include refid="utility.now" /> <!-- 삭제 일시 -->
, DLTR = #{levyExcl.modifiedBy} <!-- 삭제자 --> , DLTR = #{levyExcl.modifiedBy} <!-- 삭제자 -->
, DEL_RSN = #{levyExcl.delRsn} <!-- 삭제 사유 --> , DEL_RSN = #{levyExcl.delRsn} <!-- 삭제 사유 -->
@ -325,6 +301,30 @@
AND DEL_YN = 'N' AND DEL_YN = 'N'
</update> </update>
<select id="selectCrdnInfo" parameterType="string" resultType="dataobject">/* 단속 대장 객체 가져오기(levyExclMapper.selectCrdnInfo) */
SELECT C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.VHRNO <!-- 차량번호 -->
, C.CRDN_STDG_NM <!-- 단속 법정동 명 -->
, C.CRDN_ROAD_NM <!-- 단속 도로 명 -->
, C.CRDN_PLC <!-- 단속 장소 -->
, C.CRDN_STTS_CD <!-- 단속 상태 코드 -->
, C.CRDN_STTS_CHG_DT <!-- 단속 상태 변경 일시 -->
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 -->
, (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, L.LEVY_ID <!-- 부과 ID -->
, CC.CVLCPT_LINK_ID <!-- 민원 연계 ID -->
, CC.CVLCPT_PRCS_CD <!-- 민원 처리 코드 -->
, LE.LEVY_EXCL_ID <!-- 부과제외 ID -->
FROM TB_CRDN C
LEFT OUTER JOIN TB_LEVY L ON (C.CRDN_ID = L.CRDN_ID AND L.DEL_YN = 'N')
LEFT OUTER JOIN TB_CRDN_CVLCPT CC ON (C.LINK_ID = CC.CVLCPT_LINK_ID AND C.CVLCPT_LINK_YN = 'Y' AND CC.DEL_YN = 'N')
LEFT OUTER JOIN TB_LEVY_EXCL LE ON (C.CRDN_ID = LE.CRDN_ID AND LE.DEL_YN = 'N')
WHERE C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
AND C.DEL_YN = 'N' <!-- 삭제 여부 -->
</select>
<select id="selectCvlcptAnsWords" parameterType="map" resultType="dataobject">/* 민원답변문구 대장 객체 가져오기(levyExclMapper.selectCvlcptAnsWords) */ <select id="selectCvlcptAnsWords" parameterType="map" resultType="dataobject">/* 민원답변문구 대장 객체 가져오기(levyExclMapper.selectCvlcptAnsWords) */
SELECT CAW.ANS_WORDS_ID <!-- 답변 문구 ID --> SELECT CAW.ANS_WORDS_ID <!-- 답변 문구 ID -->
, CAW.ANS_SE_CD <!-- 답변 구분 코드 --> , CAW.ANS_SE_CD <!-- 답변 구분 코드 -->
@ -340,10 +340,11 @@
AND CAW.USE_YN = 'Y' AND CAW.USE_YN = 'Y'
</select> </select>
<update id="updateCvlcptPrcsRsltCn" parameterType="map">/* 단속민원 대장 민원처리결과내용 초기화(levyExclMapper.updateCvlcptPrcsRsltCn) */ <update id="updateCrdnCvlcptPrcsRsltCn" parameterType="map">/* 단속민원 대장 민원처리결과내용 초기화(levyExclMapper.updateCrdnCvlcptPrcsRsltCn) */
UPDATE TB_CRDN_CVLCPT UPDATE TB_CRDN_CVLCPT
SET CVLCPT_PRCS_SUMRY = NULL <!-- 민원 처리 요약 --> SET CVLCPT_PRCS_SUMRY = NULL <!-- 민원 처리 요약 -->
, CVLCPT_PRCS_RSLT_CN = NULL <!-- 민원 처리 결과 내용 --> , CVLCPT_PRCS_RSLT_CN = NULL <!-- 민원 처리 결과 내용 -->
, CVLCPT_PRCS_CMPTN_DT = NULL <!-- 민원 처리 완료 일시 -->
, MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 --> , MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 -->
, MDFR = #{crdnCvlcpt.modifiedBy} <!-- 수정자 --> , MDFR = #{crdnCvlcpt.modifiedBy} <!-- 수정자 -->
WHERE CVLCPT_LINK_ID = #{crdnCvlcpt.cvlcptLinkId} <!-- 민원 연계 ID --> WHERE CVLCPT_LINK_ID = #{crdnCvlcpt.cvlcptLinkId} <!-- 민원 연계 ID -->

@ -77,7 +77,6 @@
, OS.REG_DT <!-- 등록 일시 --> , OS.REG_DT <!-- 등록 일시 -->
, OS.MDFCN_DT <!-- 수정 일시 --> , OS.MDFCN_DT <!-- 수정 일시 -->
, OS.DEL_DT <!-- 삭제 일시 --> , OS.DEL_DT <!-- 삭제 일시 -->
, OS.DEL_RSN <!-- 삭제 사유 -->
, (CONCAT(OS.ANS_YMD, OS.ANS_TM)) AS ANS_YMD_TM <!-- 답변 일시 --> , (CONCAT(OS.ANS_YMD, OS.ANS_TM)) AS ANS_YMD_TM <!-- 답변 일시 -->
, (SELECT GET_CODE_NM('FIM029', OS.RCPT_SE_CD) FROM DUAL) AS RCPT_SE_NM <!-- 접수 구분 명 --> , (SELECT GET_CODE_NM('FIM029', OS.RCPT_SE_CD) FROM DUAL) AS RCPT_SE_NM <!-- 접수 구분 명 -->
, (SELECT GET_CODE_NM('FIM032', OS.OWNR_REL_CD) FROM DUAL) AS OWNR_REL_NM <!-- 소유주 관계 명 --> , (SELECT GET_CODE_NM('FIM032', OS.OWNR_REL_CD) FROM DUAL) AS OWNR_REL_NM <!-- 소유주 관계 명 -->
@ -116,7 +115,6 @@
, P.RTPYR_SE_CD <!-- 납부자 구분 코드 --> , P.RTPYR_SE_CD <!-- 납부자 구분 코드 -->
, P.RTPYR_NO <!-- 납부자 번호 --> , P.RTPYR_NO <!-- 납부자 번호 -->
, P.RTPYR_NM <!-- 납부자 명 --> , P.RTPYR_NM <!-- 납부자 명 -->
, P.RTPYR_BRDT <!-- 납부자 생년월일 -->
, P.ZIP <!-- 우편번호 --> , P.ZIP <!-- 우편번호 -->
, P.ADDR <!-- 주소 --> , P.ADDR <!-- 주소 -->
, P.DTL_ADDR <!-- 상세 주소 --> , P.DTL_ADDR <!-- 상세 주소 -->
@ -124,7 +122,6 @@
, (SELECT GET_BRDT_FORMAT(P.RTPYR_BRDT, '.') FROM DUAL) AS RTPYR_BRDT_MASK <!-- 납부자 생년월일 마스크 --> , (SELECT GET_BRDT_FORMAT(P.RTPYR_BRDT, '.') FROM DUAL) AS RTPYR_BRDT_MASK <!-- 납부자 생년월일 마스크 -->
, R.RDUCT_ID <!-- 감경 ID --> , R.RDUCT_ID <!-- 감경 ID -->
, R.RDUCT_RSN_CD <!-- 감경 사유 코드 --> , R.RDUCT_RSN_CD <!-- 감경 사유 코드 -->
, R.ETC_CN AS RDUCT_ETC_CN <!-- 기타 내용 -->
, (CASE WHEN R.RDUCT_AMT IS NOT NULL THEN R.RDUCT_AMT , (CASE WHEN R.RDUCT_AMT IS NOT NULL THEN R.RDUCT_AMT
ELSE (SELECT C.FFNLG_CRDN_AMT*T.WKSN_RDUCT_RT/100 FROM TB_TASK T WHERE C.SGG_CD=T.SGG_CD AND C.TASK_SE_CD=T.TASK_SE_CD AND T.USE_YN='Y') ELSE (SELECT C.FFNLG_CRDN_AMT*T.WKSN_RDUCT_RT/100 FROM TB_TASK T WHERE C.SGG_CD=T.SGG_CD AND C.TASK_SE_CD=T.TASK_SE_CD AND T.USE_YN='Y')
END ) AS RDUCT_AMT <!-- 감경 금액 --> END ) AS RDUCT_AMT <!-- 감경 금액 -->
@ -139,10 +136,7 @@
<select id="selectOpnnSbmsnList" parameterType="map" resultType="dataobject">/* 의견제출 대장 목록 조회(opnnSbmsnMapper.selectOpnnSbmsnList) */ <select id="selectOpnnSbmsnList" parameterType="map" resultType="dataobject">/* 의견제출 대장 목록 조회(opnnSbmsnMapper.selectOpnnSbmsnList) */
<include refid="utility.paging-prefix" /> <include refid="utility.paging-prefix" />
<include refid="selectList" /> <include refid="selectList" />
WHERE C.SGG_CD = #{sggCd} <!-- 시군구 코드 --> <where>
<if test="taskSeCd != null">
AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 -->
</if>
<if test="schRcptYmdFrom != null"> <if test="schRcptYmdFrom != null">
AND OS.RCPT_YMD <![CDATA[>=]]> #{schRcptYmdFrom} <!-- 접수 일자 시작 --> AND OS.RCPT_YMD <![CDATA[>=]]> #{schRcptYmdFrom} <!-- 접수 일자 시작 -->
</if> </if>
@ -163,6 +157,15 @@
</if> </if>
<if test="schOpnnSbmsnSeCd != null"> <if test="schOpnnSbmsnSeCd != null">
AND OS.OPNN_SBMSN_SE_CD = #{schOpnnSbmsnSeCd} <!-- 의견 제출 구분 코드 --> AND OS.OPNN_SBMSN_SE_CD = #{schOpnnSbmsnSeCd} <!-- 의견 제출 구분 코드 -->
</if>
<if test="delYN != null">
AND OS.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if>
<if test="sggCd != null">
AND C.SGG_CD = #{sggCd} <!-- 시군구 코드 -->
</if>
<if test="taskSeCd != null">
AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 -->
</if> </if>
<if test="schVhrno != null"> <if test="schVhrno != null">
AND C.VHRNO = #{schVhrno} <!-- 차량번호 --> AND C.VHRNO = #{schVhrno} <!-- 차량번호 -->
@ -172,9 +175,6 @@
</if> </if>
<if test="schCrdnYmdTo != null"> <if test="schCrdnYmdTo != null">
AND C.CRDN_YMD <![CDATA[<=]]> #{schCrdnYmdTo} <!-- 단속 일자 종료 --> AND C.CRDN_YMD <![CDATA[<=]]> #{schCrdnYmdTo} <!-- 단속 일자 종료 -->
</if>
<if test="delYN != null">
AND OS.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if> </if>
AND C.DEL_YN = 'N' <!-- 단속 삭제 여부 --> AND C.DEL_YN = 'N' <!-- 단속 삭제 여부 -->
<choose> <choose>
@ -244,6 +244,7 @@
</otherwise> </otherwise>
</choose> </choose>
</if> </if>
</where>
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
<include refid="utility.paging-suffix" /> <include refid="utility.paging-suffix" />
</select> </select>
@ -272,6 +273,14 @@
, OS.ANS_YMD <!-- 답변 일자 --> , OS.ANS_YMD <!-- 답변 일자 -->
, OS.ANS_TM <!-- 답변 시각 --> , OS.ANS_TM <!-- 답변 시각 -->
, OS.ANS_CN <!-- 답변 내용 --> , OS.ANS_CN <!-- 답변 내용 -->
, OS.DEL_YN <!-- 삭제 여부 -->
, OS.REG_DT <!-- 등록 일시 -->
, OS.RGTR <!-- 등록자 -->
, OS.MDFCN_DT <!-- 수정 일시 -->
, OS.MDFR <!-- 수정자 -->
, OS.DEL_DT <!-- 삭제 일시 -->
, OS.DLTR <!-- 삭제자 -->
, OS.DEL_RSN <!-- 삭제 사유 -->
, (CONCAT(OS.ANS_YMD, OS.ANS_TM)) AS ANS_YMD_TM <!-- 답변 일시 --> , (CONCAT(OS.ANS_YMD, OS.ANS_TM)) AS ANS_YMD_TM <!-- 답변 일시 -->
, (SELECT GET_CODE_NM('FIM029', OS.RCPT_SE_CD) FROM DUAL) AS RCPT_SE_NM <!-- 접수 구분 코드 --> , (SELECT GET_CODE_NM('FIM029', OS.RCPT_SE_CD) FROM DUAL) AS RCPT_SE_NM <!-- 접수 구분 코드 -->
, (SELECT GET_CODE_NM('FIM032', OS.OWNR_REL_CD) FROM DUAL) AS OWNR_REL_NM <!-- 소유주 관계 코드 --> , (SELECT GET_CODE_NM('FIM032', OS.OWNR_REL_CD) FROM DUAL) AS OWNR_REL_NM <!-- 소유주 관계 코드 -->
@ -302,7 +311,7 @@
, P.ADDR <!-- 주소 --> , P.ADDR <!-- 주소 -->
, P.DTL_ADDR <!-- 상세 주소 --> , P.DTL_ADDR <!-- 상세 주소 -->
FROM TB_OPNN_SBMSN OS FROM TB_OPNN_SBMSN OS
LEFT OUTER JOIN TB_CRDN C ON (OS.CRDN_ID = C.CRDN_ID) INNER JOIN TB_CRDN C ON (OS.CRDN_ID = C.CRDN_ID)
LEFT OUTER JOIN TB_PAYER P ON (C.RTPYR_ID = P.RTPYR_ID) LEFT OUTER JOIN TB_PAYER P ON (C.RTPYR_ID = P.RTPYR_ID)
</sql> </sql>
@ -316,45 +325,18 @@
</if> </if>
<if test="opnnId != null"> <if test="opnnId != null">
AND OS.OPNN_ID = #{opnnId} <!-- 의견제출 ID --> AND OS.OPNN_ID = #{opnnId} <!-- 의견제출 ID -->
</if>
<if test="delYN != null">
AND OS.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if> </if>
<if test="crdnId != null"> <if test="crdnId != null">
AND C.CRDN_ID = #{crdnId} <!-- 단속 ID --> AND C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
AND C.DEL_YN = 'N' <!-- 단속 삭제 여부 --> AND C.DEL_YN = 'N' <!-- 단속 삭제 여부 -->
</if> </if>
<if test="delYN != null">
AND OS.DEL_YN = #{delYN} <!-- 삭제 여부 -->
</if>
</where> </where>
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
</select> </select>
<select id="selectCrdn" parameterType="map" resultType="dataobject">/* 단속 대장 객체 가져오기(levyExclMapper.selectCrdn) */
SELECT C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.VHRNO <!-- 차량번호 -->
, C.CRDN_STTS_CD <!-- 단속 상태 코드 -->
, C.CRDN_STTS_CHG_DT <!-- 단속 상태 변경 일시 -->
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 -->
, (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, P.RTPYR_ID <!-- 납부자 ID -->
, P.RTPYR_NO <!-- 납부자 번호 -->
, P.RTPYR_NM <!-- 납부자 명 -->
, P.RTPYR_TELNO <!-- 납부자 전화번호 -->
, P.RTPYR_MBL_TELNO <!-- 납부자 휴대 전화번호 -->
, P.RTPYR_EML <!-- 납부자 이메일 -->
, P.RTPYR_BRDT <!-- 납부자 생년월일 -->
, P.ZIP <!-- 우편번호 -->
, P.ADDR <!-- 주소 -->
, P.DTL_ADDR <!-- 상세 주소 -->
, OS.OPNN_ID <!-- 의견 ID -->
FROM TB_CRDN C
LEFT OUTER JOIN TB_PAYER P ON (C.RTPYR_ID = P.RTPYR_ID)
LEFT OUTER JOIN TB_OPNN_SBMSN OS ON (C.CRDN_ID = OS.CRDN_ID AND OS.DEL_YN = 'N')
WHERE C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
AND C.DEL_YN = 'N' <!-- 삭제 여부 -->
</select>
<select id="selectOpnnSbmsnDlbrDecsns" parameterType="map" resultType="dataobject">/* 의견제출 심의 의결서 가져오기(opnnSbmsnMapper.selectOpnnSbmsnDlbrDecsns) */ <select id="selectOpnnSbmsnDlbrDecsns" parameterType="map" resultType="dataobject">/* 의견제출 심의 의결서 가져오기(opnnSbmsnMapper.selectOpnnSbmsnDlbrDecsns) */
SELECT OS.OPNN_ID <!-- 의견 ID --> SELECT OS.OPNN_ID <!-- 의견 ID -->
, OS.RCPT_NO <!-- 접수 번호 --> , OS.RCPT_NO <!-- 접수 번호 -->
@ -540,9 +522,36 @@
AND DEL_YN = 'N' AND DEL_YN = 'N'
</update> </update>
<select id="selectCrdnInfo" parameterType="string" resultType="dataobject">/* 단속 대장 객체 가져오기(levyExclMapper.selectCrdnInfo) */
SELECT C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.VHRNO <!-- 차량번호 -->
, C.CRDN_STTS_CD <!-- 단속 상태 코드 -->
, C.CRDN_STTS_CHG_DT <!-- 단속 상태 변경 일시 -->
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 -->
, (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, P.RTPYR_ID <!-- 납부자 ID -->
, P.RTPYR_NO <!-- 납부자 번호 -->
, P.RTPYR_NM <!-- 납부자 명 -->
, P.RTPYR_TELNO <!-- 납부자 전화번호 -->
, P.RTPYR_MBL_TELNO <!-- 납부자 휴대 전화번호 -->
, P.RTPYR_EML <!-- 납부자 이메일 -->
, P.RTPYR_BRDT <!-- 납부자 생년월일 -->
, P.ZIP <!-- 우편번호 -->
, P.ADDR <!-- 주소 -->
, P.DTL_ADDR <!-- 상세 주소 -->
, OS.OPNN_ID <!-- 의견 ID -->
FROM TB_CRDN C
LEFT OUTER JOIN TB_PAYER P ON (C.RTPYR_ID = P.RTPYR_ID)
LEFT OUTER JOIN TB_OPNN_SBMSN OS ON (C.CRDN_ID = OS.CRDN_ID AND OS.DEL_YN = 'N')
WHERE C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
AND C.DEL_YN = 'N' <!-- 삭제 여부 -->
</select>
<update id="updateCrdnOpnnSbmsnYn" parameterType="map">/* 단속 대장 의견제출여부 수정(opnnSbmsnMapper.updateCrdnOpnnSbmsnYn) */ <update id="updateCrdnOpnnSbmsnYn" parameterType="map">/* 단속 대장 의견제출여부 수정(opnnSbmsnMapper.updateCrdnOpnnSbmsnYn) */
UPDATE TB_CRDN UPDATE TB_CRDN
SET OPNN_SBMSN_YN = #{crdn.opnnSbmsnYn} <!-- 의견 제출 여부 --> SET OPNN_SBMSN_YN= #{crdn.opnnSbmsnYn} <!-- 의견 제출 여부 -->
, MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 --> , MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 -->
, MDFR = #{crdn.modifiedBy} <!-- 수정자 --> , MDFR = #{crdn.modifiedBy} <!-- 수정자 -->
WHERE CRDN_ID = #{crdn.crdnId} <!-- 단속 ID --> WHERE CRDN_ID = #{crdn.crdnId} <!-- 단속 ID -->

@ -21,7 +21,7 @@
<result property="operItemCd" column="OPER_ITEM_CD" /> <!-- 운영 항목 코드 --> <result property="operItemCd" column="OPER_ITEM_CD" /> <!-- 운영 항목 코드 -->
<result property="spclBizCd" column="SPCL_BIZ_CD" /> <!-- 특별회계 사업 코드 --> <result property="spclBizCd" column="SPCL_BIZ_CD" /> <!-- 특별회계 사업 코드 -->
<result property="levyNo" column="LEVY_NO" /> <!-- 부과 번호 --> <result property="levyNo" column="LEVY_NO" /> <!-- 부과 번호 -->
<result property="inspySn" column="INSPY_SN" /> <!-- 분납 --> <result property="inspyNo" column="INSPY_NO" /> <!-- 분납 -->
<result property="levySeCd" column="LEVY_SE_CD" /> <!-- 부과 구분 코드 --> <result property="levySeCd" column="LEVY_SE_CD" /> <!-- 부과 구분 코드 -->
<result property="untySeCd" column="UNTY_SE_CD" /> <!-- 통합 구분 코드 --> <result property="untySeCd" column="UNTY_SE_CD" /> <!-- 통합 구분 코드 -->
<result property="rductSeCd" column="RDUCT_SE_CD" /> <!-- 감경 구분 코드 --> <result property="rductSeCd" column="RDUCT_SE_CD" /> <!-- 감경 구분 코드 -->
@ -283,7 +283,7 @@
, L.OPER_ITEM_CD <!-- 운영 항목 코드 --> , L.OPER_ITEM_CD <!-- 운영 항목 코드 -->
, L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 --> , L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, L.LEVY_NO <!-- 부과 번호 --> , L.LEVY_NO <!-- 부과 번호 -->
, L.INSPY_SN <!-- 분납 --> , L.INSPY_NO <!-- 분납 -->
, L.LEVY_SE_CD <!-- 부과 구분 코드 --> , L.LEVY_SE_CD <!-- 부과 구분 코드 -->
, L.UNTY_SE_CD <!-- 통합 구분 코드 --> , L.UNTY_SE_CD <!-- 통합 구분 코드 -->
, L.RDUCT_SE_CD <!-- 감경 구분 코드 --> , L.RDUCT_SE_CD <!-- 감경 구분 코드 -->
@ -542,65 +542,6 @@
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
</select> </select>
<select id="selectCrdn" parameterType="map" resultType="dataobject">/* 단속 정보 가져오기(levyMapper.selectCrdn) */
SELECT C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.CVLCPT_LINK_YN
, C.LINK_TBL_NM
, C.LINK_ID
, C.RTPYR_ID
, C.CRDN_YMD
, C.CRDN_TM
, C.VHRNO
, C.CRDN_STDG_NM
, C.CRDN_ROAD_NM
, C.CRDN_PLC
, C.VLTN_ID
, C.GPS_X
, C.GPS_Y
, C.ATCH_FILE_CNT
, C.VIN
, C.VHCL_NM
, C.VHCL_COLOR
, C.FFNLG_CRDN_AMT
, C.FFNLG_RDUCT_RT
, C.FFNLG_AMT
, C.ADVNTCE_BGNG_YMD
, C.ADVNTCE_DUDT_YMD
, C.ADVNTCE_AMT
, C.CRDN_STTS_CD
, C.CRDN_STTS_CHG_DT
, C.ADTN_AMT
, C.MINUS_AMT
, C.RCVMT_AMT
, (SELECT GET_MASK_DATETIME(C.CRDN_YMD, '-', C.CRDN_TM, ':') FROM DUAL) AS CRDN_YMD_TM_MASK <!-- 단속 일시 마스크 -->
, (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, V.VLTN_CD <!-- 위반 코드 -->
, V.VLTN_ARTCL <!-- 위반 항목 -->
, V.VLTN_LAW_NM <!-- 위반 법 명 -->
, V.VLTN_LAW1 <!-- 위반 법1 -->
, V.VLTN_LAW2 <!-- 위반 법2 -->
, V.VLTN_LAW_ETC <!-- 위반 법 기타 -->
, V.ACNTG_SE_CD <!-- 회계 구분 코드 -->
, V.TXITM_CD <!-- 세목 코드 -->
, V.OPER_ITEM_CD <!-- 운영 항목 코드 -->
, V.SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, P.RTPYR_ID <!-- 납부자 ID -->
, P.RTPYR_NO <!-- 납부자 번호 -->
, P.RTPYR_NM <!-- 납부자 명 -->
, P.RTPYR_STTS_CD <!-- 납부자 상태 코드 -->
, (SELECT GET_CODE_NM('FIM014', P.RTPYR_STTS_CD) FROM DUAL) AS RTPYR_STTS_NM <!-- 납부자 상태 명 -->
, L.LEVY_ID <!-- 부과 ID -->
, <include refid="utility.today" /> AS TODAY <!-- 오늘 일자 -->
FROM TB_CRDN C
INNER JOIN TB_VLTN V ON (C.VLTN_ID = V.VLTN_ID)
LEFT OUTER JOIN TB_PAYER P ON (C.RTPYR_ID = P.RTPYR_ID)
LEFT OUTER JOIN TB_LEVY L ON (C.CRDN_ID = L.CRDN_ID AND L.DEL_YN = 'N')
WHERE C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
AND C.DEL_YN = 'N' <!-- 삭제 여부 -->
</select>
<select id="selectMaxLevyNo" parameterType="map" resultType="String">/* 고지번호 가져오기(levyMapper.selectMaxLevyNo) */ <select id="selectMaxLevyNo" parameterType="map" resultType="String">/* 고지번호 가져오기(levyMapper.selectMaxLevyNo) */
SELECT LPAD(IFNULL(MAX(LEVY_NO) + 1, 1), 6, '0') AS NEW_LEVY_NO SELECT LPAD(IFNULL(MAX(LEVY_NO) + 1, 1), 6, '0') AS NEW_LEVY_NO
FROM TB_LEVY FROM TB_LEVY
@ -611,6 +552,50 @@
AND TXITM_CD = #{txitmCd} AND TXITM_CD = #{txitmCd}
</select> </select>
<select id="selectLevyAmt" parameterType="map" resultType="dataobject">/* 부과 금액 가져오기(levyMapper.selectLevyAmt) */
SELECT LEVY_ID <!-- 부과 ID -->
, CRDN_ID <!-- 단속 ID -->
, DEPT_CD <!-- 부서 코드 -->
, SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, FYR <!-- 회계연도 -->
, ACNTG_SE_CD <!-- 회계 구분 코드 -->
, TXITM_CD <!-- 세목 코드 -->
, OPER_ITEM_CD <!-- 운영 항목 코드 -->
, LEVY_NO <!-- 부과 번호 -->
, INSPY_NO <!-- 분납 번호 -->
, FFNLG_AMT <!-- 과태료 금액 -->
, LEVY_PCPTAX <!-- 부과 본세 -->
, LEVY_ADAMT <!-- 부과 가산금 -->
, INSPY_INT <!-- 분납 이자 -->
, RCVMT_PCPTAX <!-- 수납 본세 -->
, RCVMT_ADAMT <!-- 수납 가산금 -->
, RDCAMT_PCPTAX <!-- 감액 본세 -->
, RDCAMT_ADAMT <!-- 감액 가산금 -->
, SUM_AMT <!-- 합계 금액 -->
, LEVY_PCPTAX - RCVMT_PCPTAX - RDCAMT_PCPTAX AS LAST_PCPTAX <!-- 최종 본세 -->
, LEVY_ADAMT - RCVMT_ADAMT - RDCAMT_ADAMT AS LAST_ADAMT <!-- 가산금 -->
FROM TB_LEVY
<choose>
<when test="crdnId != null">
WHERE CRDN_ID = #{crdnId} <!-- 단속 ID -->
</when>
<when test="levyId != null">
WHERE LEVY_ID = #{levyId} <!-- 부과 ID -->
</when>
<otherwise>
WHERE DEPT_CD = #{deptCd} <!-- 부서 코드 -->
AND SPCL_BIZ_CD = #{spclBizCd} <!-- 특별회계 사업 코드 -->
AND FYR = #{fyr} <!-- 회계연도 -->
AND ACNTG_SE_CD = #{acntgSeCd} <!-- 회계 구분 코드 -->
AND TXITM_CD = #{txitmCd} <!-- 세목 코드 -->
AND OPER_ITEM_CD = #{operItemCd} <!-- 운영 항목 코드 -->
AND LEVY_NO = #{levyNo} <!-- 부과 번호 -->
AND INSPY_NO = #{inspyNo} <!-- 분납 번호 -->
</otherwise>
</choose>
AND DEL_YN = 'N' <!-- 삭제 여부 -->
</select>
<insert id="insertLevy" parameterType="map">/* 부과 대장 등록(levyMapper.insertLevy) */ <insert id="insertLevy" parameterType="map">/* 부과 대장 등록(levyMapper.insertLevy) */
<selectKey resultType="string" keyProperty="levy.levyId" keyColumn="NEW_ID" order="BEFORE"> <selectKey resultType="string" keyProperty="levy.levyId" keyColumn="NEW_ID" order="BEFORE">
SELECT CONCAT(DATE_FORMAT(CURRENT_DATE, '%Y'), LPAD(CAST(IFNULL(MAX(SUBSTRING(LEVY_ID, 5)) + 1, 1) AS INT), 16, '0')) AS NEW_ID SELECT CONCAT(DATE_FORMAT(CURRENT_DATE, '%Y'), LPAD(CAST(IFNULL(MAX(SUBSTRING(LEVY_ID, 5)) + 1, 1) AS INT), 16, '0')) AS NEW_ID
@ -632,7 +617,7 @@
, OPER_ITEM_CD <!-- 운영 항목 코드 --> , OPER_ITEM_CD <!-- 운영 항목 코드 -->
, SPCL_BIZ_CD <!-- 특별회계 사업 코드 --> , SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, LEVY_NO <!-- 부과 번호 --> , LEVY_NO <!-- 부과 번호 -->
, INSPY_SN <!-- 분납 --> , INSPY_NO <!-- 분납 -->
, LEVY_SE_CD <!-- 부과 구분 코드 --> , LEVY_SE_CD <!-- 부과 구분 코드 -->
, UNTY_SE_CD <!-- 통합 구분 코드 --> , UNTY_SE_CD <!-- 통합 구분 코드 -->
, RDUCT_SE_CD <!-- 감경 구분 코드 --> , RDUCT_SE_CD <!-- 감경 구분 코드 -->
@ -730,7 +715,7 @@
, #{levy.operItemCd} <!-- 운영 항목 코드 --> , #{levy.operItemCd} <!-- 운영 항목 코드 -->
, #{levy.spclBizCd} <!-- 특별회계 사업 코드 --> , #{levy.spclBizCd} <!-- 특별회계 사업 코드 -->
, #{levy.levyNo} <!-- 부과 번호 --> , #{levy.levyNo} <!-- 부과 번호 -->
, #{levy.inspySn} <!-- 분납 순번 --> , #{levy.inspyNo} <!-- 분납 번호 -->
, #{levy.levySeCd} <!-- 부과 구분 코드 --> , #{levy.levySeCd} <!-- 부과 구분 코드 -->
, #{levy.untySeCd} <!-- 통합 구분 코드 --> , #{levy.untySeCd} <!-- 통합 구분 코드 -->
, #{levy.rductSeCd} <!-- 감경 구분 코드 --> , #{levy.rductSeCd} <!-- 감경 구분 코드 -->
@ -825,7 +810,7 @@
, OPER_ITEM_CD = #{levy.operItemCd} <!-- 운영 항목 코드 --> , OPER_ITEM_CD = #{levy.operItemCd} <!-- 운영 항목 코드 -->
, SPCL_BIZ_CD = #{levy.spclBizCd} <!-- 특별회계 사업 코드 --> , SPCL_BIZ_CD = #{levy.spclBizCd} <!-- 특별회계 사업 코드 -->
, LEVY_NO = #{levy.levyNo} <!-- 부과 번호 --> , LEVY_NO = #{levy.levyNo} <!-- 부과 번호 -->
, INSPY_SN = #{levy.inspySn} <!-- 분납 순번 --> , INSPY_NO = #{levy.inspyNo} <!-- 분납 번호 -->
, LEVY_SE_CD = #{levy.levySeCd} <!-- 부과 구분 코드 --> , LEVY_SE_CD = #{levy.levySeCd} <!-- 부과 구분 코드 -->
, UNTY_SE_CD = #{levy.untySeCd} <!-- 통합 구분 코드 --> , UNTY_SE_CD = #{levy.untySeCd} <!-- 통합 구분 코드 -->
, RDUCT_SE_CD = #{levy.rductSeCd} <!-- 감경 구분 코드 --> , RDUCT_SE_CD = #{levy.rductSeCd} <!-- 감경 구분 코드 -->
@ -929,11 +914,12 @@
AND DEL_YN = 'N' AND DEL_YN = 'N'
</update> </update>
<update id="updateRcvmtAmt" parameterType="map">/* 부과 대장에 수납 금액 정보를 수정(levyMapper.updateRcvmtAmt) */ <update id="updateRcvmt" parameterType="map">/* 부과 대장에 수납 금액 정보를 수정(levyMapper.updateRcvmt) */
UPDATE TB_LEVY UPDATE TB_LEVY
SET RCVMT_PCPTAX = #{levy.rcvmtPcptax} <!-- 수납 본세 --> SET RCVMT_PCPTAX = #{levy.rcvmtPcptax} <!-- 수납 본세 -->
, RCVMT_ADAMT = #{levy.rcvmtAdamt} <!-- 수납 가산금 --> , RCVMT_ADAMT = #{levy.rcvmtAdamt} <!-- 수납 가산금 -->
, SUM_AMT = #{levy.sumAmt} <!-- 합계 금액 --> , SUM_AMT = #{levy.sumAmt} <!-- 합계 금액 -->
, DUDT_AFTR_AMT = #{levy.dudtAftrAmt} <!-- 납기 후 금액 -->
, RCVMT_YMD = #{levy.rcvmtYmd} <!-- 수납 일자 --> , RCVMT_YMD = #{levy.rcvmtYmd} <!-- 수납 일자 -->
, PAY_MTHD_SE_CD = #{levy.payMthdSeCd} <!-- 납부 방법 구분 코드 --> , PAY_MTHD_SE_CD = #{levy.payMthdSeCd} <!-- 납부 방법 구분 코드 -->
, MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 --> , MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 -->
@ -942,9 +928,21 @@
AND DEL_YN = 'N' AND DEL_YN = 'N'
</update> </update>
<update id="updateRdcamt" parameterType="map">/* 부과 대장에 감액 금액 정보를 수정(levyMapper.updateRdcamt) */
UPDATE TB_LEVY
SET RDCAMT_PCPTAX = #{levy.rdcamtPcptax} <!-- 감액 본세 -->
, RDCAMT_ADAMT = #{levy.rdcamtAdamt} <!-- 감액 가산금 -->
, SUM_AMT = #{levy.sumAmt} <!-- 합계 금액 -->
, DUDT_AFTR_AMT = #{levy.dudtAftrAmt} <!-- 납기 후 금액 -->
, MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 -->
, MDFR = #{levy.modifiedBy} <!-- 수정자 -->
WHERE LEVY_ID = #{levy.levyId} <!-- 부과 ID -->
AND DEL_YN = 'N'
</update>
<update id="deleteLevy" parameterType="map">/* 부과 대장 삭제(levyMapper.deleteLevy) */ <update id="deleteLevy" parameterType="map">/* 부과 대장 삭제(levyMapper.deleteLevy) */
UPDATE TB_LEVY UPDATE TB_LEVY
SET DEL_YN = 'Y' <!-- 삭제 여부 --> SET DEL_YN = 'Y'
, DEL_DT = <include refid="utility.now" /> <!-- 삭제 일시 --> , DEL_DT = <include refid="utility.now" /> <!-- 삭제 일시 -->
, DLTR = #{levy.modifiedBy} <!-- 삭제자 --> , DLTR = #{levy.modifiedBy} <!-- 삭제자 -->
, DEL_RSN = #{levy.delRsn} <!-- 삭제 사유 --> , DEL_RSN = #{levy.delRsn} <!-- 삭제 사유 -->
@ -952,4 +950,63 @@
AND DEL_YN = 'N' AND DEL_YN = 'N'
</update> </update>
<select id="selectCrdn" parameterType="string" resultType="dataobject">/* 단속 정보 가져오기(levyMapper.selectCrdn) */
SELECT C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.CVLCPT_LINK_YN
, C.LINK_TBL_NM
, C.LINK_ID
, C.RTPYR_ID
, C.CRDN_YMD
, C.CRDN_TM
, C.VHRNO
, C.CRDN_STDG_NM
, C.CRDN_ROAD_NM
, C.CRDN_PLC
, C.VLTN_ID
, C.GPS_X
, C.GPS_Y
, C.ATCH_FILE_CNT
, C.VIN
, C.VHCL_NM
, C.VHCL_COLOR
, C.FFNLG_CRDN_AMT
, C.FFNLG_RDUCT_RT
, C.FFNLG_AMT
, C.ADVNTCE_BGNG_YMD
, C.ADVNTCE_DUDT_YMD
, C.ADVNTCE_AMT
, C.CRDN_STTS_CD
, C.CRDN_STTS_CHG_DT
, C.ADTN_AMT
, C.MINUS_AMT
, C.RCVMT_AMT
, (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, (SELECT GET_MASK_DATETIME(C.CRDN_YMD, '-', C.CRDN_TM, ':') FROM DUAL) AS CRDN_YMD_TM_MASK <!-- 단속 일시 마스크 -->
, V.VLTN_CD <!-- 위반 코드 -->
, V.VLTN_ARTCL <!-- 위반 항목 -->
, V.VLTN_LAW_NM <!-- 위반 법 명 -->
, V.VLTN_LAW1 <!-- 위반 법1 -->
, V.VLTN_LAW2 <!-- 위반 법2 -->
, V.VLTN_LAW_ETC <!-- 위반 법 기타 -->
, V.ACNTG_SE_CD <!-- 회계 구분 코드 -->
, V.TXITM_CD <!-- 세목 코드 -->
, V.OPER_ITEM_CD <!-- 운영 항목 코드 -->
, V.SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, P.RTPYR_ID <!-- 납부자 ID -->
, P.RTPYR_NO <!-- 납부자 번호 -->
, P.RTPYR_NM <!-- 납부자 명 -->
, P.RTPYR_STTS_CD <!-- 납부자 상태 코드 -->
, (SELECT GET_CODE_NM('FIM014', P.RTPYR_STTS_CD) FROM DUAL) AS RTPYR_STTS_NM <!-- 납부자 상태 명 -->
, L.LEVY_ID <!-- 부과 ID -->
, <include refid="utility.today" /> AS TODAY <!-- 오늘 일자 -->
FROM TB_CRDN C
INNER JOIN TB_VLTN V ON (C.VLTN_ID = V.VLTN_ID)
LEFT OUTER JOIN TB_PAYER P ON (C.RTPYR_ID = P.RTPYR_ID)
LEFT OUTER JOIN TB_LEVY L ON (C.CRDN_ID = L.CRDN_ID AND L.DEL_YN = 'N')
WHERE C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
AND C.DEL_YN = 'N' <!-- 삭제 여부 -->
</select>
</mapper> </mapper>

@ -158,7 +158,7 @@
, L.OPER_ITEM_CD <!-- 운영 항목 코드 --> , L.OPER_ITEM_CD <!-- 운영 항목 코드 -->
, L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 --> , L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, L.LEVY_NO <!-- 부과 번호 --> , L.LEVY_NO <!-- 부과 번호 -->
, L.INSPY_SN <!-- 분납 --> , L.INSPY_NO <!-- 분납 -->
, L.LEVY_SE_CD <!-- 부과 구분 코드 --> , L.LEVY_SE_CD <!-- 부과 구분 코드 -->
, L.LEVY_YMD <!-- 부과 일자 --> , L.LEVY_YMD <!-- 부과 일자 -->
, L.FRST_DUDT_YMD <!-- 최초 납기 일자 --> , L.FRST_DUDT_YMD <!-- 최초 납기 일자 -->

@ -18,7 +18,7 @@
<result property="acntgSeCd" column="ACNTG_SE_CD" /> <!-- 회계 구분 코드 --> <result property="acntgSeCd" column="ACNTG_SE_CD" /> <!-- 회계 구분 코드 -->
<result property="txitmCd" column="TXITM_CD" /> <!-- 세목 코드 --> <result property="txitmCd" column="TXITM_CD" /> <!-- 세목 코드 -->
<result property="levyNo" column="LEVY_NO" /> <!-- 부과 번호 --> <result property="levyNo" column="LEVY_NO" /> <!-- 부과 번호 -->
<result property="inspySn" column="INSPY_SN" /> <!-- 분납 일련번호 --> <result property="inspyNo" column="INSPY_NO" /> <!-- 분납 일련번호 -->
<result property="lastPcptax" column="LAST_PCPTAX" /> <!-- 최종 본세 --> <result property="lastPcptax" column="LAST_PCPTAX" /> <!-- 최종 본세 -->
<result property="lastAdamt" column="LAST_ADAMT" /> <!-- 최종 가산금 --> <result property="lastAdamt" column="LAST_ADAMT" /> <!-- 최종 가산금 -->
<result property="rcvmtSn" column="RCVMT_SN" /> <!-- 수납 일련번호 --> <result property="rcvmtSn" column="RCVMT_SN" /> <!-- 수납 일련번호 -->
@ -59,7 +59,7 @@
, R.ACNTG_SE_CD <!-- 회계 구분 코드 --> , R.ACNTG_SE_CD <!-- 회계 구분 코드 -->
, R.TXITM_CD <!-- 세목 코드 --> , R.TXITM_CD <!-- 세목 코드 -->
, R.LEVY_NO <!-- 부과 번호 --> , R.LEVY_NO <!-- 부과 번호 -->
, R.INSPY_SN <!-- 분납 일련번호 --> , R.INSPY_NO <!-- 분납 번호 -->
, R.LAST_PCPTAX <!-- 최종 본세 --> , R.LAST_PCPTAX <!-- 최종 본세 -->
, R.LAST_ADAMT <!-- 최종 가산금 --> , R.LAST_ADAMT <!-- 최종 가산금 -->
, R.RCVMT_SN <!-- 수납 일련번호 --> , R.RCVMT_SN <!-- 수납 일련번호 -->
@ -263,7 +263,7 @@
, R.ACNTG_SE_CD <!-- 회계 구분 코드 --> , R.ACNTG_SE_CD <!-- 회계 구분 코드 -->
, R.TXITM_CD <!-- 세목 코드 --> , R.TXITM_CD <!-- 세목 코드 -->
, R.LEVY_NO <!-- 부과 번호 --> , R.LEVY_NO <!-- 부과 번호 -->
, R.INSPY_SN <!-- 분납 일련번호 --> , R.INSPY_NO <!-- 분납 번호 -->
, R.LAST_PCPTAX <!-- 최종 본세 --> , R.LAST_PCPTAX <!-- 최종 본세 -->
, R.LAST_ADAMT <!-- 최종 가산금 --> , R.LAST_ADAMT <!-- 최종 가산금 -->
, R.RCVMT_SN <!-- 수납 일련번호 --> , R.RCVMT_SN <!-- 수납 일련번호 -->
@ -326,47 +326,6 @@
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
</select> </select>
<select id="selectLevyInfo" parameterType="map" resultType="dataobject">/* 부과 대장 객체 가져오기(rcvmtMapper.selectLevyInfo) */
SELECT L.LEVY_ID <!-- 부과 ID -->
, L.DEPT_CD <!-- 부서 코드 -->
, L.FYR <!-- 회계연도 -->
, L.ACNTG_SE_CD <!-- 회계 구분 코드 -->
, L.TXITM_CD <!-- 세목 코드 -->
, L.LEVY_NO <!-- 부과 번호 -->
, L.FFNLG_AMT <!-- 과태료 금액 -->
, L.LEVY_PCPTAX <!-- 부과 본세 -->
, L.LEVY_ADAMT <!-- 부과 가산금 -->
, L.INSPY_INT <!-- 분납 이자 -->
, L.RCVMT_PCPTAX <!-- 수납 본세 -->
, L.RCVMT_ADAMT <!-- 수납 가산금 -->
, L.LEVY_PCPTAX - L.RCVMT_PCPTAX - L.RDCAMT_PCPTAX AS LAST_PCPTAX <!-- 최종 본세 -->
, L.LEVY_ADAMT - L.RCVMT_ADAMT - L.RDCAMT_ADAMT AS LAST_ADAMT <!-- 가산금 -->
, C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.VHRNO <!-- 차량번호 -->
, C.CRDN_PLC <!-- 단속 장소 -->
, C.CRDN_STTS_CD <!-- 단속 상태 코드 -->
, C.CRDN_STTS_CHG_DT <!-- 단속 상태 변경 일시 -->
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 -->
, (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, <include refid="utility.today" /> AS RCVMT_YMD <!-- 수납 일자 -->
, <include refid="utility.today" /> AS PSTMRK_YMD <!-- 소인 일자 -->
, <include refid="utility.today" /> AS ACNTG_YMD <!-- 회계 일자 -->
FROM TB_LEVY L
INNER JOIN TB_CRDN C ON (L.CRDN_ID = C.CRDN_ID)
<choose>
<when test="crdnId != null">
WHERE L.CRDN_ID = #{crdnId} <!-- 단속 ID -->
</when>
<otherwise>
WHERE L.LEVY_ID = #{levyId} <!-- 부과 ID -->
</otherwise>
</choose>
AND L.DEL_YN = #{delYN} <!-- 삭제 여부 -->
<include refid="utility.orderBy" />
</select>
<update id="updateRcvmtRtrcn" parameterType="map">/* 수납 대장 수납취소 정보 수정(rcvmtMapper.updateRcvmtRtrcn) */ <update id="updateRcvmtRtrcn" parameterType="map">/* 수납 대장 수납취소 정보 수정(rcvmtMapper.updateRcvmtRtrcn) */
UPDATE TB_RCVMT UPDATE TB_RCVMT
SET RCVMT_RTRCN_YN = #{rcvmt.rcvmtRtrcnYn} <!-- 수납 취소 여부 --> SET RCVMT_RTRCN_YN = #{rcvmt.rcvmtRtrcnYn} <!-- 수납 취소 여부 -->
@ -397,7 +356,7 @@
, ACNTG_SE_CD <!-- 회계 구분 코드 --> , ACNTG_SE_CD <!-- 회계 구분 코드 -->
, TXITM_CD <!-- 세목 코드 --> , TXITM_CD <!-- 세목 코드 -->
, LEVY_NO <!-- 부과 번호 --> , LEVY_NO <!-- 부과 번호 -->
, INSPY_SN <!-- 분납 일련번호 --> , INSPY_NO <!-- 분납 번호 -->
, LAST_PCPTAX <!-- 최종 본세 --> , LAST_PCPTAX <!-- 최종 본세 -->
, LAST_ADAMT <!-- 최종 가산금 --> , LAST_ADAMT <!-- 최종 가산금 -->
, RCVMT_SN <!-- 수납 일련번호 --> , RCVMT_SN <!-- 수납 일련번호 -->
@ -435,7 +394,7 @@
, #{rcvmt.acntgSeCd} <!-- 회계 구분 코드 --> , #{rcvmt.acntgSeCd} <!-- 회계 구분 코드 -->
, #{rcvmt.txitmCd} <!-- 세목 코드 --> , #{rcvmt.txitmCd} <!-- 세목 코드 -->
, #{rcvmt.levyNo} <!-- 부과 번호 --> , #{rcvmt.levyNo} <!-- 부과 번호 -->
, #{rcvmt.inspySn} <!-- 분납 일련번호 --> , #{rcvmt.inspyNo} <!-- 분납 번호 -->
, #{rcvmt.lastPcptax} <!-- 최종 본세 --> , #{rcvmt.lastPcptax} <!-- 최종 본세 -->
, #{rcvmt.lastAdamt} <!-- 최종 가산금 --> , #{rcvmt.lastAdamt} <!-- 최종 가산금 -->
, #{rcvmt.rcvmtSn} <!-- 수납 일련번호 --> , #{rcvmt.rcvmtSn} <!-- 수납 일련번호 -->
@ -473,7 +432,7 @@
, ACNTG_SE_CD = #{rcvmt.acntgSeCd} <!-- 회계 구분 코드 --> , ACNTG_SE_CD = #{rcvmt.acntgSeCd} <!-- 회계 구분 코드 -->
, TXITM_CD = #{rcvmt.txitmCd} <!-- 세목 코드 --> , TXITM_CD = #{rcvmt.txitmCd} <!-- 세목 코드 -->
, LEVY_NO = #{rcvmt.levyNo} <!-- 부과 번호 --> , LEVY_NO = #{rcvmt.levyNo} <!-- 부과 번호 -->
, INSPY_SN = #{rcvmt.inspySn} <!-- 분납 일련번호 --> , INSPY_NO = #{rcvmt.inspyNo} <!-- 분납 번호 -->
, LAST_PCPTAX = #{rcvmt.lastPcptax} <!-- 최종 본세 --> , LAST_PCPTAX = #{rcvmt.lastPcptax} <!-- 최종 본세 -->
, LAST_ADAMT = #{rcvmt.lastAdamt} <!-- 최종 가산금 --> , LAST_ADAMT = #{rcvmt.lastAdamt} <!-- 최종 가산금 -->
, RCVMT_SN = #{rcvmt.rcvmtSn} <!-- 수납 일련번호 --> , RCVMT_SN = #{rcvmt.rcvmtSn} <!-- 수납 일련번호 -->
@ -510,4 +469,55 @@
AND DEL_YN = 'N' <!-- 삭제 여부 --> AND DEL_YN = 'N' <!-- 삭제 여부 -->
</update> </update>
<select id="selectLevyInfo" parameterType="map" resultType="dataobject">/* 부과 대장 객체 가져오기(rcvmtMapper.selectLevyInfo) */
SELECT L.LEVY_ID <!-- 부과 ID -->
, L.DEPT_CD <!-- 부서 코드 -->
, L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, L.FYR <!-- 회계연도 -->
, L.ACNTG_SE_CD <!-- 회계 구분 코드 -->
, L.TXITM_CD <!-- 세목 코드 -->
, L.OPER_ITEM_CD <!-- 운영 항목 코드 -->
, L.LEVY_NO <!-- 부과 번호 -->
, L.INSPY_NO <!-- 분납 번호 -->
, L.FFNLG_AMT <!-- 과태료 금액 -->
, L.LEVY_PCPTAX <!-- 부과 본세 -->
, L.LEVY_ADAMT <!-- 부과 가산금 -->
, L.INSPY_INT <!-- 분납 이자 -->
, L.RCVMT_PCPTAX <!-- 수납 본세 -->
, L.RCVMT_ADAMT <!-- 수납 가산금 -->
, L.LEVY_PCPTAX - L.RCVMT_PCPTAX - L.RDCAMT_PCPTAX AS LAST_PCPTAX <!-- 최종 본세 -->
, L.LEVY_ADAMT - L.RCVMT_ADAMT - L.RDCAMT_ADAMT AS LAST_ADAMT <!-- 가산금 -->
, C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.VHRNO <!-- 차량번호 -->
, C.CRDN_PLC <!-- 단속 장소 -->
, C.CRDN_STTS_CD <!-- 단속 상태 코드 -->
, C.CRDN_STTS_CHG_DT <!-- 단속 상태 변경 일시 -->
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 -->
, (SELECT GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, <include refid="utility.today" /> AS RCVMT_YMD <!-- 수납 일자 -->
, <include refid="utility.today" /> AS PSTMRK_YMD <!-- 소인 일자 -->
, <include refid="utility.today" /> AS ACNTG_YMD <!-- 회계 일자 -->
FROM TB_LEVY L
INNER JOIN TB_CRDN C ON (L.CRDN_ID = C.CRDN_ID)
<choose>
<when test="levyId != null">
WHERE L.LEVY_ID = #{levyId} <!-- 부과 ID -->
</when>
<otherwise>
WHERE DEPT_CD = #{deptCd} <!-- 부서 코드 -->
AND SPCL_BIZ_CD = #{spclBizCd} <!-- 특별회계 사업 코드 -->
AND FYR = #{fyr} <!-- 회계연도 -->
AND ACNTG_SE_CD = #{acntgSeCd} <!-- 회계 구분 코드 -->
AND TXITM_CD = #{txitmCd} <!-- 세목 코드 -->
AND OPER_ITEM_CD = #{operItemCd} <!-- 운영 항목 코드 -->
AND LEVY_NO = #{levyNo} <!-- 부과 번호 -->
AND INSPY_NO = #{inspyNo} <!-- 분납 번호 -->
</otherwise>
</choose>
AND L.DEL_YN = 'N'
<include refid="utility.orderBy" />
</select>
</mapper> </mapper>

@ -0,0 +1,176 @@
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="cokr.xit.fims.rdca.dao.RdcamtMapper">
<!-- 감액 대장 정보 매퍼
========== 변경 이력 ==========
2024-02-01 JoJH 최초 작성
============================ -->
<resultMap id="rdcamtRow" type="cokr.xit.fims.rdca.Rdcamt"> <!-- 감액 대장 -->
<result property="rdcamtId" column="RDCAMT_ID" /> <!-- 감액 ID -->
<result property="levyId" column="LEVY_ID" /> <!-- 부과 ID -->
<result property="lastPcptax" column="LAST_PCPTAX" /> <!-- 최종 본세 -->
<result property="lastAdamt" column="LAST_ADAMT" /> <!-- 최종 가산금 -->
<result property="rdcamtYmd" column="RDCAMT_YMD" /> <!-- 감액 일자 -->
<result property="rdcamtSeCd" column="RDCAMT_SE_CD" /> <!-- 감액 구분 코드 -->
<result property="rdcamtRsnCd" column="RDCAMT_RSN_CD" /> <!-- 감액 사유 코드 -->
<result property="rdcamtPcptax" column="RDCAMT_PCPTAX" /> <!-- 감액 본세 -->
<result property="rdcamtAdamt" column="RDCAMT_ADAMT" /> <!-- 감액 가산금 -->
<result property="rdcamtRtrcnYn" column="RDCAMT_RTRCN_YN" /> <!-- 감액 취소 여부 -->
<result property="rdcamtRtrcnYmd" column="RDCAMT_RTRCN_YMD" /> <!-- 감액 취소 일자 -->
<result property="rdcamtRtrcnRsn" column="RDCAMT_RTRCN_RSN" /> <!-- 감액 취소 사유 -->
<result property="delYN" column="DEL_YN" /> <!-- 삭제 여부 -->
<result property="createdAt" column="REG_DT" /> <!-- 등록 일시 -->
<result property="createdBy" column="RGTR" /> <!-- 등록자 -->
<result property="lastModified" column="MDFCN_DT" /> <!-- 수정 일시 -->
<result property="modifiedBy" column="MDFR" /> <!-- 수정자 -->
<result property="removedAt" column="DEL_DT" /> <!-- 삭제 일시 -->
<result property="removedBy" column="DLTR" /> <!-- 삭제자 -->
<result property="delRsn" column="DEL_RSN" /> <!-- 삭제 사유 -->
</resultMap>
<sql id="selectList">
SELECT R.RDCAMT_ID <!-- 감액 ID -->
, R.LEVY_ID <!-- 부과 ID -->
, R.LAST_PCPTAX <!-- 최종 본세 -->
, R.LAST_ADAMT <!-- 최종 가산금 -->
, R.RDCAMT_YMD <!-- 감액 일자 -->
, R.RDCAMT_SE_CD <!-- 감액 구분 코드 -->
, R.RDCAMT_RSN_CD <!-- 감액 사유 코드 -->
, R.RDCAMT_PCPTAX <!-- 감액 본세 -->
, R.RDCAMT_ADAMT <!-- 감액 가산금 -->
, R.RDCAMT_RTRCN_YN <!-- 감액 취소 여부 -->
, R.RDCAMT_RTRCN_YMD <!-- 감액 취소 일자 -->
, R.RDCAMT_RTRCN_RSN <!-- 감액 취소 사유 -->
, R.DEL_YN <!-- 삭제 여부 -->
, R.REG_DT <!-- 등록 일시 -->
, R.RGTR <!-- 등록자 -->
, R.MDFCN_DT <!-- 수정 일시 -->
, R.MDFR <!-- 수정자 -->
, R.DEL_DT <!-- 삭제 일시 -->
, R.DLTR <!-- 삭제자 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = L.RGTR) AS RGTR_NM <!-- 등록자 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = L.MDFR) AS MDFR_NM <!-- 수정자 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = L.DLTR) AS DLTR_NM <!-- 삭제자 명 -->
FROM TB_RDCAMT R
INNER JOIN TB_LEVY L ON (R.LEVY_ID = L.LEVY_ID)
</sql>
<sql id="select">
SELECT R.RDCAMT_ID <!-- 감액 ID -->
, R.LEVY_ID <!-- 부과 ID -->
, R.LAST_PCPTAX <!-- 최종 본세 -->
, R.LAST_ADAMT <!-- 최종 가산금 -->
, R.RDCAMT_YMD <!-- 감액 일자 -->
, R.RDCAMT_SE_CD <!-- 감액 구분 코드 -->
, R.RDCAMT_RSN_CD <!-- 감액 사유 코드 -->
, R.RDCAMT_PCPTAX <!-- 감액 본세 -->
, R.RDCAMT_ADAMT <!-- 감액 가산금 -->
, R.RDCAMT_RTRCN_YN <!-- 감액 취소 여부 -->
, R.RDCAMT_RTRCN_YMD <!-- 감액 취소 일자 -->
, R.RDCAMT_RTRCN_RSN <!-- 감액 취소 사유 -->
, R.DEL_YN <!-- 삭제 여부 -->
, R.REG_DT <!-- 등록 일시 -->
, R.RGTR <!-- 등록자 -->
, R.MDFCN_DT <!-- 수정 일시 -->
, R.MDFR <!-- 수정자 -->
, R.DEL_DT <!-- 삭제 일시 -->
, R.DLTR <!-- 삭제자 -->
, R.DEL_RSN <!-- 삭제 사유 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = L.RGTR) AS RGTR_NM <!-- 등록자 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = L.MDFR) AS MDFR_NM <!-- 수정자 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = L.DLTR) AS DLTR_NM <!-- 삭제자 명 -->
FROM TB_RDCAMT
</sql>
<select id="selectRdcamtList" parameterType="map" resultType="dataobject">/* 감액 대장 목록 조회(rdcamtMapper.selectRdcamtList) */
<include refid="utility.paging-prefix" />
<include refid="selectList" />
<where></where>
<include refid="utility.orderBy" />
<include refid="utility.paging-suffix" />
</select>
<select id="selectRdcamts" parameterType="map" resultType="dataobject">/* 감액 대장 객체 가져오기(rdcamtMapper.selectRdcamts) */
<include refid="select" />
<where></where>
<include refid="utility.orderBy" />
</select>
<insert id="insertRdcamt" parameterType="map">/* 감액 대장 등록(rdcamtMapper.insertRdcamt) */
<selectKey resultType="string" keyProperty="rdcamt.rdcamtId" keyColumn="NEW_ID" order="BEFORE">
SELECT CONCAT(DATE_FORMAT(CURRENT_DATE, '%Y'), LPAD(CAST(IFNULL(MAX(SUBSTRING(LEVY_ID, 5)) + 1, 1) AS INT), 16, '0')) AS NEW_ID
FROM TB_RDCAMT
WHERE RDCAMT_ID LIKE CONCAT(DATE_FORMAT(CURRENT_DATE, '%Y'), '%')
</selectKey>
INSERT
INTO TB_RDCAMT (
RDCAMT_ID <!-- 감액 ID -->
, LEVY_ID <!-- 부과 ID -->
, LAST_PCPTAX <!-- 최종 본세 -->
, LAST_ADAMT <!-- 최종 가산금 -->
, RDCAMT_YMD <!-- 감액 일자 -->
, RDCAMT_SE_CD <!-- 감액 구분 코드 -->
, RDCAMT_RSN_CD <!-- 감액 사유 코드 -->
, RDCAMT_PCPTAX <!-- 감액 본세 -->
, RDCAMT_ADAMT <!-- 감액 가산금 -->
, RDCAMT_RTRCN_YN <!-- 감액 취소 여부 -->
, RDCAMT_RTRCN_YMD <!-- 감액 취소 일자 -->
, RDCAMT_RTRCN_RSN <!-- 감액 취소 사유 -->
, DEL_YN <!-- 삭제 여부 -->
, REG_DT <!-- 등록 일시 -->
, RGTR <!-- 등록자 -->
, MDFCN_DT <!-- 수정 일시 -->
, MDFR <!-- 수정자 -->
)
VALUES (
#{rdcamt.rdcamtId} <!-- 감액 ID -->
, #{rdcamt.levyId} <!-- 부과 ID -->
, #{rdcamt.lastPcptax} <!-- 최종 본세 -->
, #{rdcamt.lastAdamt} <!-- 최종 가산금 -->
, #{rdcamt.rdcamtYmd} <!-- 감액 일자 -->
, #{rdcamt.rdcamtSeCd} <!-- 감액 구분 코드 -->
, #{rdcamt.rdcamtRsnCd} <!-- 감액 사유 코드 -->
, #{rdcamt.rdcamtPcptax} <!-- 감액 본세 -->
, #{rdcamt.rdcamtAdamt} <!-- 감액 가산금 -->
, 'N' <!-- 감액 취소 여부 -->
, #{rdcamt.rdcamtRtrcnYmd} <!-- 감액 취소 일자 -->
, #{rdcamt.rdcamtRtrcnRsn} <!-- 감액 취소 사유 -->
, 'N' <!-- 삭제 여부 -->
, <include refid="utility.now" /> <!-- 등록 일시 -->
, #{rdcamt.createdBy} <!-- 등록자 -->
, <include refid="utility.now" /> <!-- 수정 일시 -->
, #{rdcamt.modifiedBy} <!-- 수정자 -->
)
</insert>
<update id="updateRdcamt" parameterType="map">/* 감액 대장 수정(rdcamtMapper.updateRdcamt) */
UPDATE TB_RDCAMT
SET LAST_PCPTAX = #{rdcamt.lastPcptax} <!-- 최종 본세 -->
, LAST_ADAMT = #{rdcamt.lastAdamt} <!-- 최종 가산금 -->
, RDCAMT_YMD = #{rdcamt.rdcamtYmd} <!-- 감액 일자 -->
, RDCAMT_SE_CD = #{rdcamt.rdcamtSeCd} <!-- 감액 구분 코드 -->
, RDCAMT_RSN_CD = #{rdcamt.rdcamtRsnCd} <!-- 감액 사유 코드 -->
, RDCAMT_PCPTAX = #{rdcamt.rdcamtPcptax} <!-- 감액 본세 -->
, RDCAMT_ADAMT = #{rdcamt.rdcamtAdamt} <!-- 감액 가산금 -->
, RDCAMT_RTRCN_YN = #{rdcamt.rdcamtRtrcnYn} <!-- 감액 취소 여부 -->
, RDCAMT_RTRCN_YMD = #{rdcamt.rdcamtRtrcnYmd} <!-- 감액 취소 일자 -->
, RDCAMT_RTRCN_RSN = #{rdcamt.rdcamtRtrcnRsn} <!-- 감액 취소 사유 -->
, MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 -->
, MDFR = #{rdcamt.modifiedBy} <!-- 수정자 -->
WHERE RDCAMT_ID = #{rdcamt.rdcamtId} <!-- 감액 ID -->
AND DEL_YN = 'N' <!-- 삭제 여부 -->
</update>
<update id="deleteRdcamt" parameterType="map">/* 감액 대장 삭제(rdcamtMapper.deleteRdcamt) */
UPDATE TB_RDCAMT
SET DEL_YN = 'Y'
, DEL_DT = <include refid="utility.now" /> <!-- 삭제 일시 -->
, DLTR = #{rdcamt.modifiedBy} <!-- 삭제자 -->
, DEL_RSN = #{rdcamt.delRsn} <!-- 삭제 사유 -->
WHERE RDCAMT_ID = #{rdcamt.rdcamtId} <!-- 부과 제외 ID -->
AND DEL_YN = 'N'
</update>
</mapper>

@ -683,7 +683,7 @@
, L.OPER_ITEM_CD <!-- 운영 항목 코드 --> , L.OPER_ITEM_CD <!-- 운영 항목 코드 -->
, L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 --> , L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, L.LEVY_NO <!-- 부과 번호 --> , L.LEVY_NO <!-- 부과 번호 -->
, L.INSPY_SN <!-- 분납 --> , L.INSPY_NO <!-- 분납 -->
, L.LEVY_SE_CD <!-- 부과 구분 코드 --> , L.LEVY_SE_CD <!-- 부과 구분 코드 -->
, L.LEVY_YMD <!-- 부과 일자 --> , L.LEVY_YMD <!-- 부과 일자 -->
, L.FRST_DUDT_YMD <!-- 최초 납기 일자 --> , L.FRST_DUDT_YMD <!-- 최초 납기 일자 -->

@ -314,13 +314,13 @@
, P.ZIP <!-- 우편번호 --> , P.ZIP <!-- 우편번호 -->
, L.LEVY_ID <!-- 부과 ID --> , L.LEVY_ID <!-- 부과 ID -->
, L.DEPT_CD <!-- 부서 코드 --> , L.DEPT_CD <!-- 부서 코드 -->
, L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, L.FYR <!-- 회계연도 --> , L.FYR <!-- 회계연도 -->
, L.ACNTG_SE_CD <!-- 회계 구분 코드 --> , L.ACNTG_SE_CD <!-- 회계 구분 코드 -->
, L.TXITM_CD <!-- 세목 코드 --> , L.TXITM_CD <!-- 세목 코드 -->
, L.OPER_ITEM_CD <!-- 운영 항목 코드 --> , L.OPER_ITEM_CD <!-- 운영 항목 코드 -->
, L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, L.LEVY_NO <!-- 부과 번호 --> , L.LEVY_NO <!-- 부과 번호 -->
, L.INSPY_SN <!-- 분납 --> , L.INSPY_NO <!-- 분납 -->
, L.LEVY_SE_CD <!-- 부과 구분 코드 --> , L.LEVY_SE_CD <!-- 부과 구분 코드 -->
, L.LEVY_YMD <!-- 부과 일자 --> , L.LEVY_YMD <!-- 부과 일자 -->
, L.FRST_DUDT_YMD <!-- 최초 납기 일자 --> , L.FRST_DUDT_YMD <!-- 최초 납기 일자 -->

@ -144,23 +144,24 @@
, L.LEVY_ID <!-- 부과 ID --> , L.LEVY_ID <!-- 부과 ID -->
, L.INST_CD <!-- 기관 코드 --> , L.INST_CD <!-- 기관 코드 -->
, L.DEPT_CD <!-- 부서 코드 --> , L.DEPT_CD <!-- 부서 코드 -->
, L.SPCL_BIZ_CD <!-- 특별회계 사업 코드 -->
, L.FYR <!-- 회계 연도 --> , L.FYR <!-- 회계 연도 -->
, L.ACNTG_SE_CD <!-- 회계 구분 코드 --> , L.ACNTG_SE_CD <!-- 회계 구분 코드 -->
, L.TXITM_CD <!-- 세목 코드 --> , L.TXITM_CD <!-- 세목 코드 -->
, L.LEVY_NO <!-- 부과 번호 --> , L.LEVY_NO <!-- 부과 번호 -->
, L.INSPY_SN <!-- 분납 순번 --> , L.INSPY_NO <!-- 분납 번호 -->
, (CONCAT(L.FYR, '-', L.LEVY_NO)) AS GOJI_NO <!-- 고지번호 -->
, L.LEVY_PCPTAX <!-- 부과 본세 --> , L.LEVY_PCPTAX <!-- 부과 본세 -->
, L.LEVY_ADAMT <!-- 부과 가산금 --> , L.LEVY_ADAMT <!-- 부과 가산금 -->
, L.INSPY_INT <!-- 분납 이자 --> , L.INSPY_INT <!-- 분납 이자 -->
, L.LEVY_PCPTAX + L.LEVY_ADAMT + L.INSPY_INT AS LEVY_AMT <!-- 부과금액 -->
, L.RCVMT_PCPTAX <!-- 수납 본세 --> , L.RCVMT_PCPTAX <!-- 수납 본세 -->
, L.RCVMT_ADAMT <!-- 수납 가산금 --> , L.RCVMT_ADAMT <!-- 수납 가산금 -->
, L.RCVMT_PCPTAX + L.RCVMT_ADAMT AS RCVMT_AMT <!-- 수납 금액 -->
, L.RDCAMT_PCPTAX <!-- 감액 본세 --> , L.RDCAMT_PCPTAX <!-- 감액 본세 -->
, L.RDCAMT_ADAMT <!-- 감액 가산금 --> , L.RDCAMT_ADAMT <!-- 감액 가산금 -->
, L.RDCAMT_PCPTAX + L.RDCAMT_ADAMT AS REDUC_AMT <!-- 감액 금액 -->
, L.SUM_AMT <!-- 합계 금액 --> , L.SUM_AMT <!-- 합계 금액 -->
, (CONCAT(L.FYR, '-', L.LEVY_NO)) AS GOJI_NO <!-- 고지번호 -->
, L.LEVY_PCPTAX + L.LEVY_ADAMT + L.INSPY_INT AS LEVY_AMT <!-- 부과금액 -->
, L.RCVMT_PCPTAX + L.RCVMT_ADAMT AS RCVMT_AMT <!-- 수납 금액 -->
, L.RDCAMT_PCPTAX + L.RDCAMT_ADAMT AS RDCAMT_AMT <!-- 감액 금액 -->
FROM TB_CRDN C FROM TB_CRDN C
INNER JOIN TB_CRDN_ADI CA ON (C.CRDN_ID = CA.CRDN_ID) INNER JOIN TB_CRDN_ADI CA ON (C.CRDN_ID = CA.CRDN_ID)
INNER JOIN TB_VLTN V ON (C.VLTN_ID = V.VLTN_ID) INNER JOIN TB_VLTN V ON (C.VLTN_ID = V.VLTN_ID)

@ -374,7 +374,7 @@
$("#btnRemove--${pageName}").prop("disabled", keys.length < 1); $("#btnRemove--${pageName}").prop("disabled", keys.length < 1);
}; };
// 수정 dialog // 부과제외 정보 dialog
$P.control.getInfo = (params) => { $P.control.getInfo = (params) => {
if (!params) return; if (!params) return;

@ -184,7 +184,7 @@
$("#levyExclSeCd--${pageName}").val(cmnCode.code); $("#levyExclSeCd--${pageName}").val(cmnCode.code);
$("#levyExclSeNm--${pageName}").val(cmnCode.value); $("#levyExclSeNm--${pageName}").val(cmnCode.value);
let reasons = FIM022.list().filter(reason => "1" == seCode ? reason.code < "200" : reason.code > "200"); let reasons = FIM022.list().filter(reason => "2" == seCode ? reason.code > "200" : reason.code < "200");
$("#levyExclRsnCd--${pageName}").html(reasons.map(reason => "<option value='" + reason.code + "'>" + reason.value + "</option>").join()); $("#levyExclRsnCd--${pageName}").html(reasons.map(reason => "<option value='" + reason.code + "'>" + reason.value + "</option>").join());
if (typeof rsnCode != "undefined" && rsnCode != "") { if (typeof rsnCode != "undefined" && rsnCode != "") {

@ -13,14 +13,14 @@
<div> <div>
<!-- 상단 버튼 --> <!-- 상단 버튼 -->
<div class="container-page-btn"> <div class="container-page-btn">
<button type="button" class="btn btn-outline-dark w-px-120" id="btnReset--${pageName}" title="초기화" onclick="fnResetAndChangeBiz${pageName}();"> <button type="button" class="btn btn-outline-dark w-px-120" id="btnReset--${pageName}" title="초기화">
초기화 초기화
</button> </button>
<span class="container-window-btn-right"> <span class="container-window-btn-right">
<button type="button" class="btn btn-search w-px-120" id="btnSearch--${pageName}" title="검색" onclick="fnSearchList${pageName}();"> <button type="button" class="btn btn-search w-px-120" id="btnSearch--${pageName}" title="검색">
검색 검색
</button> </button>
<button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀" onclick="fnExcel${pageName}();"> <button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀">
엑셀 엑셀
</button> </button>
</span> </span>
@ -201,15 +201,21 @@
<thead class="sticky-thead"> <thead class="sticky-thead">
<tr id="theadTr--${pageName}" <tr id="theadTr--${pageName}"
data-by="by--${pageName}" data-by-output="byOutput--${pageName}" data-main-option="mainOption--${pageName}" data-sub-option="subOption--${pageName}"> data-by="by--${pageName}" data-by-output="byOutput--${pageName}" data-main-option="mainOption--${pageName}" data-sub-option="subOption--${pageName}">
</tr>
</thead>
<tbody id="tbody--${pageName}">
</tbody>
<template id="${infoPrefix}Col--${pageName}">
<th class="cmn" style="width: 72px;">NO.</th> <th class="cmn" style="width: 72px;">NO.</th>
<th class="cmn" style="width: 56px;"><input type="checkbox" class="form-check-input" onchange="${pageName}Control.select(this.checked);"></th> <th class="cmn" style="width: 56px;"><input type="checkbox" class="form-check-input" onchange="pageObject['${pageName}'].control.select(this.checked);" />
<th class="cmn" style="width: 160px;">업무구분</th> <th class="cmn" style="width: 160px;">업무구분</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('FYR', this.innerText, 'match', 'part');">회계연도</th> <th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('FYR', this.innerText, 'match', 'part');">회계연도</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('ACNTG_SE_CD', this.innerText, 'codeValue', 'FIM074');">회계코드</th> <th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('ACNTG_SE_CD', this.innerText, 'codeValue', 'FIM074');">회계코드</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('TXITM_CD', this.innerText, 'codeValue', 'FIM075');">세목코드</th> <th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('TXITM_CD', this.innerText, 'codeValue', 'FIM075');">세목코드</th>
<th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('TXITM_CD', this.innerText, 'codeValue', 'FIM075');">세목명</th> <th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('TXITM_CD', this.innerText, 'codeValue', 'FIM075');">세목명</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('LEVY_NO', this.innerText, 'match', 'part');">부과번호</th> <th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('LEVY_NO', this.innerText, 'match', 'part');">부과번호</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('INSPY_SN', this.innerText, 'match', 'part');">분납순번</th> <th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('INSPY_NO', this.innerText, 'match', 'part');">분납순번</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('LEVY_SE_CD', this.innerText, 'codeValue', 'FIM040');">부과구분</th> <th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('LEVY_SE_CD', this.innerText, 'codeValue', 'FIM040');">부과구분</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('UNTY_SE_CD', this.innerText, 'codeValue', 'FIM072');">통합구분</th> <th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('UNTY_SE_CD', this.innerText, 'codeValue', 'FIM072');">통합구분</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('RDUCT_SE_CD', this.innerText, 'codeValue', 'FIM046');">감경구분</th> <th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('RDUCT_SE_CD', this.innerText, 'codeValue', 'FIM046');">감경구분</th>
@ -253,21 +259,18 @@
<th class="cmn" style="width: 180px;">수정일시</th> <th class="cmn" style="width: 180px;">수정일시</th>
<th class="cmn" style="width: 140px;">수정사용자</th> <th class="cmn" style="width: 140px;">수정사용자</th>
<th class="cmn dummy-th"></th> <th class="cmn dummy-th"></th>
</tr> </template>
</thead>
<tbody id="tbody--${pageName}">
</tbody>
<template id="${infoPrefix}Row--${pageName}"> <template id="${infoPrefix}Row--${pageName}">
<tr data-key="{LEVY_ID}"> <tr data-key="{LEVY_ID}">
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ROW_NUM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ROW_NUM}</td>
<td class="cmn text-center"><input type="checkbox" class="form-check-input" value="{LEVY_ID}" onchange="${pageName}Control.select('{LEVY_ID}', this.checked);"></td> <td class="cmn text-center"><input type="checkbox" class="form-check-input" value="{LEVY_ID}" onchange="pageObject['${pageName}'].control.select('{LEVY_ID}', this.checked);" /></td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{TASK_SE_NM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{TASK_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{FYR}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{FYR}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ACNTG_SE_CD}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ACNTG_SE_CD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{TXITM_CD}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{TXITM_CD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{TXITM_NM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{TXITM_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_NO}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{INSPY_SN}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{INSPY_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_SE_NM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{UNTY_SE_NM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{UNTY_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RDUCT_SE_NM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RDUCT_SE_NM}</td>
@ -314,7 +317,19 @@
</tr> </tr>
</template> </template>
<template id="${infoPrefix}NotFound--${pageName}"> <template id="${infoPrefix}NotFound--${pageName}">
<tr class="odd"> <tr class="bpv">
<td valign="top" colspan="55" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
<tr class="dpv">
<td valign="top" colspan="55" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
<tr class="eca">
<td valign="top" colspan="55" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
<tr class="pvs">
<td valign="top" colspan="55" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
<tr class="tpv">
<td valign="top" colspan="55" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td> <td valign="top" colspan="55" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr> </tr>
</template> </template>
@ -329,8 +344,6 @@
</div> </div>
<!-- / Content --> <!-- / Content -->
<div class="content-backdrop fade"></div> <div class="content-backdrop fade"></div>
</div> </div>
<!-- / inner page html <div class="content-wrapper"> --> <!-- / inner page html <div class="content-wrapper"> -->
@ -339,23 +352,30 @@
/************************************************************************** /**************************************************************************
* Global Variable * Global Variable
**************************************************************************/ **************************************************************************/
pageObject["${pageName}"] = {};
/**************************************************************************
* script 진입
**************************************************************************/
$(document).ready(function() {
// pageObject
var $P = pageObject["${pageName}"];
// URL // URL
var ${pageName}PrefixUrl = "/levy/levy01"; $P.PrefixUrl = "/levy/levy01";
// FormFields // FormFields
var ${pageName}Fields = new FimsFormFields("#frmSearch--${pageName}"); $P.formFields = new FimsFormFields("#frmSearch--${pageName}");
/************************************************************************** /**************************************************************************
* DatasetControl * DatasetControl
**************************************************************************/ **************************************************************************/
var ${pageName}Control = new DatasetControl({ $P.control = new DatasetControl({
prefix : "levy" prefix : "levy"
, prefixName : "부과" , prefixName : "부과"
, infoSize : "xl" , infoSize : "xl"
, keymapper : info => info ? info.LEVY_ID : "" , keymapper : info => info ? info.LEVY_ID : ""
, dataGetter : obj => obj.levyList , dataGetter : obj => obj.levyList
, appendData : true , appendData : true
, untilPageNum : 0 // 현재 페이지 번호
, tableRenderComplete : false // dataTables 에 자료 추가 완료 여부
, formats : { , formats : {
LEVY_YMD : dateFormat LEVY_YMD : dateFormat
, FRST_DUDT_YMD : dateFormat , FRST_DUDT_YMD : dateFormat
@ -378,28 +398,33 @@
, MDFCN_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.beforeCurrent = null;
/************************************************************************** /**************************************************************************
* DatasetControl 이벤트 * DatasetControl 이벤트
**************************************************************************/ **************************************************************************/
// Dataset 변경 // Dataset 변경
${pageName}Control.onDatasetChange = obj => { $P.control.onDatasetChange = obj => {
renderList${pageName}(obj.${infoPrefix}Total); $P.renderList(obj.${infoPrefix}Total);
$("#paging--${pageName}").setPagingInfo({ $("#paging--${pageName}").setPagingInfo({
list : ${pageName}Control.dataset list : $P.control.dataset
, prefix : "paging--${pageName}" , prefix : "paging--${pageName}"
, start : obj.${infoPrefix}Start , start : obj.${infoPrefix}Start
, totalSize : obj.${infoPrefix}Total , totalSize : obj.${infoPrefix}Total
, fetchSize : obj.${infoPrefix}Fetch , fetchSize : obj.${infoPrefix}Fetch
, func : "${pageName}Control.load({index})" , func : "$P.control.load({index})"
}); });
${pageName}Control.tableRenderComplete = true; // dataTables 에 자료 추가 완료 $P.control.tableRenderComplete = true; // dataTables 에 자료 추가 완료
}; };
// 현재 선택 자료 변경 이벤트 // 현재 선택 자료 변경 이벤트
${pageName}Control.onCurrentChange = item => { $P.control.onCurrentChange = item => {
if (!item) return; if (!item) return;
let key = item.data.LEVY_ID; let key = item.data.LEVY_ID;
@ -408,8 +433,8 @@
}; };
// 선택(체크) 변경 이벤트 // 선택(체크) 변경 이벤트
${pageName}Control.onSelectionChange = selected => { $P.control.onSelectionChange = selected => {
let ${infoPrefix}List = ${pageName}Control.dataset; let ${infoPrefix}List = $P.control.dataset;
let keys = selected.map(e => ${infoPrefix}List.getKey(e)); let keys = selected.map(e => ${infoPrefix}List.getKey(e));
$("#tbody--${pageName} input[type='checkbox']").each(function() { $("#tbody--${pageName} input[type='checkbox']").each(function() {
@ -420,17 +445,17 @@
}; };
// 부과 정보 dialog // 부과 정보 dialog
${pageName}Control.getInfo = (params) => { $P.control.getInfo = (params) => {
if (!params) return; if (!params) return;
let dialogTitle = ""; let dialogTitle = "";
if (params.callPurpose == "create") { if (params.callPurpose == "create") {
dialogTitle = ${pageName}Control.prefixName + " 등록"; dialogTitle = $P.control.prefixName + " 등록";
} else if (params.callPurpose == "update") { } else if (params.callPurpose == "update") {
dialogTitle = ${pageName}Control.prefixName + " 수정"; dialogTitle = $P.control.prefixName + " 수정";
} else { } else {
dialogTitle = ${pageName}Control.prefixName + " 정보"; dialogTitle = $P.control.prefixName + " 정보";
} }
} }
@ -438,57 +463,66 @@
* DataTables 이벤트 * DataTables 이벤트
**************************************************************************/ **************************************************************************/
// DataTables에 click, dbclick 이벤트 // DataTables에 click, dbclick 이벤트
renderList${pageName} = (totalSize) => { $P.renderList = (totalSize) => {
let ${infoPrefix}List = ${pageName}Control.dataset; let ${infoPrefix}List = $P.control.dataset;
let empty = ${infoPrefix}List.empty; let empty = ${infoPrefix}List.empty;
let clsForTask = $("#frmSearch--${pageName} input[name='taskSeCd']:checked").val().toLowerCase(); // 소문자
// 업무별 DataTables(그리드) tr, td
let foundContent = document.getElementById("${infoPrefix}Row--${pageName}").content;
let foundTr = $(foundContent).find("tr")[0].cloneNode(false);
let foundTds = $(foundContent).find("." + clsForTask + ",.cmn");
foundTds.each(function() {
foundTr.appendChild(this.cloneNode(true));
});
//
let replacer = (str, dataItem) => str
.replace(/{onclick}/gi, "pageObject['${pageName}'].control.setCurrent('" + dataItem.getValue("LEVY_ID") + "');")
.replace(/{ondblclick}/gi, "pageObject['${pageName}'].getTotalInfo('" + dataItem.getValue("CRDN_ID") + "');");
let trs = empty ? let trs = empty ? [document.getElementById("${infoPrefix}NotFound--${pageName}").content.querySelector("." + clsForTask + ",.cmn").outerHTML]
[document.getElementById("${infoPrefix}NotFound--${pageName}").innerHTML] : <%-- from template#${infoPrefix}NotFound --%> : ${infoPrefix}List.inStrings(foundTr.outerHTML, replacer);
${infoPrefix}List.inStrings(
document.getElementById("${infoPrefix}Row--${pageName}").innerHTML, <%-- from template#${infoPrefix}Row --%>
(str, dataItem) => str
.replace(/{onclick}/gi, "${pageName}Control.setCurrent('" + dataItem.getValue("LEVY_ID") + "');")
.replace(/{ondblclick}/gi, "getTotalInfo${pageName}('" + dataItem.getValue("CRDN_ID") + "');")
);
let noMore = (totalSize == ${infoPrefix}List.length); let noMore = (totalSize == ${infoPrefix}List.length);
let initScroll = (${pageName}Control.query.pageNum < 2) && (${pageName}Control.untilPageNum == 0); let initScroll = ($P.control.query.pageNum < 2) && ($P.control.untilPageNum == 0);
$("#table-responsive--${pageName}")[0].changeContent(trs.join(), initScroll, noMore); $("#table-responsive--${pageName}")[0].changeContent(trs.join(), initScroll, noMore);
if (${pageName}Control.untilPageNum != 0) { if ($P.control.untilPageNum != 0) {
${pageName}Control.query.fetchSize = ${pageName}Control.defaultFetchSize; $P.control.query.fetchSize = $P.control.defaultFetchSize;
${pageName}Control.query.pageNum = ${pageName}Control.untilPageNum; $P.control.query.pageNum = $P.control.untilPageNum;
${pageName}Control.untilPageNum = 0; $P.control.untilPageNum = 0;
} }
// checkbox 체크 해제 // checkbox 체크 해제
$("th input[type='checkbox']").prop("checked", false); $("th input[type='checkbox']").prop("checked", false);
//보안모드 // 보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked")); fn_securityModeToggle($("#securityMode--top").is(":checked"));
} }
// DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트 // DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트
scrollDataList${pageName} = () => { $P.scrollDataList = () => {
${pageName}Control.tableRenderComplete = false; // dataTables 에 자료 추가 false $P.control.tableRenderComplete = false; // dataTables 에 자료 추가 false
${pageName}Control.load(${pageName}Control.query.pageNum + 1); $P.control.load($P.control.query.pageNum + 1);
} }
/************************************************************************** /**************************************************************************
* 사용자 함수(function) * 사용자 함수(function)
**************************************************************************/ **************************************************************************/
// callback 사용자 검색 // callback 사용자 검색
callbackFindUser${pageName} = (userId, userNm) => { $P.callbackFindUser = (userId, userNm) => {
$("#schRgtrCd--${pageName}").val(userId); // 사용자 ID $("#schRgtrCd--${pageName}").val(userId); // 사용자 ID
$("#schRgtrNm--${pageName}").val(userNm); // 사용자 명 $("#schRgtrNm--${pageName}").val(userNm); // 사용자 명
} }
// 사용자 검색 // 사용자 검색
getFindUser${pageName} = () => { $P.getFindUser = () => {
let params = { let params = {
callbackFuncName : "callbackFindUser${pageName}" callbackFuncName : "$P.callbackFindUser"
} }
ajax.get({ ajax.get({
@ -506,18 +540,18 @@
} }
// 개별총정보 dialog // 개별총정보 dialog
getTotalInfo${pageName} = (crdnId) => { $P.getTotalInfo = (crdnId) => {
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return; if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return;
let params = { let params = {
callControlName : "${pageName}Control" callControlName : "pageObject['${pageName}'].control"
, sggCd : $("#sggCd--${pageName}").val() , sggCd : $("#sggCd--${pageName}").val()
, taskSeCd : $("input[name=taskSeCd]:checked").val() , taskSeCd : $("input[name=taskSeCd]:checked").val()
, crdnId : crdnId , crdnId : crdnId
} }
ajax.get({ ajax.get({
url : wctx.url(params.taskSeCd + "/sprt/sprt02/010/main.do") url : wctx.url("/" + params.taskSeCd + "/sprt/sprt02/010/main.do")
, data : params , data : params
, success : resp => { , success : resp => {
dialog.open({ dialog.open({
@ -525,50 +559,55 @@
, title : "개별총정보" , title : "개별총정보"
, content : resp , content : resp
, size : "xxl" , size : "xxl"
, init : () => { }
, onClose : () => { }
}); });
} }
}); });
} }
// 검색 자료 재조회 // 검색 자료 재조회
refreshList${pageName} = () => { $P.refreshList = () => {
${pageName}Control.untilPageNum = ${pageName}Control.query.pageNum; $P.control.untilPageNum = $P.control.query.pageNum;
${pageName}Control.query.fetchSize = ${pageName}Control.defaultFetchSize * ${pageName}Control.query.pageNum; $P.control.query.fetchSize = $P.control.defaultFetchSize * $P.control.query.pageNum;
${pageName}Control.load(1); $P.control.load(1);
} }
/************************************************************************** /**************************************************************************
* 버튼 clickEvent * 버튼 clickEvent
**************************************************************************/ **************************************************************************/
// 업무 구분 변경 // 업무 구분 변경
fnResetAndChangeBiz${pageName} = (taskSeCd) => { $P.fnResetAndChangeBiz = (taskSeCd) => {
// 업무 구분 코드 // 업무 구분 코드
if (typeof taskSeCd == "undefined" || taskSeCd == null || taskSeCd == "") { if (typeof taskSeCd == "undefined" || taskSeCd == null || taskSeCd == "") {
taskSeCd = $("#layout-navbar input[name='taskSeCd']:checked").val(); taskSeCd = $("#layout-navbar input[name='taskSeCd']:checked").val();
} }
// 초기 기본 설정 // 초기 기본 설정
initForm${pageName}(); $P.initForm();
// 기본 데이터 설정 // 기본 데이터 설정
setFormData${pageName}(taskSeCd); $P.initData(taskSeCd);
// 업무 구분별 설정
$P.setTask(taskSeCd);
// dataset 초기화
$P.control.dataset.clear();
} }
// 검색 버튼 이벤트 // 검색 버튼 이벤트
fnSearchList${pageName} = () => { $P.fnSearchList = () => {
// 검색조건 // 검색조건
${pageName}Control.query = ${pageName}Fields.get(); $P.control.query = $P.formFields.get();
$P.control.query.fetchSize = $P.control.defaultFetchSize; // 한번에 조회되는 자료 건수
$P.control.query.delYN = "N"; // 삭제 여부
${pageName}Control.query.fetchSize = ${pageName}Control.defaultFetchSize; // 한번에 조회되는 자료 건수 FETCH_XS = 30 $P.control.load(1);
${pageName}Control.query.delYn = "N"; // 삭제 여부
${pageName}Control.load(1);
} }
// 엑셀 버튼 이벤트 // 엑셀 버튼 이벤트
fnExcel${pageName} = () => { $P.fnExcel = () => {
if (${pageName}Control.dataset.empty) { if ($P.control.dataset.empty) {
dialog.alert({ dialog.alert({
content : "검색된 자료가 없습니다." content : "검색된 자료가 없습니다."
, onOK : () => { } , onOK : () => { }
@ -580,21 +619,27 @@
// DataTables(그리드) // DataTables(그리드)
let cellDefs = getCellDefs($("#theadTr--${pageName} th").not(".dummy-th").not(":eq(0)") let cellDefs = getCellDefs($("#theadTr--${pageName} th").not(".dummy-th").not(":eq(0)")
, $($("#${infoPrefix}Row--${pageName}")[0].content).find("td").not(".dummy-td").not(":eq(0)")); , $($("#${infoPrefix}Row--${pageName}")[0].content).find("td").not(".dummy-td").not(":eq(0)"));
${pageName}Control.query.cellDefs = cellDefs; $P.control.query.cellDefs = cellDefs;
${pageName}Control.download(); $P.control.download();
} }
// 사용자 조회 버튼 이벤트 // 사용자 조회 버튼 이벤트
fnFindUser${pageName} = () => { $P.fnFindUser = () => {
getFindUser${pageName}(); $P.getFindUser();
} }
/************************************************************************** /**************************************************************************
* 초기 설정 * 초기 설정
**************************************************************************/ **************************************************************************/
// 이벤트 // 이벤트
setEvent${pageName} = () => { $P.setEvent = () => {
// 기본 버튼 이벤트
$("#btnReset--${pageName}").on("click", () => $P.fnResetAndChangeBiz()); // 초기화
$("#btnSearch--${pageName}").on("click", () => $P.fnSearchList()); // 검색
$("#btnExcel--${pageName}").on("click", () => $P.fnExcel()); // 엑셀
$("#btnFindUser--${pageName}").on("click", () => $P.fnFindUser()); // 사용자 검색
// 동적검색에서 엔터(Enter) 키를 누르면 검색한다. // 동적검색에서 엔터(Enter) 키를 누르면 검색한다.
$("#term--${pageName}").keypress(function(e) { $("#term--${pageName}").keypress(function(e) {
if (e.keyCode == 13) { if (e.keyCode == 13) {
@ -615,67 +660,97 @@
}); });
}); });
// 업무 버튼 이벤트
// DataTables width 변경 조정 업무별 그리드가 존재 한다면.. crdn06010-main.jsp 참고 // DataTables width 변경 조정 업무별 그리드가 존재 한다면.. crdn06010-main.jsp 참고
$("#DataTables_Table_0--${pageName}").find("th").resizable( {handles : "e"} ); $("#DataTables_Table_0--${pageName}").find("th").resizable( {handles : "e"} );
// DataTables 스크롤 이벤트 생성 // DataTables 스크롤 이벤트 생성
fnMakeScrollableTable($("#table-responsive--${pageName}")[0], scrollDataList${pageName}); fnMakeScrollableTable($("#table-responsive--${pageName}")[0], $P.scrollDataList);
} }
// 화면 초기 설정 // 초기 화면 설정
initForm${pageName} = () => { $P.initForm = () => {
// 화면 초기화 // 화면 초기화
$("#frmSearch--${pageName}")[0].reset(); $("#frmSearch--${pageName}")[0].reset();
// input, select 초기화
let searchForm = $("#frmSearch--${pageName}");
searchForm.find("input[type='radio']").not("[name='taskSeCd']").prop("checked", false);
searchForm.find("input[type='checkbox']").prop("checked", false);
searchForm.find("input[type='text']").val("");
searchForm.find("input[type='hidden']").val("");
searchForm.find("select").each(function() { $(this).find("option:eq(0)").prop("selected", true); });
// 최고 관리자 경우 업무구분을 선택할 수 있도록 하자. // 최고 관리자 경우 업무구분을 선택할 수 있도록 하자.
$("#frmSearch--${pageName} input[name='taskSeCd']").each(function(i) { $("#frmSearch--${pageName} input[name='taskSeCd']").each(function(i) {
$(this).prop("disabled", "true"); $(this).prop("disabled", "true");
}); });
// 달력 초기화
initDatepicker("frmSearch--${pageName}");
$("#schFyr--${pageName}").val(new Date().getFullYear()); $("#schFyr--${pageName}").val(new Date().getFullYear());
$("#schLevyNoFrom--${pageName}").val("000000"); $("#schLevyNoFrom--${pageName}").val("000000");
$("#schLevyNoTo--${pageName}").val("999999"); $("#schLevyNoTo--${pageName}").val("999999");
// 달력 초기화 // 동적 검색
initDatepicker("frmSearch--${pageName}"); $("#byOutput--${pageName}").val("동적 검색");
// 사용자 이름 // 사용자 이름
$("#schRgtrNm--${pageName}").prop("readonly", true); $("#schRgtrNm--${pageName}").prop("readonly", true);
// dataset 초기화
${pageName}Control.dataset.clear();
} }
// 기본 데이터 설정 // 기본 데이터 설정
setFormData${pageName} = (taskSeCd) => { $P.initData = (taskSeCd) => {
// ${pageName}Control 설정 // 시군구 코드
${pageName}Control.defaultFetchSize = FETCH_XS; // 1 페이지당 조회되는 자료 건수 index.jsp에서 확인 FETCH_XS = 30 $("#sggCd--${pageName}").val("${sggCd}");
// 업무 구분 코드
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + taskSeCd + "']").prop("checked", true);
}
// 업무 구분별 설정
$P.setTask = (taskSeCd) => {
let clsForTask = taskSeCd.toLowerCase();
// 업무별 조회조건
renderForTask("frmSearch--${pageName}", clsForTask);
// 화면 데이터 설정 // 업무별 그리드 th
$("#sggCd--${pageName}").val("${sggCd}"); // 시군구 코드 $("#DataTables_Table_0--${pageName}").find("th").resizable( "destroy" );
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + taskSeCd + "']").prop("checked", true); // 업무 구분
let colContent = document.getElementById("${infoPrefix}Col--${pageName}").content;
let cols = $(colContent).find("." + clsForTask + ",.cmn");
let colsOuterHTML = "";
cols.each(function() {
colsOuterHTML += this.outerHTML;
});
$("#theadTr--${pageName}").html(colsOuterHTML);
$("#DataTables_Table_0--${pageName}").find("th").resizable( {handles : "e"} );
// URL 설정 // URL 설정
setURL${pageName}(taskSeCd); $P.setURL(taskSeCd);
} }
// URL 설정 // 업무구분에 따른 URL 설정
setURL${pageName} = (taskSeCd) => { $P.setURL = (taskSeCd) => {
${pageName}Control.urls.load = wctx.url(taskSeCd + ${pageName}PrefixUrl + "/050/list.do"); // 조회 $P.control.urls.load = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/050/list.do"); // 조회
} }
/************************************************************************** /**************************************************************************
* script 진입 * 최초 실행 함수
**************************************************************************/ **************************************************************************/
$(document).ready(function() { // 1. 이벤트 설정
// 이벤트 설정 $P.setEvent();
setEvent${pageName}();
// 보안모드 // 2. 화면 초기 설정 및 업무 구분 변경
fn_securityModeToggle($("#securityMode--top").is(":checked")); // $P.fnResetAndChangeBiz($("#layout-navbar input[name='taskSeCd']:checked").val());
$P.fnResetAndChangeBiz("DPV");
// 화면 초기 설정 및 업무 구분 변경 // 3. 보안모드
fnResetAndChangeBiz${pageName}($("#layout-navbar input[name='taskSeCd']:checked").val()); fn_securityModeToggle($("#securityMode--top").is(":checked"));
}); });
</script> </script>

@ -57,10 +57,10 @@
<label for="levyNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">부과번호</label> <label for="levyNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">부과번호</label>
<input type="text" class="form-control w-30" id="levyNo--${pageName}" name="levyNo" data-map="LEVY_NO" /> <input type="text" class="form-control w-30" id="levyNo--${pageName}" name="levyNo" data-map="LEVY_NO" />
</div> </div>
<!-- 분납 번 --> <!-- 분납 번 -->
<div class="col-md-4"> <div class="col-md-4">
<label for="levyNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">분납번</label> <label for="inspyNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">분납번</label>
<input type="text" class="form-control w-15" id="inspySn--${pageName}" name="inspySn" data-map="INSPY_SN" /> <input type="text" class="form-control w-15" id="inspyNo--${pageName}" name="inspyNo" data-map="INSPY_NO" />
</div> </div>
<!-- 부과 본세 --> <!-- 부과 본세 -->
<div class="col-md-4"> <div class="col-md-4">
@ -302,7 +302,7 @@
$("#txitmCd--${pageName}").prop("readonly", true); // 세목 코드 $("#txitmCd--${pageName}").prop("readonly", true); // 세목 코드
$("#fyr--${pageName}").prop("readonly", true); // 회계연도 $("#fyr--${pageName}").prop("readonly", true); // 회계연도
$("#levyNo--${pageName}").prop("readonly", true); // 부과 번호 $("#levyNo--${pageName}").prop("readonly", true); // 부과 번호
$("#inspySn--${pageName}").prop("readonly", true); // 분납 순번 $("#inspyNo--${pageName}").prop("readonly", true); // 분납 순번
$("#levyPcptax--${pageName}").prop("readonly", true); // 부과 본세 $("#levyPcptax--${pageName}").prop("readonly", true); // 부과 본세
$("#levyAdamt--${pageName}").prop("readonly", true); // 부과 가산금 $("#levyAdamt--${pageName}").prop("readonly", true); // 부과 가산금
$("#inspyInt--${pageName}").prop("readonly", true); // 단속 상태 $("#inspyInt--${pageName}").prop("readonly", true); // 단속 상태

@ -0,0 +1,796 @@
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
<!-- 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">
<div class="wrapper-list">
<div>
<!-- 상단 버튼 -->
<div class="container-page-btn">
<button type="button" class="btn btn-outline-dark w-px-120" id="btnReset--${pageName}" title="초기화">
초기화
</button>
<span class="container-window-btn-right">
<button type="button" class="btn btn-search w-px-120" id="btnSearch--${pageName}" title="검색">
검색
</button>
<button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀">
엑셀
</button>
</span>
</div>
<!-- / 상단 버튼 -->
<!-- 검색 조건 영역 -->
<form id="frmSearch--${pageName}" name="frmSearch">
<!-- hidden -->
<input type="hidden" id="sggCd--${pageName}" name="sggCd" />
<!-- 메인 조건 -->
<div class="container-search">
<div class="row g-1">
<!-- 업무구분 -->
<div class="col-12">
<label class="form-label fw-bold form-search-title text-end">업무구분</label>
<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);">
${item.value}
</label>
</c:forEach>
</span>
</div>
<!-- 부과제외일자 -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end">부과제외일자</label>
<span class="form-search-linebox">
<input type="text" class="form-control form-date" id="schLevyExclYmdFrom--${pageName}" name="schLevyExclYmdFrom"
data-fmt-type="day" autocomplete="off" title="시작 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
~
<input type="text" class="form-control form-date" id="schLevyExclYmdTo--${pageName}" name="schLevyExclYmdTo"
data-fmt-type="day" autocomplete="off" title="종료 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
</span>
</div>
<!-- 부과제외구분 -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end">부과제외구분</label>
<select class="form-select w-px-100" id="schLevyExclSeCd--${pageName}" name="schLevyExclSeCd">
<option value="">전체</option>
<c:forEach items="${FIM021List}" 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">단속일자</label>
<span class="form-search-linebox">
<input type="text" class="form-control form-date" id="schCrdnYmdFrom--${pageName}" name="schCrdnYmdFrom"
data-fmt-type="day" autocomplete="off" title="시작 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
~
<input type="text" class="form-control form-date" id="schCrdnYmdTo--${pageName}" name="schCrdnYmdTo"
data-fmt-type="day" autocomplete="off" title="종료 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
</span>
</div>
<!-- 차량번호 -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end">차량번호</label>
<input type="text" class="form-control w-px-160" id="schVhrno--${pageName}" name="schVhrno" autocomplete="off" />
</div>
<!-- 납부자명 -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end">납부자명</label>
<input type="text" class="form-control w-px-160" id="schRtpyrNm--${pageName}" name="schRtpyrNm" 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="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" autocomplete="off" />
<!-- 상세 검색조건 버튼 -->
<span class="flr">
<button type="button" class="btn btn-open-detail" data-bs-toggle="collapse" data-bs-target="#searchDetail--${pageName}">
<i class="bx bx-chevron-down"></i>
상세검색
</button>
</span>
</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">
<option value="regDt">등록일자</option>
<option value="mdfcnDt">수정일자</option>
</select>
<span class="form-search-linebox">
<input type="text" class="form-control form-date" id="schRegDateFrom--${pageName}" name="schRegDateFrom"
data-fmt-type="day" title="시작 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
~
<input type="text" class="form-control form-date" id="schRegDateTo--${pageName}" name="schRegDateTo"
data-fmt-type="day" title="종료 날짜 선택">
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
</span>
</div>
<!-- 등록자명, 수정자명 -->
<div class="col-6">
<select class="form-select 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="사용자 검색" onclick="fnFindUser${pageName}();">
검색
</button>
</div>
</div>
</div> <!-- / 상세 조건 -->
</form> <!-- / 검색 조건 영역 -->
<!-- 업무 버튼 및 건수 표시 -->
<div>
<span class="container-page-btn">
<!-- 건수, 페이지 표시 -->
<div class="d-flex flex-row justify-content-between">
<label class="dataTables_info" id="paging--${pageName}PagingInfo" role="status" aria-live="polite"></label>
<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="btnUpdate--${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" id="table-responsive--${pageName}" style="overflow-x:scroll; height:460px; overflow-y:scroll;" >
<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}">
</tr>
</thead>
<tbody id="tbody--${pageName}">
</tbody>
<template id="${infoPrefix}Col--${pageName}">
<th class="cmn" style="width: 72px;">NO.</th>
<th class="cmn" style="width: 56px;"><input type="checkbox" class="form-check-input" onchange="pageObject['${pageName}'].control.select(this.checked);" />
<th class="cmn" style="width: 160px;">업무구분</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('LEVY_EXCL_YMD', this.innerText, 'ymd', '');">부과제외일자</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('LEVY_EXCL_SE_CD', this.innerText, 'codeValue', 'FIM021');">부과제외구분</th>
<th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('LEVY_EXCL_RSN_CD', this.innerText, 'codeValue', 'FIM022');">부과제외사유</th>
<th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('ETC_CN', this.innerText, 'match', 'part');">기타내용</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('CVLCPT_APLY_NO', this.innerText, 'match', 'part');">민원신청번호</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('CVLCPT_RCPT_NO', this.innerText, 'match', 'part');">민원접수번호</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('CVLCPT_RCPT_YMD', this.innerText, 'ymd', '');">민원접수일자</th>
<th class="cmn" style="width: 180px;" onclick="searchFromGridTitle('CRDN_YMD', this.innerText, 'ymd', '');">단속일시</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('VHRNO', this.innerText, 'match', 'part');">차량번호</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RTPYR_SE_CD', this.innerText, 'codeValue', 'FIM011');">납부자구분</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('RTPYR_NO', this.innerText, 'ymd', '');">납부자번호</th>
<th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('RTPYR_NM', this.innerText, 'match', 'part');">납부자명</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('CRDN_STDG_NM', this.innerText, 'match', 'part');">단속법정동</th>
<th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('CRDN_PLC', this.innerText, 'match', 'part');">단속장소</th>
<th class="bpv" style="width: 280px;" onclick="searchFromGridTitle('DTL_CRDN_PLC', this.innerText, 'match', 'part');">상세단속장소</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('VLTN_ARTCL', this.innerText, 'match', 'part');">위반항목</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('FFNLG_CRDN_AMT', this.innerText, 'match', 'part');">최초단속금액</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('CRDN_STTS_CD', this.innerText, 'codeValue', 'FIM010');">처리상태</th>
<th class="pvs" style="width: 140px;" onclick="searchFromGridTitle('CRDN_SPAREA_CD', this.innerText, 'codeValue', 'FIM007');">단속특별구역</th>
<th class="eca" style="width: 140px;" onclick="searchFromGridTitle('USE_FUEL_CD', this.innerText, 'codeValue', 'LVS005');">사용연료</th>
<th class="dpv" style="width: 140px;" onclick="searchFromGridTitle('PARKNG_PSBLTY_RSLT_CD', this.innerText, 'codeValue', 'FIM034');">주차가능여부</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('ZIP', this.innerText, 'match', 'part');">우편번호</th>
<th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('ADDR', this.innerText, 'match', 'part');">주소</th>
<th class="cmn" style="width: 320px;" onclick="searchFromGridTitle('DTL_ADDR', this.innerText, 'match', 'part');">상세주소</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>
</template>
<template id="${infoPrefix}Row--${pageName}">
<tr data-key="{LEVY_EXCL_ID}">
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ROW_NUM}</td>
<td class="cmn text-center"><input type="checkbox" class="form-check-input" value="{LEVY_EXCL_ID}" onchange="pageObject['${pageName}'].control.select('{LEVY_EXCL_ID}', this.checked);" /></td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{TASK_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_EXCL_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_EXCL_SE_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{LEVY_EXCL_RSN_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ETC_CN}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CVLCPT_APLY_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CVLCPT_RCPT_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CVLCPT_RCPT_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_YMD_TM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{VHRNO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NO}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_STDG_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_PLC}</td>
<td class="bpv text-start" onclick="{onclick}" ondblclick="{ondblclick}">{DTL_CRDN_PLC}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{VLTN_ARTCL}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_CRDN_AMT}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_STTS_NM}</td>
<td class="pvs text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_SPAREA_NM}</td>
<td class="eca text-center" onclick="{onclick}" ondblclick="{ondblclick}">{USE_FUEL_NM}</td>
<td class="dpv text-center" onclick="{onclick}" ondblclick="{ondblclick}">{PARKNG_PSBLTY_RSLT_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ZIP}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ADDR}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{DTL_ADDR}</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="bpv">
<td valign="top" colspan="29" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
<tr class="dpv">
<td valign="top" colspan="29" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
<tr class="eca">
<td valign="top" colspan="29" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
<tr class="pvs">
<td valign="top" colspan="29" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
<tr class="tpv">
<td valign="top" colspan="29" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
</template>
</table>
</div>
</div>
</div>
<!-- / DataTables(그리드) -->
</div>
</div> <!-- <div class="wrapper-list"> -->
</div> <!-- <div class="card"> -->
</div> <!-- <div class="container-xxl flex-grow-1 px-0"> -->
<!-- Content -->
<div class="content-backdrop fade"></div>
</div>
<!-- / inner page html <div class="content-wrapper"> -->
<script>
/**************************************************************************
* Global Variable
**************************************************************************/
pageObject["${pageName}"] = {};
/**************************************************************************
* script 진입
**************************************************************************/
$(document).ready(function() {
// pageObject
var $P = pageObject["${pageName}"];
// URL
$P.PrefixUrl = "/excl/excl01";
// FormFields
$P.formFields = new FimsFormFields("#frmSearch--${pageName}");
/**************************************************************************
* DatasetControl
**************************************************************************/
$P.control = new DatasetControl({
prefix : "levyExcl"
, prefixName : "부과제외"
, infoSize : "md"
, keymapper : info => info ? info.LEVY_EXCL_ID : ""
, dataGetter : obj => obj.levyExclList
, appendData : true
, urls : {
load : wctx.url("/" + $P.PrefixUrl + "/010/list.do") // 조회
, remove : wctx.url("/" + $P.PrefixUrl + "/010/remove.do") // 삭제
, getInfo : wctx.url("/" + $P.PrefixUrl + "/020/info.do") // 수정
}
, formats : {
LEVY_EXCL_YMD : dateFormat
, CRDN_YMD_TM : datetimeFormat
, CVLCPT_RCPT_YMD : dateFormat
, FFNLG_CRDN_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.beforeCurrent = null;
/**************************************************************************
* DatasetControl 이벤트
**************************************************************************/
// Dataset 변경 이벤트
$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 : "$P.control.load({index})"
});
$P.control.tableRenderComplete = true; // dataTables 에 자료 추가 완료
};
// 현재 선택 자료 변경 이벤트
$P.control.onCurrentChange = item => {
if (!item) return;
let key = item.data.LEVY_EXCL_ID;
$("#tbody--${pageName}").setCurrentRow(key);
};
// 선택(체크) 변경 이벤트
$P.control.onSelectionChange = selected => {
let ${infoPrefix}List = $P.control.dataset;
let keys = selected.map(e => ${infoPrefix}List.getKey(e));
$("#tbody--${pageName} input[type='checkbox']").each(function() {
let checkbox = $(this);
checkbox.prop("checked", keys.includes(checkbox.val()));
});
$("#btnRemove--${pageName}").prop("disabled", keys.length < 1);
};
// 수정 dialog
$P.control.getInfo = (params) => {
if (!params) return;
let dialogTitle = "";
if (params.callPurpose == "create") {
dialogTitle = $P.control.prefixName + " 등록";
} else if (params.callPurpose == "update") {
dialogTitle = $P.control.prefixName + " 수정";
} else {
dialogTitle = $P.control.prefixName + " 정보";
}
ajax.get({
url : $P.control.urls.getInfo + "?openerPageName=${pageName}"
, data : params || {}
, success : resp => {
dialog.open({
id : $P.control.prefixed("Dialog")
, title : dialogTitle
, content : resp
, size : $P.control.infoSize
, init : () => { }
, onClose : () => { $P.refreshList(); } // 자료 재조회
});
}
});
}
// 삭제 callback
$P.control.onRemove = (resp) => {
let btnTitle = $("#btnRemove--${pageName}").attr("title");
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, btnTitle);
// 메시지 출력
dialog.alert({
content : showMessage
, onOK : () => { }
});
if (resp.saved) {
$P.refreshList(); // 자료 재조회
}
}
// 삭제
$P.control.remove = (params) => {
if (!params) return;
ajax.post({
url : $P.control.urls.remove
, data : params
, success : resp => $P.control.onRemove(resp)
});
}
/**************************************************************************
* DataTables 이벤트
**************************************************************************/
// DataTables에 click, dbclick 이벤트
$P.renderList = (totalSize) => {
let ${infoPrefix}List = $P.control.dataset;
let empty = ${infoPrefix}List.empty;
let clsForTask = $("#frmSearch--${pageName} input[name='taskSeCd']:checked").val().toLowerCase(); // 소문자
// 업무별 DataTables(그리드) tr, td
let foundContent = document.getElementById("${infoPrefix}Row--${pageName}").content;
let foundTr = $(foundContent).find("tr")[0].cloneNode(false);
let foundTds = $(foundContent).find("." + clsForTask + ",.cmn");
foundTds.each(function() {
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") + "');");
let trs = empty ? [document.getElementById("${infoPrefix}NotFound--${pageName}").content.querySelector("." + clsForTask + ",.cmn").outerHTML]
: ${infoPrefix}List.inStrings(foundTr.outerHTML, replacer);
let noMore = (totalSize == ${infoPrefix}List.length);
let initScroll = ($P.control.query.pageNum < 2) && ($P.control.untilPageNum == 0);
$("#table-responsive--${pageName}")[0].changeContent(trs.join(), initScroll, noMore);
if ($P.control.untilPageNum != 0) {
$P.control.query.fetchSize = $P.control.defaultFetchSize;
$P.control.query.pageNum = $P.control.untilPageNum;
$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.load($P.control.query.pageNum + 1);
}
/**************************************************************************
* 사용자 함수(function)
**************************************************************************/
// callback 사용자 검색
$P.callbackFindUser = (userId, userNm) => {
$("#schRgtrCd--${pageName}").val(userId); // 사용자 ID
$("#schRgtrNm--${pageName}").val(userNm); // 사용자 명
}
// 사용자 검색
$P.getFindUser = () => {
let params = {
callbackFuncName : "$P.callbackFindUser"
}
ajax.get({
url : wctx.url("/user/user02/010/main.do")
, data : params || {}
, success : resp => {
dialog.open({
id : "userDialog"
, title : "사용자 검색"
, content : resp
, size : "lg"
});
}
});
}
// 개별총정보 dialog
$P.getTotalInfo = (crdnId) => {
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return;
let params = {
callControlName : "pageObject['${pageName}'].control"
, sggCd : $("#sggCd--${pageName}").val()
, taskSeCd : $("input[name=taskSeCd]:checked").val()
, crdnId : crdnId
}
ajax.get({
url : wctx.url("/" + params.taskSeCd + "/sprt/sprt02/010/main.do")
, data : params
, success : resp => {
dialog.open({
id : "totalInfoMainDialog"
, title : "개별총정보"
, content : resp
, size : "xxl"
, init : () => { }
, onClose : () => { }
});
}
});
}
// 검색 자료 재조회
$P.refreshList = () => {
$P.control.untilPageNum = $P.control.query.pageNum;
$P.control.query.fetchSize = $P.control.defaultFetchSize * $P.control.query.pageNum;
$P.control.load(1);
}
// 삭제 callback
$P.callbackRemove = (obj) => {
let selected = $P.control.dataset.getKeys("selected");
if (selected.length < 1) return;
// 서버에 전송할 data(파라미터) 생성
let params = {};
params[$P.control.prefixed("IDs")] = selected.join(","); // IDs
params.delRsn = obj.reason; // 삭제 사유
$P.control.remove(params);
}
/**************************************************************************
* 버튼 clickEvent
**************************************************************************/
// 업무 구분 변경
$P.fnResetAndChangeBiz = (taskSeCd) => {
// 업무 구분 코드
if (typeof taskSeCd == "undefined" || taskSeCd == null || taskSeCd == "") {
taskSeCd = $("#layout-navbar input[name='taskSeCd']:checked").val();
}
// 초기 기본 설정
$P.initForm();
// 기본 데이터 설정
$P.initData(taskSeCd);
// 업무 구분별 설정
$P.setTask(taskSeCd);
// dataset 초기화
$P.control.dataset.clear();
}
// 검색 버튼 이벤트
$P.fnSearchList = () => {
// 검색조건
$P.control.query = $P.formFields.get();
$P.control.query.fetchSize = $P.control.defaultFetchSize; // 한번에 조회되는 자료 건수
$P.control.query.delYN = "N"; // 삭제 여부
$P.control.load(1);
}
// 엑셀 버튼 이벤트
$P.fnExcel = () => {
if ($P.control.dataset.empty) {
dialog.alert({
content : "검색된 자료가 없습니다."
, onOK : () => { }
});
return;
}
// DataTables(그리드)
let cellDefs = getCellDefs($("#theadTr--${pageName} th").not(".dummy-th").not(":eq(0)")
, $($("#${infoPrefix}Row--${pageName}")[0].content).find("td").not(".dummy-td").not(":eq(0)"));
$P.control.query.cellDefs = cellDefs;
$P.control.download();
}
// 사용자 조회 버튼 이벤트
$P.fnFindUser = () => {
$P.getFindUser();
}
// 수정 버튼 이벤트
$P.fnUpdate = () => {
let levyExclId = $P.control.dataset.getValue("LEVY_EXCL_ID");
let levyExclSeCd = $P.control.dataset.getValue("LEVY_EXCL_SE_CD");
// 부과제외 ID 가 없다면.. return
if (typeof levyExclId == "undefined" || levyExclId == null || levyExclId == "") return;
let params = {
callPurpose : "update"
, sggCd : $P.control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd : $P.control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, levyExclId : levyExclId // 부과제외 ID
, levyExclSeCd : levyExclSeCd // 부과제외 구분 코드
};
$P.control.getInfo(params);
}
// 삭제 버튼 이벤트
$P.fnRemove = () => {
// 선택 자료
let selected = $P.control.dataset.getKeys("selected");
if (selected.length < 1) return;
// 삭제 메세지 확인
dialog.alert({
content : "선택하신 " + selected.length + "건의 " + $P.control.prefixName + " 정보를 삭제하시겠습니까?"
, onOK : () => {
// 삭제 사유 입력
let popupWidth = 640;
let popupHeight = 240;
let popupX = (window.screen.width / 2) - (popupWidth / 2);
let popupY = (window.screen.height / 2) - (popupHeight / 2);
window.open(
encodeURI(wctx.url("/resources/html/inputRsnDialog.html"
+ "?openerPageName=${pageName}"
+ "&prefix=" + $P.control.prefix
+ "&usePurpose=" + "remove"
+ "&ttlNm=" + "삭제"
))
, "inputDelRsnDialog"
, 'status=no, height=' + popupHeight + ', width=' + popupWidth + ', left='+ popupX + ', top='+ popupY
);
}
});
}
/**************************************************************************
* 초기 설정
**************************************************************************/
// 이벤트 설정
$P.setEvent = () => {
// 기본 버튼 이벤트
$("#btnReset--${pageName}").on("click", () => $P.fnResetAndChangeBiz()); // 초기화
$("#btnSearch--${pageName}").on("click", () => $P.fnSearchList()); // 검색
$("#btnExcel--${pageName}").on("click", () => $P.fnExcel()); // 엑셀
$("#btnFindUser--${pageName}").on("click", () => $P.fnFindUser()); // 사용자 검색
// 동적검색에서 엔터(Enter) 키를 누르면 검색한다.
$("#term--${pageName}").keypress(function(e) {
if (e.keyCode == 13) {
fnSearchList${pageName}();   
}    
});
// form-date 항목에서 키보드로 입력시 날짜 포맷팅 적용
$("#frmSearch--${pageName}").find(".form-date").each(function() {
$(this).on("input", function() {
let value = this.value.replaceAll("-", "");
if (value.length > 7) {
this.value = value.substring(0, 4) + "-" + value.substring(4, 6) + "-" + value.substring(6);
} else if(value.length > 5) {
this.value = value.substring(0, 4) + "-" + value.substring(4);
}
});
});
// 업무 버튼 이벤트
$("#btnUpdate--${pageName}").on("click", () => $P.fnUpdate()); // 부과제외 수정
$("#btnRemove--${pageName}").on("click", () => $P.fnRemove()); // 부과제외 삭제
// DataTables width 변경 조정 업무별 그리드가 존재 한다면.. crdn06010-main.jsp 참고
$("#DataTables_Table_0--${pageName}").find("th").resizable( {handles : "e"} );
// DataTables 스크롤 이벤트 생성
fnMakeScrollableTable($("#table-responsive--${pageName}")[0], $P.scrollDataList);
}
// 초기 화면 설정
$P.initForm = () => {
// 화면 초기화
$("#frmSearch--${pageName}")[0].reset();
// input, select 초기화
let searchForm = $("#frmSearch--${pageName}");
searchForm.find("input[type='radio']").not("[name='taskSeCd']").prop("checked", false);
searchForm.find("input[type='checkbox']").prop("checked", false);
searchForm.find("input[type='text']").val("");
searchForm.find("input[type='hidden']").val("");
searchForm.find("select").each(function() { $(this).find("option:eq(0)").prop("selected", true); });
// 최고 관리자 경우 업무구분을 선택할 수 있도록 하자.
$("#frmSearch--${pageName} input[name='taskSeCd']").each(function(i) {
$(this).prop("disabled", "true");
});
// 달력 초기화
initDatepicker("frmSearch--${pageName}");
$("#schLevyExclYmdFrom--${pageName}").datepicker("setDate", new Date());
$("#schLevyExclYmdTo--${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);
// 일자
$("#schLevyExclYmdFrom--${pageName}").datepicker("setDate", DateUtil.getDateDay(-7).date);
$("#schLevyExclYmdTo--${pageName}").datepicker("setDate", new Date());
}
// 업무 구분별 설정
$P.setTask = (taskSeCd) => {
let clsForTask = taskSeCd.toLowerCase();
// 업무별 조회조건
renderForTask("frmSearch--${pageName}", clsForTask);
// 업무별 그리드 th
$("#DataTables_Table_0--${pageName}").find("th").resizable( "destroy" );
let colContent = document.getElementById("${infoPrefix}Col--${pageName}").content;
let cols = $(colContent).find("." + clsForTask + ",.cmn");
let colsOuterHTML = "";
cols.each(function() {
colsOuterHTML += this.outerHTML;
});
$("#theadTr--${pageName}").html(colsOuterHTML);
$("#DataTables_Table_0--${pageName}").find("th").resizable( {handles : "e"} );
// URL 설정
$P.setURL(taskSeCd);
}
// 업무구분에 따른 URL 설정
$P.setURL = (taskSeCd) => {
$P.control.urls.load = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/010/list.do"); // 조회
$P.control.urls.remove = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/010/remove.do"); // 삭제
$P.control.urls.getInfo = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/020/info.do"); // 수정
}
/**************************************************************************
* 최초 실행 함수
**************************************************************************/
// 1. 이벤트 설정
$P.setEvent();
// 2. 화면 초기 설정 및 업무 구분 변경
$P.fnResetAndChangeBiz($("#layout-navbar input[name='taskSeCd']:checked").val());
// 3. 보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked"));
});
</script>

@ -0,0 +1,280 @@
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
<!-- inner page html -->
<div class="content-wrapper">
<!-- 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="crdnId--${pageName}" name="crdnId" data-map="CRDN_ID" />
<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="levyExclId--${pageName}" name="levyExclId" data-map="LEVY_EXCL_ID" />
<div class="row g-1">
<!-- 단속일시 -->
<div class="col-md-12">
<label for="crdnYmdTm--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">단속일시</label>
<input type="text" class="form-control w-35" id="crdnYmdTm--${pageName}" name="crdnYmdTm" data-map="CRDN_YMD_TM" data-fmt-type="dt" />
</div>
<!-- 차량번호 -->
<div class="col-md-12">
<label for="vhrno--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">차량번호</label>
<input type="text" class="form-control w-px-120" id="vhrno--${pageName}" name="vhrno" data-map="VHRNO" autocomplete="off" />
</div>
<!-- 부과 제외 구분 -->
<div class="col-md-12">
<label for="levyExclSeNm--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end required">부과제외구분</label>
<input type="text" class="form-control w-px-120" id="levyExclSeNm--${pageName}" autocomplete="off" />
<input type="hidden" id="levyExclSeCd--${pageName}" name="levyExclSeCd" data-map="LEVY_EXCL_SE_CD" />
</div>
<!-- 부과 제외 일자 -->
<div class="col-md-12">
<label for="levyExclYmd--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end required">부과제외일자</label>
<input type="text" class="form-control form-date" id="levyExclYmd--${pageName}" name="levyExclYmd" data-map="LEVY_EXCL_YMD"
data-fmt-type="day" autocomplete="off" title="날짜 선택" maxlength="10" required />
<button type="button" class="bx bx-sm bx-calendar bg-white" id="btnLevyExclYmd--${pageName}"></button>
</div>
<!-- 부과 제외 사유 -->
<div class="col-md-12">
<label for="levyExclRsnCd--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end required">부과제외사유</label>
<select class="form-select" id="levyExclRsnCd--${pageName}" name="levyExclRsnCd" data-map="LEVY_EXCL_RSN_CD" required>
<option value="">선택하세요</option>
<c:forEach items="${FIM022List}" var="item">
<option value="${item.code}">${item.value}</option>
</c:forEach>
</select>
</div>
<!-- 기타 내용 -->
<div class="col-md-12">
<label for="etcCn--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">기타 내용</label>
<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"> -->
<!-- 업무 버튼 표시 -->
<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> <!-- / Content <div class="container flex-grow-1 px-0"> -->
</div> <!-- / inner page html <div class="content-wrapper"> -->
<script>
/**************************************************************************
* Global Variable
**************************************************************************/
pageObject["${pageName}"] = {};
// infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정)
var ${pageName}CallPurpose = "${callPurpose}";
// 공통 코드
var FIM021 = new CommonCodes(${FIM021}, true);
var FIM022 = new CommonCodes(${FIM022}, true);
/**************************************************************************
* script 진입
**************************************************************************/
$(document).ready(function() {
// pageObject
var $P = pageObject["${pageName}"];
// URL
$P.PrefixUrl = "/excl/excl01";
// FormFields
$P.formFields = new FimsFormFields("#frmEdit--${pageName}");
/**************************************************************************
* DatasetControl
**************************************************************************/
$P.control = new DatasetControl({
prefix : "levyExcl"
, prefixName : "부과제외"
, keymapper : info => info ? info.LEVY_EXCL_ID : ""
, dataGetter : obj => obj.levyExclInfo
, urls : {
create : wctx.url("/" + $P.PrefixUrl + "/020/create.do") // 등록
, update : wctx.url("/" + $P.PrefixUrl + "/020/update.do") // 수정
}
});
/**************************************************************************
* DatasetControl 이벤트
**************************************************************************/
$P.control.onCurrentChange = item => {
if (!item) return;
// Dataset 셋팅
$P.formFields.set(item);
// 업무구분에 따른 URL 변경
$P.setURL(item.data.TASK_SE_CD);
// 부과제외구분에 따른 부과제외사유 설정
$P.setFim021(item.data.LEVY_EXCL_SE_CD, item.data.LEVY_EXCL_RSN_CD);
// 호출용도가 등록 이라면..
if (${pageName}CallPurpose = "create") {
$("#levyExclYmd--${pageName}").datepicker("setDate", new Date());
}
}
// 저장 callback
$P.control.onSave = (resp) => {
let dialogTitle = $("#" + $P.control.prefix + "Dialog").find("h5.modal-title").html();
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, dialogTitle);
// 메시지 출력
dialog.alert({
content : showMessage
, onOK : () => { }
});
if (resp.saved) {
dialog.close($P.control.prefix + "Dialog");
if ("${savedCallbackFuncName}" != "") {
${savedCallbackFuncName}(resp.saved);
}
}
}
// 저장
$P.control.save = (info) => {
if (!info) return;
let create = isEmpty(info.levyExclId);
// 민원 접수 관리에서 호출했다면..
if (create && "${saveCallbackFuncName}" != "") {
${saveCallbackFuncName}(info);
} else {
ajax.post({
url : !create ? $P.control.urls.update : $P.control.urls.create
, data : info
, success : resp => $P.control.onSave(resp)
});
}
}
/**************************************************************************
* 사용자 함수(function)
**************************************************************************/
// 부과제외 구분에 따른 부과제외 사유 코드 설정
$P.setFim021 = (seCode, rsnCode) => {
let cmnCode = FIM021[seCode];
$("#levyExclSeCd--${pageName}").val(cmnCode.code);
$("#levyExclSeNm--${pageName}").val(cmnCode.value);
let reasons = FIM022.list().filter(reason => "2" == seCode ? reason.code > "200" : reason.code < "200");
$("#levyExclRsnCd--${pageName}").html(reasons.map(reason => "<option value='" + reason.code + "'>" + reason.value + "</option>").join());
if (typeof rsnCode != "undefined" && rsnCode != "") {
$("#levyExclRsnCd--${pageName}").val(rsnCode);
}
}
/**************************************************************************
* 버튼 clickEvent
**************************************************************************/
// 저장 버튼 클릭 이벤트
$P.fnSave = () => {
// validate 확인
if (!customValidate($("#frmEdit--${pageName}").find("input, select, textarea"))) return;
dialog.alert({
content : "현재 " + $P.control.prefixName + " 정보를 저장하시겠습니까?"
, onOK : () => {
$P.control.save($P.formFields.get());
}
});
}
/**************************************************************************
* 초기 셋팅
**************************************************************************/
// 이벤트 설정
$P.setEvent = () => {
// form-date 항목에서 키보드로 입력시 날짜 포맷팅 적용
$("#frmEdit--${pageName}").find(".form-date").each(function() {
$(this).on("input", function() {
let value = this.value.replaceAll("-","");
if (value.length > 7) {
this.value = value.substring(0, 4) + "-" + value.substring(4, 6) + "-" + value.substring(6);
} else if(value.length > 5) {
this.value = value.substring(0, 4) + "-" + value.substring(4);
}
});
});
// 업무 버튼 이벤트
$("#btnSave--${pageName}").on("click", () => $P.fnSave()); // 저장
}
// 초기 화면 설정
$P.initForm = () => {
// 달력 초기화
initDatepicker("frmEdit--${pageName}");
$("#levyExclYmd--${pageName}").datepicker("setDate", new Date());
// 화면 활성화 설정
$("#crdnYmdTm--${pageName}").prop("readonly", true); // 단속 일시
$("#vhrno--${pageName}").prop("readonly", true); // 차량번호
$("#levyExclSeNm--${pageName}").prop("readonly", true); // 부과 제외 구분
if (${pageName}CallPurpose == "view") {
// input 요소들을 disabled
$("#frmEdit--${pageName}").find("input,textarea,select").prop("disabled", true);
// button 요소들을 disabled
$("#btnLevyExclYmd--${pageName}").prop("disabled", true); // 부과제외 일자 달력 버튼
$("#btnSave--${pageName}").prop("disabled", true); // 저장 버튼
}
}
// 기본 데이터 설정
$P.initData = () => {
}
// 업무구분에 따른 URL 설정
$P.setURL = (taskSeCd) => {
$P.control.urls.create = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/020/create.do"); // 등록
$P.control.urls.update = wctx.url("/" + taskSeCd + $P.PrefixUrl + "/020/update.do"); // 수정
}
/**************************************************************************
* 최초 실행 함수
**************************************************************************/
// 1. 이벤트 설정
$P.setEvent();
// 2. 초기 화면 설정
$P.initForm();
// 3. 기본 데이터 설정
$P.initData();
// 4. Dataset 설정
$P.control.setData([${levyExclInfo}]);
});
</script>

@ -842,7 +842,7 @@
**************************************************************************/ **************************************************************************/
// 이벤트 설정 // 이벤트 설정
$P.setEvent = () => { $P.setEvent = () => {
// 버튼 이벤트 // 업무 버튼 이벤트
$("#btnViewCvlcptOrgnl--${pageName}").on("click", () => $P.fnViewCvlcptOrgnl()); // 민원 원본 보기 $("#btnViewCvlcptOrgnl--${pageName}").on("click", () => $P.fnViewCvlcptOrgnl()); // 민원 원본 보기
$("#btnViewAnswerPreview--${pageName}").on("click", () => $P.fnViewAnswerPreview()); // 민원 답변 보기 $("#btnViewAnswerPreview--${pageName}").on("click", () => $P.fnViewAnswerPreview()); // 민원 답변 보기
$("#btnUpdateCrdn--${pageName}").on("click", () => $P.fnUpdateCrdn()); // 단속 정보 수정 $("#btnUpdateCrdn--${pageName}").on("click", () => $P.fnUpdateCrdn()); // 단속 정보 수정

@ -15,6 +15,15 @@
<!-- 업무 버튼 --> <!-- 업무 버튼 -->
<div class="container-page-btn"> <div class="container-page-btn">
<label class="w-px-120 bg-label-danger pe-2 col-form-label text-sm-center">부과 정보</label> <label class="w-px-120 bg-label-danger pe-2 col-form-label text-sm-center">부과 정보</label>
<!-- 버튼 우측 정렬 -->
<span class="container-window-btn-right">
<button type="button" class="btn btn-primary w-px-120" id="btnCreateLevy--${pageName}" title="부과 등록">
부과 등록
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnCreateLevyExcl--${pageName}" title="부과 취소">
부과 취소
</button>
</span>
</div> <!-- <div class="container-page-btn"> --> </div> <!-- <div class="container-page-btn"> -->
<div class="row g-1"> <div class="row g-1">
@ -45,7 +54,7 @@
<div class="col-md-4"> <div class="col-md-4">
<label for="levyNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">부과번호</label> <label for="levyNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">부과번호</label>
<input type="text" class="form-control w-20" id="levyNo--${pageName}" name="levyNo" data-map="LEVY_NO" readonly /> <input type="text" class="form-control w-20" id="levyNo--${pageName}" name="levyNo" data-map="LEVY_NO" readonly />
<input type="text" class="form-control w-10" id="inspySn--${pageName}" name="inspySn" data-map="INSPY_SN" readonly /> <input type="text" class="form-control w-10" id="inspyNo--${pageName}" name="inspyNo" data-map="INSPY_NO" readonly />
</div> </div>
<!-- 과세 물건 --> <!-- 과세 물건 -->
<div class="col-md-4"> <div class="col-md-4">
@ -277,6 +286,7 @@
**************************************************************************/ **************************************************************************/
$P.control = new DatasetControl({ $P.control = new DatasetControl({
prefix : "levy" prefix : "levy"
, prefixName : "부과"
, keymapper : info => info ? info.LEVY_ID : "" , keymapper : info => info ? info.LEVY_ID : ""
, dataGetter : obj => obj.levy , dataGetter : obj => obj.levy
, formats : { , formats : {
@ -378,10 +388,75 @@
}); });
} }
// 부과제외 dialog
$P.createLevyExcl = (params) => {
if (!params) return;
ajax.get({
url : wctx.url("/" + params.taskSeCd + "/excl/excl01/020/info.do")
, data : params || {}
, success : resp => {
if ((typeof resp) != "string") {
if (resp.rtnMsg != "") {
dialog.alert(resp.rtnMsg);
}
return;
} else {
dialog.open({
id : "levyExclDialog"
, title : params.btnTitle
, content : resp
, size : "md"
, onClose : () => { $P.refreshDataInfo(); }
});
}
}
});
}
/************************************************************************** /**************************************************************************
* 버튼 clickEvent * 버튼 clickEvent
**************************************************************************/ **************************************************************************/
// 부과 등록
$P.fnCreateLevy = () => {
}
// 부과 취소
$P.fnCreateLevyExcl = () => {
// 버튼 title
let btnTitle = $("#btnCreateLevyExcl--${pageName}").attr("title");
// 단속 ID
let crdnId = $("#crdnId--${pageNameMain}").val();
// 단속 ID 가 없다면.. return
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return;
// 단속 상태 코드
let crdnSttsCd = $("#crdnSttsCd--${pageNameMain}").val();
let crdnSttsNm = $("#crdnSttsNm--${pageNameMain}").val();
// 단속 상태 코드 확인
if (Number(crdnSttsCd) < 51 || Number(crdnSttsCd) > 55) {
dialog.alert({
content : "단속상태가 '" + crdnSttsNm + "' 입니다."
+ "<br>" + "[" + btnTitle + "]" + " 실행이 취소되었습니다."
, onOK : () => { }
});
return;
}
let params = {
callPurpose : "create"
, btnTitle : btnTitle
, crdnId : crdnId
, sggCd : $("#sggCd--${pageNameMain}").val()
, taskSeCd : $("#taskSeCd--${pageNameMain}").val()
, levyExclSeCd : "3"
, delYN : "N"
};
$P.createLevyExcl(params);
}
/************************************************************************** /**************************************************************************
* 초기 셋팅 * 초기 셋팅
@ -389,6 +464,8 @@
// 이벤트 설정 // 이벤트 설정
$P.setEvent = () => { $P.setEvent = () => {
// 업무 버튼 이벤트 // 업무 버튼 이벤트
$("#btnCreateLevy--${pageName}").on("click", () => $P.fnCreateLevy()); // 부과 등록
$("#btnCreateLevyExcl--${pageName}").on("click", () => $P.fnCreateLevyExcl()); // 부과 취소
} }
// 기본 데이터 설정 // 기본 데이터 설정
@ -396,6 +473,8 @@
// 화면 호출(callPurpose)이 view 라면 버튼 비활성화 // 화면 호출(callPurpose)이 view 라면 버튼 비활성화
if (${pageNameMain}CallPurpose == "view") { if (${pageNameMain}CallPurpose == "view") {
// button 요소들을 disabled = true // button 요소들을 disabled = true
$("#btnCreateLevy--${pageName}").prop("disabled", true);
$("#btnCreateLevyExcl--${pageName}").prop("disabled", true);
} }
} }

@ -70,7 +70,7 @@
<td class="text-center" onclick="{onclick}">{ACNTG_SE_CD}</td> <td class="text-center" onclick="{onclick}">{ACNTG_SE_CD}</td>
<td class="text-center" onclick="{onclick}">{TXITM_CD}</td> <td class="text-center" onclick="{onclick}">{TXITM_CD}</td>
<td class="text-center" onclick="{onclick}">{LEVY_NO}</td> <td class="text-center" onclick="{onclick}">{LEVY_NO}</td>
<td class="text-center" onclick="{onclick}">{INSPY_SN}</td> <td class="text-center" onclick="{onclick}">{INSPY_NO}</td>
<td class="text-center" onclick="{onclick}">{RCVMT_YMD}</td> <td class="text-center" onclick="{onclick}">{RCVMT_YMD}</td>
<td class="text-end" onclick="{onclick}">{RCVMT_AMT}</td> <td class="text-end" onclick="{onclick}">{RCVMT_AMT}</td>
<td class="text-end" onclick="{onclick}">{RCVMT_PCPTAX}</td> <td class="text-end" onclick="{onclick}">{RCVMT_PCPTAX}</td>
@ -134,7 +134,7 @@
<div class="col-md-3"> <div class="col-md-3">
<label for="levyNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">부과번호</label> <label for="levyNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">부과번호</label>
<input type="text" class="form-control w-20" id="levyNo--${pageName}" name="levyNo" data-map="LEVY_NO" readonly /> <input type="text" class="form-control w-20" id="levyNo--${pageName}" name="levyNo" data-map="LEVY_NO" readonly />
<input type="text" class="form-control w-10" id="inspySn--${pageName}" name="inspySn" data-map="INSPY_SN" readonly /> <input type="text" class="form-control w-10" id="inspyNo--${pageName}" name="inspyNo" data-map="INSPY_NO" readonly />
</div> </div>
<!-- 수납 순번 --> <!-- 수납 순번 -->
<div class="col-md-3"> <div class="col-md-3">

Loading…
Cancel
Save