전자우편발송 수정.

main
JoJH 1 week ago
parent dee17927e6
commit 11eb145dab

@ -241,7 +241,7 @@
$P.dataTableDblClick = (dataIndex) => { $P.dataTableDblClick = (dataIndex) => {
if (!dataIndex) return; if (!dataIndex) return;
// 민원상담 ID 가 없다면.. 입력 // 안내문 ID 가 없다면.. 입력
let gdntcId = $P.ctrl.getValue("GDNTC_ID"); let gdntcId = $P.ctrl.getValue("GDNTC_ID");
if (!gdntcId) return; if (!gdntcId) return;
@ -289,8 +289,6 @@
// 초기화 // 초기화
$P.fnReset(taskSeCd); $P.fnReset(taskSeCd);
// dataset 초기화
$P.ctrl.dataset.clear();
// 업무 구분에 따른 URL 설정 // 업무 구분에 따른 URL 설정
$P.fnSetURL(taskSeCd); $P.fnSetURL(taskSeCd);
@ -371,7 +369,6 @@
, callPurpose: "create" , callPurpose: "create"
, sggCd: $P.$findn("sggCd").val() // 시군구 코드 , sggCd: $P.$findn("sggCd").val() // 시군구 코드
, taskSeCd: $P.$findn("frmSearch").find("[name='taskSeCd']:checked").val() // 업무 구분 코드 , taskSeCd: $P.$findn("frmSearch").find("[name='taskSeCd']:checked").val() // 업무 구분 코드
}; };
$P.ctrl.getInfo(params); $P.ctrl.getInfo(params);
@ -429,10 +426,10 @@
// 이벤트 설정 // 이벤트 설정
$P.setEvent = () => { $P.setEvent = () => {
// 기본 버튼 이벤트 // 기본 버튼 이벤트
$P.$findn("btnReset").on("click", () => { $P.fnResetAndChangeBiz() }); // 초기화 $P.$findn("btnReset").on("click", () => $P.fnResetAndChangeBiz()); // 초기화
$P.$findn("btnSearch").on("click", () => { $P.fnSearchList() }); // 검색 $P.$findn("btnSearch").on("click", () => $P.fnSearchList()); // 검색
$P.$findn("btnExcel").on("click", () => { $P.fnExcel() }); // 엑셀 $P.$findn("btnExcel").on("click", () => $P.fnExcel()); // 엑셀
$P.$findn("btnFindUser").on("click", () => $P.fnGetFindUser()); // 사용자 검색 $P.$findn("btnFindUser").on("click", () => $P.fnGetFindUser()); // 사용자 검색
// 동적검색에서 엔터(Enter) 키를 누르면 검색한다. // 동적검색에서 엔터(Enter) 키를 누르면 검색한다.
$P.$findn("term").onEnterPress($P.fnSearchList); $P.$findn("term").onEnterPress($P.fnSearchList);
@ -458,6 +455,7 @@
$P.fnReset = (taskSeCd) => { $P.fnReset = (taskSeCd) => {
// 초기화 // 초기화
$P.findn("frmSearch").reset(); // 화면 초기화 $P.findn("frmSearch").reset(); // 화면 초기화
$P.ctrl.dataset.clear(); // dataset 초기화
AppSupport.initDatepicker($P.findn("frmSearch")); // 달력 초기화 AppSupport.initDatepicker($P.findn("frmSearch")); // 달력 초기화
AppSupport.initDetailSearchButton($P.findn("frmSearch")); // 상세검색 버튼 화살표 AppSupport.initDetailSearchButton($P.findn("frmSearch")); // 상세검색 버튼 화살표

@ -121,6 +121,8 @@
// button 요소들을 disabled // button 요소들을 disabled
$P.$findn("btnSave").prop("disabled", true); // 저장 버튼 $P.$findn("btnSave").prop("disabled", true); // 저장 버튼
} else if ($P.callPurpose == "update") {
$P.$findn("sndngSeCd").prop("disabled", true); // 발송 구분 코드
} }
} }

File diff suppressed because it is too large Load Diff

