의견제출관리 추가
parent
f9c0e8085b
commit
25e102ee22
@ -0,0 +1,98 @@
|
|||||||
|
package cokr.xit.fims.excl.dao;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.egovframe.rte.psl.dataaccess.mapper.Mapper;
|
||||||
|
|
||||||
|
import cokr.xit.fims.excl.Excl;
|
||||||
|
import cokr.xit.fims.excl.ExclQuery;
|
||||||
|
import cokr.xit.foundation.component.AbstractMapper;
|
||||||
|
import cokr.xit.foundation.data.DataObject;
|
||||||
|
|
||||||
|
/** 의견제출 대장 정보 DAO
|
||||||
|
*
|
||||||
|
* <p>상세 설명: 의견제출 대장 테이블에 접근하여 데이터를 조회하고 저장한다.
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* ============ 변경 이력 ============
|
||||||
|
* 2023-06-27 JoJH 최초 작성
|
||||||
|
* ================================
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
@Mapper("excl02Mapper")
|
||||||
|
public interface Excl02Mapper extends AbstractMapper {
|
||||||
|
|
||||||
|
/**지정한 조건에 따라 의견제출 대장 목록을 조회하여 반환한다.<br />
|
||||||
|
* @param req 의견제출 대장 조회 조건
|
||||||
|
* @return 의견제출 대장 목록
|
||||||
|
*/
|
||||||
|
List<DataObject> selectOpnnSbmsnList(ExclQuery req);
|
||||||
|
|
||||||
|
/**지정한 조건에 따라 의견제출 대장 객체들을 반환한다.
|
||||||
|
* @param req 의견제출 대장 조회 조건
|
||||||
|
* @return 의견제출 대장 객체 목록
|
||||||
|
*/
|
||||||
|
List<Excl> selectOpnnSbmsns(ExclQuery req);
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 등록한다.
|
||||||
|
* @param params 파라미터
|
||||||
|
* <ul><li>"opnnSbmsn" - 의견제출 대장</li>
|
||||||
|
* <li>"currentUser" - 현재 접속한 사용자</li>
|
||||||
|
* </ul>
|
||||||
|
* @return 저장된 정보수
|
||||||
|
*/
|
||||||
|
int insertOpnnSbmsn(Map<String, Object> params);
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 등록한다.
|
||||||
|
* @param opnnSbmsn 의견제출 대장
|
||||||
|
* @return 저장 여부
|
||||||
|
* <ul><li>저장됐으면 true</li>
|
||||||
|
* <li>그렇지 않으면 false</li>
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
default boolean insert(Excl excl) {
|
||||||
|
return excl != null && insertOpnnSbmsn(params().set("excl", excl)) == 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 수정한다.
|
||||||
|
* @param params 파라미터
|
||||||
|
* <ul><li>"opnnSbmsn" - 의견제출 대장</li>
|
||||||
|
* <li>"currentUser" - 현재 접속한 사용자</li>
|
||||||
|
* </ul>
|
||||||
|
* @return 저장된 정보수
|
||||||
|
*/
|
||||||
|
int updateOpnnSbmsn(Map<String, Object> params);
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 수정한다.
|
||||||
|
* @param opnnSbmsn 의견제출 대장
|
||||||
|
* @return 저장 여부
|
||||||
|
* <ul><li>저장됐으면 true</li>
|
||||||
|
* <li>그렇지 않으면 false</li>
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
default boolean update(Excl excl) {
|
||||||
|
return excl != null && updateOpnnSbmsn(params().set("excl", excl)) == 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**지정한 의견제출 대장을 삭제한다.
|
||||||
|
* @param params 파라미터
|
||||||
|
* <ul><li>"opnnSbmsn" - 의견제출 대장</li>
|
||||||
|
* <li>"currentUser" - 현재 접속한 사용자</li>
|
||||||
|
* </ul>
|
||||||
|
* @return 저장된 정보수
|
||||||
|
*/
|
||||||
|
int deleteOpnnSbmsn(Map<String, ?> params);
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 삭제한다.
|
||||||
|
* @param opnnSbmsn 의견제출 대장
|
||||||
|
* @return 저장 여부
|
||||||
|
* <ul><li>저장됐으면 true</li>
|
||||||
|
* <li>그렇지 않으면 false</li>
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
default boolean delete(Excl excl) {
|
||||||
|
return excl != null && deleteOpnnSbmsn(params().set("excl", excl)) == 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,60 @@
|
|||||||
|
package cokr.xit.fims.excl.service;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import cokr.xit.fims.excl.Excl;
|
||||||
|
import cokr.xit.fims.excl.ExclQuery;
|
||||||
|
import cokr.xit.foundation.data.DataObject;
|
||||||
|
|
||||||
|
/**의견제출 대장 관리 서비스 인터페이스.
|
||||||
|
*
|
||||||
|
* <p>상세 설명:
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* ============ 변경 이력 ============
|
||||||
|
* 2023-06-27 JoJH 최초 작성
|
||||||
|
* ================================
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
public interface Excl02Service {
|
||||||
|
|
||||||
|
/**지정한 조건에 따라 의견제출 대장 목록을 조회하여 반환한다.
|
||||||
|
* @param req 의견제출 대장 조회 조건
|
||||||
|
* @return 의견제출 대장 목록
|
||||||
|
*/
|
||||||
|
List<DataObject> getOpnnSbmsnList(ExclQuery req);
|
||||||
|
|
||||||
|
/**지정한 조건에 따라 의견제출 대장 객체들을 반환한다.
|
||||||
|
* @param req 의견제출 대장 조회 조건
|
||||||
|
* @return 의견제출 대장 객체 목록
|
||||||
|
*/
|
||||||
|
List<Excl> getOpnnSbmsns(ExclQuery req);
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 등록한다.
|
||||||
|
* @param opnnSbmsn 의견제출 대장
|
||||||
|
* @return 저장 여부
|
||||||
|
* <ul><li>저장됐으면 true</li>
|
||||||
|
* <li>그렇지 않으면 false</li>
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
boolean create(Excl excl);
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 수정한다.
|
||||||
|
* @param opnnSbmsn 의견제출 대장
|
||||||
|
* @return 저장 여부
|
||||||
|
* <ul><li>저장됐으면 true</li>
|
||||||
|
* <li>그렇지 않으면 false</li>
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
boolean update(Excl excl);
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 삭제한다.
|
||||||
|
* @param opnnSbmsn 의견제출 대장
|
||||||
|
* @return 저장 여부
|
||||||
|
* <ul><li>저장됐으면 true</li>
|
||||||
|
* <li>그렇지 않으면 false</li>
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
boolean remove(Excl excl);
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,81 @@
|
|||||||
|
package cokr.xit.fims.excl.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.excl.Excl;
|
||||||
|
import cokr.xit.fims.excl.ExclQuery;
|
||||||
|
import cokr.xit.fims.excl.dao.Excl02Mapper;
|
||||||
|
|
||||||
|
/**의견제출 대장 정보 관리 Bean
|
||||||
|
*
|
||||||
|
* <p>상세 설명: 의견제출 대장 DAO(Excl02Mapper)를 사용해 업무 기능을 구현한 클래스
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* ============ 변경 이력 ============
|
||||||
|
* 2023-06-27 JoJH 최초 작성
|
||||||
|
* ================================
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
@Component("excl02Bean")
|
||||||
|
public class Excl02Bean extends AbstractComponent {
|
||||||
|
|
||||||
|
/** 의견제출 대장 정보 DAO */
|
||||||
|
@Resource(name = "excl02Mapper")
|
||||||
|
private Excl02Mapper excl02Mapper;
|
||||||
|
|
||||||
|
/**지정한 조건에 따라 의견제출 대장 목록을 조회하여 반환한다.
|
||||||
|
* @param req 의견제출 대장 조회 조건
|
||||||
|
* @return 의견제출 대장 목록
|
||||||
|
*/
|
||||||
|
public List<DataObject> getOpnnSbmsnList(ExclQuery req) {
|
||||||
|
return excl02Mapper.selectOpnnSbmsnList(req);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**지정한 조건에 따라 의견제출 대장 객체들을 반환한다.
|
||||||
|
* @param req 의견제출 대장 조회 조건
|
||||||
|
* @return 의견제출 대장 객체 목록
|
||||||
|
*/
|
||||||
|
public List<Excl> getOpnnSbmsns(ExclQuery req) {
|
||||||
|
return excl02Mapper.selectOpnnSbmsns(req);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 등록한다.
|
||||||
|
* @param excl 의견제출 대장
|
||||||
|
* @return 저장 여부
|
||||||
|
* <ul><li>저장됐으면 true</li>
|
||||||
|
* <li>그렇지 않으면 false</li>
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
public boolean create(Excl excl) {
|
||||||
|
return excl02Mapper.insert(excl);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 수정한다.
|
||||||
|
* @param excl 의견제출 대장
|
||||||
|
* @return 저장 여부
|
||||||
|
* <ul><li>저장됐으면 true</li>
|
||||||
|
* <li>그렇지 않으면 false</li>
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
public boolean update(Excl excl) {
|
||||||
|
return excl02Mapper.update(excl);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 삭제한다.
|
||||||
|
* @param excl 의견제출 대장
|
||||||
|
* @return 저장 여부
|
||||||
|
* <ul><li>저장됐으면 true</li>
|
||||||
|
* <li>그렇지 않으면 false</li>
|
||||||
|
* </ul>
|
||||||
|
*/
|
||||||
|
public boolean remove(Excl excl) {
|
||||||
|
return excl02Mapper.delete(excl);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,57 @@
|
|||||||
|
package cokr.xit.fims.excl.service.bean;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
|
||||||
|
import cokr.xit.fims.excl.Excl;
|
||||||
|
import cokr.xit.fims.excl.ExclQuery;
|
||||||
|
import cokr.xit.fims.excl.service.Excl02Service;
|
||||||
|
import cokr.xit.foundation.component.AbstractServiceBean;
|
||||||
|
import cokr.xit.foundation.data.DataObject;
|
||||||
|
|
||||||
|
/**의견제출 대장 서비스 구현체.
|
||||||
|
*
|
||||||
|
* <p>상세 설명: 의견제출 대장 업무 기능을 구현한 클래스
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* ============ 변경 이력 ============
|
||||||
|
* 2023-06-27 JoJH 최초 작성
|
||||||
|
* ================================
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
@Service("excl02Service")
|
||||||
|
public class Excl02ServiceBean extends AbstractServiceBean implements Excl02Service {
|
||||||
|
|
||||||
|
/** 의견제출 대장 정보 Bean */
|
||||||
|
@Resource(name = "excl02Bean")
|
||||||
|
protected Excl02Bean excl02Bean;
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<DataObject> getOpnnSbmsnList(ExclQuery req) {
|
||||||
|
return excl02Bean.getOpnnSbmsnList(req);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public List<Excl> getOpnnSbmsns(ExclQuery req) {
|
||||||
|
return excl02Bean.getOpnnSbmsns(req);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean create(Excl excl) {
|
||||||
|
return excl02Bean.create(excl);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean update(Excl excl) {
|
||||||
|
return excl02Bean.update(excl);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean remove(Excl excl) {
|
||||||
|
return excl02Bean.remove(excl);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,126 @@
|
|||||||
|
package cokr.xit.fims.excl.web;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
|
||||||
|
import org.springframework.stereotype.Controller;
|
||||||
|
import org.springframework.web.bind.annotation.PostMapping;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import org.springframework.web.servlet.ModelAndView;
|
||||||
|
|
||||||
|
import cokr.xit.base.code.CommonCode;
|
||||||
|
import cokr.xit.base.web.ApplicationController;
|
||||||
|
import cokr.xit.fims.excl.Excl;
|
||||||
|
import cokr.xit.fims.excl.ExclQuery;
|
||||||
|
import cokr.xit.fims.excl.service.Excl02Service;
|
||||||
|
|
||||||
|
/**의견제출 대장 서비스의 웹 컨트롤러
|
||||||
|
*
|
||||||
|
* <p>상세 설명:
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* ============ 변경 이력 ============
|
||||||
|
* 2023-06-27 JoJH 최초 작성
|
||||||
|
* ================================
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
@Controller
|
||||||
|
@RequestMapping(name="의견제출 대장", value="/excl/excl02")
|
||||||
|
public class Excl02Controller extends ApplicationController {
|
||||||
|
|
||||||
|
/**의견제출 대장 서비스*/
|
||||||
|
@Resource(name="excl02Service")
|
||||||
|
protected Excl02Service excl02Service;
|
||||||
|
|
||||||
|
/**의견제출 대장 관리 메인화면(excl/excl02/010-main)을 연다.
|
||||||
|
* 조건없는 {@link #getOpnnSbmsnList(ExclQuery) 의견제출 대장 조회 결과}를 포함시킨다.
|
||||||
|
* @return /excl/excl02/010-main
|
||||||
|
*/
|
||||||
|
@RequestMapping(name="의견제출 대장 메인", value="/010/main.do")
|
||||||
|
public ModelAndView main() {
|
||||||
|
ModelAndView mav = getOpnnSbmsnList(new ExclQuery().setPageNum(1));
|
||||||
|
|
||||||
|
// View(jsp)
|
||||||
|
mav.setViewName("/fims/excl/excl02010-main");
|
||||||
|
|
||||||
|
// View(jsp)에서 사용할 공통코드를 조회
|
||||||
|
Map<String, List<CommonCode>> commonCodes = getCodesOf("FIM031", "FIM054");
|
||||||
|
|
||||||
|
mav.addObject("FIM031List", commonCodes.get("FIM031"));
|
||||||
|
mav.addObject("FIM054List", commonCodes.get("FIM054"));
|
||||||
|
addCodes(commonCodes, mav, "FIM031", "FIM054");
|
||||||
|
|
||||||
|
// View(jsp)에서 사용할 id 뒤에 붙일 suffix
|
||||||
|
mav.addObject("pageName", "excl02010");
|
||||||
|
|
||||||
|
// return mav.addObject("opnnSbmsnList", toJson(mav.getModel().get("opnnSbmsnList")));
|
||||||
|
return mav;
|
||||||
|
}
|
||||||
|
//
|
||||||
|
/**의견제출 대장 목록을 조회하여 반환한다.<br />
|
||||||
|
* {@link Excl02Service#getOpnnSbmsnList(ExclQuery)} 참고
|
||||||
|
* @param req 의견제출 대장 조회 조건
|
||||||
|
* @return jsonView
|
||||||
|
* <pre><code> {
|
||||||
|
* "opnnSbmsnList": [의견제출 대장 목록]
|
||||||
|
* "opnnSbmsnStart": 의견제출 대장 목록 시작 인덱스
|
||||||
|
* "opnnSbmsnFetch": 한 번에 가져오는 의견제출 대장 목록 수
|
||||||
|
* "opnnSbmsnTotal": 조회 결과 찾은 전체 의견제출 대장 수
|
||||||
|
* }</code></pre>
|
||||||
|
*/
|
||||||
|
@RequestMapping(name="의견제출 대장 조회", value="/010/list.do")
|
||||||
|
public ModelAndView getOpnnSbmsnList(ExclQuery req) {
|
||||||
|
List<?> result = excl02Service.getOpnnSbmsnList(setFetchSize(req));
|
||||||
|
|
||||||
|
return setCollectionInfo(new ModelAndView("jsonView"), result, "opnnSbmsn");
|
||||||
|
}
|
||||||
|
|
||||||
|
/**의견제출 대장를 등록한다.
|
||||||
|
* @param opnnSbmsn 의견제출 대장 정보
|
||||||
|
* @return jsonView
|
||||||
|
* <pre><code> {
|
||||||
|
* "saved": 등록되었으면 true, 그렇지 않으면 false
|
||||||
|
* }</code></pre>
|
||||||
|
*/
|
||||||
|
@PostMapping(name="의견제출 대장 등록", value="/010/create.do")
|
||||||
|
public ModelAndView create(Excl excl) {
|
||||||
|
boolean saved = excl02Service.create(excl);
|
||||||
|
|
||||||
|
return new ModelAndView("jsonView")
|
||||||
|
.addObject("saved", saved);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**의견제출 대장 정보를 수정한다.
|
||||||
|
* @param opnnSbmsn 의견제출 대장 정보
|
||||||
|
* @return jsonView
|
||||||
|
* <pre><code> {
|
||||||
|
* "saved": 수정되었으면 true, 그렇지 않으면 false
|
||||||
|
* }</code></pre>
|
||||||
|
*/
|
||||||
|
@PostMapping(name="의견제출 대장 수정", value="/010/update.do")
|
||||||
|
public ModelAndView update(Excl excl) {
|
||||||
|
boolean saved = excl02Service.update(excl);
|
||||||
|
|
||||||
|
return new ModelAndView("jsonView")
|
||||||
|
.addObject("saved", saved);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**지정한 의견제출 대장를 제거한다.
|
||||||
|
* @param opnnSbmsnIDs 의견제출 대장 아이디
|
||||||
|
* @return jsonView
|
||||||
|
* <pre><code> {
|
||||||
|
* "affected": 저장된 정보수
|
||||||
|
* "saved": 저장되었으면 true, 그렇지 않으면 false
|
||||||
|
* }</code></pre>
|
||||||
|
*/
|
||||||
|
@PostMapping(name="의견제출 대장 제거", value="/010/remove.do")
|
||||||
|
public ModelAndView remove(Excl excl) {
|
||||||
|
boolean saved = excl02Service.remove(excl);
|
||||||
|
|
||||||
|
return new ModelAndView("jsonView")
|
||||||
|
.addObject("saved", saved);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,332 @@
|
|||||||
|
<?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.excl.dao.Excl02Mapper">
|
||||||
|
|
||||||
|
<!-- 의견제출 대장 정보 매퍼
|
||||||
|
========== 변경 이력 ==========
|
||||||
|
2023-06-27 JoJH 최초 작성
|
||||||
|
============================ -->
|
||||||
|
|
||||||
|
<resultMap id="opnnSbmsnRow" type="cokr.xit.fims.excl.Excl">
|
||||||
|
<!-- TB_OPNN_SBMSN 의견제출 대장 -->
|
||||||
|
<result property="opnnId" column="OPNN_ID" /> <!-- 의견 ID -->
|
||||||
|
<result property="crdnId" column="CRDN_ID" /> <!-- 단속 ID -->
|
||||||
|
<result property="rcptNo" column="RCPT_NO" /> <!-- 접수 번호 -->
|
||||||
|
<result property="rcptYmd" column="RCPT_YMD" /> <!-- 접수 일자 -->
|
||||||
|
<result property="rcptSeCd" column="RCPT_SE_CD" /> <!-- 접수 구분 코드 -->
|
||||||
|
<result property="rcptSeNm" column="RCPT_SE_NM" /> <!-- 접수 구분 명 -->
|
||||||
|
<result property="ownrRelCd" column="OWNR_REL_CD" /> <!-- 소유주 관계 코드 -->
|
||||||
|
<result property="ownrRelNm" column="OWNR_REL_NM" /> <!-- 소유주 관계 명 -->
|
||||||
|
<result property="sttrNm" column="STTR_NM" /> <!-- 진술자 명 -->
|
||||||
|
<result property="sttrBrdt" column="STTR_BRDT" /> <!-- 진술자 생년월일 -->
|
||||||
|
<result property="sttrBrdtFormat" column="STTR_BRDT_FORMAT" /> <!-- 진술자 생년월일 -->
|
||||||
|
<result property="sttrRrno" column="STTR_RRNO" /> <!-- 진술자 주민등록번호 -->
|
||||||
|
<result property="sttrAddr" column="STTR_ADDR" /> <!-- 진술자 주소 -->
|
||||||
|
<result property="sttrDaddr" column="STTR_DADDR" /> <!-- 진술자 상세주소 -->
|
||||||
|
<result property="sttrZip" column="STTR_ZIP" /> <!-- 진술자 우편번호 -->
|
||||||
|
<result property="sttrCttpc" column="STTR_CTTPC" /> <!-- 진술자 연락처 -->
|
||||||
|
<result property="sttrEml" column="STTR_EML" /> <!-- 진술자 이메일 -->
|
||||||
|
<result property="opnnSbmsnCn" column="OPNN_SBMSN_CN" /> <!-- 의견 제출 내용 -->
|
||||||
|
<result property="opnnSbmsnSeCd" column="OPNN_SBMSN_SE_CD" /> <!-- 의견 제출 구분 코드 -->
|
||||||
|
<result property="opnnSbmsnSeNm" column="OPNN_SBMSN_SE_NM" /> <!-- 의견 제출 구분 명 -->
|
||||||
|
<result property="opnnSbmsnGist" column="OPNN_SBMSN_GIST" /> <!-- 의견 제출 요지 -->
|
||||||
|
<result property="atchFileCnt" column="ATCH_FILE_CNT" /> <!-- 첨부 파일 수 -->
|
||||||
|
<result property="docNo" column="DOC_NO" /> <!-- 문서 번호 -->
|
||||||
|
<result property="ntfctnSeCd" column="NTFCTN_SE_CD" /> <!-- 통보 구분 코드 -->
|
||||||
|
<result property="ntfctnSeNm" column="NTFCTN_SE_NM" /> <!-- 통보 구분 명 -->
|
||||||
|
<result property="picRvwOpnn" column="PIC_RVW_OPNN" /> <!-- 담당자 검토 의견 -->
|
||||||
|
<result property="ansCn" column="ANS_CN" /> <!-- 답변 내용 -->
|
||||||
|
<result property="ansYmd" column="ANS_YMD" /> <!-- 답변 일자 -->
|
||||||
|
<result property="ansTm" column="ANS_TM" /> <!-- 답변 시각 -->
|
||||||
|
<result property="opnnSbmsnSttsCd" column="OPNN_SBMSN_STTS_CD" /> <!-- 의견 제출 상태 코드 -->
|
||||||
|
<result property="opnnSbmsnSttsNm" column="OPNN_SBMSN_STTS_NM" /> <!-- 의견 제출 상태 명 -->
|
||||||
|
<result property="delYn" column="DEL_YN" /> <!-- 삭제 여부 -->
|
||||||
|
<result property="regDt" column="REG_DT" /> <!-- 등록 일시 -->
|
||||||
|
<result property="rgtr" column="RGTR" /> <!-- 등록자 -->
|
||||||
|
<result property="mdfcnDt" column="MDFCN_DT" /> <!-- 수정 일시 -->
|
||||||
|
<result property="mdfr" column="MDFR" /> <!-- 수정자 -->
|
||||||
|
<result property="delDt" column="DEL_DT" /> <!-- 삭제 일시 -->
|
||||||
|
<result property="dltr" column="DLTR" /> <!-- 삭제자 -->
|
||||||
|
<result property="delRsn" column="DEL_RSN" /> <!-- 삭제 사유 -->
|
||||||
|
</resultMap>
|
||||||
|
|
||||||
|
<sql id="select">
|
||||||
|
SELECT A.OPNN_ID /* 의견 ID */
|
||||||
|
, A.CRDN_ID /* 단속 ID */
|
||||||
|
, A.RCPT_NO /* 접수 번호 */
|
||||||
|
, A.RCPT_YMD /* 접수 일자 */
|
||||||
|
, A.RCPT_SE_CD /* 접수 구분 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM029', A.RCPT_SE_CD) FROM DUAL) AS RCPT_SE_NM /* 접수 구분 코드 */
|
||||||
|
, A.OWNR_REL_CD /* 소유주 관계 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM032', A.OWNR_REL_CD) FROM DUAL) AS OWNR_REL_NM /* 소유주 관계 코드 */
|
||||||
|
, A.STTR_NM /* 진술자 명 */
|
||||||
|
, A.STTR_BRDT /* 진술자 생년월일 */
|
||||||
|
, (SELECT FN_GET_BRDT_FORMAT(A.STTR_BRDT, '.') FROM DUAL) AS STTR_BRDT_FORMAT /* 납부자 생년월일 */
|
||||||
|
, A.STTR_RRNO /* 진술자 주민등록번호 */
|
||||||
|
, A.STTR_ADDR /* 진술자 주소 */
|
||||||
|
, A.STTR_DADDR /* 진술자 상세주소 */
|
||||||
|
, A.STTR_ZIP /* 진술자 우편번호 */
|
||||||
|
, A.STTR_CTTPC /* 진술자 연락처 */
|
||||||
|
, A.STTR_EML /* 진술자 이메일 */
|
||||||
|
, A.OPNN_SBMSN_CN /* 의견 제출 내용 */
|
||||||
|
, A.OPNN_SBMSN_SE_CD /* 의견 제출 구분 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM033', A.OPNN_SBMSN_SE_CD) FROM DUAL) AS OPNN_SBMSN_SE_NM /* 의견 제출 구분 명 */
|
||||||
|
, A.OPNN_SBMSN_GIST /* 의견 제출 요지 */
|
||||||
|
, A.ATCH_FILE_CNT /* 첨부 파일 수 */
|
||||||
|
, A.DOC_NO /* 문서 번호 */
|
||||||
|
, A.NTFCTN_SE_CD /* 통보 구분 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM030', A.NTFCTN_SE_CD) FROM DUAL) AS NTFCTN_SE_NM /* 통보 구분 코드 */
|
||||||
|
, A.PIC_RVW_OPNN /* 담당자 검토 의견 */
|
||||||
|
, A.ANS_CN /* 답변 내용 */
|
||||||
|
, A.ANS_YMD /* 답변 일자 */
|
||||||
|
, A.ANS_TM /* 답변 시각 */
|
||||||
|
, (CONCAT(A.ANS_YMD, A.ANS_TM)) AS ANS_YMD_TM /* 답변 일시 */
|
||||||
|
, A.OPNN_SBMSN_STTS_CD /* 의견 제출 상태 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM031', A.OPNN_SBMSN_STTS_CD) FROM DUAL) AS OPNN_SBMSN_STTS_NM /* 의견 제출 상태 명 */
|
||||||
|
, A.DEL_YN /* 삭제 여부 */
|
||||||
|
, A.REG_DT /* 등록 일시 */
|
||||||
|
, A.RGTR /* 등록자 */
|
||||||
|
, A.MDFCN_DT /* 수정 일시 */
|
||||||
|
, A.MDFR /* 수정자 */
|
||||||
|
, A.DEL_DT /* 삭제 일시 */
|
||||||
|
, A.DLTR /* 삭제자 */
|
||||||
|
, A.DEL_RSN /* 삭제 사유 */
|
||||||
|
FROM TB_OPNN_SBMSN A
|
||||||
|
</sql>
|
||||||
|
|
||||||
|
<select id="selectOpnnSbmsns" parameterType="map" resultMap="opnnSbmsnRow">/* 의견제출 대장 객체 가져오기(opnnSbmsnMapper.selectOpnnSbmsns) */
|
||||||
|
<include refid="select" />
|
||||||
|
WHERE A.OPNN_ID = #{opnnId} /* 의견 ID */
|
||||||
|
<include refid="utility.orderBy" />
|
||||||
|
</select>
|
||||||
|
|
||||||
|
<sql id="selectList">
|
||||||
|
SELECT A.OPNN_ID /* 의견 ID */
|
||||||
|
, A.CRDN_ID /* 단속 ID */
|
||||||
|
, A.RCPT_NO /* 접수 번호 */
|
||||||
|
, A.RCPT_YMD /* 접수 일자 */
|
||||||
|
, A.RCPT_SE_CD /* 접수 구분 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM029', A.RCPT_SE_CD) FROM DUAL) AS RCPT_SE_NM /* 접수 구분 코드 */
|
||||||
|
, A.OWNR_REL_CD /* 소유주 관계 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM032', A.OWNR_REL_CD) FROM DUAL) AS OWNR_REL_NM /* 소유주 관계 코드 */
|
||||||
|
, A.STTR_NM /* 진술자 명 */
|
||||||
|
, A.STTR_BRDT /* 진술자 생년월일 */
|
||||||
|
, (SELECT FN_GET_BRDT_FORMAT(A.STTR_BRDT, '.') FROM DUAL) AS STTR_BRDT_FORMAT /* 납부자 생년월일 */
|
||||||
|
, A.STTR_RRNO /* 진술자 주민등록번호 */
|
||||||
|
, A.STTR_ADDR /* 진술자 주소 */
|
||||||
|
, A.STTR_DADDR /* 진술자 상세주소 */
|
||||||
|
, A.STTR_ZIP /* 진술자 우편번호 */
|
||||||
|
, A.STTR_CTTPC /* 진술자 연락처 */
|
||||||
|
, A.STTR_EML /* 진술자 이메일 */
|
||||||
|
, A.OPNN_SBMSN_CN /* 의견 제출 내용 */
|
||||||
|
, A.OPNN_SBMSN_SE_CD /* 의견 제출 구분 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM033', A.OPNN_SBMSN_SE_CD) FROM DUAL) AS OPNN_SBMSN_SE_NM /* 의견 제출 구분 명 */
|
||||||
|
, A.OPNN_SBMSN_GIST /* 의견 제출 요지 */
|
||||||
|
, A.ATCH_FILE_CNT /* 첨부 파일 수 */
|
||||||
|
, A.DOC_NO /* 문서 번호 */
|
||||||
|
, A.NTFCTN_SE_CD /* 통보 구분 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM030', A.NTFCTN_SE_CD) FROM DUAL) AS NTFCTN_SE_NM /* 통보 구분 코드 */
|
||||||
|
, A.PIC_RVW_OPNN /* 담당자 검토 의견 */
|
||||||
|
, A.ANS_CN /* 답변 내용 */
|
||||||
|
, A.ANS_YMD /* 답변 일자 */
|
||||||
|
, A.ANS_TM /* 답변 시각 */
|
||||||
|
, (CONCAT(A.ANS_YMD, A.ANS_TM)) AS ANS_YMD_TM /* 답변 일시 */
|
||||||
|
, A.OPNN_SBMSN_STTS_CD /* 의견 제출 상태 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM031', A.OPNN_SBMSN_STTS_CD) FROM DUAL) AS OPNN_SBMSN_STTS_NM /* 의견 제출 상태 명 */
|
||||||
|
, A.DEL_YN /* 삭제 여부 */
|
||||||
|
, A.REG_DT /* 등록 일시 */
|
||||||
|
, A.RGTR /* 등록자 */
|
||||||
|
, A.MDFCN_DT /* 수정 일시 */
|
||||||
|
, A.MDFR /* 수정자 */
|
||||||
|
, A.DEL_DT /* 삭제 일시 */
|
||||||
|
, A.DLTR /* 삭제자 */
|
||||||
|
, A.DEL_RSN /* 삭제 사유 */
|
||||||
|
, C.SGG_CD /* 시군구 코드 */
|
||||||
|
, C.TASK_SE_CD /* 업무 구분 코드 */
|
||||||
|
, C.CRDN_SE_CD /* 단속 구분 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM002', C.CRDN_SE_CD) FROM DUAL) AS CRDN_SE_NM /* 단속 구분 코드 */
|
||||||
|
, C.CRDN_YMD /* 단속 일자 */
|
||||||
|
, C.CRDN_TM /* 단속 시각 */
|
||||||
|
, (CONCAT(C.CRDN_YMD, C.CRDN_TM)) AS CRDN_YMD_TM /* 단속 일시 */
|
||||||
|
, C.VHRNO /* 차량번호 */
|
||||||
|
, C.CRDN_STDG_NM /* 단속 법정동 명 */
|
||||||
|
, C.CRDN_ROAD_NM /* 단속 도로 명 */
|
||||||
|
, C.CRDN_PLC /* 단속 장소 */
|
||||||
|
, C.DTL_CRDN_PLC /* 상세 단속 장소 */
|
||||||
|
, C.CRDN_STTS_CD /* 단속 상태 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM010', C.CRDN_STTS_CD) FROM DUAL) AS CRDN_STTS_NM /* 단속 상태 명 */
|
||||||
|
, D.RTPYR_ID /* 납부자 ID */
|
||||||
|
, D.RTPYR_SE_CD /* 납부자 구분 코드 */
|
||||||
|
, (SELECT FN_GET_CODE_NM('FIM011', D.RTPYR_SE_CD) FROM DUAL) AS RTPYR_SE_NM /* 납부자 구분 명 */
|
||||||
|
, D.RTPYR_NO /* 납부자 번호 */
|
||||||
|
, D.RTPYR_NM /* 납부자 명 */
|
||||||
|
, (SELECT FN_GET_BRDT_FORMAT(D.RTPYR_BRDT, '.') FROM DUAL) AS RTPYR_BRDT_FORMAT /* 납부자 생년월일 */
|
||||||
|
, D.ZIP /* 우편번호 */
|
||||||
|
, D.ADDR /* 주소 */
|
||||||
|
, D.DTL_ADDR /* 상세 주소 */
|
||||||
|
FROM TB_OPNN_SBMSN A
|
||||||
|
INNER JOIN TB_CRDN C ON (A.CRDN_ID = C.CRDN_ID)
|
||||||
|
LEFT OUTER JOIN TB_PAYER D ON (C.RTPYR_ID = D.RTPYR_ID)
|
||||||
|
</sql>
|
||||||
|
|
||||||
|
<select id="selectOpnnSbmsnList" parameterType="map" resultType="dataobject">/* 의견제출 대장 목록 조회(opnnSbmsnMapper.selectOpnnSbmsnList) */
|
||||||
|
<include refid="utility.paging-prefix" />
|
||||||
|
<include refid="selectList" />
|
||||||
|
|
||||||
|
WHERE C.SGG_CD = #{sggCd} /* 시군구 코드 */
|
||||||
|
AND C.TASK_SE_CD = #{taskSeCd} /* 업무 구분 코드 */
|
||||||
|
<choose>
|
||||||
|
<when test="schDateOpt == 'rcptYmd'">
|
||||||
|
<if test="schDateFrom != null">
|
||||||
|
AND A.RCPT_YMD <![CDATA[ >= ]]> #{schDateFrom}
|
||||||
|
</if>
|
||||||
|
<if test="schDateTo != null">
|
||||||
|
AND A.RCPT_YMD <![CDATA[ <= ]]> #{schDateTo}
|
||||||
|
</if>
|
||||||
|
</when>
|
||||||
|
<when test="schDateOpt == 'ansYmd'">
|
||||||
|
<if test="schDateFrom != null">
|
||||||
|
AND A.ANS_YMD <![CDATA[ >= ]]> #{schDateFrom}
|
||||||
|
</if>
|
||||||
|
<if test="schDateTo != null">
|
||||||
|
AND A.ANS_YMD <![CDATA[ <= ]]> #{schDateTo}
|
||||||
|
</if>
|
||||||
|
</when>
|
||||||
|
<when test="schDateOpt == 'crdnYmd'">
|
||||||
|
<if test="schDateFrom != null">
|
||||||
|
AND C.CRDN_YMD <![CDATA[ >= ]]> #{schDateFrom}
|
||||||
|
</if>
|
||||||
|
<if test="schDateTo != null">
|
||||||
|
AND C.CRDN_YMD <![CDATA[ <= ]]> #{schDateTo}
|
||||||
|
</if>
|
||||||
|
</when>
|
||||||
|
<otherwise>
|
||||||
|
</otherwise>
|
||||||
|
</choose>
|
||||||
|
<if test="opnnSbmsnSttsCd != null">
|
||||||
|
AND A.OPNN_SBMSN_STTS_CD = #{opnnSbmsnSttsCd}
|
||||||
|
</if>
|
||||||
|
|
||||||
|
<include refid="utility.orderBy" />
|
||||||
|
<include refid="utility.paging-suffix" />
|
||||||
|
</select>
|
||||||
|
|
||||||
|
<insert id="insertOpnnSbmsn" parameterType="map">/* 의견제출 대장 등록(opnnSbmsnMapper.insertOpnnSbmsn) */
|
||||||
|
INSERT
|
||||||
|
INTO TB_OPNN_SBMSN (
|
||||||
|
OPNN_ID <!-- 의견 ID -->
|
||||||
|
, CRDN_ID <!-- 단속 ID -->
|
||||||
|
, RCPT_NO <!-- 접수 번호 -->
|
||||||
|
, RCPT_YMD <!-- 접수 일자 -->
|
||||||
|
, RCPT_SE_CD <!-- 접수 구분 코드 -->
|
||||||
|
, OWNR_REL_CD <!-- 소유주 관계 코드 -->
|
||||||
|
, STTR_NM <!-- 진술자 명 -->
|
||||||
|
, STTR_BRDT <!-- 진술자 생년월일 -->
|
||||||
|
, STTR_RRNO <!-- 진술자 주민등록번호 -->
|
||||||
|
, STTR_ADDR <!-- 진술자 주소 -->
|
||||||
|
, STTR_DADDR <!-- 진술자 상세주소 -->
|
||||||
|
, STTR_ZIP <!-- 진술자 우편번호 -->
|
||||||
|
, STTR_CTTPC <!-- 진술자 연락처 -->
|
||||||
|
, STTR_EML <!-- 진술자 이메일 -->
|
||||||
|
, OPNN_SBMSN_CN <!-- 의견 제출 내용 -->
|
||||||
|
, OPNN_SBMSN_SE_CD <!-- 의견 제출 구분 코드 -->
|
||||||
|
, OPNN_SBMSN_GIST <!-- 의견 제출 요지 -->
|
||||||
|
, ATCH_FILE_CNT <!-- 첨부 파일 수 -->
|
||||||
|
, DOC_NO <!-- 문서 번호 -->
|
||||||
|
, NTFCTN_SE_CD <!-- 통보 구분 코드 -->
|
||||||
|
, PIC_RVW_OPNN <!-- 담당자 검토 의견 -->
|
||||||
|
, ANS_CN <!-- 답변 내용 -->
|
||||||
|
, ANS_YMD <!-- 답변 일자 -->
|
||||||
|
, ANS_TM <!-- 답변 시각 -->
|
||||||
|
, OPNN_SBMSN_STTS_CD <!-- 의견 제출 상태 코드 -->
|
||||||
|
, DEL_YN <!-- 삭제 여부 -->
|
||||||
|
, REG_DT <!-- 등록 일시 -->
|
||||||
|
, RGTR <!-- 등록자 -->
|
||||||
|
, MDFCN_DT <!-- 수정 일시 -->
|
||||||
|
, MDFR <!-- 수정자 -->
|
||||||
|
, DEL_DT <!-- 삭제 일시 -->
|
||||||
|
, DLTR <!-- 삭제자 -->
|
||||||
|
, DEL_RSN <!-- 삭제 사유 -->
|
||||||
|
)
|
||||||
|
VALUES (
|
||||||
|
#{opnnSbmsn.opnnId} <!-- 의견 ID -->
|
||||||
|
, #{opnnSbmsn.crdnId} <!-- 단속 ID -->
|
||||||
|
, #{opnnSbmsn.rcptNo} <!-- 접수 번호 -->
|
||||||
|
, #{opnnSbmsn.rcptYmd} <!-- 접수 일자 -->
|
||||||
|
, #{opnnSbmsn.rcptSeCd} <!-- 접수 구분 코드 -->
|
||||||
|
, #{opnnSbmsn.ownrRelCd} <!-- 소유주 관계 코드 -->
|
||||||
|
, #{opnnSbmsn.sttrNm} <!-- 진술자 명 -->
|
||||||
|
, #{opnnSbmsn.sttrBrdt} <!-- 진술자 생년월일 -->
|
||||||
|
, #{opnnSbmsn.sttrRrno} <!-- 진술자 주민등록번호 -->
|
||||||
|
, #{opnnSbmsn.sttrAddr} <!-- 진술자 주소 -->
|
||||||
|
, #{opnnSbmsn.sttrDaddr} <!-- 진술자 상세주소 -->
|
||||||
|
, #{opnnSbmsn.sttrZip} <!-- 진술자 우편번호 -->
|
||||||
|
, #{opnnSbmsn.sttrCttpc} <!-- 진술자 연락처 -->
|
||||||
|
, #{opnnSbmsn.sttrEml} <!-- 진술자 이메일 -->
|
||||||
|
, #{opnnSbmsn.opnnSbmsnCn} <!-- 의견 제출 내용 -->
|
||||||
|
, #{opnnSbmsn.opnnSbmsnSeCd} <!-- 의견 제출 구분 코드 -->
|
||||||
|
, #{opnnSbmsn.opnnSbmsnGist} <!-- 의견 제출 요지 -->
|
||||||
|
, #{opnnSbmsn.atchFileCnt} <!-- 첨부 파일 수 -->
|
||||||
|
, #{opnnSbmsn.docNo} <!-- 문서 번호 -->
|
||||||
|
, #{opnnSbmsn.ntfctnSeCd} <!-- 통보 구분 코드 -->
|
||||||
|
, #{opnnSbmsn.picRvwOpnn} <!-- 담당자 검토 의견 -->
|
||||||
|
, #{opnnSbmsn.ansCn} <!-- 답변 내용 -->
|
||||||
|
, #{opnnSbmsn.ansYmd} <!-- 답변 일시 -->
|
||||||
|
, #{opnnSbmsn.ansTm} <!-- 답변 일시 -->
|
||||||
|
, #{opnnSbmsn.opnnSbmsnSttsCd} <!-- 의견 제출 상태 코드 -->
|
||||||
|
, #{opnnSbmsn.delYn} <!-- 삭제 여부 -->
|
||||||
|
, <include refid="utility.now" /> <!-- 등록 일시 -->
|
||||||
|
, #{currentUser.id} <!-- 등록자 -->
|
||||||
|
, <include refid="utility.now" /> <!-- 수정 일시 -->
|
||||||
|
, #{currentUser.id} <!-- 수정자 -->
|
||||||
|
, #{opnnSbmsn.delDt} <!-- 삭제 일시 -->
|
||||||
|
, #{opnnSbmsn.dltr} <!-- 삭제자 -->
|
||||||
|
, #{opnnSbmsn.delRsn} <!-- 삭제 사유 -->
|
||||||
|
)
|
||||||
|
</insert>
|
||||||
|
|
||||||
|
<update id="updateOpnnSbmsn" parameterType="map">/* 의견제출 대장 수정(opnnSbmsnMapper.updateOpnnSbmsn) */
|
||||||
|
UPDATE TB_OPNN_SBMSN
|
||||||
|
SET CRDN_ID = #{opnnSbmsn.crdnId} <!-- 단속 ID -->
|
||||||
|
, RCPT_NO = #{opnnSbmsn.rcptNo} <!-- 접수 번호 -->
|
||||||
|
, RCPT_YMD = #{opnnSbmsn.rcptYmd} <!-- 접수 일자 -->
|
||||||
|
, RCPT_SE_CD = #{opnnSbmsn.rcptSeCd} <!-- 접수 구분 코드 -->
|
||||||
|
, OWNR_REL_CD = #{opnnSbmsn.ownrRelCd} <!-- 소유주 관계 코드 -->
|
||||||
|
, STTR_NM = #{opnnSbmsn.sttrNm} <!-- 진술자 명 -->
|
||||||
|
, STTR_BRDT = #{opnnSbmsn.sttrBrdt} <!-- 진술자 생년월일 -->
|
||||||
|
, STTR_RRNO = #{opnnSbmsn.sttrRrno} <!-- 진술자 주민등록번호 -->
|
||||||
|
, STTR_ADDR = #{opnnSbmsn.sttrAddr} <!-- 진술자 주소 -->
|
||||||
|
, STTR_DADDR = #{opnnSbmsn.sttrDaddr} <!-- 진술자 상세주소 -->
|
||||||
|
, STTR_ZIP = #{opnnSbmsn.sttrZip} <!-- 진술자 우편번호 -->
|
||||||
|
, STTR_CTTPC = #{opnnSbmsn.sttrCttpc} <!-- 진술자 연락처 -->
|
||||||
|
, STTR_EML = #{opnnSbmsn.sttrEml} <!-- 진술자 이메일 -->
|
||||||
|
, OPNN_SBMSN_CN = #{opnnSbmsn.opnnSbmsnCn} <!-- 의견 제출 내용 -->
|
||||||
|
, OPNN_SBMSN_TYPE = #{opnnSbmsn.opnnSbmsnType} <!-- 의견 제출 유형 -->
|
||||||
|
, OPNN_SBMSN_GIST = #{opnnSbmsn.opnnSbmsnGist} <!-- 의견 제출 요지 -->
|
||||||
|
, ATCH_FILE_CNT = #{opnnSbmsn.atchFileCnt} <!-- 첨부 파일 수 -->
|
||||||
|
, DOC_NO = #{opnnSbmsn.docNo} <!-- 문서 번호 -->
|
||||||
|
, NTFCTN_SE_CD = #{opnnSbmsn.ntfctnSeCd} <!-- 통보 구분 코드 -->
|
||||||
|
, PIC_RVW_OPNN = #{opnnSbmsn.picRvwOpnn} <!-- 담당자 검토 의견 -->
|
||||||
|
, ANS_CN = #{opnnSbmsn.ansCn} <!-- 답변 내용 -->
|
||||||
|
, ANS_YMD = #{opnnSbmsn.ansYmd} <!-- 답변 일시 -->
|
||||||
|
, ANS_TM = #{opnnSbmsn.ansTm} <!-- 답변 일시 -->
|
||||||
|
, OPNN_SBMSN_STTS_CD = #{opnnSbmsn.opnnSbmsnSttsCd} <!-- 의견 제출 상태 코드 -->
|
||||||
|
, DEL_YN = #{opnnSbmsn.delYn} <!-- 삭제 여부 -->
|
||||||
|
, MDFCN_DT = <include refid="utility.now" /> <!-- 수정 일시 -->
|
||||||
|
, MDFR = #{currentUser.id} <!-- 수정자 -->
|
||||||
|
, DEL_DT = #{opnnSbmsn.delDt} <!-- 삭제 일시 -->
|
||||||
|
, DLTR = #{opnnSbmsn.dltr} <!-- 삭제자 -->
|
||||||
|
, DEL_RSN = #{opnnSbmsn.delRsn} <!-- 삭제 사유 -->
|
||||||
|
WHERE OPNN_ID = #{opnnSbmsn.opnnId} /* 의견 ID */
|
||||||
|
</update>
|
||||||
|
|
||||||
|
<update id="deleteOpnnSbmsn" parameterType="map">/* 의견제출 대장 삭제(opnnSbmsnMapper.deleteOpnnSbmsn) */
|
||||||
|
UPDATE TB_OPNN_SBMSN
|
||||||
|
SET DEL_YN = 'Y'
|
||||||
|
, DEL_DT = <include refid="utility.now" /> /* 삭제 일시 */
|
||||||
|
, DLTR = #{currentUser.id} /* 삭제자 */
|
||||||
|
, DEL_RSN = #{opnnSbmsn.delRsn} /* 삭제 사유 */
|
||||||
|
WHERE OPNN_ID = #{opnnSbmsn.opnnId} /* 의견 ID */
|
||||||
|
</update>
|
||||||
|
|
||||||
|
</mapper>
|
@ -0,0 +1,395 @@
|
|||||||
|
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
|
||||||
|
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
|
||||||
|
|
||||||
|
<!-- inner page html -->
|
||||||
|
<div class="content-wrapper">
|
||||||
|
<!-- Content -->
|
||||||
|
<div class="container-xxl flex-grow-1 px-0">
|
||||||
|
<%--h4 id="pageTitle" class="fw-bold py-3 mb-4">페이지 제목</h4--%>
|
||||||
|
<c:set var="prefixName" scope="request">의견제출</c:set>
|
||||||
|
<!-- Page Body -->
|
||||||
|
<div class="card">
|
||||||
|
<div class="wrapper-list">
|
||||||
|
<div>
|
||||||
|
<!-- 상단 버튼 -->
|
||||||
|
<div class="container-page-btn">
|
||||||
|
<button type="button" class="btn btn-outline-dark" id="btnReset--${pageName}" title="초기화">초기화</button>
|
||||||
|
<span class="container-window-btn-right">
|
||||||
|
<button type="button" class="btn btn-search" id="btnSearch--${pageName}" title="검색">검색</button>
|
||||||
|
<button type="button" class="btn btn-search" id="btnExcel--${pageName}" title="엑셀">엑셀</button>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<!-- / 상단 버튼 -->
|
||||||
|
|
||||||
|
<!-- 검색 조건 영역 -->
|
||||||
|
<form id="frmSearch--${pageName}" name="frmSearch">
|
||||||
|
<!-- 메인 조건 -->
|
||||||
|
<div class="container-search">
|
||||||
|
<div class="row g-1">
|
||||||
|
<!-- 업무구분 -->
|
||||||
|
<div class="col-1">
|
||||||
|
<label class="form-label fw-bold form-search-title text-end" for="rdoTaskSeCd--${pageName}">업무구분</label>
|
||||||
|
</div>
|
||||||
|
<div class="col-11">
|
||||||
|
<span class="form-search-linebox">
|
||||||
|
<c:forEach items="${FIM054List}" var="item">
|
||||||
|
<label>
|
||||||
|
<input type="radio" class="form-check-input" id="rdoTaskSeCd--${pageName}" name="taskSeCd" alt="업무구분"
|
||||||
|
value="${item.code}"
|
||||||
|
onchange="pageObject['${pageName}'].fnResetAndChangeBiz(this.value);"
|
||||||
|
required>
|
||||||
|
${item.value}
|
||||||
|
</label>
|
||||||
|
</c:forEach>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<!-- 의견제출일자 -->
|
||||||
|
<div class="col-1">
|
||||||
|
<select class="form-select" id="schDateOpt--${pageName}" name="schDateOpt">
|
||||||
|
<option value="rcptYmd">접수일자</option>
|
||||||
|
<option value="ansYmd">답변일자</option>
|
||||||
|
<option value="crdnYmd">단속일자</option>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<div class="col-5">
|
||||||
|
<span class="form-search-linebox">
|
||||||
|
<input type="text" class="form-control form-date" id="schDateFrom--${pageName}" name="schDateFrom"
|
||||||
|
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="schDateTo--${pageName}" name="schDateTo"
|
||||||
|
data-fmt-type="day" title="종료 날짜 선택" />
|
||||||
|
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<!-- 진술자명 -->
|
||||||
|
<div class="col-1">
|
||||||
|
<label class="form-label fw-bold form-search-title text-end">진술자명</label>
|
||||||
|
</div>
|
||||||
|
<div class="col-5">
|
||||||
|
<input type="text" id="sttrNm--${pageName}" name="sttrNm" class="form-control" />
|
||||||
|
</div>
|
||||||
|
<!-- 의견제출상태 -->
|
||||||
|
<div class="col-1">
|
||||||
|
<label class="form-label fw-bold form-search-title text-end">의견제출상태</label>
|
||||||
|
</div>
|
||||||
|
<div class="col-5">
|
||||||
|
<select id="opnnSbmsnSttsCd--${pageName}" name="opnnSbmsnSttsCd" class="form-select">
|
||||||
|
<option value="">전체</option>
|
||||||
|
<c:forEach items="${FIM031List}" var="item">
|
||||||
|
<option value="${item.code}">${item.value}</option>
|
||||||
|
</c:forEach>
|
||||||
|
</select>
|
||||||
|
</div>
|
||||||
|
<!-- 차량번호 -->
|
||||||
|
<div class="col-1">
|
||||||
|
<label class="form-label fw-bold form-search-title text-end">차량번호</label>
|
||||||
|
</div>
|
||||||
|
<div class="col-5">
|
||||||
|
<input type="text" class="form-control" id="vhrno--${pageName}" name="vhrno" />
|
||||||
|
</div>
|
||||||
|
<!-- 동적검색 -->
|
||||||
|
<div class="col-12">
|
||||||
|
<input type="hidden" id="by--${pageName}" name="by" />
|
||||||
|
<input type="text" class="form-control" id="byOutput--${pageName}" value="동적 검색" readonly />
|
||||||
|
<input type="text" class="form-control" 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>
|
||||||
|
<!-- / 메인 조건 -->
|
||||||
|
|
||||||
|
<!-- 상세 조건 -->
|
||||||
|
<div id="searchDetail--${pageName}" class="container-search container-search-detail collapse">
|
||||||
|
<div class="row">
|
||||||
|
<!-- 등록일자, 수정일자 -->
|
||||||
|
<div class="col-1">
|
||||||
|
<label class="form-label fw-bold form-search-title text-end">일자검색</label>
|
||||||
|
</div>
|
||||||
|
<div class="col-5">
|
||||||
|
<select class="form-select" id="schDetailDateOpt--${pageName}" name="schDetailDateOpt">
|
||||||
|
<option value="">조건선택</option>
|
||||||
|
<option value="regDt">등록일자</option>
|
||||||
|
<option value="mdfcnDt">수정일자</option>
|
||||||
|
</select>
|
||||||
|
<span class="form-search-linebox">
|
||||||
|
<input type="text" class="form-control form-date" id="schDetailDateFrom--${pageName}" name="schDetailDateFrom"
|
||||||
|
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="schDetailDateTo--${pageName}" name="schDetailDateTo"
|
||||||
|
data-fmt-type="day" title="종료 날짜 선택">
|
||||||
|
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<!-- 등록자명, 수정자명 -->
|
||||||
|
<div class="col-1">
|
||||||
|
<label class="form-label fw-bold form-search-title text-end">사용자검색</label>
|
||||||
|
</div>
|
||||||
|
<div class="col-5">
|
||||||
|
<select class="form-select" id="schUserOpt--${pageName}" name="schUserOpt">
|
||||||
|
<option value="">조건선택</option>
|
||||||
|
<option value="rgtr">등록자명</option>
|
||||||
|
<option value="mdfr">수정자명</option>
|
||||||
|
</select>
|
||||||
|
<input type="text" class="form-control" id="userNm--${pageName}" name="userNm" />
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- / 상세 조건 -->
|
||||||
|
</form>
|
||||||
|
<!-- / 검색 조건 영역 -->
|
||||||
|
|
||||||
|
<!-- 업무 버튼 및 건수 표시 -->
|
||||||
|
<div>
|
||||||
|
<span class="container-page-btn">
|
||||||
|
<!-- 업무 버튼 -->
|
||||||
|
<a href="#" class="btn btn-blue" id="" title="업무처리1">업무 처리1</a>
|
||||||
|
<a href="#" class="btn btn-blue" id="" title="업무처리2">업무 처리2</a>
|
||||||
|
|
||||||
|
<span class="container-window-btn-right">
|
||||||
|
<!-- 건수, 페이지 표시 -->
|
||||||
|
<div class="d-flex flex-row justify-content-between">
|
||||||
|
<label id="paging--${pageName}PagingInfo" class="dataTables_info" role="status" aria-live="polite"></label>
|
||||||
|
<ul id="paging--${pageName}" class="pagination pagination-primary">
|
||||||
|
</ul>
|
||||||
|
</div>
|
||||||
|
</span>
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
<!-- / 업무 버튼 및 건수 표시 -->
|
||||||
|
|
||||||
|
<!-- DataTables(그리드) -->
|
||||||
|
<div class="card-datatable text-nowrap">
|
||||||
|
<div id="DataTables_Table_0_wrapper--${pageName}" class="dataTables_wrapper dt-bootstrap5 no-footer">
|
||||||
|
<div id="table-responsive--${pageName}" class="table-responsive" style="overflow-x:scroll; height:400px; overflow-y:scroll;" >
|
||||||
|
<table class="datatables-ajax table table-bordered dataTable no-footer"
|
||||||
|
id="DataTables_Table_0--${pageName}" aria-describedby="DataTables_Table_0_info">
|
||||||
|
<thead>
|
||||||
|
<tr id="theadTr--${pageName}" style="text-align:center;">
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 24px;">NO.</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 24px;">
|
||||||
|
<input type="checkbox" class="form-check-input" onchange="${pageName}Control.select(this.checked);">
|
||||||
|
</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">접수일자</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">접수번호</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">단속일시</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">차량번호</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">진술자명</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 80px;">의견제출상태</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">의견제출분류</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 300px;">의견제출요지</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">등록일시</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">등록자</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">수정일시</th>
|
||||||
|
<th class="sorting" tabindex="0" aria-controls="DataTables_Table_0" rowspan="1" colspan="1" style="width: 120px;">수정자</th>
|
||||||
|
</tr>
|
||||||
|
</thead>
|
||||||
|
<tbody id="tbody--${pageName}">
|
||||||
|
</tbody>
|
||||||
|
<template id="${infoPrefix}Row">
|
||||||
|
<tr data-key="{OPNN_ID}">
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{ROW_NUM}</td>
|
||||||
|
<td style="text-align:center;">
|
||||||
|
<input value="{OPNN_ID}" onchange="${pageName}Control.select('{OPNN_ID}', this.checked);" type="checkbox" class="form-check-input">
|
||||||
|
</td>
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{RCPT_YMD}</td>
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{RCPT_NO}</td>
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{CRDN_YMD_TM}</td>
|
||||||
|
<td style="text-align:left;" {onclick} {ondblclick}>{VHRNO}</td>
|
||||||
|
<td style="text-align:left;" {onclick} {ondblclick}>{STTR_NM}</td>
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{OPNN_SBMSN_STTS_NM}</td>
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{OPNN_SBMSN_SE_NM}</td>
|
||||||
|
<td style="text-align:left;" {onclick} {ondblclick}>{OPNN_SBMSN_GIST}</td>
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{REG_DT}</td>
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{RGTR}</td>
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{MDFCN_DT}</td>
|
||||||
|
<td style="text-align:center;" {onclick} {ondblclick}>{MDFR}</td>
|
||||||
|
</tr>
|
||||||
|
</template>
|
||||||
|
<template id="${infoPrefix}NotFound">
|
||||||
|
<tr class="odd">
|
||||||
|
<td valign="top" colspan="14" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
|
||||||
|
</tr>
|
||||||
|
</template>
|
||||||
|
</table>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- / DataTables(그리드) -->
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
<!-- / Wrapper-list -->
|
||||||
|
</div>
|
||||||
|
<!-- / Card -->
|
||||||
|
</div>
|
||||||
|
<!-- / Content -->
|
||||||
|
|
||||||
|
<jsp:include page="/WEB-INF/jsp/include/bottom.jsp" />
|
||||||
|
|
||||||
|
<div class="content-backdrop fade"></div>
|
||||||
|
</div>
|
||||||
|
<!-- Content wrapper -->
|
||||||
|
|
||||||
|
<!-- js -->
|
||||||
|
<script src="<c:url value="/resources/js/fims/excl/excl02.js?${ver}"/>"></script>
|
||||||
|
|
||||||
|
<script>
|
||||||
|
/**************************************************************************
|
||||||
|
* Global Variable
|
||||||
|
**************************************************************************/
|
||||||
|
// Control 생성
|
||||||
|
var ${pageName}Control = new OpnnSbmsnControl();
|
||||||
|
|
||||||
|
// 공통코드
|
||||||
|
var FIM031 = new CommonCodes(${FIM031});
|
||||||
|
var FIM054 = new CommonCodes(${FIM054});
|
||||||
|
|
||||||
|
|
||||||
|
// script 진입
|
||||||
|
$(document).ready(function() {
|
||||||
|
// 검색조건 초기값 셋팅
|
||||||
|
initSearch${pageName}();
|
||||||
|
|
||||||
|
// 이벤트
|
||||||
|
setEvent${pageName}();
|
||||||
|
});
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
* 초기 셋팅
|
||||||
|
**************************************************************************/
|
||||||
|
// 검색조건 초기값 셋팅
|
||||||
|
function initSearch${pageName}() {
|
||||||
|
// 달력 초기화
|
||||||
|
initDatepicker("frmSearch--${pageName}");
|
||||||
|
|
||||||
|
$("#schDateFrom--${pageName}").datepicker("setDate", DateUtil.getDateDay(-365).date);
|
||||||
|
$("#schDateTo--${pageName}").datepicker("setDate", new Date());
|
||||||
|
$("#schDetailDateFrom--${pageName}").datepicker("setDate", new Date());
|
||||||
|
$("#schDetailDateTo--${pageName}").datepicker("setDate", new Date());
|
||||||
|
|
||||||
|
// 업무구분
|
||||||
|
let defaultBizValue = $("#layout-navbar input[name='taskSeCd']:checked").val();
|
||||||
|
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + defaultBizValue + "']").prop("checked",true);
|
||||||
|
}
|
||||||
|
|
||||||
|
//
|
||||||
|
function setEvent${pageName}() {
|
||||||
|
// 검색 버튼 이벤트
|
||||||
|
$("#btnSearch--${pageName}").on("click", () => searchList${pageName}());
|
||||||
|
|
||||||
|
// 테이블 스크롤 이벤트
|
||||||
|
$("#table-responsive--${pageName}").scroll(function() {
|
||||||
|
let el = $(this);
|
||||||
|
|
||||||
|
if (el.scrollTop() == 0) return;
|
||||||
|
|
||||||
|
if ((el[0].scrollHeight - el.scrollTop() + 15) == el.outerHeight()) {
|
||||||
|
searchList${pageName}(${pageName}Control.query.pageNum + 1);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
* Event
|
||||||
|
**************************************************************************/
|
||||||
|
// Dataset 변경
|
||||||
|
${pageName}Control.onDatasetChange = obj => {
|
||||||
|
renderList${pageName}();
|
||||||
|
|
||||||
|
$("#paging--${pageName}").setPaging({
|
||||||
|
list : ${pageName}Control.dataset
|
||||||
|
// , prefix : ${pageName}Control.prefix
|
||||||
|
, prefix : "paging--${pageName}"
|
||||||
|
, start : obj.${infoPrefix}Start
|
||||||
|
, totalSize : obj.${infoPrefix}Total
|
||||||
|
, fetchSize : obj.${infoPrefix}Fetch
|
||||||
|
, func : "${pageName}Control.load({index})"
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
// DataTables 클릭 이벤트
|
||||||
|
${pageName}Control.onCurrentChange = item => {
|
||||||
|
if (!item) return;
|
||||||
|
|
||||||
|
let key = item.data.USER_ID;
|
||||||
|
$("#${infoPrefix}List").setCurrentRow(key);
|
||||||
|
};
|
||||||
|
|
||||||
|
// DataTables checkbox 클릭 이벤트
|
||||||
|
${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()));
|
||||||
|
});
|
||||||
|
|
||||||
|
${pageName}Control.urls.load = wctx.url("/excl/excl02/020/info.do");
|
||||||
|
|
||||||
|
// $("#btnRemove${infoPrefix}s").prop("disabled", keys.length < 1);
|
||||||
|
};
|
||||||
|
|
||||||
|
//
|
||||||
|
$("#term").onEnterPress(searchList${pageName}());
|
||||||
|
|
||||||
|
/**************************************************************************
|
||||||
|
*
|
||||||
|
**************************************************************************/
|
||||||
|
// 검색조건 파라미터 가져오기
|
||||||
|
function getParams${pageName}() {
|
||||||
|
let formFields = new FimsFormFields("#frmSearch--${pageName}");
|
||||||
|
let data = formFields.get();
|
||||||
|
|
||||||
|
data.sggCd = "41480"; // 시군구 코드 임시
|
||||||
|
data.fetchSize = 30; // 한번에 30건씩 조회
|
||||||
|
|
||||||
|
return data;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 검색
|
||||||
|
function searchList${pageName}(pageNumber) {
|
||||||
|
if (!pageNumber) {
|
||||||
|
pageNumber = 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
${pageName}Control.query = getParams${pageName}();
|
||||||
|
|
||||||
|
${pageName}Control.urls.load = wctx.url("/excl/excl02/010/list.do");
|
||||||
|
${pageName}Control.load(pageNumber);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 테이블에 data 셋팅
|
||||||
|
function renderList${pageName}() {
|
||||||
|
let ${infoPrefix}List = ${pageName}Control.dataset;
|
||||||
|
let empty = ${infoPrefix}List.empty;
|
||||||
|
|
||||||
|
let trs = empty ?
|
||||||
|
[document.getElementById("${infoPrefix}NotFound").innerHTML] : <%-- from template#${infoPrefix}NotFound --%>
|
||||||
|
${infoPrefix}List.inStrings(
|
||||||
|
document.getElementById("${infoPrefix}Row").innerHTML, <%-- from template#${infoPrefix}Row --%>
|
||||||
|
(str, dataItem) => str
|
||||||
|
.replace(/{onclick}/gi, 'onclick="${pageName}Control.setCurrent(\'' + dataItem.getValue("{OPNN_ID}") + '\');"')
|
||||||
|
.replace(/{ondblclick}/gi, 'ondblclick="${pageName}Control.getInfo(\'' + dataItem.getValue("{OPNN_ID}") + '\')"')
|
||||||
|
);
|
||||||
|
|
||||||
|
$("#tbody--${pageName}").html(trs.join());
|
||||||
|
$("th input[type='checkbox']").prop("checked", false);
|
||||||
|
}
|
||||||
|
|
||||||
|
function fnResetAndChangeBiz(taskSeCd) {
|
||||||
|
$("tbody--${pageName}").html("");
|
||||||
|
|
||||||
|
// ${pageName}Control.load = wctx.url("/crdn/crdn06/010/"+ taskSeCd +"/list.do");
|
||||||
|
// ${pageName}Control.getInfo = wctx.url("/sprt/sprt01/020/"+ taskSeCd +"/info.do");
|
||||||
|
}
|
||||||
|
|
||||||
|
</script>
|
@ -0,0 +1,22 @@
|
|||||||
|
class OpnnSbmsnControl extends DatasetControl {
|
||||||
|
constructor(conf) {
|
||||||
|
super(conf || {
|
||||||
|
prefix : "opnnSbmsn"
|
||||||
|
, prefixName : "의견제출"
|
||||||
|
, infoSize : "xl"
|
||||||
|
, keymapper : info => info ? info.OPNN_ID : ""
|
||||||
|
, dataGetter : obj => obj.opnnSbmsnList
|
||||||
|
, appendData : true
|
||||||
|
, formats : {
|
||||||
|
RCPT_YMD : dateFormat
|
||||||
|
, ANS_YMD : dateFormat
|
||||||
|
, ANS_YMD_TM : datetimeFormat
|
||||||
|
, CRDN_YMD_TM : datetimeFormat
|
||||||
|
, REG_DT : datetimeFormat
|
||||||
|
, MDFCN_DT : datetimeFormat
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,49 @@
|
|||||||
|
package cokr.xit.fims.excl.service;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
import javax.annotation.Resource;
|
||||||
|
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
|
||||||
|
import cokr.xit.foundation.data.DataObject;
|
||||||
|
import cokr.xit.foundation.test.TestSupport;
|
||||||
|
|
||||||
|
import cokr.xit.fims.excl.Excl;
|
||||||
|
import cokr.xit.fims.excl.ExclQuery;
|
||||||
|
|
||||||
|
/**OpnnSbmsnService 테스트.
|
||||||
|
*
|
||||||
|
* <p>상세 설명:
|
||||||
|
*
|
||||||
|
* <pre>
|
||||||
|
* ============ 변경 이력 ============
|
||||||
|
* 2023-06-27 JoJH 최초 작성
|
||||||
|
* ================================
|
||||||
|
* </pre>
|
||||||
|
*/
|
||||||
|
public class Excl02ServiceTest extends TestSupport {
|
||||||
|
@Resource(name = "excl02Service")
|
||||||
|
private Excl02Service excl02Service;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void getOpnnSbmsnList() {
|
||||||
|
List<DataObject> opnnSbmsnList = excl02Service.getOpnnSbmsnList(new ExclQuery());
|
||||||
|
opnnSbmsnList.forEach(System.out::println);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void getOpnnSbmsns() {
|
||||||
|
List<Excl> opnnSbmsns = excl02Service.getOpnnSbmsns(new ExclQuery());
|
||||||
|
opnnSbmsns.forEach(System.out::println);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void create() {}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void update() {}
|
||||||
|
|
||||||
|
@Test
|
||||||
|
void remove() {}
|
||||||
|
}
|
Loading…
Reference in New Issue