1. 공시송달 현황 수정.

2. 공시송달 상세 추가.
main
jjh 1 year ago
parent 4761765b12
commit b2b12d070f

@ -38,6 +38,8 @@ public class SndbQuery extends CmmnQuery {
private String schSndngYmdTo; // 발송(TB_SNDNG)_발송 일자 종료 private String schSndngYmdTo; // 발송(TB_SNDNG)_발송 일자 종료
private String schDlvrYmdFrom; // 발송상세(TB_SNDNG_DTL)_배달 일자 시작 private String schDlvrYmdFrom; // 발송상세(TB_SNDNG_DTL)_배달 일자 시작
private String schDlvrYmdTo; // 발송상세(TB_SNDNG_DTL)_배달 일자 종료 private String schDlvrYmdTo; // 발송상세(TB_SNDNG_DTL)_배달 일자 종료
private String schSvbtcYmdFrom; // 공시송달(TB_SVBTC)_공시송달 일자 시작
private String schSvbtcYmdTo; // 공시송달(TB_SVBTC)_공시송달 일자 종료
private String schSndngSeCd; // 발송, 발송상세(TB_SNDNG_DTL)_발송 구분 코드 private String schSndngSeCd; // 발송, 발송상세(TB_SNDNG_DTL)_발송 구분 코드
// 상세 검색 조건 // 상세 검색 조건
private String schDetailRegDtOpt; // 상세 검색 등록 일자 구분 private String schDetailRegDtOpt; // 상세 검색 등록 일자 구분
@ -267,6 +269,26 @@ public class SndbQuery extends CmmnQuery {
return self(); return self();
} }
public String getSchSvbtcYmdFrom() {
return ifEmpty(schSvbtcYmdFrom, () -> null);
}
public <T extends SndbQuery> T setSchSvbtcYmdFrom(String schSvbtcYmdFrom) {
this.schSvbtcYmdFrom = schSvbtcYmdFrom;
return self();
}
public String getSchSvbtcYmdTo() {
return ifEmpty(schSvbtcYmdTo, () -> null);
}
public <T extends SndbQuery> T setSchSvbtcYmdTo(String schSvbtcYmdTo) {
this.schSvbtcYmdTo = schSvbtcYmdTo;
return self();
}
public String getSchSndngSeCd() { public String getSchSndngSeCd() {
return ifEmpty(schSndngSeCd, () -> null); return ifEmpty(schSndngSeCd, () -> null);
} }

@ -35,6 +35,14 @@ public interface SvbtcMapper extends AbstractMapper {
*/ */
List<DataObject> selectSvbtcs(SndbQuery req); List<DataObject> selectSvbtcs(SndbQuery req);
/** .
* @param req
* @return
*/
List<DataObject> selectSvbtcDtls(SndbQuery req);
/** . /** .
* @param params * @param params
* <ul><li>"svbtc" - </li> * <ul><li>"svbtc" - </li>

@ -50,9 +50,23 @@ public interface SndngService {
*/ */
List<DataObject> getSndbkList(SndbQuery req); List<DataObject> getSndbkList(SndbQuery req);
/** .
* @param req
* @return
*/
List<DataObject> getSvbtcList(SndbQuery req);
/** .
* @param req
* @return
*/
List<DataObject> getSvbtcs(SndbQuery req);
/** .
* @param req
* @return
*/
List<DataObject> getSvbtcDtls(SndbQuery req);
/** . /** .
* @param req * @param req
@ -190,17 +204,6 @@ public interface SndngService {
*/ */
boolean removeSndngDtl(SndngDtl sndngDtl); boolean removeSndngDtl(SndngDtl sndngDtl);
/** .
* @param req
* @return
*/
List<DataObject> getSvbtcList(SndbQuery req);
/** .
* @param req
* @return
*/
List<DataObject> getSvbtcs(SndbQuery req);
/** . /** .
* @param svbtc * @param svbtc

@ -1133,6 +1133,16 @@ public class SndngBean extends AbstractComponent {
return svbtcMapper.selectSvbtcs(req); return svbtcMapper.selectSvbtcs(req);
} }
/** .
* @param req
* @return
*/
public List<DataObject> getSvbtcDtls(SndbQuery req) {
return svbtcMapper.selectSvbtcDtls(req);
}
/** . /** .
* @param svbtc * @param svbtc
* @return * @return

@ -153,6 +153,11 @@ public class SndngServiceBean extends AbstractServiceBean implements SndngServic
return sndngBean.getSvbtcs(req); return sndngBean.getSvbtcs(req);
} }
@Override
public List<DataObject> getSvbtcDtls(SndbQuery req) {
return sndngBean.getSvbtcDtls(req);
}
@Override @Override
public boolean createSvbtc(Svbtc svbtc) { public boolean createSvbtc(Svbtc svbtc) {
return sndngBean.createSvbtc(svbtc); return sndngBean.createSvbtc(svbtc);

@ -65,7 +65,8 @@ public class Sndb01Controller extends ApplicationController {
, sendBackMain = "/230/main.do" // 반송 현황 메인 화면 , sendBackMain = "/230/main.do" // 반송 현황 메인 화면
, getSendBackList = "/230/list.do" // 반송 현황 목록 조회 , getSendBackList = "/230/list.do" // 반송 현황 목록 조회
, serviceByPublicNoticeMain = "/240/main.do" // 공시송달 현황 메인 화면 , serviceByPublicNoticeMain = "/240/main.do" // 공시송달 현황 메인 화면
, getServiceByPublicNoticeList = "/240/list.do" // 공시송달 현황 목록 조회
, getServiceByPublicNoticeInfo = "/250/info.do" // 공시송달 상세 조회
; ;
} }
@ -625,13 +626,53 @@ public class Sndb01Controller extends ApplicationController {
ManagedUser managedUser = (ManagedUser)currentUser().getUser(); ManagedUser managedUser = (ManagedUser)currentUser().getUser();
// View(jsp)에서 사용할 공통코드를 조회 // View(jsp)에서 사용할 공통코드를 조회
Map<String, List<CommonCode>> commonCodes = getCodesOf("FIM054"); Map<String, List<CommonCode>> commonCodes = getCodesOf("FIM047", "FIM054");
return mav.addObject("pageName", "sndb01240") // View(jsp)에서 사용할 id 뒤에 붙일 suffix return mav.addObject("pageName", "sndb01240") // View(jsp)에서 사용할 id 뒤에 붙일 suffix
.addObject("infoPrefix", "svbtc") // prefix .addObject("infoPrefix", "svbtc") // prefix
.addObject("sggCd", managedUser.getOrgID()) // 시군구 코드(SGG_CD) .addObject("sggCd", managedUser.getOrgID()) // 시군구 코드(SGG_CD)
.addObject("FIM054List", commonCodes.get("FIM054")) // 업무 구분 코드(TASK_SE_CD) .addObject("FIM054List", commonCodes.get("FIM054")) // 업무 구분 코드(TASK_SE_CD)
.addObject("FIM047List", commonCodes.get("FIM047")) // 발송 구분 코드(SNDNG_SE_CD)
; ;
} }
/** .<br />
* {@link SndngService#getSndngList(SndngQuery)}
* @param req
* @return jsonView
* <pre><code> {
* "sndngList": [ ]
* "sndngStart":
* "sndngFetch":
* "sndngTotal":
* }</code></pre>
*/
public ModelAndView getServiceByPublicNoticeList(SndbQuery req) {
List<?> result = sndngService.getSvbtcList(setFetchSize(req));
return setCollectionInfo(new ModelAndView("jsonView"), result, "svbtc");
}
/** - (sndb/sndb01/250-info) .
* @param svbtcId ID
* @return fims/sndb/sndb01250-info jsonView
* <pre>{
* "sndngDtls": [ ]
* }</pre>
*/
public ModelAndView getServiceByPublicNoticeInfo(SndbQuery req) {
List<?> sndngDtls = sndngService.getSvbtcDtls(req);
boolean json = jsonResponse();
ModelAndView mav = new ModelAndView(json ? "jsonView" : "fims/sndb/sndb01250-info");
return mav.addObject("pageName", "sndb01250")
.addObject("sggCd", req.getSggCd())
.addObject("taskSeCd", req.getTaskSeCd())
.addObject("svbtcDtl", json ? sndngDtls : toJson(sndngDtls)) // 계도장 발송 현황 세부내용
;
}
} }

