공시송달 한글파일 출력 추가.

main
jjh 10 months ago
parent 119f68e65e
commit e57ef14ad2

@ -9,7 +9,7 @@ import cokr.xit.fims.sprt.PrintOption;
import cokr.xit.foundation.data.DataObject; import cokr.xit.foundation.data.DataObject;
import kr.dogfoot.hwplib.object.HWPFile; import kr.dogfoot.hwplib.object.HWPFile;
public class DlbrDecsn implements HWPFormatWriter { public class DlbrDecsnList implements HWPFormatWriter {
@Override @Override
public void setting(HWPPrintUtil hwpPrintUtil) { public void setting(HWPPrintUtil hwpPrintUtil) {

@ -0,0 +1,49 @@
package cokr.xit.fims.cmmn.hwp.format;
import java.util.List;
import cokr.xit.fims.cmmn.hwp.ClickHereEditor;
import cokr.xit.fims.cmmn.hwp.HWPFormatWriter;
import cokr.xit.fims.cmmn.hwp.HWPPrintUtil;
import cokr.xit.fims.sprt.PrintOption;
import cokr.xit.foundation.data.DataObject;
import kr.dogfoot.hwplib.object.HWPFile;
public class SvbtcList implements HWPFormatWriter {
@Override
public void setting(HWPPrintUtil hwpPrintUtil) {
hwpPrintUtil.setFormatName("svbtc");
hwpPrintUtil.setFormatKorName("공시송달");
hwpPrintUtil.setFormatType("list");
hwpPrintUtil.setRecordPerPartFile(9);
hwpPrintUtil.setBaseFormatFilePath("template/hwp/svbtcList_root.hwp");
hwpPrintUtil.setAttachFormatFilePath("template/hwp/svbtcList_inner.hwp");
}
@Override
public void writeGlobalInfo(HWPFile baseFile, List<DataObject> dataObjectList, PrintOption printOption, HWPPrintUtil hwpPrintUtil) {
//
ClickHereEditor baseFileEditor = new ClickHereEditor(baseFile);
baseFileEditor.set("공시송달일자", dataObjectList.get(0).string("SVBTC_YMD"));
baseFileEditor.set("공시송달종료일자", dataObjectList.get(0).string("SVBTC_END_YMD"));
}
@Override
public void writeSingleDataInfo(HWPFile baseFile, HWPFile attachFile, DataObject dataObject, HWPPrintUtil hwpPrintUtil) {
//
ClickHereEditor attachFileEditor = new ClickHereEditor(attachFile);
attachFileEditor.set("성명", dataObject.string("RCPN_NM_MASK"));
attachFileEditor.set("주소", dataObject.string("RCPN_WHOL_ADDR_MASK"));
attachFileEditor.set("차량번호", dataObject.string("VHRNO_MASK"));
attachFileEditor.set("위반장소", dataObject.string("CRDN_PLC"));
attachFileEditor.set("위반일자", dataObject.string("CRDN_DT"));
attachFileEditor.set("반송일자", dataObject.string("DLVR_YMD"));
attachFileEditor.set("반송사유", dataObject.string("UNDLVR_RSN_NM"));
}
}

@ -11,9 +11,9 @@ import org.springframework.stereotype.Service;
import cokr.xit.base.file.FileInfo; import cokr.xit.base.file.FileInfo;
import cokr.xit.fims.cmmn.hwp.AddUtil; import cokr.xit.fims.cmmn.hwp.AddUtil;
import cokr.xit.fims.cmmn.hwp.format.DlbrDecsnList;
import cokr.xit.fims.cmmn.hwp.HWPFormatWriter; import cokr.xit.fims.cmmn.hwp.HWPFormatWriter;
import cokr.xit.fims.cmmn.hwp.HWPPrintUtil; import cokr.xit.fims.cmmn.hwp.HWPPrintUtil;
import cokr.xit.fims.cmmn.hwp.format.DlbrDecsn;
import cokr.xit.fims.excl.LevyExclQuery; import cokr.xit.fims.excl.LevyExclQuery;
import cokr.xit.fims.excl.OpnnSbmsn; import cokr.xit.fims.excl.OpnnSbmsn;
import cokr.xit.fims.excl.service.OpnnSbmsnService; import cokr.xit.fims.excl.service.OpnnSbmsnService;
@ -120,7 +120,7 @@ public class OpnnSbmsnServiceBean extends AbstractServiceBean implements OpnnSbm
Map<String, String> result = new HashMap<>(); Map<String, String> result = new HashMap<>();
HWPPrintUtil printUtil = new HWPPrintUtil(); HWPPrintUtil printUtil = new HWPPrintUtil();
HWPFormatWriter hwpFormatWriter = new DlbrDecsn(); HWPFormatWriter hwpFormatWriter = new DlbrDecsnList();
hwpFormatWriter.setting(printUtil); hwpFormatWriter.setting(printUtil);
UserInfo userInfo = currentUser(); UserInfo userInfo = currentUser();

@ -46,16 +46,16 @@ public class Excl02Controller extends ApplicationController {
public class METHOD_URL { public class METHOD_URL {
public static final String public static final String
opinionSubmissionMain = "/010/main.do" // 의견제출 관리 메인 화면 opinionSubmissionMain = "/010/main.do" // 의견제출 관리 메인 화면
, getOpinionSubmissionList = "/010/list.do" // 의견제출 대장 목록 조회 , getOpinionSubmissionList = "/010/list.do" // 의견제출 대장 목록 조회
, getOpinionSubmissionInfo = "/020/info.do" // 의견제출 대장 조회 , getOpinionSubmissionInfo = "/020/info.do" // 의견제출 대장 조회
, createOpinionSubmission = "/020/create.do" // 의견제출 대장 등럭 , createOpinionSubmission = "/020/create.do" // 의견제출 대장 등럭
, updateOpinionSubmission = "/020/update.do" // 의견제출 대장 수정 , updateOpinionSubmission = "/020/update.do" // 의견제출 대장 수정
, getOpinionSubmissionAnswerInfo = "/030/info.do" // 의견제출 대장 심의 조회 , getOpinionSubmissionAnswerInfo = "/030/info.do" // 의견제출 대장 심의 조회
, updateOpinionSubmissionAnswer = "/030/update.do" // 의견제출 대장 심의 수정 , updateOpinionSubmissionAnswer = "/030/update.do" // 의견제출 대장 심의 수정
, removeOpinionSubmission = "/010/remove.do" // 의견제출 대장 삭제 , removeOpinionSubmission = "/010/remove.do" // 의견제출 대장 삭제
, removeOpinionSubmissionList = "/010/removes.do" // 의견제출 대장 목록 삭제 , removeOpinionSubmissionList = "/010/removes.do" // 의견제출 대장 목록 삭제
, makeDlbrDecsnFileFromHwpFormat = "/040/makeDlbrDecsnHwp.do" // 의견제출 심의 의결서 HWP 저장 , makeDlbrDecsnFileFromHwpFormat = "/010/makeHwp.do" // 의견제출 심의의결서 HWP 저장
; ;
} }

@ -37,6 +37,11 @@ public class Svbtc extends AbstractEntity {
*/ */
private String svbtcYmd; private String svbtcYmd;
/**
*
*/
private String svbtcEndYmd;
/** /**
* *
*/ */

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

@ -1,10 +1,12 @@
package cokr.xit.fims.sndb.service; package cokr.xit.fims.sndb.service;
import java.util.List; import java.util.List;
import java.util.Map;
import cokr.xit.foundation.data.DataObject; import cokr.xit.foundation.data.DataObject;
import cokr.xit.fims.sndb.Svbtc; import cokr.xit.fims.sndb.Svbtc;
import cokr.xit.fims.sprt.PrintOption;
import cokr.xit.fims.sndb.SndbQuery; import cokr.xit.fims.sndb.SndbQuery;
/** . /** .
@ -49,6 +51,11 @@ public interface SvbtcService {
*/ */
List<DataObject> getSvbtcDtls(SndbQuery req); List<DataObject> getSvbtcDtls(SndbQuery req);
/** .
* @param req IDs
* @return
*/
Map<String, String> makeSvbtcFileFromHwpFormat(String formatType, String formatName, PrintOption printOption, String... svbtcIDs);
/** . /** .
* @param svbtc * @param svbtc

@ -110,6 +110,14 @@ public class SvbtcBean extends AbstractComponent {
return svbtcMapper.selectSvbtcDtls(req); return svbtcMapper.selectSvbtcDtls(req);
} }
/** .
* @param req
* @return
*/
public List<DataObject> getSvbtcPrint(SndbQuery req) {
return svbtcMapper.selectSvbtcPrint(req);
}
/** . /** .
* @param svbtc * @param svbtc
* @return * @return

@ -1,17 +1,31 @@
package cokr.xit.fims.sndb.service.bean; package cokr.xit.fims.sndb.service.bean;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List; import java.util.List;
import java.util.Map;
import javax.annotation.Resource; import javax.annotation.Resource;
import org.springframework.core.io.ClassPathResource;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
import cokr.xit.foundation.UserInfo;
import cokr.xit.foundation.component.AbstractServiceBean; import cokr.xit.foundation.component.AbstractServiceBean;
import cokr.xit.foundation.data.DataObject; import cokr.xit.foundation.data.DataObject;
import kr.dogfoot.hwplib.object.HWPFile;
import kr.dogfoot.hwplib.reader.HWPReader;
import kr.dogfoot.hwplib.writer.HWPWriter;
import cokr.xit.fims.sndb.Svbtc; import cokr.xit.fims.sndb.Svbtc;
import cokr.xit.fims.cmmn.hwp.AddUtil;
import cokr.xit.fims.cmmn.hwp.HWPFormatWriter;
import cokr.xit.fims.cmmn.hwp.HWPPrintUtil;
import cokr.xit.fims.cmmn.hwp.format.SvbtcList;
import cokr.xit.fims.mngt.service.bean.FactionBean;
import cokr.xit.fims.sndb.SndbQuery; import cokr.xit.fims.sndb.SndbQuery;
import cokr.xit.fims.sndb.service.SvbtcService; import cokr.xit.fims.sndb.service.SvbtcService;
import cokr.xit.fims.sprt.PrintOption;
/** . /** .
* *
@ -30,6 +44,10 @@ public class SvbtcServiceBean extends AbstractServiceBean implements SvbtcServic
@Resource(name = "svbtcBean") @Resource(name = "svbtcBean")
private SvbtcBean svbtcBean; private SvbtcBean svbtcBean;
/* Bean */
@Resource(name="factionBean")
protected FactionBean factionBean;
@Override @Override
public List<DataObject> getSvbtcList(SndbQuery req) { public List<DataObject> getSvbtcList(SndbQuery req) {
return svbtcBean.getSvbtcList(req); return svbtcBean.getSvbtcList(req);
@ -55,6 +73,102 @@ public class SvbtcServiceBean extends AbstractServiceBean implements SvbtcServic
return svbtcBean.getSvbtcDtls(req); return svbtcBean.getSvbtcDtls(req);
} }
@Override
public Map<String, String> makeSvbtcFileFromHwpFormat(String formatType, String formatName, PrintOption printOption, String... selectIDs) {
Map<String, String> result = new HashMap<>();
HWPPrintUtil printUtil = new HWPPrintUtil();
HWPFormatWriter hwpFormatWriter = new SvbtcList();
hwpFormatWriter.setting(printUtil);
UserInfo userInfo = currentUser();
factionBean.initUserInfo(userInfo);
printUtil.setPrintRequestUserInfo(userInfo);
// 자료 조회
SndbQuery req = new SndbQuery();
if (formatName.equals("svbtc") ) {
req.setSvbtcId(selectIDs[0]);
req.setDelYN("N");
} else if (formatName.equals("svbtcDtl") ) {
req.setSndngDtlIDs(selectIDs);
req.setDelYN("N");
}
List<DataObject> dataObjectList = svbtcBean.getSvbtcPrint(req);
int totalDataCount = dataObjectList.size();
List<String> partFileList = new ArrayList<>();
printUtil.calcTotalPartFileCount(totalDataCount);
try {
int dataIndex = 0;
for(int partFileIndex = 0; partFileIndex < printUtil.getTotalPartFileCount(); partFileIndex++) {
// 새 파일 생성
String resultHwpPath = printUtil.newFileFromFormatFile();
HWPFile resultFile = HWPReader.fromFile(resultHwpPath);
// 공통사항 세팅
hwpFormatWriter.writeGlobalInfo(resultFile, dataObjectList, printOption, printUtil);
HWPWriter.toFile(resultFile, resultHwpPath);
// 데이터 건별 처리
for (int recordIndex = 0; recordIndex < printUtil.getRecordPerPartFile(); recordIndex++) {
if (dataIndex < dataObjectList.size()) {
DataObject dataObject = dataObjectList.get(dataIndex);
if (formatType.equals("list")) {
InputStream attachFormatIS = new ClassPathResource(printUtil.getAttachFormatFilePath()).getInputStream();
HWPFile attachFormatFile = HWPReader.fromInputStream(attachFormatIS);
hwpFormatWriter.writeSingleDataInfo(null, attachFormatFile, dataObject, printUtil);
AddUtil.insertTableInCell(attachFormatFile, resultFile, "내부");
} else {
hwpFormatWriter.writeSingleDataInfo(resultFile, null, dataObject, printUtil);
}
}
if (formatType.equals("list")) {
dataIndex++;
}
}
if (!formatType.equals("list")) {
dataIndex++;
}
HWPWriter.toFile(resultFile, resultHwpPath);
partFileList.add(resultHwpPath);
}
// 결과 파일 병합
if (partFileList.size() >= 2) {
String basePath = partFileList.get(0);
HWPFile baseFile = HWPReader.fromFile(basePath);
for (int iLoop = 2; iLoop <= partFileList.size(); iLoop++) {
String attachPath = partFileList.get(iLoop - 1);
HWPFile attachFile = HWPReader.fromFile(attachPath);
AddUtil.appendToLast(attachFile, baseFile);
}
HWPWriter.toFile(baseFile, basePath);
}
String downlaodFileName = printUtil.getFormatKorName() + "_" + printUtil.getPrintRequestDt() + ".hwp";
result.put("fileName", downlaodFileName);
result.put("filePath", partFileList.get(0));
} catch (Exception e) {
e.printStackTrace();
throw new RuntimeException("한글 파일 출력 중 오류가 발생하였습니다.");
}
return result;
}
@Override @Override
public String create(Svbtc svbtc) { public String create(Svbtc svbtc) {
return svbtcBean.create(svbtc); return svbtcBean.create(svbtc);

@ -29,6 +29,7 @@ import cokr.xit.fims.sndb.Svbtc;
import cokr.xit.fims.sndb.service.SndngDtlService; import cokr.xit.fims.sndb.service.SndngDtlService;
import cokr.xit.fims.sndb.service.SndngService; import cokr.xit.fims.sndb.service.SndngService;
import cokr.xit.fims.sndb.service.SvbtcService; import cokr.xit.fims.sndb.service.SvbtcService;
import cokr.xit.fims.sprt.PrintOption;
import cokr.xit.foundation.data.DataObject; import cokr.xit.foundation.data.DataObject;
/** /**
@ -76,8 +77,10 @@ public class Sndb01Controller extends ApplicationController {
, serviceByPublicNoticeMain = "/240/main.do" // 공시송달 현황 메인 화면 , serviceByPublicNoticeMain = "/240/main.do" // 공시송달 현황 메인 화면
, getServiceByPublicNoticeList = "/240/list.do" // 공시송달 현황 목록 조회 , getServiceByPublicNoticeList = "/240/list.do" // 공시송달 현황 목록 조회
, removeServiceByPublicNotice = "/240/remove.do" // 공시송달 삭제 , removeServiceByPublicNotice = "/240/remove.do" // 공시송달 삭제
, makeSvbtcFileFromHwpFormat = "/240/makeSvbtcHwp.do" // 공시송달 한글 파일 출력
, getServiceByPublicNoticeDetailInfo = "/250/info.do" // 공시송달 상세 화면 , getServiceByPublicNoticeDetailInfo = "/250/info.do" // 공시송달 상세 화면
, getServiceByPublicNoticeDetailList = "/250/list.do" // 공시송달 상세 목록 조회 , getServiceByPublicNoticeDetailList = "/250/list.do" // 공시송달 상세 목록 조회
, makeSvbtcDetailsFileFromHwpFormat = "/250/makeSvbtcDtlHwp.do" // 공시송달 상세 한글 파일 출력
, getServiceByPublicNoticeInfo = "/260/info.do" // 공시송달 정보 , getServiceByPublicNoticeInfo = "/260/info.do" // 공시송달 정보
, createServiceByPublicNotice = "/260/create.do" // 공시송달 등록 , createServiceByPublicNotice = "/260/create.do" // 공시송달 등록
, updateServiceByPublicNotice = "/260/update.do" // 공시송달 수정 , updateServiceByPublicNotice = "/260/update.do" // 공시송달 수정
@ -1434,6 +1437,40 @@ public class Sndb01Controller extends ApplicationController {
} }
} }
/** .
* @return hwp
*/
public ModelAndView makeSvbtcFileFromHwpFormat(String... svbtcIDs) {
Map<String,String> result = null;
PrintOption printOption = new PrintOption();
result = svbtcService.makeSvbtcFileFromHwpFormat("list", "svbtc", printOption, svbtcIDs);
ModelAndView mav = new ModelAndView("jsonView");
mav.addAllObjects(result);
return mav;
}
/** .
* @return hwp
*/
public ModelAndView makeSvbtcDetailsFileFromHwpFormat(String... sndngDtlIDs) {
Map<String,String> result = null;
PrintOption printOption = new PrintOption();
result = svbtcService.makeSvbtcFileFromHwpFormat("list", "svbtcDtl", printOption, sndngDtlIDs);
ModelAndView mav = new ModelAndView("jsonView");
mav.addAllObjects(result);
return mav;
}
/** ID . /** ID .
* @param svbtcId ID * @param svbtcId ID
* @return fims/sndb/sndb01260-info jsonView * @return fims/sndb/sndb01260-info jsonView

@ -673,6 +673,12 @@ public class DpvController {
return super.getServiceByPublicNoticeList(req); return super.getServiceByPublicNoticeList(req);
} }
@Override
@RequestMapping(name="공시송달 한글 저장", value=METHOD_URL.makeSvbtcFileFromHwpFormat)
public ModelAndView makeSvbtcFileFromHwpFormat(String... svbtcIDs) {
return super.makeSvbtcFileFromHwpFormat(svbtcIDs);
}
@Override @Override
@RequestMapping(name="공시송달 상세 화면", value=METHOD_URL.getServiceByPublicNoticeDetailInfo) @RequestMapping(name="공시송달 상세 화면", value=METHOD_URL.getServiceByPublicNoticeDetailInfo)
public ModelAndView getServiceByPublicNoticeDetailInfo(SndbQuery req) { public ModelAndView getServiceByPublicNoticeDetailInfo(SndbQuery req) {
@ -685,6 +691,12 @@ public class DpvController {
return super.getServiceByPublicNoticeDetailList(req); return super.getServiceByPublicNoticeDetailList(req);
} }
@Override
@RequestMapping(name="공시송달 상세 한글 저장", value=METHOD_URL.makeSvbtcDetailsFileFromHwpFormat)
public ModelAndView makeSvbtcDetailsFileFromHwpFormat(String... sndngDtlIDs) {
return super.makeSvbtcDetailsFileFromHwpFormat(sndngDtlIDs);
}
@Override @Override
@RequestMapping(name="공시송달 정보", value=METHOD_URL.getServiceByPublicNoticeInfo) @RequestMapping(name="공시송달 정보", value=METHOD_URL.getServiceByPublicNoticeInfo)
public ModelAndView getServiceByPublicNoticeInfo(SndbQuery req) { public ModelAndView getServiceByPublicNoticeInfo(SndbQuery req) {

@ -8,23 +8,24 @@
============================ --> ============================ -->
<resultMap id="svbtcRow" type="cokr.xit.fims.sndb.Svbtc"> <resultMap id="svbtcRow" type="cokr.xit.fims.sndb.Svbtc">
<result property="svbtcId" column="SVBTC_ID" /> <!-- 공시송달 ID --> <result property="svbtcId" column="SVBTC_ID" /> <!-- 공시송달 ID -->
<result property="sggCd" column="SGG_CD" /> <!-- 시군구 코드 --> <result property="sggCd" column="SGG_CD" /> <!-- 시군구 코드 -->
<result property="taskSeCd" column="TASK_SE_CD" /> <!-- 업무 구분 코드 --> <result property="taskSeCd" column="TASK_SE_CD" /> <!-- 업무 구분 코드 -->
<result property="sndngSeCd" column="SNDNG_SE_CD" /> <!-- 발송 구분 코드 --> <result property="sndngSeCd" column="SNDNG_SE_CD" /> <!-- 발송 구분 코드 -->
<result property="svbtcYmd" column="SVBTC_YMD" /> <!-- 공시송달 일자 --> <result property="svbtcYmd" column="SVBTC_YMD" /> <!-- 공시송달 일자 -->
<result property="ttlNm" column="TTL_NM" /> <!-- 제목 명 --> <result property="svbtcEndYmd" column="SVBTC_END_YMD" /> <!-- 공시송달 종료 일자 -->
<result property="docNo" column="DOC_NO" /> <!-- 문서 번호 --> <result property="ttlNm" column="TTL_NM" /> <!-- 제목 명 -->
<result property="etcCn" column="ETC_CN" /> <!-- 기타 내용 --> <result property="docNo" column="DOC_NO" /> <!-- 문서 번호 -->
<result property="tnocs" column="TNOCS" /> <!-- 총건수 --> <result property="etcCn" column="ETC_CN" /> <!-- 기타 내용 -->
<result property="delYN" column="DEL_YN" /> <!-- 삭제 여부 --> <result property="tnocs" column="TNOCS" /> <!-- 총건수 -->
<result property="createdAt" column="REG_DT" /> <!-- 등록 일시 --> <result property="delYN" column="DEL_YN" /> <!-- 삭제 여부 -->
<result property="createdBy" column="RGTR" /> <!-- 등록자 --> <result property="createdAt" column="REG_DT" /> <!-- 등록 일시 -->
<result property="lastModified" column="MDFCN_DT" /> <!-- 수정 일시 --> <result property="createdBy" column="RGTR" /> <!-- 등록자 -->
<result property="modifiedBy" column="MDFR" /> <!-- 수정자 --> <result property="lastModified" column="MDFCN_DT" /> <!-- 수정 일시 -->
<result property="removedAt" column="DEL_DT" /> <!-- 삭제 일시 --> <result property="modifiedBy" column="MDFR" /> <!-- 수정자 -->
<result property="removedBy" column="DLTR" /> <!-- 삭제자 --> <result property="removedAt" column="DEL_DT" /> <!-- 삭제 일시 -->
<result property="delRsn" column="DEL_RSN" /> <!-- 삭제 사유 --> <result property="removedBy" column="DLTR" /> <!-- 삭제자 -->
<result property="delRsn" column="DEL_RSN" /> <!-- 삭제 사유 -->
</resultMap> </resultMap>
<sql id="select"> <sql id="select">
@ -33,6 +34,7 @@
, SV.TASK_SE_CD <!-- 업무 구분 코드 --> , SV.TASK_SE_CD <!-- 업무 구분 코드 -->
, SV.SNDNG_SE_CD <!-- 발송 구분 코드 --> , SV.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, SV.SVBTC_YMD <!-- 공시송달 일자 --> , SV.SVBTC_YMD <!-- 공시송달 일자 -->
, SV.SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
, SV.TTL_NM <!-- 제목 명 --> , SV.TTL_NM <!-- 제목 명 -->
, SV.DOC_NO <!-- 문서 번호 --> , SV.DOC_NO <!-- 문서 번호 -->
, SV.ETC_CN <!-- 기타 내용 --> , SV.ETC_CN <!-- 기타 내용 -->
@ -148,6 +150,7 @@
, SV.TASK_SE_CD <!-- 업무 구분 코드 --> , SV.TASK_SE_CD <!-- 업무 구분 코드 -->
, SV.SNDNG_SE_CD <!-- 발송 구분 코드 --> , SV.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, SV.SVBTC_YMD <!-- 공시송달 일자 --> , SV.SVBTC_YMD <!-- 공시송달 일자 -->
, SV.SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
, SV.DOC_NO <!-- 문서 번호 --> , SV.DOC_NO <!-- 문서 번호 -->
, SV.TTL_NM <!-- 제목 명 --> , SV.TTL_NM <!-- 제목 명 -->
, SV.ETC_CN <!-- 기타 내용 --> , SV.ETC_CN <!-- 기타 내용 -->
@ -230,6 +233,11 @@
<if test="svbtcId != null"> <if test="svbtcId != null">
AND SV.SVBTC_ID = #{svbtcId} <!-- 공시송달 ID --> AND SV.SVBTC_ID = #{svbtcId} <!-- 공시송달 ID -->
</if> </if>
<if test="sndngDtlIDs != null">
AND SV.SNDNG_DTL_ID IN ( <!-- 발송 상세 IDs -->
<foreach collection="sndngDtlIDs" item="sndngDtlId" separator=","> #{sndngDtlId} </foreach>
)
</if>
<if test="sndngDtlId != null"> <if test="sndngDtlId != null">
AND SD.SNDNG_DTL_ID = #{sndngDtlId} <!-- 발송 상세 ID --> AND SD.SNDNG_DTL_ID = #{sndngDtlId} <!-- 발송 상세 ID -->
</if> </if>
@ -246,6 +254,74 @@
<include refid="utility.orderBy" /> <include refid="utility.orderBy" />
</select> </select>
<select id="selectSvbtcPrint" parameterType="map" resultType="dataobject">/* 공시송달 상세 객체 가져오기(svbtcMapper.selectSvbtcDtls) */
SELECT SV.SVBTC_ID <!-- 공시송달 ID -->
, SV.SGG_CD <!-- 시군구 코드 -->
, SV.TASK_SE_CD <!-- 업무 구분 코드 -->
, SV.SNDNG_SE_CD <!-- 발송 구분 코드 -->
, SV.SVBTC_YMD <!-- 공시송달 일자 -->
, SV.SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
, SV.DOC_NO <!-- 문서 번호 -->
, SV.TTL_NM <!-- 제목 명 -->
, SV.ETC_CN <!-- 기타 내용 -->
, SV.TNOCS <!-- 총건수 -->
, SD.SNDNG_DTL_ID <!-- 발송 상세 ID -->
, SD.SNDNG_ID <!-- 발송 ID -->
, SD.CRDN_ID <!-- 단속 ID -->
, SD.VHRNO <!-- 차량번호 -->
, SD.CRDN_DT <!-- 단속 일시 -->
, SD.CRDN_STDG_NM <!-- 단속 법정동 명 -->
, SD.CRDN_PLC <!-- 단속 장소 -->
, SD.FFNLG_AMT <!-- 과태료 금액 -->
, SD.PCPTAX <!-- 본세 -->
, SD.ADAMT <!-- 가산금 -->
, SD.SUM_AMT <!-- 합계 금액 -->
, SD.RCPN_NM <!-- 수령인 명 -->
, SD.RCPN_BRDT <!-- 수령인 생년월일 -->
, SD.RCPN_ADDR <!-- 수령인 주소 -->
, SD.RCPN_DTL_ADDR <!-- 수령인 상세 주소 -->
, SD.RCPN_ZIP <!-- 수령인 우편번호 -->
, SD.CON_KEY <!-- 외부연계식별키 -->
, SD.RG_NO <!-- 등기 번호 -->
, SD.DLVR_YMD <!-- 배달 일자 -->
, SD.DLVR_TM <!-- 배달 시각 -->
, SD.UNDLVR_RSN_NM <!-- 미배달 사유 명 -->
, SD.ACTL_RCPN_NM <!-- 실제 수령인 명 -->
, SD.RCPN_REL_NM <!-- 수령인 관계 명 -->
, SD.RCPN_NM AS RCPN_NM_MASK <!-- 수령인 명 -->
, CONCAT(SD.RCPN_ADDR, ' ', SD.RCPN_DTL_ADDR) AS RCPN_WHOL_ADDR_MASK <!-- 수령인 명 -->
, SD.VHRNO AS VHRNO_MASK
FROM TB_SVBTC SV
INNER JOIN TB_SNDNG_DTL SD ON (SV.SVBTC_ID = SD.SVBTC_ID)
<where>
<if test="svbtcIDs != null">
AND SV.SVBTC_ID IN ( <!-- 공시송달 IDs -->
<foreach collection="svbtcIDs" item="svbtcId" separator=","> #{svbtcId} </foreach>
)
</if>
<if test="svbtcId != null">
AND SV.SVBTC_ID = #{svbtcId} <!-- 공시송달 ID -->
</if>
<if test="sndngDtlIDs != null">
AND SV.SNDNG_DTL_ID IN ( <!-- 발송 상세 IDs -->
<foreach collection="sndngDtlIDs" item="sndngDtlId" separator=","> #{sndngDtlId} </foreach>
)
</if>
<if test="sndngDtlId != null">
AND SD.SNDNG_DTL_ID = #{sndngDtlId} <!-- 발송 상세 ID -->
</if>
<if test="sndngId != null">
AND SD.SNDNG_ID = #{sndngId} <!-- 발송 ID -->
</if>
<if test="crdnId != null">
AND SD.CRDN_ID = #{crdnId} <!-- 단속 ID -->
</if>
AND SV.DEL_YN = 'N' <!-- 삭제 여부 -->
AND SD.DEL_YN = 'N' <!-- 삭제 여부 -->
</where>
<include refid="utility.orderBy" />
</select>
<insert id="insertSvbtc" parameterType="map">/* 공시송달 대장 등록(svbtcMapper.insertSvbtc) */ <insert id="insertSvbtc" parameterType="map">/* 공시송달 대장 등록(svbtcMapper.insertSvbtc) */
<selectKey resultType="string" keyProperty="svbtc.svbtcId" keyColumn="NEW_ID" order="BEFORE"> <selectKey resultType="string" keyProperty="svbtc.svbtcId" keyColumn="NEW_ID" order="BEFORE">
SELECT CONCAT(DATE_FORMAT(CURRENT_DATE, '%Y'), LPAD(CAST(IFNULL(MAX(SUBSTRING(SVBTC_ID, 5)) + 1, 1) AS INT), 16, '0')) AS NEW_ID SELECT CONCAT(DATE_FORMAT(CURRENT_DATE, '%Y'), LPAD(CAST(IFNULL(MAX(SUBSTRING(SVBTC_ID, 5)) + 1, 1) AS INT), 16, '0')) AS NEW_ID
@ -259,6 +335,7 @@
, TASK_SE_CD <!-- 업무 구분 코드 --> , TASK_SE_CD <!-- 업무 구분 코드 -->
, SNDNG_SE_CD <!-- 발송 구분 코드 --> , SNDNG_SE_CD <!-- 발송 구분 코드 -->
, SVBTC_YMD <!-- 공시송달 일자 --> , SVBTC_YMD <!-- 공시송달 일자 -->
, SVBTC_END_YMD <!-- 공시송달 종료 일자 -->
, TTL_NM <!-- 제목 명 --> , TTL_NM <!-- 제목 명 -->
, DOC_NO <!-- 문서 번호 --> , DOC_NO <!-- 문서 번호 -->
, ETC_CN <!-- 기타 내용 --> , ETC_CN <!-- 기타 내용 -->
@ -275,6 +352,7 @@
, #{svbtc.taskSeCd} <!-- 업무 구분 코드 --> , #{svbtc.taskSeCd} <!-- 업무 구분 코드 -->
, #{svbtc.sndngSeCd} <!-- 발송 구분 코드 --> , #{svbtc.sndngSeCd} <!-- 발송 구분 코드 -->
, #{svbtc.svbtcYmd} <!-- 공시송달 일자 --> , #{svbtc.svbtcYmd} <!-- 공시송달 일자 -->
, #{svbtc.svbtcEndYmd} <!-- 공시송달 종료 일자 -->
, #{svbtc.ttlNm} <!-- 제목 명 --> , #{svbtc.ttlNm} <!-- 제목 명 -->
, #{svbtc.docNo} <!-- 문서 번호 --> , #{svbtc.docNo} <!-- 문서 번호 -->
, #{svbtc.etcCn} <!-- 기타 내용 --> , #{svbtc.etcCn} <!-- 기타 내용 -->
@ -290,6 +368,7 @@
<update id="updateSvbtc" parameterType="map">/* 공시송달 대장 수정(svbtcMapper.updateSvbtc) */ <update id="updateSvbtc" parameterType="map">/* 공시송달 대장 수정(svbtcMapper.updateSvbtc) */
UPDATE TB_SVBTC UPDATE TB_SVBTC
SET SVBTC_YMD = #{svbtc.svbtcYmd} <!-- 공시송달 일자 --> SET SVBTC_YMD = #{svbtc.svbtcYmd} <!-- 공시송달 일자 -->
, SVBTC_END_YMD= #{svbtc.svbtcEndYmd} <!-- 공시송달 종료 일자 -->
, TTL_NM = #{svbtc.ttlNm} <!-- 제목 명 --> , TTL_NM = #{svbtc.ttlNm} <!-- 제목 명 -->
, DOC_NO = #{svbtc.docNo} <!-- 문서 번호 --> , DOC_NO = #{svbtc.docNo} <!-- 문서 번호 -->
, ETC_CN = #{svbtc.etcCn} <!-- 기타 내용 --> , ETC_CN = #{svbtc.etcCn} <!-- 기타 내용 -->

@ -10,211 +10,211 @@
<!-- Page Body --> <!-- Page Body -->
<div class="card"> <div class="card">
<div class="wrapper-list"> <div class="wrapper-list">
<div>
<!-- 상단 버튼 --> <!-- 상단 버튼 -->
<div class="container-page-btn"> <div class="container-page-btn">
<button type="button" class="btn btn-outline-dark w-px-120" id="btnReset--${pageName}" title="초기화" onclick="fnResetAndChangeBiz${pageName}();"> <button type="button" class="btn btn-outline-dark w-px-120" id="btnReset--${pageName}" title="초기화" onclick="fnResetAndChangeBiz${pageName}();">
초기화 초기화
</button>
<span class="container-window-btn-right">
<button type="button" class="btn btn-search w-px-120" id="btnSearch--${pageName}" title="검색" onclick="fnSearchList${pageName}();">
검색
</button> </button>
<span class="container-window-btn-right"> <button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀" onclick="fnExcel${pageName}();">
<button type="button" class="btn btn-search w-px-120" id="btnSearch--${pageName}" title="검색" onclick="fnSearchList${pageName}();"> 엑셀
검색 </button>
</button> </span>
<button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀" onclick="fnExcel${pageName}();"> </div>
엑셀 <!-- / 상단 버튼 -->
</button>
</span> <!-- 검색 조건 영역 -->
</div> <form id="frmSearch--${pageName}" name="frmSearch">
<!-- / 상단 버튼 --> <!-- hidden -->
<input type="hidden" id="sggCd--${pageName}" name="sggCd" data-map="SGG_CD" />
<!-- 검색 조건 영역 -->
<form id="frmSearch--${pageName}" name="frmSearch"> <!-- 메인 조건 -->
<!-- hidden --> <div class="container-search">
<input type="hidden" id="sggCd--${pageName}" name="sggCd" data-map="SGG_CD" /> <div class="row g-1">
<!-- 업무구분 -->
<!-- 메인 조건 --> <div class="col-12">
<div class="container-search"> <label class="form-label fw-bold form-search-title text-end">업무구분</label>
<div class="row g-1"> <span class="form-search-linebox">
<!-- 업무구분 --> <c:forEach items="${taskListForSgg}" var="item">
<div class="col-12"> <label>
<label class="form-label fw-bold form-search-title text-end">업무구분</label> <input type="radio" class="form-check-input" name="taskSeCd" alt="업무구분"
<span class="form-search-linebox"> value="${item.code}" onchange="fnResetAndChangeBiz${pageName}(this.value);">
<c:forEach items="${taskListForSgg}" var="item"> ${item.value}
<label> </label>
<input type="radio" class="form-check-input" name="taskSeCd" alt="업무구분" </c:forEach>
value="${item.code}" onchange="fnResetAndChangeBiz${pageName}(this.value);"> </span>
${item.value}
</label>
</c:forEach>
</span>
</div>
<!-- 공시송달 일자 -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end">송달일자</label>
<span class="form-search-linebox">
<input type="text" class="form-control form-date" id="schSvbtcYmdFrom--${pageName}" name="schSvbtcYmdFrom"
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="schSvbtcYmdTo--${pageName}" name="schSvbtcYmdTo"
data-fmt-type="day" title="종료 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
</span>
</div>
<!-- 발송구분 -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end">발송구분</label>
<select class="form-select w-px-150" id="schSndngSeCd--${pageName}" name="schSndngSeCd">
<option value="">전체</option>
<c:forEach items="${FIM047List}" var="item">
<option value="${item.code}">${item.value}</option>
</c:forEach>
</select>
</div>
<!-- 문서 번호 -->
<div class="col-6">
<label class="form-label fw-bold form-search-title text-end">문서번호</label>
<input type="text" class="form-control w-px-160" id="schDocNo--${pageName}" name="schDocNo" autocomplete="off" />
</div>
<!-- 동적검색 -->
<div class="col-6">
<input type="hidden" id="by--${pageName}" name="by" />
<input type="text" class="form-control" id="byOutput--${pageName}" value="동적 검색" readonly />
<input type="hidden" id="mainOption--${pageName}" name="mainOption" />
<input type="hidden" id="subOption--${pageName}" name="subOption" />
<input type="text" class="form-control w-px-300" id="term--${pageName}" name="term" />
<!-- 상세 검색조건 버튼 -->
<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> <!-- 공시송달 일자 -->
<!-- / 메인 조건 --> <div class="col-6">
<label class="form-label fw-bold form-search-title text-end">송달일자</label>
<!-- 상세 조건 --> <span class="form-search-linebox">
<div id="searchDetail--${pageName}" class="container-search container-search-detail collapse"> <input type="text" class="form-control form-date" id="schSvbtcYmdFrom--${pageName}" name="schSvbtcYmdFrom"
<div class="row g-1"> data-fmt-type="day" title="시작 날짜 선택" />
<!-- 등록일자, 수정일자 --> <button type="button" class="bx bx-sm bx-calendar bg-white"></button>
<div class="col-6"> ~
<select class="form-select text-center" id="schRegDateOpt--${pageName}" name="schRegDateOpt"> <input type="text" class="form-control form-date" id="schSvbtcYmdTo--${pageName}" name="schSvbtcYmdTo"
<option value="regDt">등록일자</option> data-fmt-type="day" title="종료 날짜 선택" />
<option value="mdfcnDt">수정일자</option> <button type="button" class="bx bx-sm bx-calendar bg-white"></button>
</select> </span>
<span class="form-search-linebox"> </div>
<input type="text" class="form-control form-date" id="schRegDateFrom--${pageName}" name="schRegDateFrom" <!-- 발송구분 -->
data-fmt-type="day" title="시작 날짜 선택" /> <div class="col-6">
<button type="button" class="bx bx-sm bx-calendar bg-white"></button> <label class="form-label fw-bold form-search-title text-end">발송구분</label>
~ <select class="form-select w-px-150" id="schSndngSeCd--${pageName}" name="schSndngSeCd">
<input type="text" class="form-control form-date" id="schRegDateTo--${pageName}" name="schRegDateTo" <option value="">전체</option>
data-fmt-type="day" title="종료 날짜 선택"> <c:forEach items="${FIM047List}" var="item">
<button type="button" class="bx bx-sm bx-calendar bg-white"></button> <option value="${item.code}">${item.value}</option>
</span> </c:forEach>
</div> </select>
<!-- 등록자명, 수정자명 --> </div>
<div class="col-6"> <!-- 문서 번호 -->
<select class="form-select text-center" id="schRgtrOpt--${pageName}" name="schRgtrOpt"> <div class="col-6">
<option value="rgtr">등록자</option> <label class="form-label fw-bold form-search-title text-end">문서번호</label>
<option value="mdfr">수정자</option> <input type="text" class="form-control w-px-160" id="schDocNo--${pageName}" name="schDocNo" autocomplete="off" />
</select> </div>
<input type="hidden" id="schRgtrCd--${pageName}" name="schRgtrCd" /> <!-- 동적검색 -->
<input type="text" class="form-control" id="schRgtrNm--${pageName}" name="schRgtrNm" /> <div class="col-6">
<button type="button" class="btn btn-sm btn-outline-dark" id="btnFindUser--${pageName}" title="사용자 검색" onclick="fnFindUser${pageName}();"> <input type="hidden" id="by--${pageName}" name="by" />
검색 <input type="text" class="form-control" id="byOutput--${pageName}" value="동적 검색" readonly />
<input type="hidden" id="mainOption--${pageName}" name="mainOption" />
<input type="hidden" id="subOption--${pageName}" name="subOption" />
<input type="text" class="form-control w-px-300" id="term--${pageName}" name="term" />
<!-- 상세 검색조건 버튼 -->
<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> </button>
</div> </span>
</div> </div>
</div> <!-- / 상세 조건 --> </div>
</form> </div>
<!-- / 검색 조건 영역 --> <!-- / 메인 조건 -->
<!-- 업무 버튼 및 건수 표시 --> <!-- 상세 조건 -->
<div> <div id="searchDetail--${pageName}" class="container-search container-search-detail collapse">
<span class="container-page-btn"> <div class="row g-1">
<!-- 건수, 페이지 표시 --> <!-- 등록일자, 수정일자 -->
<div class="d-flex flex-row justify-content-between"> <div class="col-6">
<label class="dataTables_info" id="paging--${pageName}PagingInfo" role="status" aria-live="polite"></label> <select class="form-select text-center" id="schRegDateOpt--${pageName}" name="schRegDateOpt">
<ul class="pagination pagination-primary" id="paging--${pageName}"> <option value="regDt">등록일자</option>
</ul> <option value="mdfcnDt">수정일자</option>
</select>
<span class="form-search-linebox">
<input type="text" class="form-control form-date" id="schRegDateFrom--${pageName}" name="schRegDateFrom"
data-fmt-type="day" title="시작 날짜 선택" />
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
~
<input type="text" class="form-control form-date" id="schRegDateTo--${pageName}" name="schRegDateTo"
data-fmt-type="day" title="종료 날짜 선택">
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
</span>
</div> </div>
<span class="container-window-btn-right"> <!-- 등록자명, 수정자명 -->
<!-- 업무 버튼 --> <div class="col-6">
<button type="button" class="btn btn-primary w-px-120" id="btnHwpPrint--${pageName}" title="한글파일 출력" onclick="fnHwpPrint${pageName}();"> <select class="form-select text-center" id="schRgtrOpt--${pageName}" name="schRgtrOpt">
한글파일 출력 <option value="rgtr">등록자</option>
</button> <option value="mdfr">수정자</option>
<button type="button" class="btn btn-primary w-px-120" id="btnUpdateSvbtc--${pageName}" title="공시송달 수정" onclick="fnUpdateSvbtc${pageName}();"> </select>
공시송달 수정 <input type="hidden" id="schRgtrCd--${pageName}" name="schRgtrCd" />
</button> <input type="text" class="form-control" id="schRgtrNm--${pageName}" name="schRgtrNm" />
<button type="button" class="btn btn-primary w-px-120" id="btnRemoveSvbtc--${pageName}" title="공시송달 삭제" onclick="fnRemoveSvbtc${pageName}();"> <button type="button" class="btn btn-sm btn-outline-dark" id="btnFindUser--${pageName}" title="사용자 검색" onclick="fnFindUser${pageName}();">
공시송달 삭제 검색
</button> </button>
</span>
</span>
</div>
<!-- / 업무 버튼 및 건수 표시 -->
<!-- DataTables(그리드) -->
<div class="card-datatable text-nowrap">
<div class="dataTables_wrapper dt-bootstrap5 no-footer" id="DataTables_Table_0_wrapper--${pageName}">
<div class="table-responsive" id="table-responsive--${pageName}" style="overflow-x:scroll; height:400px; overflow-y:scroll;" >
<table class="table-layout-fixed dataTable datatables-ajax table table-bordered no-footer" id="DataTables_Table_0--${pageName}" aria-describedby="DataTables_Table_0_info">
<thead class="sticky-thead">
<tr id="theadTr--${pageName}"
data-by="by--${pageName}" data-by-output="byOutput--${pageName}" data-main-option="mainOption--${pageName}" data-sub-option="subOption--${pageName}">
<th class="cmn" style="width: 72px;">NO.</th>
<th class="cmn" style="width: 56px;"><input type="checkbox" class="form-check-input" onchange="${pageName}Control.select(this.checked);"></th>
<th class="cmn" style="width: 160px;">업무구분</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('SNDNG_SE_CD', this.innerText, 'codeValue', 'FIM047');">발송구분</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('SVBTC_YMD', this.innerText, 'ymd', '');">공시송달일자</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('TNOCS', this.innerText, 'match', 'part');">총건수</th>
<th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('DOC_NO', this.innerText, 'match', 'part');">문서번호</th>
<th class="cmn" style="width: 320px;" onclick="searchFromGridTitle('TTL_NM', this.innerText, 'match', 'part');">제목</th>
<th class="cmn" style="width: 320px;" onclick="searchFromGridTitle('ETC_CN', this.innerText, 'match', 'part');">기타내용</th>
<th class="cmn" style="width: 180px;">등록일시</th>
<th class="cmn" style="width: 140px;">등록사용자</th>
<th class="cmn" style="width: 180px;">수정일시</th>
<th class="cmn" style="width: 140px;">수정사용자</th>
<th class="cmn dummy-th"></th>
</tr>
</thead>
<tbody id="tbody--${pageName}">
</tbody>
<template id="${infoPrefix}Row--${pageName}">
<tr data-key="{SVBTC_ID}">
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ROW_NUM}</td>
<td class="cmn text-center"><input type="checkbox" class="form-check-input" value="{SVBTC_ID}" onchange="${pageName}Control.select('{SVBTC_ID}', this.checked);"></td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{TASK_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SVBTC_YMD}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{TNOCS}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{DOC_NO}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{TTL_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ETC_CN}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{REG_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGTR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFR_NM}</td>
<td class="cmn dummy-td"></td>
</tr>
</template>
<template id="${infoPrefix}NotFound--${pageName}">
<tr class="odd">
<td valign="top" colspan="13" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
</template>
</table>
</div> </div>
</div> </div>
</div> </div> <!-- / 상세 조건 -->
<!-- / DataTables(그리드) --> </form>
<!-- / 검색 조건 영역 -->
<!-- 업무 버튼 및 건수 표시 -->
<div>
<span class="container-page-btn">
<!-- 건수, 페이지 표시 -->
<div class="d-flex flex-row justify-content-between">
<label class="dataTables_info" id="paging--${pageName}PagingInfo" role="status" aria-live="polite"></label>
<ul class="pagination pagination-primary" id="paging--${pageName}">
</ul>
</div>
<span class="container-window-btn-right">
<!-- 업무 버튼 -->
<button type="button" class="btn btn-primary w-px-120" id="btnHwpSvbtc--${pageName}" title="한글파일 출력" onclick="fnHwpSvbtc${pageName}();">
한글파일 출력
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnUpdateSvbtc--${pageName}" title="공시송달 수정" onclick="fnUpdateSvbtc${pageName}();">
공시송달 수정
</button>
<button type="button" class="btn btn-primary w-px-120" id="btnRemoveSvbtc--${pageName}" title="공시송달 삭제" onclick="fnRemoveSvbtc${pageName}();">
공시송달 삭제
</button>
</span>
</span>
</div> </div>
<!-- / 업무 버튼 및 건수 표시 -->
<!-- DataTables(그리드) -->
<div class="card-datatable text-nowrap">
<div class="dataTables_wrapper dt-bootstrap5 no-footer" id="DataTables_Table_0_wrapper--${pageName}">
<div class="table-responsive" id="table-responsive--${pageName}" style="overflow-x:scroll; height:400px; overflow-y:scroll;" >
<table class="table-layout-fixed dataTable datatables-ajax table table-bordered no-footer" id="DataTables_Table_0--${pageName}" aria-describedby="DataTables_Table_0_info">
<thead class="sticky-thead">
<tr id="theadTr--${pageName}"
data-by="by--${pageName}" data-by-output="byOutput--${pageName}" data-main-option="mainOption--${pageName}" data-sub-option="subOption--${pageName}">
<th class="cmn" style="width: 72px;">NO.</th>
<th class="cmn" style="width: 56px;"><input type="checkbox" class="form-check-input" onchange="${pageName}Control.select(this.checked);"></th>
<th class="cmn" style="width: 160px;">업무구분</th>
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('SNDNG_SE_CD', this.innerText, 'codeValue', 'FIM047');">발송구분</th>
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('SVBTC_YMD', this.innerText, 'ymd', '');">공시송달일자</th>
<th class="cmn" style="width: 100px;" onclick="searchFromGridTitle('TNOCS', this.innerText, 'match', 'part');">총건수</th>
<th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('DOC_NO', this.innerText, 'match', 'part');">문서번호</th>
<th class="cmn" style="width: 320px;" onclick="searchFromGridTitle('TTL_NM', this.innerText, 'match', 'part');">제목</th>
<th class="cmn" style="width: 320px;" onclick="searchFromGridTitle('ETC_CN', this.innerText, 'match', 'part');">기타내용</th>
<th class="cmn" style="width: 180px;">등록일시</th>
<th class="cmn" style="width: 140px;">등록사용자</th>
<th class="cmn" style="width: 180px;">수정일시</th>
<th class="cmn" style="width: 140px;">수정사용자</th>
<th class="cmn dummy-th"></th>
</tr>
</thead>
<tbody id="tbody--${pageName}">
</tbody>
<template id="${infoPrefix}Row--${pageName}">
<tr data-key="{SVBTC_ID}">
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ROW_NUM}</td>
<td class="cmn text-center"><input type="checkbox" class="form-check-input" value="{SVBTC_ID}" onchange="${pageName}Control.select('{SVBTC_ID}', this.checked);"></td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{TASK_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SNDNG_SE_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{SVBTC_YMD}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{TNOCS}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{DOC_NO}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{TTL_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ETC_CN}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{REG_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGTR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFR_NM}</td>
<td class="cmn dummy-td"></td>
</tr>
</template>
<template id="${infoPrefix}NotFound--${pageName}">
<tr class="odd">
<td valign="top" colspan="13" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</tr>
</template>
</table>
</div>
</div>
</div> <!-- / DataTables(그리드) -->
</div> <!-- / Wrapper-list --> </div> <!-- / Wrapper-list -->
</div> <!-- / Card --> </div> <!-- / Card -->
</div>
<!-- / Content --> <span id="tempArea--${pageName}" hidden></span>
</div> <!-- / Content -->
<jsp:include page="/WEB-INF/jsp/include/bottom.jsp" /> <jsp:include page="/WEB-INF/jsp/include/bottom.jsp" />
@ -437,6 +437,37 @@
}); });
} }
// 한글파일 출력
makeHwpFileSvbtc${pageName} = (params) => {
let selected = ${pageName}Control.dataset.getKeys("selected");
if (selected.length < 1) return;
if (!params) {
params = {};
params["svbtcIDs"] = selected.join(",");
}
let taskSeCd = $("#frmSearch--${pageName} input[name='taskSeCd']:checked").val();
ajax.get({
url : wctx.url("/" + taskSeCd + "/sndb/sndb01/240/makeSvbtcHwp.do")
, data : params || {}
, success : resp => {
if (resp.filePath != null && resp.filePath != "") {
let a = document.createElement("a");
a.href = resp.filePath;
a.download = resp.fileName;
document.getElementById("tempArea--${pageName}").appendChild(a);
a.click();
document.getElementById("tempArea--${pageName}").removeChild(a);
}
}
});
}
// 공시송달 수정 // 공시송달 수정
getSvbtcInfo${pageName} = (params) => { getSvbtcInfo${pageName} = (params) => {
if (!params) return; if (!params) return;
@ -543,6 +574,11 @@
getFindUser${pageName}(); getFindUser${pageName}();
} }
// 한글파일 출력 버튼 이벤트
fnHwpSvbtc${pageName} = () => {
makeHwpFileSvbtc${pageName}();
}
// 수정 버튼 이벤트 // 수정 버튼 이벤트
fnUpdateSvbtc${pageName} = () => { fnUpdateSvbtc${pageName} = () => {
let svbtcId = ${pageName}Control.dataset.getValue("SVBTC_ID"); let svbtcId = ${pageName}Control.dataset.getValue("SVBTC_ID");

@ -31,7 +31,7 @@
<button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀" onclick="fnExcel${pageName}();"> <button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀" onclick="fnExcel${pageName}();">
엑셀 엑셀
</button> </button>
<button type="button" class="btn btn-primary w-px-120" id="btnHwpPrint--${pageName}" title="한글파일 출력" onclick="fnHwpPrint${pageName}();"> <button type="button" class="btn btn-primary w-px-120" id="btnHwpSvbtcDtl--${pageName}" title="한글파일 출력" onclick="fnHwpSvbtcDtl${pageName}();">
한글파일 출력 한글파일 출력
</button> </button>
<button type="button" class="btn btn-primary w-px-120" id="btnRemove--${pageName}" title="공시송달 삭제" onclick="fnRemove${pageName}();"> <button type="button" class="btn btn-primary w-px-120" id="btnRemove--${pageName}" title="공시송달 삭제" onclick="fnRemove${pageName}();">
@ -299,6 +299,35 @@
/************************************************************************** /**************************************************************************
* 사용자 함수(function) * 사용자 함수(function)
**************************************************************************/ **************************************************************************/
// 공시송달 HWP 저장
makeHwpFileSvbtcDtl${pageName} = (params) => {
let selected = ${pageName}Control.dataset.getKeys("selected");
if (selected.length < 1) return;
if (!params) {
params = {};
params["sndngDtlIDs"] = selected.join(",");
}
ajax.get({
url : wctx.url("/" + params.taskSeCd + "/sndb/sndb01/250/makeSvbtcDtlHwp.do")
, data : params || {}
, success : resp => {
if (resp.filePath != null && resp.filePath != "") {
let a = document.createElement("a");
a.href = resp.filePath;
a.download = resp.fileName;
document.getElementById("tempArea--${pageName}").appendChild(a);
a.click();
document.getElementById("tempArea--${pageName}").removeChild(a);
}
}
});
}
// 개별총정보 dialog // 개별총정보 dialog
getTotalInfo${pageName} = (crdnId) => { getTotalInfo${pageName} = (crdnId) => {
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return; if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return;
@ -356,8 +385,8 @@
} }
// 한글파일 출력 버튼 이벤트 // 한글파일 출력 버튼 이벤트
fnHwpPrint${pageName} = () => { fnHwpSvbtcDtl${pageName} = () => {
makeHwpFileSvbtcDtl${pageName}();
} }
// 공시송달 삭제 버튼 이벤트 // 공시송달 삭제 버튼 이벤트

@ -560,6 +560,7 @@
$(document).ready(function() { $(document).ready(function() {
// 이벤트 설정 // 이벤트 설정
setEvent${pageName}(); setEvent${pageName}();
// 기본 데이터 설정 // 기본 데이터 설정
initData${pageName}(); initData${pageName}();

@ -306,7 +306,7 @@
<form id="frmUploadSet--${pageName}" method="post" enctype="multipart/form-data"> <form id="frmUploadSet--${pageName}" method="post" enctype="multipart/form-data">
<input type="file" id="inputUploadSet--${pageName}" name="inputUploadSet" multiple accept="image/*" hidden /> <input type="file" id="inputUploadSet--${pageName}" name="inputUploadSet" multiple accept="image/*" hidden />
</form> </form>
</div> <!-- 단속 이미지 <div class="card" style="width:500px;"> --> </div> <!-- 단속 이미지 -->
</div> <!-- <div class="d-flex flex-row justify-content-evenly"> --> </div> <!-- <div class="d-flex flex-row justify-content-evenly"> -->
</div> <!-- <div class="content-wrapper"> --> </div> <!-- <div class="content-wrapper"> -->

@ -28,7 +28,7 @@
<button type="button" class="btn btn-primary" id="btnRemoveOpnnSbmsn--${pageName}" title="의견제출 삭제" onclick="fnRemoveOpnnSbmsn${pageName}();"> <button type="button" class="btn btn-primary" id="btnRemoveOpnnSbmsn--${pageName}" title="의견제출 삭제" onclick="fnRemoveOpnnSbmsn${pageName}();">
의견제출 삭제 의견제출 삭제
</button> </button>
<button type="button" class="btn btn-primary" id="btnPrintDlbrtLtfr--${pageName}" title="심의의결서 출력" onclick="fnPrintDlbrtLtfr${pageName}();"> <button type="button" class="btn btn-primary" id="btnPrintDlbrDecsn--${pageName}" title="심의의결서 출력" onclick="fnPrintDlbrDecsn${pageName}();">
심의의결서 출력 심의의결서 출력
</button> </button>
</span> </span>
@ -174,7 +174,6 @@
<span id="tempArea--${pageName}" hidden></span> <span id="tempArea--${pageName}" hidden></span>
</form> </form>
</div> </div>
<script> <script>
@ -270,7 +269,7 @@
// 삭제 // 삭제
${pageName}Control.removeOpnnSbmsn = (params) => { ${pageName}Control.removeOpnnSbmsn = (params) => {
ajax.post({ ajax.post({
url : wctx.url(params.taskSeCd + "/excl/excl02/010/remove.do") url : wctx.url("/" + params.taskSeCd + "/excl/excl02/010/remove.do")
, data : params || {} , data : params || {}
, success : resp => ${pageName}Control.onRemove(resp) , success : resp => ${pageName}Control.onRemove(resp)
}); });
@ -279,12 +278,31 @@
/************************************************************************** /**************************************************************************
* 사용자 함수(function) * 사용자 함수(function)
**************************************************************************/ **************************************************************************/
// 심의 dialog
getOpnnSbmsnDlbrtInfo${pageName} = (params) => {
if (!params) return;
ajax.get({
url : wctx.url("/" + params.taskSeCd + "/excl/excl02/030/info.do")
, data : params || {}
, success : resp => {
dialog.open({
id : ${pageName}Control.prefixed("SbmsnDialog")
, title : "의견제출 심의"
, content : resp
, size : "lg"
, onClose : () => { refreshDataInfo${pageName}(); } // callback 자료 조회
});
}
});
}
// 심의의결서 출력 // 심의의결서 출력
getOpnnDlbrDecsnForm${pageName} = (params) => { makeHwpFileDlbrDecsn${pageName} = (params) => {
if (!params) return; if (!params) return;
ajax.get({ ajax.get({
url : wctx.url(params.taskSeCd + "/excl/excl02/040/makeDlbrDecsnHwp.do") url : wctx.url("/" + params.taskSeCd + "/excl/excl02/010/makeHwp.do")
, data : params || {} , data : params || {}
, success : resp => { , success : resp => {
if (resp.filePath != null && resp.filePath != "") { if (resp.filePath != null && resp.filePath != "") {
@ -301,25 +319,6 @@
}); });
} }
// 심의 dialog
getOpnnSbmsnDlbrtInfo${pageName} = (params) => {
if (!params) return;
ajax.get({
url : wctx.url(params.taskSeCd + "/excl/excl02/030/info.do")
, data : params || {}
, success : resp => {
dialog.open({
id : ${pageName}Control.prefixed("SbmsnDialog")
, title : "의견제출 심의"
, content : resp
, size : "lg"
, onClose : () => { refreshDataInfo${pageName}(); } // callback 자료 조회
});
}
});
}
// 자료 재조회 // 자료 재조회
refreshDataInfo${pageName} = () => { refreshDataInfo${pageName} = () => {
let crdnId = $("#crdnId--${pageNameMain}").val(); let crdnId = $("#crdnId--${pageNameMain}").val();
@ -336,7 +335,7 @@
}; };
ajax.get({ ajax.get({
url : wctx.url(params.taskSeCd + "/sprt/sprt02/030/info.do") url : wctx.url("/" + params.taskSeCd + "/sprt/sprt02/030/info.do")
, headers: { Accept: "application/json; charset=utf-8" } // json , headers: { Accept: "application/json; charset=utf-8" } // json
, data : params || {} , data : params || {}
, success : resp => { , success : resp => {
@ -420,7 +419,7 @@
} }
// 심의의결서 출력 버튼 이벤트 // 심의의결서 출력 버튼 이벤트
fnPrintDlbrtLtfr${pageName} = () => { fnPrintDlbrDecsn${pageName} = () => {
let opnnId = ${pageName}Control.dataset.getValue("OPNN_ID"); let opnnId = ${pageName}Control.dataset.getValue("OPNN_ID");
// 의견제출 ID 가 없다면.. return // 의견제출 ID 가 없다면.. return
@ -433,7 +432,7 @@
, opnnIDs : opnnId // 의견제출 ID , opnnIDs : opnnId // 의견제출 ID
}; };
getOpnnDlbrDecsnForm${pageName}(params); makeHwpFileDlbrDecsn${pageName}(params);
} }
// 의견제출 심의 버튼 이벤트 // 의견제출 심의 버튼 이벤트
@ -517,22 +516,8 @@
} }
// 화면 초기 설정
initForm${pageName} = () => {
// 화면 초기화
$("#frmEdit--${pageName}")[0].reset();
}
// 화면 데이터 셋팅 // 화면 데이터 셋팅
setFormData${pageName} = () => { initData${pageName} = () => {
// 날짜, 시간
if ($("#ansYmd--${pageName}").val() == "") {
$("#ansYmd--${pageName}").datepicker("setDate", new Date());
}
if ($("#ansTm--${pageName}").val() == "" || $("#ansTm--${pageName}").val() == "::") {
$("#ansTm--${pageName}").val(new Date().toTimeString().split(" ")[0]); // "09:51:35 GMT+0900 (한국 표준시)"의 형식에서 공백을 기준으로 잘라 시간 부분만 가져와줍니다.
}
// 화면 호출(callPurpose)이 view 라면 버튼 비활성화 // 화면 호출(callPurpose)이 view 라면 버튼 비활성화
if (${pageNameMain}CallPurpose == "view") { if (${pageNameMain}CallPurpose == "view") {
// button 요소들을 disabled = true // button 요소들을 disabled = true
@ -550,8 +535,8 @@
// 이벤트 설정 // 이벤트 설정
setEvent${pageName}(); setEvent${pageName}();
// 화면 초기 설정 // 기본 데이터 설정
initForm${pageName}(); initData${pageName}();
// Dataset 설정 // Dataset 설정
let opnnSbmsn = ${opnnSbmsn}; // 의견제출 정보 let opnnSbmsn = ${opnnSbmsn}; // 의견제출 정보
@ -559,8 +544,6 @@
${pageName}Control.setData([opnnSbmsn]); ${pageName}Control.setData([opnnSbmsn]);
} }
// 화면 데이터 셋팅
setFormData${pageName}();
}); });
</script> </script>

Loading…
Cancel
Save