@ -1,295 +1,226 @@
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%> <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%> <%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
<c:set var="prefixName" scope="request">우편통합 발송 내역</c:set> <c:set var="prefixName" scope="request">우편통합 발송 상세 내역</c:set>
<!-- inner page html --> <!-- inner page html -->
<div class="content-pop"> <div class="content-wrapper" data-doctx="${pageName}">
<!-- Content --> <!-- Content -->
<div class="container flex-grow-1 px-0"> <div class="container flex-grow-1 px-0">
<div class="card"> <div class="card wrapper-list">
<!-- 입력 영역 --> <!-- 상단 버튼 -->
<form id="frmEdit--${pageName}" name="frmEdit"> <div class="container-page-btn">
<!-- hidden --> <span class="container-window-btn-right">
<input type="hidden" id="conKey--${pageName}" name="conKey" /> <button type="button" class="btn btn-excel w-px-120" name="btnExcel" title="엑셀">
</form> 엑셀
<!-- 입력 영역 --> </button>
</span>
<!-- 업무 버튼 및 건수 표시 --> </div>
<div> <!-- 상단 버튼 -->
<span class="container-page-btn">
<!-- 건수, 페이지 표시 --> <!-- 입력 영역 -->
<div class="d-flex flex-row justify-content-between"> <form name="frmEdit">
<span class="dataTables_info" id="paging--${pageName}PagingInfo" role="status" aria-live="polite"></span> <!-- hidden -->
<ul class="pagination pagination-primary" id="paging--${pageName}"> <input type="hidden" name="conKey" />
</ul> </form>
</div> <!-- 입력 영역 -->
<!-- 업무 버튼 -->
<span class="container-window-btn-right"> <!-- 업무 버튼 및 건수 표시 -->
<button type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀"> <div>
엑셀 <span class="container-page-btn" name="gridButtonArea">
</button> <!-- 건수, 페이지 표시 -->
</span> <div class="d-flex flex-row justify-content-between">
</span> <span is="paging-info" class="dataTables_info" name="dataPagingInfo" role="status" aria-live="polite"></span>
</div> <ul class="pagination pagination-primary" name="dataPaging">
<!-- 업무 버튼 및 건수 표시 --> </ul>
</div>
<!-- DataTables(그리드) --> </span>
<div class="card-datatable text-nowrap" id="datatable--${pageName}"> </div>
<div class="dataTables_wrapper dt-bootstrap5 no-footer" id="DataTables_Table_0_wrapper--${pageName}"> <!-- 업무 버튼 및 건수 표시 -->
<div class="table-responsive ox-scroll oy-scroll h-px-500" id="table-responsive--${pageName}">
<table class="table-layout-fixed dataTable datatables-ajax table table-bordered no-footer" id="DataTables_Table_0--${pageName}" aria-describedby="DataTables_Table_0_info"> <!-- DataTables(그리드) -->
<thead class="sticky-thead"> <div class="card-datatable text-nowrap">
<tr id="theadTr--${pageName}" <div class="dataTables_wrapper dt-bootstrap5 no-footer">
data-by="by--${pageName}" data-by-output="byOutput--${pageName}" data-main-option="mainOption--${pageName}" data-sub-option="subOption--${pageName}"> <div class="table-responsive ox-scroll oy-scroll h-px-600" name="tableRspns">
<th class="cmn" style="width: 72px;">No.</th> <table class="table-layout-fixed dataTable datatables-ajax table table-bordered no-footer" aria-describedby="DataTables_Table_0_info">
<th class="cmn" style="width: 180px;">등록일시</th> <thead class="sticky-thead">
<th class="cmn" style="width: 160px;">등기번호</th> <tr name="theadTr" data-search-target="[data-doctx='${pageName}']">
<th class="cmn" style="width: 100px;">우편번호</th> <th class="cmn" style="width: 72px;">No.</th>
<th class="cmn" style="width: 200px;">수취인명</th> <th class="cmn" style="width: 180px;">등록일시</th>
<th class="cmn" style="width: 180px;">배달일시</th> <th class="cmn" style="width: 160px;">등기번호</th>
<th class="cmn" style="width: 120px;">배달결과</th> <th class="cmn" style="width: 100px;">우편번호</th>
<th class="cmn" style="width: 120px;">수령인명</th> <th class="cmn" style="width: 200px;">수취인명</th>
<th class="cmn" style="width: 120px;">수령인관계</th> <th class="cmn" style="width: 180px;">배달일시</th>
<th class="cmn" style="width: 200px;">미배달사유</th> <th class="cmn" style="width: 120px;">배달결과</th>
<th class="cmn" style="width: 280px;">주소</th> <th class="cmn" style="width: 120px;">수령인명</th>
<th class="cmn" style="width: 320px;">상세주소</th> <th class="cmn" style="width: 120px;">수령인관계</th>
<th class="cmn" style="width: 240px;">연계식별키</th> <th class="cmn" style="width: 200px;">미배달사유</th>
<th class="cmn" style="width: 140px;">등록사용자</th> <th class="cmn" style="width: 280px;">주소</th>
<th class="cmn" style="width: 180px;">수정일시</th> <th class="cmn" style="width: 320px;">상세주소</th>
<th class="cmn" style="width: 140px;">수정사용자</th> <th class="cmn" style="width: 240px;">연계식별키</th>
<th class="cmn dummy-th"></th> <th class="cmn" style="width: 140px;">등록사용자</th>
</tr> <th class="cmn" style="width: 180px;">수정일시</th>
</thead> <th class="cmn" style="width: 140px;">수정사용자</th>
<tbody id="tbody--${pageName}"> <th class="cmn dummy-th"></th>
</tbody> </tr>
<template id="${infoPrefix}Row--${pageName}"> </thead>
<tr data-key="{RGST_NMBR}">
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ROW_NUM}</td> <tbody name="tbodyList">
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{REG_DT}</td> </tbody>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGST_NMBR}</td> <template is="curly-brackets" name="tmpltRows">
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RECEV_CAR_OWNER_ZIPCODE}</td> <tr data-index="{data-index}">
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RECEV_CAR_OWNER_NM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ROW_NUM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DELIV_YMD_TM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{REG_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DELIVRSLTCD_NM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGST_NMBR}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{SUBRECPRSNNM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RECEV_CAR_OWNER_ZIPCODE}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RELRECPRSNCDNM}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RECEV_CAR_OWNER_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{NONDELIVREASNCDNM}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DELIV_YMD_TM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RECEV_CAR_OWNER_ADDR}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DELIVRSLTCD_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RECEV_CAR_OWNER_DETAILADDR}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{SUBRECPRSNNM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CON_KEY}</td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RELRECPRSNCDNM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGTR_NM}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{NONDELIVREASNCDNM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RECEV_CAR_OWNER_ADDR}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFR_NM}</td> <td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RECEV_CAR_OWNER_DETAILADDR}</td>
<td class="cmn dummy-td"></td> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CON_KEY}</td>
</tr> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGTR_NM}</td>
</template> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td>
<template id="${infoPrefix}NotFound--${pageName}"> <td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFR_NM}</td>
<tr class="odd"> <td class="cmn dummy-td"></td>
<td valign="top" colspan="17" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td> </tr>
</tr> </template>
</template> <template name="tmpltNotFound">
</table> <tr class="odd">
</div> <td valign="top" colspan="17" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</div> </tr>
</div> </template>
<!-- DataTables(그리드) --> </table>
</div> <!-- <div class="card"> --> </div>
</div> <!-- <div class="container flex-grow-1 px-0"> --> </div>
<!-- Content --> </div>
<!-- DataTables(그리드) -->
</div> <!-- <div class="card"> -->
</div> <!-- <div class="container flex-grow-1 px-0"> -->
<!-- Content -->
</div> </div>
<!-- / inner page html <div class="content-pop"> --> <!-- / inner page html <div class="content-pop"> -->
<script> <script>
/************************************************************************** LoadScript("epst02040Script", wctx.url("/webjars/js/fims/epst/epst02040.js?ver=${ver}"));
* Global Variable
**************************************************************************/ /**************************************************************************
pageObject["${pageName}"] = {}; * Global Variable
**************************************************************************/
/************************************************************************** pageObject["${pageName}"] = newDoctxFinder("${pageName}");
* script 진입
**************************************************************************/ /**************************************************************************
$(document).ready(function() { * script 진입
// pageObject **************************************************************************/
let $P = pageObject["${pageName}"]; $(document).ready(function() {
// pageObject
// infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정) let $P = pageObject["${pageName}"];
$P.callPurpose = "${callPurpose}";
// FormFields // URL
$P.formFields = new FimsFormFields("#frmEdit--${pageName}"); $P.prefixUrl = "${prefixUrl}"
// main 의 검색 조건을 그대로 유지 // datasetControl
$P.mainQuery = ${mainQuery}; $P.ctrl = newEpst02040Script("${pageName}", "[data-doctx=${pageName}]");
// query
/************************************************************************** $P.ctrl.query = ${mainQuery};
* DatasetControl // paging
**************************************************************************/ $P.pagingSupport = new FimsPagingSupport({
$P.control = new DatasetControl({ ctrl: $P.ctrl // DatasetControl
prefix: "epostRcptRegDtl" , ignoreCtrlPrefix: true // ctrl.prefix 가 있더라도 무시
, prefixName: "우편 발송 정보" , linkContainer: "[name='dataPaging']" // <ul class="pagination pagination-primary" name="dataPaging">
, keymapper: info => info ? info.RGST_NMBR : "" });
, dataGetter: obj => obj.${infoPrefix}List
, appendData: true /**************************************************************************
, formats: { * DataTables 이벤트
DELIV_YMD_TM: datetimeFormat **************************************************************************/
, REG_DT: datetimeFormat // dataTable 클릭 이벤트
, MDFCN_DT: datetimeFormat $P.dataTableClick = (dataIndex) => {
} if (!dataIndex) return;
});
// $P.control 설정 $P.$findn("tbodyList").setCurrentRow(dataIndex);
$P.control.defaultFetchSize = FETCH_XS; // 1 페이지당 조회되는 자료 건수 index.jsp에서 확인 FETCH_XS = 30
$P.control.query = { pageNum : 1, fetchSize : $P.control.defaultFetchSize }; Apply.toDataset.current($P.ctrl.dataset, dataIndex);
$P.control.beforeCurrent = null; }
/************************************************************************** // DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트
* DatasetControl 이벤트 $P.scrollDataList = () => {
**************************************************************************/ $P.ctrl.load($P.ctrl.query.pageNum + 1);
// Dataset 변경 이벤트 }
$P.control.onDatasetChange = (obj, option) => {
$P.renderList(obj.${infoPrefix}Total, option); /**************************************************************************
* 사용자 함수(function)
$("#paging--${pageName}").setPagingInfo({ **************************************************************************/
list: $P.control.dataset // 업무구분에 따른 URL 설정
, prefix: "paging--${pageName}" $P.fnSetURL = (taskSeCd) => {
, start: obj.${infoPrefix}Start $P.ctrl.urls.load = wctx.url("/" + taskSeCd + $P.prefixUrl + "/040/list.do"); // 검색
, totalSize: obj.${infoPrefix}Total }
, fetchSize: obj.${infoPrefix}Fetch
, func: "pageObject['${pageName}'].control.load({index})" /**************************************************************************
}); * 버튼 clickEvent
**************************************************************************/
// 엑셀 버튼 이벤트
}; $P.fnExcel = () => {
if ($P.ctrl.dataset.empty) {
// 현재 선택 자료 변경 이벤트 dialog.alert({
$P.control.onCurrentChange = (item) => { content: "검색된 자료가 없습니다."
if (!item) return; , init: () => { AppSupport.setDialogZindex(); }
, onOK: () => { }
let key = item.data.RGST_NMBR; });
return;
$("#tbody--${pageName}").setCurrentRow(key); }
// CON_KEY
$("#conKey--${pageName}").val(item.data.CON_KEY); // DataTables(그리드)
}; $P.ctrl.query.cellDefs =
AppSupport.getCellDefs($P.$findn("theadTr").find("th").not(".dummy-th").not(":eq(0)")
/************************************************************************** , $($P.findn("tmpltRows").content).find("td").not(".dummy-td").not(":eq(0)")
* DataTables 이벤트 , FimsSupport.getCellDefsForPrivacyCell);
**************************************************************************/
// DataTables에 click, dbclick 이벤트 $P.ctrl.download();
$P.renderList = (totalSize, option) => { }
let ${infoPrefix}List = $P.control.dataset;
let empty = ${infoPrefix}List.empty; /**************************************************************************
* 초기 셋팅
let trs = empty ? **************************************************************************/
[document.getElementById("${infoPrefix}NotFound--${pageName}").innerHTML] : <%-- from template#${infoPrefix}NotFound --%> // 이벤트 설정
${infoPrefix}List.inStrings( $P.setEvent = () => {
document.getElementById("${infoPrefix}Row--${pageName}").innerHTML, <%-- from template#${infoPrefix}Row --%> // 기본 버튼 이벤트
(str, dataItem) => str $P.$findn("btnExcel").on("click", () => $P.fnExcel()); // 엑셀
.replace(/{onclick}/gi, "pageObject['${pageName}'].control.setCurrent('" + dataItem.getValue("RGST_NMBR") + "');")
); // DataTables 스크롤을 위해서 다이얼로그 화면이 생성된 후 Dataset을 설정한다.
let modalId = $(document.querySelector("[data-doctx='${pageName}']")).parents(".modal")[0].id;
let noMore = (${infoPrefix}List.length >= totalSize); $("#" + modalId).on("shown.bs.modal", function (e) {
let initScroll = ($P.control.query.pageNum < 2); $P.ctrl.setData( {List: ${List}, Paging :${Paging}} );
if(option != null && option.reloaded){ });
initScroll = false;
} // DataTables width 변경 조정
Componentization.fnMakeResizableTable($P.findn("tableRspns"));
$("#table-responsive--${pageName}")[0].changeContent(trs.join(), initScroll, noMore); // DataTables 스크롤 이벤트 생성
Componentization.fnMakeScrollableTable($P.findn("tableRspns"), $P.scrollDataList);
// 보안모드 }
fn_securityModeToggle($("#securityMode--top").is(":checked"));
} // 초기화 이벤트
$P.fnReset = (taskSeCd) => {
// DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트 // 초기화
$P.scrollDataList = () => { $P.findn("frmEdit").reset(); // 화면 초기화
$P.ctrl.dataset.clear(); // dataset 초기화
$P.control.load($P.control.query.pageNum + 1); // 업무 구분에 따른 URL 설정
} $P.fnSetURL(taskSeCd);
}
/**************************************************************************
* 사용자 함수(function) /**************************************************************************
**************************************************************************/ * 최초 실행 함수
**************************************************************************/
// 1. 이벤트 설정
/************************************************************************** $P.setEvent();
* 버튼 clickEvent
**************************************************************************/ // 2. 초기 설정 및 업무 구분 변경
// 엑셀 버튼 이벤트 $P.fnReset("${taskSeCd}");
$P.fnExcel = () => {
if ($P.control.dataset.empty) { // 3. 보안모드
dialog.alert({ fn_securityModeToggle($("#securityMode--top").is(":checked"));
content : "검색된 자료가 없습니다." });
, onOK : () => { }
});
return;
}
// DataTables(그리드)
let cellDefs = AppSupport.getCellDefs($("#theadTr--${pageName} th").not(".dummy-th").not(":eq(0)")
, $($("#${infoPrefix}Row--${pageName}")[0].content).find("td").not(".dummy-td").not(":eq(0)")
, FimsSupport.getCellDefsForPrivacyCell);
$P.control.query.cellDefs = cellDefs;
$P.control.download();
}
/**************************************************************************
* 초기 셋팅
**************************************************************************/
// 이벤트 설정
$P.setEvent = () => {
// 기본 버튼 이벤트
$("#btnExcel--${pageName}").on("click", () => $P.fnExcel()); // 엑셀
// DataTables width 변경 조정 업무별 그리드가 존재 한다면.. crdn06010-main.jsp 참고
Componentization.fnMakeResizableTable($("#table-responsive--${pageName}")[0]);
// DataTables 스크롤 이벤트 생성
Componentization.fnMakeScrollableTable($("#table-responsive--${pageName}")[0], $P.scrollDataList);
// DataTables 스크롤을 위해서 다이얼로그 화면이 생성된 후 Dataset을 설정한다.
$("#${infoPrefix}Dialog--${openerPageName}").on("shown.bs.modal", function (e) {
$P.control.setData({
${infoPrefix}List: ${epostRcptRegDtlList}
, ${infoPrefix}Start: ${epostRcptRegDtlStart}
, ${infoPrefix}Fetch: ${epostRcptRegDtlFetch}
, ${infoPrefix}Total: ${epostRcptRegDtlTotal}
});
// 업무 구분별 설정
$P.setTask("${taskSeCd}");
});
}
// 초기 화면 설정
$P.initForm = () => {
// 화면 초기화
$("#frmEdit--${pageName}")[0].reset();
}
// 업무 구분별 설정
$P.setTask = (taskSeCd) => {
// 검색 조건 설정
$P.control.query = $P.mainQuery;
// CON_KEY
$("#conKey--${pageName}").val($P.control.dataset.getValue("CON_KEY"));
// 업무구분에 따른 URL 변경
$P.control.urls.load = wctx.url("/" + taskSeCd + "${infoPrefixUrl}" + "/040/list.do"); // 검색
}
/**************************************************************************
* 최초 실행 함수
**************************************************************************/
// 1. 이벤트 설정
$P.setEvent();
// 2. 초기 화면 설정
$P.initForm();
// 3. 보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked"));
});
</script> </script>