@ -580,9 +580,19 @@ public class DpvController {
return super.getSendBackList(req); return super.getSendBackList(req);
} }
/** . @Override
* @return fims/sndb/sndb01110-main @RequestMapping(name="공시송달 목록 조회", value=METHOD_URL.getServiceByPublicNoticeList)
*/ public ModelAndView getServiceByPublicNoticeList(SndbQuery req) {
return super.getServiceByPublicNoticeList(req);
}
@Override
@RequestMapping(name="공시송달 상세 조회", value=METHOD_URL.getServiceByPublicNoticeInfo)
public ModelAndView getServiceByPublicNoticeInfo(SndbQuery req) {
return super.getServiceByPublicNoticeInfo(req);
}
@Override @Override
@RequestMapping(name = "고지서 발송 대상", value = METHOD_URL.noticeSheetSendingTargetMain) @RequestMapping(name = "고지서 발송 대상", value = METHOD_URL.noticeSheetSendingTargetMain)
public ModelAndView noticeSheetSendingTargetMain() { public ModelAndView noticeSheetSendingTargetMain() {

@ -30,45 +30,54 @@
</resultMap> </resultMap>
<sql id="select"> <sql id="select">
SELECT SV.SVBTC_ID /* 공시송달 ID */ SELECT SV.SVBTC_ID <!-- 공시송달 ID -->
, SV.SGG_CD /* 시군구 코드 */ , SV.SGG_CD <!-- 시군구 코드 -->
, SV.TASK_SE_CD /* 업무 구분 코드 */ , SV.TASK_SE_CD <!-- 업무 구분 코드 -->
, (SELECT GET_CODE_NM('FIM054', SV.TASK_SE_CD) FROM DUAL) AS TASK_SE_NM /* 업무 구분 명 */ , (SELECT GET_CODE_NM('FIM054', SV.TASK_SE_CD) FROM DUAL) AS TASK_SE_NM <!-- 업무 구분 명 -->
, SV.VLTN_ID /* 위반 ID */ , SV.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, SV.SNDNG_SE_CD /* 발송 구분 코드 */ , (SELECT GET_CODE_NM('FIM047', SV.SNDNG_SE_CD) FROM DUAL) AS SNDNG_SE_NM <!-- 발송 구분 명 -->
, (SELECT GET_CODE_NM('FIM047', SV.SNDNG_SE_CD) FROM DUAL) AS SNDNG_SE_NM /* 발송 구분 명 */ , SV.SVBTC_YMD <!-- 공시송달 일자 -->
, SV.SVBTC_YMD /* 공시송달 일자 */ , SV.TTL_NM <!-- 제목 명 -->
, SV.TTL_NM /* 제목 명 */ , SV.DOC_NO <!-- 문서 번호 -->
, SV.DOC_NO /* 문서 번호 */ , SV.ETC_CN <!-- 기타 내용 -->
, SV.ETC_CN /* 기타 내용 */ , SV.TNOCS <!-- 총건수 -->
, SV.TNOCS /* 총건수 */ , SV.GRAMT <!-- 총금액 -->
, SV.GRAMT /* 총금액 */ , SV.DEL_YN <!-- 삭제 여부 -->
, SV.DEL_YN /* 삭제 여부 */ , SV.REG_DT <!-- 등록 일시 -->
, SV.REG_DT /* 등록 일시 */ , SV.RGTR <!-- 등록자 -->
, SV.RGTR /* 등록자 */ , (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.RGTR) AS RGTR_NM <!-- 등록자 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.RGTR) AS RGTR_NM /* 등록자 명 */ , SV.MDFCN_DT <!-- 수정 일시 -->
, SV.MDFCN_DT /* 수정 일시 */ , SV.MDFR <!-- 수정자 -->
, SV.MDFR /* 수정자 */ , (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.MDFR) AS MDFR_NM <!-- 등록자 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.RGTR) AS RGTR_NM /* 등록자 명 */ , SV.DEL_DT <!-- 삭제 일시 -->
, SV.DEL_DT /* 삭제 일시 */ , SV.DLTR <!-- 삭제자 -->
, SV.DLTR /* 삭제자 */ , (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.DLTR) AS DLTR_NM <!-- 등록자 명 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.RGTR) AS RGTR_NM /* 등록자 명 */ , SV.DEL_RSN <!-- 삭제 사유 -->
, SV.DEL_RSN /* 삭제 사유 */ , VI.VLTN_ID <!-- 위반 ID -->
, SD.SNDNG_DTL_ID /* 발송 상세 ID */ , VI.VLTN_CD <!-- 위반 코드 -->
, SD.SNDNG_ID /* 발송 ID */ , VI.VLTN_ARTCL <!-- 위반 항목 -->
, SD.CRDN_ID /* 단속 ID */
FROM TB_SVBTC SV FROM TB_SVBTC SV
INNER JOIN TB_SNDNG_DTL SD ON (SV.SVBTC_ID = SD.SVBTC_ID) LEFT OUTER JOIN TB_VLTN_INFO VI ON (SV.VLTN_ID = VI.VLTN_ID AND SV.SGG_CD = VI.SGG_CD AND SV.TASK_SE_CD = VI.TASK_SE_CD)
</sql> </sql>
<select id="selectSvbtcList" parameterType="map" resultType="dataobject">/* 공시송달 대장 목록 조회(svbtcMapper.selectSvbtcList) */ <select id="selectSvbtcList" parameterType="map" resultType="dataobject">/* 공시송달 대장 목록 조회(svbtcMapper.selectSvbtcList) */
<include refid="utility.paging-prefix" /> <include refid="utility.paging-prefix" />
<include refid="select" /> <include refid="select" />
WHERE SV.SGG_CD = #{sggCd} /* 시군구 코드 */ WHERE SV.SGG_CD = #{sggCd} <!-- 시군구 코드 -->
AND SV.TASK_SE_CD = #{taskSeCd} /* 업무 구분 코드 */ AND SV.TASK_SE_CD = #{taskSeCd} <!-- 업무 구분 코드 -->
<if test="delYn != null"> <if test="schSvbtcYmdFrom != null">
AND SV.DEL_YN = #{delYn} /* 삭제 여부 */ AND SV.SVBTC_YMD <![CDATA[ >= ]]> #{schSvbtcYmdFrom} <!-- 발송 일자 시작 -->
</if>
<if test="schSvbtcYmdTo != null">
AND SV.SVBTC_YMD <![CDATA[ <= ]]> #{schSvbtcYmdTo} <!-- 발송 일자 종료 -->
</if>
<if test="schSndngSeCd != null">
AND SV.SNDNG_SE_CD = #{schSndngSeCd} <!-- 발송 구분 코드 -->
</if> </if>
<if test="schVltnCd != null">
AND SV.VLTN_CD = #{schVltnCd} <!-- 위반 코드 -->
</if>
AND SV.DEL_YN = 'N' <!-- 삭제 여부 -->
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
<include refid="utility.paging-suffix" /> <include refid="utility.paging-suffix" />
</select> </select>
@ -77,19 +86,94 @@
<include refid="select" /> <include refid="select" />
<where> <where>
<if test="svbtcId != null"> <if test="svbtcId != null">
AND SV.SVBTC_ID = #{svbtcId} /* 공시송달 ID */ AND SV.SVBTC_ID = #{svbtcId} <!-- 공시송달 ID -->
</if> </if>
<if test="sndngDtlId != null"> <if test="sndngDtlId != null">
AND SD.SNDNG_DTL_ID = #{sndngDtlId} /* 발송 상세 ID */ AND SD.SNDNG_DTL_ID = #{sndngDtlId} <!-- 발송 상세 ID -->
</if> </if>
<if test="sndngId != null"> <if test="sndngId != null">
AND SD.SNDNG_ID = #{sndngId} /* 발송 ID */ AND SD.SNDNG_ID = #{sndngId} <!-- 발송 ID -->
</if> </if>
<if test="crdnId != null"> <if test="crdnId != null">
AND SD.CRDN_ID = #{crdnId} /* 단속 ID */ AND SD.CRDN_ID = #{crdnId} <!-- 단속 ID -->
</if> </if>
<if test="delYn != null"> <if test="delYn != null">
AND SV.DEL_YN = #{delYn} /* 삭제 여부 */ AND SV.DEL_YN = #{delYn} <!-- 삭제 여부 -->
</if>
</where>
<include refid="utility.orderBy" />
</select>
<sql id="selectDtl">
SELECT SV.SVBTC_ID <!-- 공시송달 ID -->
, SV.SGG_CD <!-- 시군구 코드 -->
, SV.TASK_SE_CD <!-- 업무 구분 코드 -->
, (SELECT GET_CODE_NM('FIM054', SV.TASK_SE_CD) FROM DUAL) AS TASK_SE_NM <!-- 업무 구분 명 -->
, SV.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, (SELECT GET_CODE_NM('FIM047', SV.SNDNG_SE_CD) FROM DUAL) AS SNDNG_SE_NM <!-- 발송 구분 명 -->
, SV.SVBTC_YMD <!-- 공시송달 일자 -->
, SV.TTL_NM <!-- 제목 명 -->
, SV.DOC_NO <!-- 문서 번호 -->
, SV.ETC_CN <!-- 기타 내용 -->
, SV.TNOCS <!-- 총건수 -->
, SV.GRAMT <!-- 총금액 -->
, SV.DEL_YN <!-- 삭제 여부 -->
, SV.REG_DT <!-- 등록 일시 -->
, SV.RGTR <!-- 등록자 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.RGTR) AS RGTR_NM <!-- 등록자 명 -->
, SV.MDFCN_DT <!-- 수정 일시 -->
, SV.MDFR <!-- 수정자 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.MDFR) AS MDFR_NM <!-- 등록자 명 -->
, SV.DEL_DT <!-- 삭제 일시 -->
, SV.DLTR <!-- 삭제자 -->
, (SELECT USER_NM FROM TB_USER X WHERE X.USER_ID = SV.DLTR) AS DLTR_NM <!-- 등록자 명 -->
, SV.DEL_RSN <!-- 삭제 사유 -->
, SD.SNDNG_DTL_ID <!-- 발송 상세 ID -->
, SD.SNDNG_ID <!-- 발송 ID -->
, SD.CRDN_ID <!-- 단속 ID -->
, SD.LEVY_ID <!-- 부과 ID -->
, SD.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, (SELECT GET_CODE_NM('FIM047', SD.SNDNG_SE_CD) FROM DUAL) AS SNDNG_SE_NM <!-- 발송 구분 명 -->
, SD.LEV_KEY <!-- 세외수입 부과키 -->
, CONCAT(SD.FYR, '-', SD.LEVY_NO) AS GOJI_NO <!-- 고지 번호 -->
, SD.SNDNG_YMD <!-- 발송 일자 -->
, SD.DUDT_YMD <!-- 납기 일자 -->
, GET_MASK_DATE(SD.DUDT_YMD, 'K') AS DUDT_YMD_MASK_KOR <!-- 납기 일자(한글표기) -->
, GET_MASK_DATE(SD.DUDT_YMD, '.') AS DUDT_YMD_MASK <!-- 납기 일자 -->
, SD.DUDT_AFTR_YMD <!-- 납기 후 일자 -->
, GET_MASK_DATE(SD.DUDT_AFTR_YMD, '.') AS DUDT_AFTR_YMD_MASK <!-- 납기 후 일자 -->
, SD.FFNLG_AMT <!-- 과태료 금액 -->
, SD.RTPYR_NM <!-- 납부자 명 -->
, SD.RTPYR_NO <!-- 납부자 번호 -->
, SD.RTPYR_ADDR <!-- 납부자 주소 -->
, SD.RTPYR_DTL_ADDR <!-- 납부자 상세 주소 -->
, SD.RTPYR_ZIP <!-- 납부자 우편번호 -->
, SD.CON_KEY <!-- 외부연계식별키 -->
, SD.RG_NO <!-- 등기 번호 -->
, SD.DLVR_YMD <!-- 배달 일자 -->
, SD.DLVR_TM <!-- 배달 시각 -->
, GET_CODE('EGP010', SD.UNDLVR_RSN_NM) AS UNDLVR_RSN_CD <!-- 미배달 사유 코드 -->
, SD.UNDLVR_RSN_NM <!-- 미배달 사유 명 -->
, SD.RCPN_NM <!-- 수령인 명 -->
, SD.RCPN_REL_NM <!-- 수령인 관계 명 -->
, SD.SNDNG_DTL_STTS_CD <!-- 발송 상세 상태 코드 -->
, (SELECT GET_CODE_NM('FIM050', SD.SNDNG_DTL_STTS_CD) FROM DUAL) AS SNDNG_DTL_STTS_NM <!-- 발송 상세 상태 명 -->
, SD.SNDNG_RCVMT_CD <!-- 발송 수납 코드 -->
, (SELECT GET_CODE_NM('FIM051', SD.SNDNG_RCVMT_CD) FROM DUAL) AS SNDNG_RCVMT_NM <!-- 발송 수납 명 -->
, SD.ADDR_CHG_CD <!-- 주소 변경 코드 -->
, VI.VLTN_ID <!-- 위반 ID -->
, VI.VLTN_CD <!-- 위반 코드 -->
, VI.VLTN_ARTCL <!-- 위반 항목 -->
FROM TB_SVBTC SV
INNER JOIN TB_SNDNG_DTL SD ON (SV.SVBTC_ID = SD.SVBTC_ID)
LEFT OUTER JOIN TB_VLTN_INFO VI ON (SV.VLTN_ID = VI.VLTN_ID AND SV.SGG_CD = VI.SGG_CD AND SV.TASK_SE_CD = VI.TASK_SE_CD)
</sql>
<select id="selectSvbtcDtls" parameterType="map" resultType="dataobject">/* 공시송달 상세 객체 가져오기(svbtcMapper.selectSvbtcDtls) */
<include refid="selectDtl" />
<where>
<if test="svbtcId != null">
AND SV.SVBTC_ID = #{svbtcId} <!-- 공시송달 ID -->
</if> </if>
</where> </where>
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
@ -98,64 +182,64 @@
<insert id="insertSvbtc" parameterType="map">/* 공시송달 대장 등록(svbtcMapper.insertSvbtc) */ <insert id="insertSvbtc" parameterType="map">/* 공시송달 대장 등록(svbtcMapper.insertSvbtc) */
INSERT INSERT
INTO TB_SVBTC ( INTO TB_SVBTC (
SVBTC_ID /* 공시송달 ID */ SVBTC_ID <!-- 공시송달 ID -->
, SGG_CD /* 시군구 코드 */ , SGG_CD <!-- 시군구 코드 -->
, TASK_SE_CD /* 업무 구분 코드 */ , TASK_SE_CD <!-- 업무 구분 코드 -->
, VLTN_ID /* 위반 ID */ , VLTN_ID <!-- 위반 ID -->
, SNDNG_SE_CD /* 발송 구분 코드 */ , SNDNG_SE_CD <!-- 발송 구분 코드 -->
, SVBTC_YMD /* 공시송달 일자 */ , SVBTC_YMD <!-- 공시송달 일자 -->
, TTL_NM /* 제목 명 */ , TTL_NM <!-- 제목 명 -->
, DOC_NO /* 문서 번호 */ , DOC_NO <!-- 문서 번호 -->
, ETC_CN /* 기타 내용 */ , ETC_CN <!-- 기타 내용 -->
, TNOCS /* 총건수 */ , TNOCS <!-- 총건수 -->
, GRAMT /* 총금액 */ , GRAMT <!-- 총금액 -->
, DEL_YN /* 삭제 여부 */ , DEL_YN <!-- 삭제 여부 -->
, REG_DT /* 등록 일시 */ , REG_DT <!-- 등록 일시 -->
, RGTR /* 등록자 */ , RGTR <!-- 등록자 -->
, MDFCN_DT /* 수정 일시 */ , MDFCN_DT <!-- 수정 일시 -->
, MDFR /* 수정자 */ , MDFR <!-- 수정자 -->
) )
VALUES ( VALUES (
#{svbtc.svbtcId} /* 공시송달 ID */ #{svbtc.svbtcId} <!-- 공시송달 ID -->
, #{svbtc.sggCd} /* 시군구 코드 */ , #{svbtc.sggCd} <!-- 시군구 코드 -->
, #{svbtc.taskSeCd} /* 업무 구분 코드 */ , #{svbtc.taskSeCd} <!-- 업무 구분 코드 -->
, #{svbtc.vltnId} /* 위반 ID */ , #{svbtc.vltnId} <!-- 위반 ID -->
, #{svbtc.sndngSeCd} /* 발송 구분 코드 */ , #{svbtc.sndngSeCd} <!-- 발송 구분 코드 -->
, #{svbtc.svbtcYmd} /* 공시송달 일자 */ , #{svbtc.svbtcYmd} <!-- 공시송달 일자 -->
, #{svbtc.ttlNm} /* 제목 명 */ , #{svbtc.ttlNm} <!-- 제목 명 -->
, #{svbtc.docNo} /* 문서 번호 */ , #{svbtc.docNo} <!-- 문서 번호 -->
, #{svbtc.etcCn} /* 기타 내용 */ , #{svbtc.etcCn} <!-- 기타 내용 -->
, #{svbtc.tnocs} /* 총건수 */ , #{svbtc.tnocs} <!-- 총건수 -->
, #{svbtc.gramt} /* 총금액 */ , #{svbtc.gramt} <!-- 총금액 -->
, 'N' /* 삭제 여부 */ , 'N' <!-- 삭제 여부 -->
, #{svbtc.createdAt} /* 등록 일시 */ , #{svbtc.createdAt} <!-- 등록 일시 -->
, #{svbtc.createdBy} /* 등록자 */ , #{svbtc.createdBy} <!-- 등록자 -->
, #{svbtc.lastModified} /* 수정 일시 */ , #{svbtc.lastModified} <!-- 수정 일시 -->
, #{svbtc.modifiedBy} /* 수정자 */ , #{svbtc.modifiedBy} <!-- 수정자 -->
) )
</insert> </insert>
<update id="updateSvbtc" parameterType="map">/* 공시송달 대장 수정(svbtcMapper.updateSvbtc) */ <update id="updateSvbtc" parameterType="map">/* 공시송달 대장 수정(svbtcMapper.updateSvbtc) */
UPDATE TB_SVBTC UPDATE TB_SVBTC
SET SVBTC_YMD = #{svbtc.svbtcYmd} /* 공시송달 일자 */ SET SVBTC_YMD = #{svbtc.svbtcYmd} <!-- 공시송달 일자 -->
, TTL_NM = #{svbtc.ttlNm} /* 제목 명 */ , TTL_NM = #{svbtc.ttlNm} <!-- 제목 명 -->
, DOC_NO = #{svbtc.docNo} /* 문서 번호 */ , DOC_NO = #{svbtc.docNo} <!-- 문서 번호 -->
, ETC_CN = #{svbtc.etcCn} /* 기타 내용 */ , ETC_CN = #{svbtc.etcCn} <!-- 기타 내용 -->
, TNOCS = #{svbtc.tnocs} /* 총건수 */ , TNOCS = #{svbtc.tnocs} <!-- 총건수 -->
, GRAMT = #{svbtc.gramt} /* 총금액 */ , GRAMT = #{svbtc.gramt} <!-- 총금액 -->
, MDFCN_DT = #{svbtc.lastModified} /* 수정 일시 */ , MDFCN_DT = #{svbtc.lastModified} <!-- 수정 일시 -->
, MDFR = #{svbtc.modifiedBy} /* 수정자 */ , MDFR = #{svbtc.modifiedBy} <!-- 수정자 -->
WHERE SVBTC_ID = #{svbtc.svbtcId} /* 공시송달 ID */ WHERE SVBTC_ID = #{svbtc.svbtcId} <!-- 공시송달 ID -->
</update> </update>
<update id="deleteSvbtc" parameterType="map">/* 공시송달 대장 삭제(svbtcMapper.deleteSvbtc) */ <update id="deleteSvbtc" parameterType="map">/* 공시송달 대장 삭제(svbtcMapper.deleteSvbtc) */
UPDATE TB_SVBTC UPDATE TB_SVBTC
SET DEL_YN = 'Y' /* 삭제 여부 */ SET DEL_YN = 'Y' <!-- 삭제 여부 -->
, DEL_DT = #{svbtc.lastModified} /* 삭제 일시 */ , DEL_DT = #{svbtc.lastModified} <!-- 삭제 일시 -->
, DLTR = #{svbtc.modifiedBy} /* 삭제자 */ , DLTR = #{svbtc.modifiedBy} <!-- 삭제자 -->
, DEL_RSN = #{svbtc.delRsn} /* 삭제 사유 */ , DEL_RSN = #{svbtc.delRsn} <!-- 삭제 사유 -->
WHERE SVBTC_ID = #{svbtc.svbtcId} /* 공시송달 ID */ WHERE SVBTC_ID = #{svbtc.svbtcId} <!-- 공시송달 ID -->
AND DEL_YN = 'N' /* 삭제 여부 */ AND DEL_YN = 'N' <!-- 삭제 여부 -->
</update> </update>
</mapper> </mapper>

