parent
075eebc38d
commit
10b7c7fd75
@ -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);
|
||||
}
|
||||
|
||||
}
|
@ -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>
|
@ -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>
|
Loading…
Reference in New Issue