@ -424,8 +424,6 @@
// 초기화 // 초기화
$P.fnReset(taskSeCd); $P.fnReset(taskSeCd);
// dataset 초기화
$P.ctrl.dataset.clear();
// 업무 구분에 따른 URL 설정 // 업무 구분에 따른 URL 설정
$P.fnSetURL(taskSeCd); $P.fnSetURL(taskSeCd);
@ -575,10 +573,10 @@
// 이벤트 설정 // 이벤트 설정
$P.setEvent = () => { $P.setEvent = () => {
// 기본 버튼 이벤트 // 기본 버튼 이벤트
$P.$findn("btnReset").on("click", () => { $P.fnResetAndChangeBiz() }); // 초기화 $P.$findn("btnReset").on("click", () => $P.fnResetAndChangeBiz()); // 초기화
$P.$findn("btnSearch").on("click", () => { $P.fnSearchList() }); // 검색 $P.$findn("btnSearch").on("click", () => $P.fnSearchList()); // 검색
$P.$findn("btnExcel").on("click", () => { $P.fnExcel() }); // 엑셀 $P.$findn("btnExcel").on("click", () => $P.fnExcel()); // 엑셀
$P.$findn("btnFindUser").on("click", () => $P.fnGetFindUser()); // 사용자 검색 $P.$findn("btnFindUser").on("click", () => $P.fnGetFindUser()); // 사용자 검색
// 동적검색에서 엔터(Enter) 키를 누르면 검색한다. // 동적검색에서 엔터(Enter) 키를 누르면 검색한다.
$P.$findn("term").onEnterPress($P.fnSearchList); $P.$findn("term").onEnterPress($P.fnSearchList);
@ -601,6 +599,7 @@
$P.fnReset = (taskSeCd) => { $P.fnReset = (taskSeCd) => {
// 초기화 // 초기화
$P.findn("frmSearch").reset(); // 화면 초기화 $P.findn("frmSearch").reset(); // 화면 초기화
$P.ctrl.dataset.clear(); // dataset 초기화
AppSupport.initDatepicker($P.findn("frmSearch")); // 달력 초기화 AppSupport.initDatepicker($P.findn("frmSearch")); // 달력 초기화
AppSupport.initDetailSearchButton($P.findn("frmSearch")); // 상세검색 버튼 화살표 AppSupport.initDetailSearchButton($P.findn("frmSearch")); // 상세검색 버튼 화살표

@ -547,8 +547,6 @@
// 초기화 // 초기화
$P.fnReset(taskSeCd); $P.fnReset(taskSeCd);
// dataset 초기화
$P.ctrl.dataset.clear();
// 업무 구분에 따른 URL 설정 // 업무 구분에 따른 URL 설정
$P.fnSetURL(taskSeCd); $P.fnSetURL(taskSeCd);
@ -751,10 +749,10 @@
// 이벤트 // 이벤트
$P.setEvent = () => { $P.setEvent = () => {
// 기본 버튼 이벤트 // 기본 버튼 이벤트
$P.$findn("btnReset").on("click", () => $P.fnResetAndChangeBiz()); // 초기화 $P.$findn("btnReset").on("click", () => $P.fnResetAndChangeBiz()); // 초기화
$P.$findn("btnSearch").on("click", () => $P.fnSearchList()); // 검색 $P.$findn("btnSearch").on("click", () => $P.fnSearchList()); // 검색
$P.$findn("btnExcel").on("click", () => $P.fnExcel()); // 엑셀 $P.$findn("btnExcel").on("click", () => $P.fnExcel()); // 엑셀
$P.$findn("btnFindUser").on("click", () => $P.fnGetFindUser()); // 사용자 검색 $P.$findn("btnFindUser").on("click", () => $P.fnGetFindUser()); // 사용자 검색
// 동적검색에서 엔터(Enter) 키를 누르면 검색한다. // 동적검색에서 엔터(Enter) 키를 누르면 검색한다.
$P.$findn("term").onEnterPress($P.fnSearchList); $P.$findn("term").onEnterPress($P.fnSearchList);
@ -786,6 +784,7 @@
$P.fnReset = (taskSeCd) => { $P.fnReset = (taskSeCd) => {
// 초기화 // 초기화
$P.findn("frmSearch").reset(); // 화면 초기화 $P.findn("frmSearch").reset(); // 화면 초기화
$P.ctrl.dataset.clear(); // dataset 초기화
AppSupport.initDatepicker($P.findn("frmSearch")); // 달력 초기화 AppSupport.initDatepicker($P.findn("frmSearch")); // 달력 초기화
AppSupport.initDetailSearchButton($P.findn("frmSearch")); // 상세검색 버튼 화살표 AppSupport.initDetailSearchButton($P.findn("frmSearch")); // 상세검색 버튼 화살표

@ -360,8 +360,6 @@
// 초기화 // 초기화
$P.fnReset(taskSeCd); $P.fnReset(taskSeCd);
// dataset 초기화
$P.ctrl.dataset.clear();
// 업무 구분에 따른 URL 설정 // 업무 구분에 따른 URL 설정
$P.fnSetURL(taskSeCd); $P.fnSetURL(taskSeCd);
@ -472,10 +470,10 @@
// 이벤트 설정 // 이벤트 설정
$P.setEvent = () => { $P.setEvent = () => {
// 기본 버튼 이벤트 // 기본 버튼 이벤트
$P.$findn("btnReset").on("click", () => { $P.fnResetAndChangeBiz() }); // 초기화 $P.$findn("btnReset").on("click", () => $P.fnResetAndChangeBiz()); // 초기화
$P.$findn("btnSearch").on("click", () => { $P.fnSearchList() }); // 검색 $P.$findn("btnSearch").on("click", () => $P.fnSearchList()); // 검색
$P.$findn("btnExcel").on("click", () => { $P.fnExcel() }); // 엑셀 $P.$findn("btnExcel").on("click", () => $P.fnExcel()); // 엑셀
$P.$findn("btnFindUser").on("click", () => $P.fnGetFindUser()); // 사용자 검색 $P.$findn("btnFindUser").on("click", () => $P.fnGetFindUser()); // 사용자 검색
// 동적검색에서 엔터(Enter) 키를 누르면 검색한다. // 동적검색에서 엔터(Enter) 키를 누르면 검색한다.
$P.$findn("term").onEnterPress($P.fnSearchList); $P.$findn("term").onEnterPress($P.fnSearchList);
@ -495,6 +493,7 @@
$P.fnReset = (taskSeCd) => { $P.fnReset = (taskSeCd) => {
// 초기화 // 초기화
$P.findn("frmSearch").reset(); // 화면 초기화 $P.findn("frmSearch").reset(); // 화면 초기화
$P.ctrl.dataset.clear(); // dataset 초기화
AppSupport.initDatepicker($P.findn("frmSearch")); // 달력 초기화 AppSupport.initDatepicker($P.findn("frmSearch")); // 달력 초기화
AppSupport.initDetailSearchButton($P.findn("frmSearch")); // 상세검색 버튼 화살표 AppSupport.initDetailSearchButton($P.findn("frmSearch")); // 상세검색 버튼 화살표

@ -126,9 +126,7 @@
$P.fnReset = () => { $P.fnReset = () => {
// 초기화 // 초기화
$P.findn("frmEdit").reset(); // 화면 초기화 $P.findn("frmEdit").reset(); // 화면 초기화
AppSupport.initDatepicker($P.findn("frmEdit")); // 달력 초기화
// 달력 초기화
AppSupport.initDatepicker($P.findn("frmEdit"));
// 기본 데이터 설정 // 기본 데이터 설정
$P.$findn("dscsnYmd").datepicker("setDate", TODAY()); // 상담 일자 $P.$findn("dscsnYmd").datepicker("setDate", TODAY()); // 상담 일자

@ -94,7 +94,7 @@ function newEpst02010Script(pageName, doctx="[data-doctx='epst02010']") {
AppSupport.setDialogZindex(); AppSupport.setDialogZindex();
} }
// , onClose: () => { ctrl.reload({all : true}); } // 자료 재조회 , onClose: () => { ctrl.reload({all : true}); } // 자료 재조회
}); });
} }
}); });

@ -0,0 +1,158 @@
function newEpst02030Script(pageName, doctx="[data-doctx='epst02030']") {
let ctrl = new DatasetControl({
doctx: doctx
, prefix: "epostRcptReg"
, prefixName: "우편발송"
, dataGetter: obj => obj["List"]
, keys: ["CON_KEY"]
, appendData: true
, infoSize: "xxl"
, urls: {
load: "/list.do"
, getInfo: "/info.do"
, remove: "/remove.do"
}
, formats: {
SEND_DATE: dateFormat
, RCEPT_YMD: dateFormat
, RECEV_CNT: numberFormat
, REG_DT: datetimeFormat
, MDFCN_DT: datetimeFormat
}
});
// 검색 조건
ctrl.query = { pageNum: 1, fetchSize: DEFAULT_FETCH_SIZE }; // 1 페이지당 자료 건수 index.jsp에서 확인
/**************************************************************************
* DatasetControl Events
**************************************************************************/
// Dataset 변경 이벤트
ctrl.onDatasetChange = (obj, option) => {
// 데이터 셋
let dataList = ctrl.dataset;
let empty = dataList.empty;
let replacer = (str, dataItem) => str
.replace(/{onclick}/gi, "pageObject['" + pageName + "'].dataTableClick('{data-index}');")
.replace(/{ondblclick}/gi, "pageObject['" + pageName + "'].dataTableDblClick('{data-index}');");
let trs = empty ?
[ctrl.find("[name='tmpltNotFound']").innerHTML]
: dataList.inStrings(ctrl.find("[name='tmpltRows']").innerHTML, replacer);
let noMore = (dataList.length >= obj["Paging"]?.totalSize); // 전체 건수
let initScroll = (ctrl.query.pageNum < 2);
if (option != null && option.reloaded) {
initScroll = false;
}
// dataTables(그리드)에 자료 표시 td
ctrl.find("[name='tableRspns']").changeContent(trs.join(), initScroll, noMore);
// checkbox 체크 해제
$(ctrl.find("[name='gridAllCheckbox']")).prop("checked", false);
// dataTables(그리드)에 페이지 표시 pagingInfo
pageObject[pageName].pagingSupport.setPagingInfo(obj);
// 보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked"));
};
// 현재 선택 자료 변경 이벤트
ctrl.onCurrentChange = (item) => {
Apply.fromDataset.currentRow(ctrl.dataset, item, ctrl.find("[name='tbodyList']"));
};
// 선택(체크) 변경 이벤트
ctrl.onSelectionChange = (selectedArr) => {
// gridCheckbox
Apply.fromDataset.gridCheckbox(ctrl.dataset, ctrl.find("[name='tbodyList']"), 1, selectedArr);
// gridButton
Apply.fromDataset.gridButton(ctrl.dataset, ctrl.find("[name='btnRemove']"), selectedArr); // 삭제 버튼
};
// 상세 정보 dialog
ctrl.getInfo = (params) => {
if (!params) return;
ajax.get({
url: ctrl.urls.getInfo
, data: params || {}
, success: (resp) => {
let dialogName = ctrl.prefixed("Dialog");
let dialogId = dialogName + "-" + uuid();
dialog.open({
id: dialogId
, title: params.btnTitle
, size: ctrl.infoSize
, content: resp
, init: () => {
$("#" + dialogId).attr("name", dialogName);
$("#" + dialogId).attr("data-ref-doctx", pageName);
AppSupport.setDialogZindex();
}
, onClose: () => { }
});
}
});
}
// 삭제 callback
ctrl.onRemove = (params, resp) => {
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, params.btnTitle);
// 메시지 출력
dialog.alert({
content: showMessage
, init: () => { AppSupport.setDialogZindex(); }
, onOK: () => { }
, onClose: () => {
if (resp.saved) { ctrl.reload({ all: true }); } // 자료 재조회
}
});
}
// 삭제
ctrl.remove = (params) => {
if (!params) return;
ajax.post({
url: ctrl.urls.remove
, data: params || {}
, success: (resp) => { ctrl.onRemove(params, resp); }
});
}
// 저장 callback
ctrl.onSave = (params, resp) => {
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, params.btnTitle);
// 메시지 출력
dialog.alert({
content: showMessage
, init: () => { AppSupport.setDialogZindex(); }
, onOK: () => { }
, onClose: () => {
if (resp.saved) { ctrl.reload({ all: true }); } // 자료 재조회
}
});
}
// 저장
ctrl.save = (params) => {
if (!params) return;
ajax.post({
url: ctrl.urls.update
, data: params || {}
, success: (resp) => { ctrl.onSave(params, resp); }
});
}
return ctrl;
}

@ -0,0 +1,67 @@
function newEpst02040Script(pageName, doctx="[data-doctx='epst02040']") {
let ctrl = new DatasetControl({
doctx: doctx
, prefix: "epostRcptRegDtl"
, prefixName: "우편발송 상세"
, dataGetter: obj => obj["List"]
, keys: ["RGST_NMBR"]
, appendData: true
, infoSize: "xl"
, urls: {
load: "/list.do"
}
, formats: {
DELIV_YMD_TM: datetimeFormat
, REG_DT: datetimeFormat
, MDFCN_DT: datetimeFormat
}
});
// 검색 조건
ctrl.query = { pageNum: 1, fetchSize: DEFAULT_FETCH_SIZE }; // 1 페이지당 자료 건수 index.jsp에서 확인
/**************************************************************************
* DatasetControl Events
**************************************************************************/
ctrl.onDatasetChange = (obj, option) => {
// 데이터 셋
let dataList = ctrl.dataset;
let empty = dataList.empty;
let replacer = (str, dataItem) => str
.replace(/{onclick}/gi, "pageObject['" + pageName + "'].dataTableClick('{data-index}');");
let trs = empty ?
[ctrl.find("[name='tmpltNotFound']").innerHTML]
: dataList.inStrings(ctrl.find("[name='tmpltRows']").innerHTML, replacer);
let noMore = (dataList.length >= obj["Paging"]?.totalSize); // 전체 건수
let initScroll = (ctrl.query.pageNum < 2);
if (option != null && option.reloaded) {
initScroll = false;
}
// dataTables(그리드)에 자료 표시 td
ctrl.find("[name='tableRspns']").changeContent(trs.join(), initScroll, noMore);
// dataTables(그리드)에 페이지 표시 pagingInfo
pageObject[pageName].pagingSupport.setPagingInfo(obj);
// 보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked"));
};
// 현재 선택 자료 변경 이벤트
ctrl.onCurrentChange = (item) => {
Apply.fromDataset.currentRow(ctrl.dataset, item, ctrl.find("[name='tbodyList']"));
if (!item) return;
// 화면에 단속 Dataset 셋팅
let formFields = new FimsFormFields(ctrl.selector("[name='frmEdit']"));
formFields.set(ctrl, item);
};
return ctrl;
}
Loading…
Cancel
Save