@ -254,7 +254,7 @@
// 발송 상세 // 발송 상세
${pageName}Control.getInfo = (sndngId) => { ${pageName}Control.getInfo = (sndngId) => {
if (!sndngId) return; if (typeof sndngId == "undefined" || sndngId == null || sndngId == "") return;
let params = { let params = {
callPurpose : "view" callPurpose : "view"
@ -272,7 +272,6 @@
, title : "계고장 세부 내용" , title : "계고장 세부 내용"
, content : resp , content : resp
, size : ${pageName}Control.infoSize , size : ${pageName}Control.infoSize
, onClose : () => { ${pageName}Control.load(${pageName}Control.query.pageNum); } // callback
}); });
} }
}); });
@ -371,7 +370,7 @@
// 달력 초기화 // 달력 초기화
initDatepicker("frmSearch--${pageName}"); initDatepicker("frmSearch--${pageName}");
$("#schSndngYmdFrom--${pageName}").datepicker("setDate", DateUtil.getDateDay(365).date); $("#schSndngYmdFrom--${pageName}").datepicker("setDate", DateUtil.getDateDay(-365).date);
$("#schSndngYmdTo--${pageName}").datepicker("setDate", new Date()); $("#schSndngYmdTo--${pageName}").datepicker("setDate", new Date());
} }

