1. 계고장 발송 대상 수정.

2. 계고장 발송 현황 수정.
main
jjh 1 year ago
parent 4e8c6d762c
commit 2438648471

@ -1,7 +1,6 @@
package cokr.xit.fims.sndb; package cokr.xit.fims.sndb;
import cokr.xit.fims.cmmn.CmmnQuery; import cokr.xit.fims.cmmn.CmmnQuery;
import cokr.xit.fims.excl.ExclQuery;
/** /**
* *
@ -209,7 +208,7 @@ public class SndbQuery extends CmmnQuery {
return ifEmpty(schDetailRegDtOpt, () -> null); return ifEmpty(schDetailRegDtOpt, () -> null);
} }
public <T extends ExclQuery> T setSchDetailRegDtOpt(String schDetailRegDtOpt) { public <T extends SndbQuery> T setSchDetailRegDtOpt(String schDetailRegDtOpt) {
this.schDetailRegDtOpt = schDetailRegDtOpt; this.schDetailRegDtOpt = schDetailRegDtOpt;
return self(); return self();
} }
@ -218,7 +217,7 @@ public class SndbQuery extends CmmnQuery {
return ifEmpty(schDetailRegDtFrom, () -> null); return ifEmpty(schDetailRegDtFrom, () -> null);
} }
public <T extends ExclQuery> T setSchDetailRegDtFrom(String schDetailRegDtFrom) { public <T extends SndbQuery> T setSchDetailRegDtFrom(String schDetailRegDtFrom) {
this.schDetailRegDtFrom = schDetailRegDtFrom; this.schDetailRegDtFrom = schDetailRegDtFrom;
return self(); return self();
} }
@ -227,7 +226,7 @@ public class SndbQuery extends CmmnQuery {
return ifEmpty(schDetailRegDtTo, () -> null); return ifEmpty(schDetailRegDtTo, () -> null);
} }
public <T extends ExclQuery> T setSchDetailRegDtTo(String schDetailRegDtTo) { public <T extends SndbQuery> T setSchDetailRegDtTo(String schDetailRegDtTo) {
this.schDetailRegDtTo = schDetailRegDtTo; this.schDetailRegDtTo = schDetailRegDtTo;
return self(); return self();
} }
@ -236,7 +235,7 @@ public class SndbQuery extends CmmnQuery {
return ifEmpty(schDetailRgtrOpt, () -> null); return ifEmpty(schDetailRgtrOpt, () -> null);
} }
public <T extends ExclQuery> T setSchDetailRgtrOpt(String schDetailRgtrOpt) { public <T extends SndbQuery> T setSchDetailRgtrOpt(String schDetailRgtrOpt) {
this.schDetailRgtrOpt = schDetailRgtrOpt; this.schDetailRgtrOpt = schDetailRgtrOpt;
return self(); return self();
} }
@ -245,7 +244,7 @@ public class SndbQuery extends CmmnQuery {
return ifEmpty(schDetailRgtrNm, () -> null); return ifEmpty(schDetailRgtrNm, () -> null);
} }
public <T extends ExclQuery> T setSchDetailRgtrNm(String schDetailRgtrNm) { public <T extends SndbQuery> T setSchDetailRgtrNm(String schDetailRgtrNm) {
this.schDetailRgtrNm = schDetailRgtrNm; this.schDetailRgtrNm = schDetailRgtrNm;
return self(); return self();
} }
@ -254,7 +253,7 @@ public class SndbQuery extends CmmnQuery {
return ifEmpty(schDetailRgtrCd, () -> null); return ifEmpty(schDetailRgtrCd, () -> null);
} }
public <T extends ExclQuery> T setSchDetailRgtr(String schDetailRgtrCd) { public <T extends SndbQuery> T setSchDetailRgtr(String schDetailRgtrCd) {
this.schDetailRgtrCd = schDetailRgtrCd; this.schDetailRgtrCd = schDetailRgtrCd;
return self(); return self();
} }

@ -50,6 +50,34 @@ public interface SndngMapper extends AbstractMapper {
List<DataObject> selectAdvntceSndngTrgtList(SndbQuery req); List<DataObject> selectAdvntceSndngTrgtList(SndbQuery req);
/** , , .
* @param req
* @return
*/
List<DataObject> selectCrdnPayerTrgts(SndbQuery req);
default DataObject selectCrdnPayerTrgtInfo(String crdnId) {
List<DataObject> InfoCrdnPayerTrgt = selectCrdnPayerTrgts(new SndbQuery().setCrdnId(crdnId));
return !InfoCrdnPayerTrgt.isEmpty() ? InfoCrdnPayerTrgt.get(0) : null;
}
/** . /** .
* @param req * @param req
* @return * @return

@ -30,7 +30,7 @@ public interface SndngService {
* @param req * @param req
* @return * @return
*/ */
List<DataObject> getWrngSndngTrgtInfo(SndbQuery req); List<DataObject> getWrngSndngTrgts(SndbQuery req);
/** . /** .
* @param req * @param req

@ -65,7 +65,7 @@ public class SndngBean extends AbstractComponent {
* @param req * @param req
* @return * @return
*/ */
public List<DataObject> getWrngSndngTrgtInfo(SndbQuery req) { public List<DataObject> getWrngSndngTrgts(SndbQuery req) {
if (req.getOrderBy() == null) { if (req.getOrderBy() == null) {
req.setOrderBy("CRDN_YMD_TM"); req.setOrderBy("CRDN_YMD_TM");
} }
@ -178,7 +178,13 @@ public class SndngBean extends AbstractComponent {
SndngDtl sndngDtl = new SndngDtl(); SndngDtl sndngDtl = new SndngDtl();
// 단속, 납부자 정보 조회 // 단속, 납부자 정보 조회
DataObject infoCrdnSndngTrgt = sndngMapper.selectSndngTrgtInfo(sndng.getCrdnIDs()[iLoop]); DataObject infoCrdnPayer = sndngMapper.selectCrdnPayerTrgtInfo(sndng.getCrdnIDs()[iLoop]);
// 납부자 ID가 없다면 오류메세지
if (infoCrdnPayer.string("RTPYR_ID").equals("")) {
// 예외를 발생시켜서 오류메세지를 보내고 DB Rollback
throw new RuntimeException("발송 상세 등록 작업중 납부자 정보가 확인되지 않았습니다." + "<p>차량번호 : " + infoCrdnPayer.string("VHRNO"));
}
// 주정차 위반, 전용차로 위반 // 주정차 위반, 전용차로 위반
if (sndng.getTaskSeCd().equals("BPV") || sndng.getTaskSeCd().equals("PVS")) { if (sndng.getTaskSeCd().equals("BPV") || sndng.getTaskSeCd().equals("PVS")) {
@ -186,20 +192,20 @@ public class SndngBean extends AbstractComponent {
} else if (sndng.getTaskSeCd().equals("DPV") || sndng.getTaskSeCd().equals("ECA") || sndng.getTaskSeCd().equals("TPV")) { } else if (sndng.getTaskSeCd().equals("DPV") || sndng.getTaskSeCd().equals("ECA") || sndng.getTaskSeCd().equals("TPV")) {
// 기본 데이터 셋팅 // 기본 데이터 셋팅
sndngDtl.setSndngId(sndng.getSndngId()); // 발송 ID sndngDtl.setSndngId(sndng.getSndngId()); // 발송 ID
sndngDtl.setCrdnId(infoCrdnSndngTrgt.string("CRDN_ID")); // 단속 ID sndngDtl.setCrdnId(infoCrdnPayer.string("CRDN_ID")); // 단속 ID
sndngDtl.setLevyId(infoCrdnSndngTrgt.string("LEVY_ID")); // 부과 ID sndngDtl.setLevyId(infoCrdnPayer.string("LEVY_ID")); // 부과 ID
sndngDtl.setVltnCd(infoCrdnSndngTrgt.string("VLTN_CD")); // 위반 코드 sndngDtl.setVltnCd(infoCrdnPayer.string("VLTN_CD")); // 위반 코드
sndngDtl.setVhrno(infoCrdnSndngTrgt.string("VHRNO")); // 차량번호 sndngDtl.setVhrno(infoCrdnPayer.string("VHRNO")); // 차량번호
sndngDtl.setCrdnDt(infoCrdnSndngTrgt.string("CRDN_YMD_TM_MASK")); // 단속 일시 sndngDtl.setCrdnDt(infoCrdnPayer.string("CRDN_YMD_TM_MASK")); // 단속 일시
sndngDtl.setCrdnPlc(infoCrdnSndngTrgt.string("CRDN_PLC")); // 단속 장소 sndngDtl.setCrdnPlc(infoCrdnPayer.string("CRDN_PLC")); // 단속 장소
sndngDtl.setSndngYmd(sndng.getSndngYmd()); // 발송 일자 sndngDtl.setSndngYmd(sndng.getSndngYmd()); // 발송 일자
sndngDtl.setDudtYmd(sndng.getDudtYmd()); // 납기 일자 sndngDtl.setDudtYmd(sndng.getDudtYmd()); // 납기 일자
if (sndng.getSndngSeCd().equals("10")) { // 계고장 if (sndng.getSndngSeCd().equals("10")) { // 계고장
ffnlgAmt = infoCrdnSndngTrgt.number("FFNLG_AMT").intValue(); // 과태료 금액 ffnlgAmt = infoCrdnPayer.number("FFNLG_AMT").intValue(); // 과태료 금액
levyPcptax = infoCrdnSndngTrgt.number("FFNLG_AMT").intValue(); // 부과 본세 levyPcptax = infoCrdnPayer.number("FFNLG_AMT").intValue(); // 부과 본세
levyAdamt = 0; // 부과 가산금 levyAdamt = 0; // 부과 가산금
levySumAmt = infoCrdnSndngTrgt.number("FFNLG_AMT").intValue(); // 부과 합계 금액 levySumAmt = infoCrdnPayer.number("FFNLG_AMT").intValue(); // 부과 합계 금액
} else { } else {
ffnlgAmt = 0; // 과태료 금액 ffnlgAmt = 0; // 과태료 금액
levyPcptax = 0; // 부과 본세 levyPcptax = 0; // 부과 본세
@ -211,11 +217,11 @@ public class SndngBean extends AbstractComponent {
sndngDtl.setLevyPcptax(levyPcptax); // 부과 본세 sndngDtl.setLevyPcptax(levyPcptax); // 부과 본세
sndngDtl.setLevyAdamt(levyAdamt); // 부과 가산금 sndngDtl.setLevyAdamt(levyAdamt); // 부과 가산금
sndngDtl.setLevySumAmt(levySumAmt); // 부과 합계 금액 sndngDtl.setLevySumAmt(levySumAmt); // 부과 합계 금액
sndngDtl.setRtpyrNm(infoCrdnSndngTrgt.string("RTPYR_NM")); // 납부자 명 sndngDtl.setRtpyrNm(infoCrdnPayer.string("RTPYR_NM")); // 납부자 명
sndngDtl.setRtpyrNo(infoCrdnSndngTrgt.string("RTPYR_NO")); // 납부자 번호 sndngDtl.setRtpyrNo(infoCrdnPayer.string("RTPYR_NO")); // 납부자 번호
sndngDtl.setRtpyrAddr(infoCrdnSndngTrgt.string("ADDR")); // 납부자 주소 sndngDtl.setRtpyrAddr(infoCrdnPayer.string("ADDR")); // 납부자 주소
sndngDtl.setRtpyrDtlAddr(infoCrdnSndngTrgt.string("DTL_ADDR")); // 납부자 상세 주소 sndngDtl.setRtpyrDtlAddr(infoCrdnPayer.string("DTL_ADDR")); // 납부자 상세 주소
sndngDtl.setRtpyrZip(infoCrdnSndngTrgt.string("ZIP")); // 납부자 우편번호 sndngDtl.setRtpyrZip(infoCrdnPayer.string("ZIP")); // 납부자 우편번호
sndngDtl.setSndngDtlSttsCd("00"); // 발송 상세 상태 코드 - 00 처리전 sndngDtl.setSndngDtlSttsCd("00"); // 발송 상세 상태 코드 - 00 처리전
sndngDtl.setDelYn("N"); // 삭제 여부 sndngDtl.setDelYn("N"); // 삭제 여부
} else { } else {
@ -232,9 +238,9 @@ public class SndngBean extends AbstractComponent {
// 단속상태이력(TB_CRDN_STTS_HSTRY) // 단속상태이력(TB_CRDN_STTS_HSTRY)
CrdnSttsHstry crdnSttsHstry = new CrdnSttsHstry(); CrdnSttsHstry crdnSttsHstry = new CrdnSttsHstry();
crdnSttsHstry.setCrdnId(infoCrdnSndngTrgt.string("CRDN_ID")); crdnSttsHstry.setCrdnId(infoCrdnPayer.string("CRDN_ID"));
crdnSttsHstry.setBfrSttsCd(infoCrdnSndngTrgt.string("CRDN_STTS_CD")); crdnSttsHstry.setBfrSttsCd(infoCrdnPayer.string("CRDN_STTS_CD"));
crdnSttsHstry.setBfrSttsChgDt(infoCrdnSndngTrgt.string("CRDN_STTS_CHG_DT")); crdnSttsHstry.setBfrSttsChgDt(infoCrdnPayer.string("CRDN_STTS_CHG_DT"));
crdnSttsHstry.setCrdnSttsCd(newCrdnSttsCd); crdnSttsHstry.setCrdnSttsCd(newCrdnSttsCd);
crdnSttsHstry.setTaskDtlId(sndngDtl.getSndngDtlId()); crdnSttsHstry.setTaskDtlId(sndngDtl.getSndngDtlId());
@ -255,15 +261,15 @@ public class SndngBean extends AbstractComponent {
// 기존에 등록된 자료가 있다면 삭제 처리 // 기존에 등록된 자료가 있다면 삭제 처리
if (infoEnisMtchg != null) { if (infoEnisMtchg != null) {
enisMtchg.setCrdnId(infoCrdnSndngTrgt.string("CRDN_ID")); enisMtchg.setCrdnId(infoCrdnPayer.string("CRDN_ID"));
enisMtchgBean.removeEnisMtchg(enisMtchg); enisMtchgBean.removeEnisMtchg(enisMtchg);
} }
enisMtchg.setCrdnId(infoCrdnSndngTrgt.string("CRDN_ID")); enisMtchg.setCrdnId(infoCrdnPayer.string("CRDN_ID"));
enisMtchg.setCrdnDt(infoCrdnSndngTrgt.string("CRDN_YMD_TM_MASK")); enisMtchg.setCrdnDt(infoCrdnPayer.string("CRDN_YMD_TM_MASK"));
enisMtchg.setStdgNm(infoCrdnSndngTrgt.string("CRDN_STDG_NM")); enisMtchg.setStdgNm(infoCrdnPayer.string("CRDN_STDG_NM"));
enisMtchg.setCrdnPlc(infoCrdnSndngTrgt.string("CRDN_PLC")); enisMtchg.setCrdnPlc(infoCrdnPayer.string("CRDN_PLC"));
enisMtchg.setLevyAmt(levyPcptax); // 부과 금액 enisMtchg.setLevyAmt(levyPcptax); // 부과 금액
enisMtchg.setAdtnAmt(levyAdamt); // 가산 금액 enisMtchg.setAdtnAmt(levyAdamt); // 가산 금액
enisMtchg.setSumAmt(levySumAmt); // 합계 금액 enisMtchg.setSumAmt(levySumAmt); // 합계 금액

@ -37,8 +37,8 @@ public class SndngServiceBean extends AbstractServiceBean implements SndngServic
} }
@Override @Override
public List<DataObject> getWrngSndngTrgtInfo(SndbQuery req) { public List<DataObject> getWrngSndngTrgts(SndbQuery req) {
return sndngBean.getWrngSndngTrgtInfo(req); return sndngBean.getWrngSndngTrgts(req);
} }
@Override @Override

@ -31,7 +31,7 @@ public class Sndb01Controller extends ApplicationController {
public static final String public static final String
warningSendingTargetMain = "/010/main.do" // 계도장 발송 대상 메인 화면 warningSendingTargetMain = "/010/main.do" // 계도장 발송 대상 메인 화면
, getWrngSndngTrgtList = "/010/list.do" // 계도장 발송 대상 목록 조회 , getWrngSndngTrgtList = "/010/list.do" // 계도장 발송 대상 목록 조회
, getWrngSndngTrgtInfo = "/020/info.do" // 발송 대상 조회 , getWrngSndngTrgts = "/020/info.do" // 계도장 발송 대상 조회
, warningSendingMain = "/030/main.do" // 계도장 발송 현황 메인 화면 , warningSendingMain = "/030/main.do" // 계도장 발송 현황 메인 화면
, getWrngSndngList = "/030/list.do" // 계도장 발송 현황 목록 조회 , getWrngSndngList = "/030/list.do" // 계도장 발송 현황 목록 조회
, getSndngDltInfo = "/040/info.do" // 발송 상세 대장 조회 , getSndngDltInfo = "/040/info.do" // 발송 상세 대장 조회
@ -92,8 +92,8 @@ public class Sndb01Controller extends ApplicationController {
* "wrngSndngTrgts": [ ] * "wrngSndngTrgts": [ ]
* }</pre> * }</pre>
*/ */
public ModelAndView getWrngSndngTrgtInfo(SndbQuery req) { public ModelAndView getWrngSndngTrgts(SndbQuery req) {
List<?> wrngSndngTrgtInfo = sndngService.getWrngSndngTrgtInfo(req); List<?> wrngSndngTrgts = sndngService.getWrngSndngTrgts(req);
boolean json = jsonResponse(); boolean json = jsonResponse();
@ -102,7 +102,7 @@ public class Sndb01Controller extends ApplicationController {
return mav return mav
.addObject("pageName", "sndb01020") .addObject("pageName", "sndb01020")
.addObject("sndngSeCd", req.getSndngSeCd()) // 발송 구분 코드 .addObject("sndngSeCd", req.getSndngSeCd()) // 발송 구분 코드
.addObject("wrngSndngTrgtInfo", json ? wrngSndngTrgtInfo : toJson(wrngSndngTrgtInfo)) // 계도장 발송 대상 정보 .addObject("wrngSndngTrgts", json ? wrngSndngTrgts : toJson(wrngSndngTrgts)) // 계도장 발송 대상 정보
; ;
} }

@ -505,9 +505,9 @@ public class DpvController {
} }
@Override @Override
@RequestMapping(name="장애인과태료업무 계고장 발송 대상 등록", value=METHOD_URL.getWrngSndngTrgtInfo) @RequestMapping(name="장애인과태료업무 계고장 발송 대상 등록", value=METHOD_URL.getWrngSndngTrgts)
public ModelAndView getWrngSndngTrgtInfo(SndbQuery req) { public ModelAndView getWrngSndngTrgts(SndbQuery req) {
return super.getWrngSndngTrgtInfo(req); return super.getWrngSndngTrgts(req);
} }
@Override @Override

@ -110,9 +110,6 @@
</resultMap> </resultMap>
<sql id="selectWrngSndngTrgt"> <sql id="selectWrngSndngTrgt">
SELECT COUNT(*) OVER() AS TNOCS
, SUM(C.FFNLG_AMT) OVER() AS GRAMT
, C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 --> , C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 --> , C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.CRDN_REG_SE_CD <!-- 단속 등록 구분 코드 --> , C.CRDN_REG_SE_CD <!-- 단속 등록 구분 코드 -->
@ -122,7 +119,6 @@
, C.CRDN_YMD <!-- 단속 일자 --> , C.CRDN_YMD <!-- 단속 일자 -->
, C.CRDN_TM <!-- 단속 시각 --> , C.CRDN_TM <!-- 단속 시각 -->
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 --> , (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 -->
, FN_GET_MASK_DATETIME(C.CRDN_YMD, C.CRDN_TM, '-', ':') AS CRDN_YMD_TM_MASK <!-- 단속 일시 마스크 -->
, C.VHRNO <!-- 차량번호 --> , C.VHRNO <!-- 차량번호 -->
, C.CRDN_STDG_NM <!-- 단속 법정동 명 --> , C.CRDN_STDG_NM <!-- 단속 법정동 명 -->
, C.CRDN_ROAD_NM <!-- 단속 도로 명 --> , C.CRDN_ROAD_NM <!-- 단속 도로 명 -->
@ -185,6 +181,7 @@
<select id="selectWrngSndngTrgtList" parameterType="map" resultType="dataobject">/* 계고장 발송 대상 목록 조회(sndngMapper.selectWrngSndngTrgtList) */ <select id="selectWrngSndngTrgtList" parameterType="map" resultType="dataobject">/* 계고장 발송 대상 목록 조회(sndngMapper.selectWrngSndngTrgtList) */
<include refid="utility.paging-prefix" /> <include refid="utility.paging-prefix" />
SELECT C.CRDN_ID <!-- 단속 ID -->
<include refid="selectWrngSndngTrgt" /> <include refid="selectWrngSndngTrgt" />
WHERE C.SGG_CD = #{sggCd} <!-- 시군구 코드 --> WHERE C.SGG_CD = #{sggCd} <!-- 시군구 코드 -->
AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 --> AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 -->
@ -322,6 +319,9 @@
</select> </select>
<select id="selectWrngSndngTrgts" parameterType="map" resultType="dataobject">/* 계고장 발송 대상 객체 가져오기(sndngMapper.selectWrngSndngTrgts) */ <select id="selectWrngSndngTrgts" parameterType="map" resultType="dataobject">/* 계고장 발송 대상 객체 가져오기(sndngMapper.selectWrngSndngTrgts) */
SELECT COUNT(*) OVER() AS TNOCS <!-- 총건수 -->
, SUM(C.FFNLG_AMT) OVER() AS GRAMT <!-- 총금액 -->
, C.CRDN_ID <!-- 단속 ID -->
<include refid="selectWrngSndngTrgt" /> <include refid="selectWrngSndngTrgt" />
<where> <where>
<if test="crdnIDs != null"> <if test="crdnIDs != null">
@ -344,9 +344,7 @@
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
</select> </select>
<select id="selectAdvntceSndngTrgtList" parameterType="map" resultType="dataobject">/* 사전통지 발송 대상 목록 조회(sndngMapper.selectAdvntceSndngTrgtList) */ <sql id="selectAdvntceSndngTrgt">
<include refid="utility.paging-prefix" />
SELECT C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 --> , C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 --> , C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.CRDN_INPT_SE_CD <!-- 단속 입력 구분 코드 --> , C.CRDN_INPT_SE_CD <!-- 단속 입력 구분 코드 -->
@ -396,9 +394,16 @@
INNER JOIN TB_VLTN_INFO VI ON (C.VLTN_ID = VI.VLTN_ID) INNER JOIN TB_VLTN_INFO VI ON (C.VLTN_ID = VI.VLTN_ID)
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_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_PAYER P ON (C.RTPYR_ID = P.RTPYR_ID) LEFT OUTER JOIN TB_PAYER P ON (C.RTPYR_ID = P.RTPYR_ID)
</sql>
<select id="selectAdvntceSndngTrgtList" parameterType="map" resultType="dataobject">/* 사전통지 발송 대상 목록 조회(sndngMapper.selectAdvntceSndngTrgtList) */
<include refid="utility.paging-prefix" />
SELECT C.CRDN_ID <!-- 단속 ID -->
<include refid="selectAdvntceSndngTrgt" />
WHERE C.SGG_CD = #{sggCd} <!-- 시군구 코드 --> WHERE C.SGG_CD = #{sggCd} <!-- 시군구 코드 -->
AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 --> AND C.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 -->
AND C.CRDN_STTS_CD = #{crdnSttsCd} <!-- 단속 상태 코드 --> AND C.CRDN_STTS_CD = #{crdnSttsCd} <!-- 단속 상태 코드 -->
AND (CC.CVLCPT_PRCS_CD <![CDATA[ <> ]]> '00' OR CC.CVLCPT_PRCS_CD IS NULL) <!-- 민원 처리 코드 -->
<if test="schCrdnYmdFrom != null"> <if test="schCrdnYmdFrom != null">
AND C.CRDN_YMD <![CDATA[ >= ]]> #{schCrdnYmdFrom} <!-- 단속 일자 시작 --> AND C.CRDN_YMD <![CDATA[ >= ]]> #{schCrdnYmdFrom} <!-- 단속 일자 시작 -->
</if> </if>
@ -517,6 +522,167 @@
<include refid="utility.paging-suffix" /> <include refid="utility.paging-suffix" />
</select> </select>
<select id="selectAdvntceSndngTrgts" parameterType="map" resultType="dataobject">/* 계고장 발송 대상 객체 가져오기(sndngMapper.selectWrngSndngTrgts) */
SELECT COUNT(*) OVER() AS TNOCS <!-- 총건수 -->
, SUM(C.ADVNTCE_AMT) OVER() AS GRAMT <!-- 총금액 -->
, C.CRDN_ID <!-- 단속 ID -->
<include refid="selectAdvntceSndngTrgt" />
<where>
<if test="crdnIDs != null">
AND C.CRDN_ID IN (
<foreach collection="crdnIDs" item="crdnId" separator=","> #{crdnId} </foreach>
)
</if>
<if test="crdnId != null">
AND C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
</if>
<choose>
<when test="crdnDelYn != null">
AND C.DEL_YN = #{crdnDelYn} <!-- 삭제 여부 -->
</when>
<otherwise>
AND C.DEL_YN = 'N' <!-- 삭제 여부 -->
</otherwise>
</choose>
</where>
<include refid="utility.orderBy" />
</select>
<sql id="selectCrdnPayerTrgt">
SELECT C.CRDN_ID <!-- 단속 ID -->
, C.SGG_CD <!-- 시군구 코드 -->
, C.TASK_SE_CD <!-- 업무 구분 코드 -->
, C.CRDN_INPT_SE_CD <!-- 단속 입력 구분 코드 -->
, (SELECT FN_GET_CODE_NM('FIM003', C.CRDN_INPT_SE_CD) FROM DUAL) AS CRDN_INPT_SE_NM <!-- 단속 입력 구분 명 -->
, C.CRDN_YMD <!-- 단속 일자 -->
, C.CRDN_TM <!-- 단속 시각 -->
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM <!-- 단속 일시 -->
, FN_GET_MASK_DATETIME(C.CRDN_YMD, C.CRDN_TM, '-', ':') AS CRDN_YMD_TM_MASK <!-- 단속 일시 마스크 -->
, C.VHRNO <!-- 차량번호 -->
, C.CRDN_STDG_NM <!-- 단속 법정동 명 -->
, C.CRDN_ROAD_NM <!-- 단속 도로 명 -->
, C.CRDN_PLC <!-- 단속 장소 -->
, C.FFNLG_AMT <!-- 과태료 금액 -->
, C.ADVNTCE_AMT <!-- 사전통지 금액 -->
, C.CRDN_STTS_CD <!-- 단속 상태 코드 -->
, (SELECT FN_GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM <!-- 단속 상태 명 -->
, C.CRDN_STTS_CHG_DT <!-- 단속 상태 변경 일시 -->
, C.REG_DT <!-- 등록 일시 -->
, C.RGTR <!-- 등록자 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = C.RGTR) AS RGTR_NM <!-- 등록자 명 -->
, C.MDFCN_DT <!-- 수정 일시 -->
, C.MDFR <!-- 수정자 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = C.MDFR) AS MDFR_NM <!-- 수정자 명 -->
, CA.CRDN_SE_CD <!-- 단속 구분 코드 -->
, (SELECT FN_GET_CODE_NM('FIM002', CA.CRDN_SE_CD) FROM DUAL) AS CRDN_SE_NM <!-- 단속 구분 명 -->
, CA.CRDN_SPAREA_CD <!-- 단속 특별구역 코드 -->
, (SELECT FN_GET_CODE_NM('FIM007', CA.CRDN_SPAREA_CD) FROM DUAL) AS CRDN_SPAREA_NM <!-- 단속 특별구역 명 -->
, CA.PARKNG_PSBLTY_RSLT_CD <!-- 주차 가능 결과 코드 -->
, (SELECT FN_GET_CODE_NM('FIM034', CA.PARKNG_PSBLTY_RSLT_CD) FROM DUAL) AS PARKNG_PSBLTY_RSLT_NM<!-- 주차 가능 결과 명 -->
, VI.VLTN_ID <!-- 위반 ID -->
, VI.VLTN_CD <!-- 위반 코드 -->
, VI.VLTN_ARTCL <!-- 위반 항목 -->
, CC.CVLCPT_LINK_ID <!-- 민원 연계 ID -->
, CC.CVLCPT_RCPT_YMD <!-- 민원 접수 일자 -->
, CC.CVLCPT_APLY_NO <!-- 민원 신청 번호 -->
, CC.CVLCPT_RCPT_NO <!-- 민원 접수 번호 -->
, CC.CVLCPT_PRCS_SUMRY <!-- 민원 처리 요약 -->
, CC.CVLCPT_PRCS_CD <!-- 민원 처리 코드 -->
, CC.CVLCPT_PRCS_CMPTN_DT <!-- 민원 처리 완료 일시 -->
, CC.CVLCPT_TRSM_CD <!-- 민원 전송 코드 -->
, CC.CVLCPT_TRSM_DT <!-- 민원 전송 일시 -->
, P.RTPYR_ID <!-- 납부자 ID -->
, P.RTPYR_NO <!-- 납부자 번호 -->
, P.RTPYR_NM <!-- 납부자 명 -->
, P.RTPYR_BRDT <!-- 납부자 생년월일 -->
, P.ZIP <!-- 우편번호 -->
, L.INST_CD <!-- 기관 코드 -->
, L.DEPT_CD <!-- 부서 코드 -->
, L.FYR <!-- 회계연도 -->
, L.ACNTG_SE <!-- 회계 구분 -->
, L.TXITM_CD <!-- 세목 코드 -->
, L.TXITM_NM <!-- 세목 명 -->
, L.LEVY_NO <!-- 부과 번호 -->
, L.INSPY_SN <!-- 분납 순번 -->
, L.LEVY_YMD <!-- 부과 일자 -->
, L.DUDT_YMD <!-- 납기 일자 -->
, L.FFNLG_AMT <!-- 과태료 금액 -->
, L.LEVY_PCPTAX <!-- 부과 본세 -->
, L.LEVY_ADAMT <!-- 부과 가산금 -->
, L.INSPY_INT <!-- 분납 이자 -->
, L.RCVMT_PCPTAX <!-- 수납 본세 -->
, L.RCVMT_ADAMT <!-- 수납 가산금 -->
, L.RDCAMT_PCPTAX <!-- 감액 본세 -->
, L.RDCAMT_ADAMT <!-- 감액 가산금 -->
, L.SUM_AMT <!-- 합계 금액 -->
, L.TXTN_THING <!-- 과세 물건 -->
, L.MNG_ARTCL1 <!-- 관리 항목1 -->
, L.MNG_ARTCL2 <!-- 관리 항목2 -->
, L.MNG_ARTCL3 <!-- 관리 항목3 -->
, L.MNG_ARTCL4 <!-- 관리 항목4 -->
, L.MNG_ARTCL5 <!-- 관리 항목5 -->
, L.MNG_ARTCL6 <!-- 관리 항목6 -->
, L.EPAYNO <!-- 전자납부번호 -->
, L.BANK_NM <!-- 은행 명 -->
, L.VR_ACTNO <!-- 가상 계좌번호 -->
, L.BANK_NM2 <!-- 은행 명2 -->
, L.VR_ACTNO2 <!-- 가상 계좌번호2 -->
, L.BANK_NM3 <!-- 은행 명3 -->
, L.VR_ACTNO3 <!-- 가상 계좌번호3 -->
, L.BANK_NM4 <!-- 은행 명4 -->
, L.VR_ACTNO4 <!-- 가상 계좌번호4 -->
, L.BANK_NM5 <!-- 은행 명5 -->
, L.VR_ACTNO5 <!-- 가상 계좌번호5 -->
, L.BANK_NM6 <!-- 은행 명6 -->
, L.VR_ACTNO6 <!-- 가상 계좌번호6 -->
, L.BANK_NM7 <!-- 은행 명7 -->
, L.VR_ACTNO7 <!-- 가상 계좌번호7 -->
, L.BANK_NM8 <!-- 은행 명8 -->
, L.VR_ACTNO8 <!-- 가상 계좌번호8 -->
, L.BANK_NM9 <!-- 은행 명9 -->
, L.VR_ACTNO9 <!-- 가상 계좌번호9 -->
, L.BANK_NM10 <!-- 은행 명10 -->
, L.VR_ACTNO10 <!-- 가상 계좌번호10 -->
, L.BANK_NM11 <!-- 은행 명11 -->
, L.VR_ACTNO11 <!-- 가상 계좌번호11 -->
FROM TB_CRDN C
INNER JOIN TB_CRDN_ADI CA ON (C.CRDN_ID = CA.CRDN_ID)
INNER JOIN TB_VLTN_INFO VI ON (C.VLTN_ID = VI.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')
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')
</sql>
<select id="selectCrdnPayerTrgts" parameterType="map" resultType="dataobject">/* 단속, 납부자, 부과 대장 객체 가져오기(sndngMapper.selectCrdnPayerTrgts) */
<include refid="selectCrdnPayerTrgt" />
<where>
<if test="crdnIDs != null">
AND C.CRDN_ID IN ( <!-- 단속 IDs -->
<foreach collection="crdnIDs" item="crdnId" separator=","> #{crdnId} </foreach>
)
</if>
<if test="crdnId != null">
AND C.CRDN_ID = #{crdnId} <!-- 단속 ID -->
</if>
<choose>
<when test="crdnDelYn != null">
AND C.DEL_YN = #{crdnDelYn} <!-- 삭제 여부 -->
</when>
<otherwise>
AND C.DEL_YN = 'N' <!-- 삭제 여부 -->
</otherwise>
</choose>
</where>
<include refid="utility.orderBy" />
</select>
<sql id="selectSndng"> <sql id="selectSndng">
@ -645,7 +811,7 @@
<foreach collection="sndngIDs" item="sndngId" separator=","> #{sndngId} </foreach> <foreach collection="sndngIDs" item="sndngId" separator=","> #{sndngId} </foreach>
) )
</if> </if>
<if test="crdnId != null"> <if test="sndngId != null">
AND S.SNDNG_ID = #{sndngId} <!-- 발송 ID --> AND S.SNDNG_ID = #{sndngId} <!-- 발송 ID -->
</if> </if>
<choose> <choose>

@ -166,10 +166,10 @@
* DatasetControl * DatasetControl
**************************************************************************/ **************************************************************************/
var ${pageName}Control = new DatasetControl({ var ${pageName}Control = new DatasetControl({
prefix : "wrngSndngTrgtInfo" prefix : "wrngSndngTrgt"
, prefixName : "계고장 발송 대상" , prefixName : "계고장 발송 대상"
, keymapper : info => info ? info.CRDN_ID : "" , keymapper : info => info ? info.CRDN_ID : ""
, dataGetter : obj => obj.wrngSndngTrgtInfoList , dataGetter : obj => obj.wrngSndngTrgtsList
, appendData : true , appendData : true
, tableRenderComplete : false // dataTables 에 자료 추가 완료 여부 , tableRenderComplete : false // dataTables 에 자료 추가 완료 여부
, urls : { , urls : {
@ -341,7 +341,7 @@
if (!customValidate($("#frmEdit--${pageName}").find("input, select, textarea"))) return; if (!customValidate($("#frmEdit--${pageName}").find("input, select, textarea"))) return;
dialog.alert({ dialog.alert({
content : "현재 " + ${pageName}Control.prefixName + " 정보를 저장하시겠습니까?" content : ${pageName}Control.prefixName + " 정보를 저장하시겠습니까?"
, onOK : () => { , onOK : () => {
${pageName}Control.save(${pageName}Fields.get()); ${pageName}Control.save(${pageName}Fields.get());
} }
@ -362,7 +362,7 @@
fn_securityModeToggle($("#securityMode--top").is(":checked")); fn_securityModeToggle($("#securityMode--top").is(":checked"));
// Dataset 셋팅 - 화면이 열리면서 조회하는 경우 addData 하여 자료를 추가 // Dataset 셋팅 - 화면이 열리면서 조회하는 경우 addData 하여 자료를 추가
${pageName}Control.addData(${wrngSndngTrgtInfo}); ${pageName}Control.addData(${wrngSndngTrgts});
$("#sndngSeCd--${pageName}").val("${sndngSeCd}"); // 발송 구분 코드 $("#sndngSeCd--${pageName}").val("${sndngSeCd}"); // 발송 구분 코드
$("#sggCd--${pageName}").val(${pageName}Control.dataset.getValue("SGG_CD")); // 시군구 코드 $("#sggCd--${pageName}").val(${pageName}Control.dataset.getValue("SGG_CD")); // 시군구 코드

Loading…
Cancel
Save