@ -155,7 +155,7 @@
$("#tbody--${pageName}").setCurrentRow(key); $("#tbody--${pageName}").setCurrentRow(key);
${pageName}Control.urls.getInfo = wctx.url("/" + ${pageName}Control.dataset.getValue("TASK_SE_CD") + "/sprt/sprt02/010/main.do"); // 개별총정보 ${pageName}Control.urls.getInfo = wctx.url("/" + item.data.TASK_SE_CD + "/sprt/sprt02/010/main.do"); // 개별총정보
}; };
// 선택(체크) 변경 이벤트 // 선택(체크) 변경 이벤트

@ -272,7 +272,6 @@
, title : "사전통지 세부 내용" , title : "사전통지 세부 내용"
, content : resp , content : resp
, size : ${pageName}Control.infoSize , size : ${pageName}Control.infoSize
, onClose : () => { ${pageName}Control.load(${pageName}Control.query.pageNum); } // callback
}); });
} }
}); });

@ -175,7 +175,7 @@
$("#tbody--${pageName}").setCurrentRow(key); $("#tbody--${pageName}").setCurrentRow(key);
${pageName}Control.urls.getInfo = wctx.url("/" + ${pageName}Control.dataset.getValue("TASK_SE_CD") + "/sprt/sprt02/010/main.do"); // 개별총정보 ${pageName}Control.urls.getInfo = wctx.url("/" + item.data.TASK_SE_CD + "/sprt/sprt02/010/main.do"); // 개별총정보
}; };
// 선택(체크) 변경 이벤트 // 선택(체크) 변경 이벤트

@ -114,13 +114,6 @@
<input type="hidden" id="mainOption--${pageName}" name="mainOption" /> <input type="hidden" id="mainOption--${pageName}" name="mainOption" />
<input type="hidden" id="subOption--${pageName}" name="subOption" /> <input type="hidden" id="subOption--${pageName}" name="subOption" />
<input type="text" class="form-control w-px-300" id="term--${pageName}" name="term" /> <input type="text" class="form-control w-px-300" id="term--${pageName}" name="term" />
<!-- 상세 검색조건 버튼 -->
<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 class="col-6"> <div class="col-6">
@ -249,7 +242,7 @@
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DLVR_TM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DLVR_TM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{UNDLVR_RSN_NM}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{UNDLVR_RSN_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_NM}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RCPN_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_SE_NM}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_YMD}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_YMD}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_AMT}</td> <td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_AMT}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NM}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NM}</td>

@ -48,59 +48,31 @@
</c:forEach> </c:forEach>
</span> </span>
</div> </div>
<!-- 의견제출 접수일자 --> <!-- 공시송달 일자 -->
<div class="col-6"> <div class="col-6">
<label class="form-label fw-bold form-search-title text-end">접수일자</label> <label class="form-label fw-bold form-search-title text-end">송달일자</label>
<span class="form-search-linebox"> <span class="form-search-linebox">
<input type="text" class="form-control form-date" id="schRcptYmdFrom--${pageName}" name="schRcptYmdFrom" <input type="text" class="form-control form-date" id="schSvbtcYmdFrom--${pageName}" name="schSvbtcYmdFrom"
data-fmt-type="day" title="시작 날짜 선택" /> data-fmt-type="day" title="시작 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button> <button type="button" class="bx bx-sm bx-calendar bg-white"></button>
~ ~
<input type="text" class="form-control form-date" id="schRcptYmdTo--${pageName}" name="schRcptYmdTo" <input type="text" class="form-control form-date" id="schSvbtcYmdTo--${pageName}" name="schSvbtcYmdTo"
data-fmt-type="day" title="종료 날짜 선택" /> data-fmt-type="day" title="종료 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button> <button type="button" class="bx bx-sm bx-calendar bg-white"></button>
</span> </span>
</div> </div>
<!-- 의견제출 답변일자 --> <!-- 발송구분 -->
<div class="col-6"> <div class="col-6">
<label class="form-label fw-bold form-search-title text-end">답변일자</label> <label class="form-label fw-bold form-search-title text-end">발송구분</label>
<span class="form-search-linebox"> <select class="form-select w-px-150" id="schSndngSeCd--${pageName}" name="schSndngSeCd">
<input type="text" class="form-control form-date" id="schAnsYmdFrom--${pageName}" name="schAnsYmdFrom"
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="schAnsYmdTo--${pageName}" name="schAnsYmdTo"
data-fmt-type="day" 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-150" id="schOpnnSbmsnSttsCd--${pageName}" name="schOpnnSbmsnSttsCd">
<option value="">전체</option> <option value="">전체</option>
<c:forEach items="${FIM031List}" var="item"> <c:forEach items="${FIM047List}" var="item">
<option value="${item.code}">${item.value}</option> <option value="${item.code}">${item.value}</option>
</c:forEach> </c:forEach>
</select> </select>
</div> </div>
<!-- 차량번호 --> <!-- -->
<div class="col-6"> <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" />
</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" 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" title="종료 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
</span>
</div> </div>
<!-- 동적검색 --> <!-- 동적검색 -->
<div class="col-6"> <div class="col-6">
@ -124,16 +96,6 @@
<!-- 상세 조건 --> <!-- 상세 조건 -->
<div id="searchDetail--${pageName}" class="container-search container-search-detail collapse"> <div id="searchDetail--${pageName}" class="container-search container-search-detail collapse">
<div class="row g-1"> <div class="row g-1">
<!-- 진술자명 -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end">진술자명</label>
<input type="text" class="form-control w-px-150" id="schSttrNm--${pageName}" name="schSttrNm" />
</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-150" id="schRtpyrNm--${pageName}" name="schRtpyrNm" />
</div>
<!-- 등록일자, 수정일자 --> <!-- 등록일자, 수정일자 -->
<div class="col-6"> <div class="col-6">
<select class="form-select text-center" id="schDetailRegDtOpt--${pageName}" name="schDetailRegDtOpt"> <select class="form-select text-center" id="schDetailRegDtOpt--${pageName}" name="schDetailRegDtOpt">
@ -175,15 +137,7 @@
</div> </div>
<span class="container-window-btn-right"> <span class="container-window-btn-right">
<!-- 업무 버튼 --> <!-- 업무 버튼 -->
<button type="button" class="btn btn-primary w-px-120" id="btnOpnnInfo--${pageName}" title="의견제출 정보" onclick="${infoPrefix}Info${pageName}();">
의견제출 정보
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnOpnnRemove--${pageName}" title="의견제출 삭제" onclick="${infoPrefix}Remove${pageName}();">
의견제출 삭제
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnOpnnDlbrInfo--${pageName}" title="심의 정보" onclick="${infoPrefix}DlbrInfo${pageName}();">
심의 정보
</button>
</span> </span>
</span> </span>
</div> </div>
@ -202,24 +156,14 @@
<input type="checkbox" class="form-check-input" onchange="${pageName}Control.select(this.checked);"> <input type="checkbox" class="form-check-input" onchange="${pageName}Control.select(this.checked);">
</th> </th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('TASK_SE_CD', this.innerText, 'codeValue', 'FIM054');">업무구분</th> <th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('TASK_SE_CD', this.innerText, 'codeValue', 'FIM054');">업무구분</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RCPT_YMD', this.innerText, 'ymd', '');">접수일자</th> <th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('SNDNG_SE_CD', this.innerText, 'codeValue', 'FIM047');">발송구분</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RCPT_NO', this.innerText, 'match', 'part');">접수번호</th> <th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('VLTN_ARTCL', this.innerText, 'match', 'part');">위반항목</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RCPT_SE_CD', this.innerText, 'codeValue', 'FIM029');">접수구분</th> <th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('SVBTC_YMD', this.innerText, 'ymd', '');">송달일자</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('NTFCTN_SE_CD', this.innerText, 'codeValue', 'FIM030');">통보구분</th> <th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('TNOCS', this.innerText, 'match', 'part');">총건수</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('STTR_NM', this.innerText, 'match', 'part');">진술자명</th> <th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('GRAMT', this.innerText, 'match', 'part');">총금액</th>
<th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('OPNN_SBMSN_STTS_CD', this.innerText, 'codeValue', 'FIM031');">의견제출상태</th> <th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('TTL_NM', this.innerText, 'match', 'part');">제목</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('OPNN_SBMSN_SE_CD', this.innerText, 'codeValue', 'FIM033');">의견제출분류</th> <th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('DOC_NO', this.innerText, 'match', 'part');">문서번호</th>
<th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('OPNN_SBMSN_GIST', this.innerText, 'match', 'part');">의견제출요지</th> <th class="cmn" style="width: 320px;" onclick="searchFromGridTitle('ETC_CN', this.innerText, 'match', 'part');">기타내용</th>
<th class="cmn" style="width: 180px;" onclick="searchFromGridTitle('CRDN_YMD', this.innerText, 'ymd', '');">단속일시</th>
<th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('VHRNO', this.innerText, 'match', 'part');">차량번호</th>
<th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('CRDN_PLC', this.innerText, 'match', 'part');">단속장소</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('FFNLG_AMT', this.innerText, 'match', 'part');">과태료금액</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('CRDN_STTS_CD', this.innerText, 'codeValue', 'FIM010');">처리상태</th>
<th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('DOC_NO', this.innerText, 'ymd', '');">문서번호</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('ANS_YMD', this.innerText, 'ymd', '');">답변일자</th>
<th class="cmn" style="width: 240px;" onclick="searchFromGridTitle('ANS_CN', this.innerText, 'match', 'part');">답변내용</th>
<th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('RTPYR_NM', this.innerText, 'match', 'part');">납부자명</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RTPYR_BRDT', this.innerText, 'match', 'part');">납부자생일</th>
<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" style="width: 180px;">수정일시</th> <th class="cmn" style="width: 180px;">수정일시</th>
@ -230,30 +174,20 @@
<tbody id="tbody--${pageName}"> <tbody id="tbody--${pageName}">
</tbody> </tbody>
<template id="${infoPrefix}Row--${pageName}"> <template id="${infoPrefix}Row--${pageName}">
<tr data-key="{OPNN_ID}"> <tr data-key="{SVBTC_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"> <td class="cmn text-center">
<input type="checkbox" class="form-check-input" value="{OPNN_ID}" onchange="${pageName}Control.select('{OPNN_ID}', this.checked);"> <input type="checkbox" class="form-check-input" value="{SVBTC_ID}" onchange="${pageName}Control.select('{SVBTC_ID}', this.checked);">
</td> </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}">{RCPT_YMD}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RCPT_NO}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{VLTN_ARTCL}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RCPT_SE_NM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SVBTC_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{NTFCTN_SE_NM}</td> <td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{TNOCS}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{STTR_NM}</td> <td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{GRAMT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{OPNN_SBMSN_STTS_NM}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{TTL_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{OPNN_SBMSN_SE_NM}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{DOC_NO}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{OPNN_SBMSN_GIST}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ETC_CN}</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-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_PLC}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_AMT}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_STTS_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DOC_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ANS_YMD}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ANS_CN}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_BRDT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{REG_DT}</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}">{RGTR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td>
@ -263,7 +197,7 @@
</template> </template>
<template id="${infoPrefix}NotFound--${pageName}"> <template id="${infoPrefix}NotFound--${pageName}">
<tr class="odd"> <tr class="odd">
<td valign="top" colspan="26" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td> <td valign="top" colspan="16" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr> </tr>
</template> </template>
</table> </table>
@ -288,7 +222,7 @@
* Global Variable * Global Variable
**************************************************************************/ **************************************************************************/
// URL // URL
var ${pageName}PrefixUrl = "/excl/excl02"; var ${pageName}PrefixUrl = "/sndb/sndb01";
// FormFields // FormFields
var ${pageName}Fields = new FormFields("#frmSearch--${pageName}"); var ${pageName}Fields = new FormFields("#frmSearch--${pageName}");
@ -296,20 +230,17 @@
* DatasetControl * DatasetControl
**************************************************************************/ **************************************************************************/
var ${pageName}Control = new DatasetControl({ var ${pageName}Control = new DatasetControl({
prefix : "opnn" prefix : "svbtc"
, prefixName : "의견제출" , prefixName : "공시송달"
, infoSize : "xl" , infoSize : "xxl"
, keymapper : info => info ? info.OPNN_ID : "" , keymapper : info => info ? info.SVBTC_ID : ""
, dataGetter : obj => obj.opnnSbmsnList , dataGetter : obj => obj.svbtcList
, appendData : true , appendData : true
, tableRenderComplete : false // dataTables 에 자료 추가 완료 여부 , tableRenderComplete : false // dataTables 에 자료 추가 완료 여부
, formats : { , formats : {
RCPT_YMD : dateFormat SVBTC_YMD : dateFormat
, ANS_YMD : dateFormat , TNOCS : numberFormat
, ANS_YMD_TM : datetimeFormat , GRAMT : numberFormat
, CRDN_YMD_TM : datetimeFormat
, FFNLG_CRDN_AMT : numberFormat
, FFNLG_AMT : numberFormat
, REG_DT : datetimeFormat , REG_DT : datetimeFormat
, MDFCN_DT : datetimeFormat , MDFCN_DT : datetimeFormat
} }
@ -338,7 +269,7 @@
${pageName}Control.onCurrentChange = item => { ${pageName}Control.onCurrentChange = item => {
if (!item) return; if (!item) return;
let key = item.data.OPNN_ID; let key = item.data.SVBTC_ID;
$("#tbody--${pageName}").setCurrentRow(key); $("#tbody--${pageName}").setCurrentRow(key);
}; };
@ -357,41 +288,31 @@
$("#btn${infoPrefix}Remove--${pageName}").prop("disabled", keys.length < 1); $("#btn${infoPrefix}Remove--${pageName}").prop("disabled", keys.length < 1);
}; };
// 개별총정보 dialog // 공시송달 상세
${pageName}Control.getInfo = (crdnId) => { ${pageName}Control.getInfo = (svbtcId) => {
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return; if (typeof svbtcId == "undefined" || svbtcId == null || svbtcId == "") return;
let params = { let params = {
callControlName : "${pageName}Control" callPurpose : "view"
, crdnId : crdnId , sggCd : ${pageName}Control.dataset.getValue("SGG_CD") // 시군구 코드
} , taskSeCd : ${pageName}Control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, svbtcId : svbtcId // 공시송달 ID
};
ajax.get({ ajax.get({
url : ${pageName}Control.urls.getInfo url : ${pageName}Control.urls.getInfo
, data : params , data : params
, success : resp => { , success : resp => {
dialog.open({ dialog.open({
id : "totalInfoMainDialog" id : ${pageName}Control.prefixed("Dialog")
, title : "개별총정보" , title : "공시송달 세부 내용"
, content : resp , content : resp
, size : "xxl" , size : ${pageName}Control.infoSize
}); });
} }
}); });
} }
// 삭제 callback
${pageName}Control.onRemove = (selected, resp) => {
let btnTitle = $("#btn${infoPrefix}Remove--${pageName}").attr("title");
let showMessage = resp.retMessage.replace(/[S]|[F]/g, btnTitle);
dialog.alert(showMessage);
if (resp.saved) {
${pageName}Control._load();
}
}
/************************************************************************** /**************************************************************************
* *
**************************************************************************/ **************************************************************************/
@ -405,8 +326,8 @@
${infoPrefix}List.inStrings( ${infoPrefix}List.inStrings(
document.getElementById("${infoPrefix}Row--${pageName}").innerHTML, <%-- from template#${infoPrefix}Row --%> document.getElementById("${infoPrefix}Row--${pageName}").innerHTML, <%-- from template#${infoPrefix}Row --%>
(str, dataItem) => str (str, dataItem) => str
.replace(/{onclick}/gi, "${pageName}Control.setCurrent('" + dataItem.getValue("OPNN_ID") + "');") .replace(/{onclick}/gi, "${pageName}Control.setCurrent('" + dataItem.getValue("SVBTC_ID") + "');")
.replace(/{ondblclick}/gi, "${pageName}Control.getInfo('" + dataItem.getValue("CRDN_ID") + "');") .replace(/{ondblclick}/gi, "${pageName}Control.getInfo('" + dataItem.getValue("SVBTC_ID") + "');")
); );
$("#tbody--${pageName}").html(trs.join()); $("#tbody--${pageName}").html(trs.join());
@ -416,44 +337,6 @@
fn_securityModeToggle($("#securityMode--top").is(":checked")); fn_securityModeToggle($("#securityMode--top").is(":checked"));
} }
// 수정 dialog -> callback 추가
getInfo${pageName} = (params) => {
if (!params) return;
ajax.get({
url : wctx.url("/" + params.taskSeCd + ${pageName}PrefixUrl + "/020/info.do")
, data : params || {}
, success : resp => {
dialog.open({
id : ${pageName}Control.prefixed("Dialog")
, title : ${pageName}Control.prefixName + " 정보"
, content : resp
, size : ${pageName}Control.infoSize
, onClose : () => { ${pageName}Control.load(${pageName}Control.query.pageNum); } // callback
});
}
});
}
// 심의 dialog
getDlbrInfo${pageName} = (params) => {
if (!params) return;
ajax.get({
url : wctx.url("/" + params.taskSeCd + ${pageName}PrefixUrl + "/030/info.do")
, data : params || {}
, success : resp => {
dialog.open({
id : ${pageName}Control.prefixed("SbmsnDialog")
, title : ${pageName}Control.prefixName + " 심의 처리"
, content : resp
, size : "lg"
, onClose : () => { ${pageName}Control.load(${pageName}Control.query.pageNum); } // callback
});
}
});
}
/************************************************************************** /**************************************************************************
* 초기 셋팅 * 초기 셋팅
**************************************************************************/ **************************************************************************/
@ -523,15 +406,14 @@
// 달력 초기화 // 달력 초기화
initDatepicker("frmSearch--${pageName}"); initDatepicker("frmSearch--${pageName}");
$("#schRcptYmdFrom--${pageName}").datepicker("setDate", DateUtil.getDateDay(-365).date); $("#schSvbtcYmdFrom--${pageName}").datepicker("setDate", DateUtil.getDateDay(-365).date);
$("#schRcptYmdTo--${pageName}").datepicker("setDate", new Date()); $("#schSvbtcYmdTo--${pageName}").datepicker("setDate", new Date());
} }
// URL 설정 // URL 설정
setURL${pageName} = (taskSeCd) => { setURL${pageName} = (taskSeCd) => {
${pageName}Control.urls.load = wctx.url("/" + taskSeCd + ${pageName}PrefixUrl + "/010/list.do"); // 조회 ${pageName}Control.urls.load = wctx.url("/" + taskSeCd + ${pageName}PrefixUrl + "/240/list.do"); // 조회
${pageName}Control.urls.remove = wctx.url("/" + taskSeCd + ${pageName}PrefixUrl + "/010/removes.do"); // 삭제 ${pageName}Control.urls.getInfo = wctx.url("/" + taskSeCd + ${pageName}PrefixUrl + "/250/info.do"); // 공시송달 세부내용
${pageName}Control.urls.getInfo = wctx.url("/" + taskSeCd + "/sprt/sprt02/010/main.do"); // 개별총정보
} }
/************************************************************************** /**************************************************************************
@ -566,7 +448,6 @@
${pageName}Control.query.fetchSize = FETCH_XS; // 한번에 조회되는 자료 건수 FETCH_XS = 30 ${pageName}Control.query.fetchSize = FETCH_XS; // 한번에 조회되는 자료 건수 FETCH_XS = 30
${pageName}Control.query.delYn = "N"; // 삭제 여부 ${pageName}Control.query.delYn = "N"; // 삭제 여부
${pageName}Control.query.crdnDelYn = "N"; // 단속 대장 삭제 여부
${pageName}Control.load(); ${pageName}Control.load();
} }
@ -576,50 +457,6 @@
} }
// 수정 버튼 이벤트
${infoPrefix}Info${pageName} = () => {
let = ${pageName}Control.dataset.getValue("OPNN_ID");
// 의견제출 ID 가 없다면.. return
if (!opnnId) return;
let params = {
callPurpose : "update"
, sggCd : ${pageName}Control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd : ${pageName}Control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, opnnId : opnnId
};
getInfo${pageName}(params);
}
// 심의 버튼 이벤트
${infoPrefix}DlbrInfo${pageName} = () => {
let opnnId = ${pageName}Control.dataset.getValue("OPNN_ID");
// 의견제출 ID 가 없다면.. return
if (!opnnId) return;
let params = {
callPurpose : "update"
, sggCd : ${pageName}Control.dataset.getValue("SGG_CD") // 시군구 코드
, taskSeCd : ${pageName}Control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
, opnnId : opnnId
};
getDlbrInfo${pageName}(params);
}
// 삭제 버튼 이벤트
${infoPrefix}Remove${pageName} = () => {
dialog.alert({
content : "선택한 의견제출 정보를 삭제하시겠습니까?"
, onOK : () => {
${pageName}Control.remove();
}
});
}
/************************************************************************** /**************************************************************************
* script 진입 * script 진입
**************************************************************************/ **************************************************************************/

@ -0,0 +1,272 @@
<%@ 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">
<!-- Page Body -->
<div class="card">
<div class="wrapper-pop">
<!-- 입력 영역 -->
<form id="frmEdit--${pageName}" name="frmEdit">
<input type="hidden" id="sggCd--${pageName}" name="sggCd" />
<input type="hidden" id="taskSeCd--${pageName}" name="taskSeCd" />
</form> <!-- /입력 영역 -->
<!-- 업무 버튼 및 건수 표시 -->
<div>
<span class="container-page-btn">
<span class="container-window-btn-right">
<!-- 업무 버튼 -->
<button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀 저장" onclick="fnExcel${pageName}();">
엑셀 저장
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnHwpPrint--${pageName}" title="한글 출력" onclick="fnHwpPrint${pageName}();">
한글 출력
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnSvbtcRemove--${pageName}" title="공시송달 삭제" onclick="fnSvbtcRemove${pageName}();">
공시송달 삭제
</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:400px; 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}">
<th class="cmn hidden" style="width: 56px;">
<input type="checkbox" class="form-check-input" onchange="${pageName}Control.select(this.checked);">
</th>
<th class="cmn" style="width: 120px;">발송상태</th>
<th class="cmn" style="width: 160px;">등기번호</th>
<th class="cmn" style="width: 120px;">발송일자</th>
<th class="cmn" style="width: 120px;">납기일자</th>
<th class="cmn" style="width: 200px;">납부자명</th>
<th class="cmn" style="width: 160px;">납부자번호</th>
<th class="cmn" style="width: 100px;">우편번호</th>
<th class="cmn" style="width: 280px;">주소</th>
<th class="cmn" style="width: 320px;">상세주소</th>
<th class="cmn" style="width: 180px;">단속일시</th>
<th class="cmn" style="width: 140px;">차량번호</th>
<th class="cmn" style="width: 280px;">단속장소</th>
<th class="cmn" style="width: 120px;">단속금액</th>
<th class="cmn" style="width: 180px;">등록일시</th>
<th class="cmn" style="width: 140px;">등록사용자</th>
<th class="cmn" style="width: 180px;">수정일시</th>
<th class="cmn" style="width: 140px;">수정사용자</th>
<th class="cmn dummy-th"></th>
</tr>
</thead>
<tbody id="tbody--${pageName}">
</tbody>
<template id="${infoPrefix}Row--${pageName}">
<tr data-key="{SNDNG_DTL_ID}">
<td class="cmn text-center hidden">
<input type="checkbox" class="form-check-input" value="{SNDNG_DTL_ID}" onchange="${pageName}Control.select('{SNDNG_DTL_ID}', this.checked);">
</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_DTL_STTS_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RG_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DUDT_YMD}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_ZIP}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_ADDR}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_DTL_ADDR}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_DT}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{VHRNO}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_PLC}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_AMT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{REG_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGTR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFR_NM}</td>
<td class="cmn dummy-td"></td>
</tr>
</template>
<template id="${infoPrefix}NotFound--${pageName}">
<tr class="odd">
<td valign="top" colspan="19" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
</template>
</table>
</div>
</div>
</div>
<!-- / DataTables(그리드) -->
</div> <!-- <div class="wrapper-list"> -->
</div> <!-- <div class="card"> -->
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
</div>
<!-- / inner page html <div class="content-wrapper"> -->
<script>
/**************************************************************************
* Global Variable
**************************************************************************/
// URL
var ${pageName}PrefixUrl = "/sndb/sndb01";
// FormFields
var ${pageName}Fields = new FormFields("#frmEdit--${pageName}");
/**************************************************************************
* DatasetControl
**************************************************************************/
var ${pageName}Control = new DatasetControl({
prefix : "wrngSndngDtl"
, prefixName : "발송 대상"
, keymapper : info => info ? info.SNDNG_DTL_ID : ""
, dataGetter : obj => obj.wrngSndngDtlList
, appendData : true
, tableRenderComplete : false // dataTables 에 자료 추가 완료 여부
, formats : {
SNDNG_YMD : dateFormat
, DUDT_YMD : dateFormat
, FFNLG_AMT : numberFormat
, REG_DT : datetimeFormat
, MDFCN_DT : datetimeFormat
}
});
/**************************************************************************
* DatasetControl 이벤트
**************************************************************************/
// Dataset 변경 이벤트
${pageName}Control.onDatasetChange = obj => {
renderList${pageName}();
${pageName}Control.select(true); // 전체 선택 되도록..
if (obj.length > 0) {
}
${pageName}Control.tableRenderComplete = true; // dataTables 에 자료 추가 완료
};
// 현재 선택 자료 변경 이벤트
${pageName}Control.onCurrentChange = item => {
if (!item) return;
let key = item.data.SNDNG_DTL_ID;
$("#tbody--${pageName}").setCurrentRow(key);
${pageName}Control.urls.getInfo = wctx.url("/" + item.data.TASK_SE_CD + "/sprt/sprt02/010/main.do"); // 개별총정보
};
// 선택(체크) 변경 이벤트
${pageName}Control.onSelectionChange = selected => {
let ${infoPrefix}List = ${pageName}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()));
});
};
// 개별총정보 dialog
${pageName}Control.getInfo = (crdnId) => {
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return;
let params = {
callControlName : "${pageName}Control"
, viewPurpose : "readonly"
, crdnId : crdnId
}
ajax.get({
url : ${pageName}Control.urls.getInfo
, data : params
, success : resp => {
dialog.open({
id : "totalInfoMainDialog"
, title : "개별총정보"
, content : resp
, size : "xxl"
});
}
});
}
/**************************************************************************
*
**************************************************************************/
// DataTables에 click, dbclick 이벤트
renderList${pageName} = () => {
let ${infoPrefix}List = ${pageName}Control.dataset;
let empty = ${infoPrefix}List.empty;
let trs = empty ?
[document.getElementById("${infoPrefix}NotFound--${pageName}").innerHTML] : <%-- from template#${infoPrefix}NotFound --%>
${infoPrefix}List.inStrings(
document.getElementById("${infoPrefix}Row--${pageName}").innerHTML, <%-- from template#${infoPrefix}Row --%>
(str, dataItem) => str
.replace(/{onclick}/gi, "${pageName}Control.setCurrent('" + dataItem.getValue("SNDNG_DTL_ID") + "');")
.replace(/{ondblclick}/gi, "${pageName}Control.getInfo('" + dataItem.getValue("CRDN_ID") + "');")
);
$("#tbody--${pageName}").html(trs.join());
$("th input[type='checkbox']").prop("checked", false);
//보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked"));
}
/**************************************************************************
* 초기 셋팅
**************************************************************************/
// 이벤트
setEvent${pageName} = () => {
// 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);
}
});
});
// DataTables width 변경 조정
$("#DataTables_Table_0--${pageName}").find("th").resizable( {handles : "e"} );
}
/**************************************************************************
* 버튼 clickEvent
**************************************************************************/
// 엑셀
fnExcel${pageName} = () => {
}
/**************************************************************************
* script 진입
**************************************************************************/
$(document).ready(function() {
// 기본 데이터
$("#sggCd--${pageName}").val("${sggCd}"); // 시군구 코드
$("#taskSeCd--${pageName}").val("${taskSeCd}"); // 업무 구분 코드
// 보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked"));
// 이벤트 설정
setEvent${pageName}();
// Dataset 셋팅 - 화면이 열리면서 조회하는 경우 addData 하여 자료를 추가
${pageName}Control.addData(${svbtcDtl});
});
</script>
Loading…
Cancel
Save