사전통지 발송대상 상세화면 수정.

main
JoJH 1 day ago
parent 62db4b7590
commit 2aaea79721

@ -40,7 +40,6 @@
<label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end" for="ttlNm">제목</label> <label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end" for="ttlNm">제목</label>
<input is="id-input" type="text" class="form-control w-87" name="ttlNm" autocomplete="off" /> <input is="id-input" type="text" class="form-control w-87" name="ttlNm" autocomplete="off" />
</div> </div>
<!-- 기타 내용 -->
<div class="col-md-12"> <div class="col-md-12">
<label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end align-top" for="etcCn">기타내용</label> <label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end align-top" for="etcCn">기타내용</label>
<textarea is="id-textarea" class="form-control w-87" name="etcCn" rows="2" data-maxlengthb="1000" autocomplete="off"></textarea> <textarea is="id-textarea" class="form-control w-87" name="etcCn" rows="2" data-maxlengthb="1000" autocomplete="off"></textarea>
@ -224,7 +223,17 @@
// DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트 // DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트
$P.scrollDataList = () => { $P.scrollDataList = () => {
$P.ctrl.load($P.ctrl.query.pageNum + 1); // 페이지
$P.ctrl.query.pageNum += 1;
ajax.get({
url: $P.ctrl.urls.load
, headers: { Accept: "application/json; charset=utf-8" } // json
, data: $P.ctrl.query
, success: (resp) => {
$P.ctrl.addData(resp);
}
});
} }
/************************************************************************** /**************************************************************************
@ -295,7 +304,7 @@
$P.fnReset = () => { $P.fnReset = () => {
// 초기화 // 초기화
$P.findn("frmEdit").reset(); // 화면 초기화 $P.findn("frmEdit").reset(); // 화면 초기화
AppSupport.initDatepicker($P.findn("frmSearch")); // 달력 초기화 AppSupport.initDatepicker($P.findn("frmEdit")); // 달력 초기화
// 기본 데이터 설정 // 기본 데이터 설정
$P.$findn("sggCd").val("${sggCd}"); // 시군구 코드 $P.$findn("sggCd").val("${sggCd}"); // 시군구 코드
@ -305,6 +314,7 @@
$P.$findn("sndngEndYmd").datepicker("setDate", TODAY()); // 납기 일자 $P.$findn("sndngEndYmd").datepicker("setDate", TODAY()); // 납기 일자
// 업무 구분에 따른 URL 설정 // 업무 구분에 따른 URL 설정
$P.ctrl.urls.load = wctx.url("/" + "${taskSeCd}" + $P.prefixUrl + "/020/info.do"); // 조회
$P.ctrl.urls.create = wctx.url("/" + "${taskSeCd}" + $P.prefixUrl + "/020/createList.do"); // 등록 $P.ctrl.urls.create = wctx.url("/" + "${taskSeCd}" + $P.prefixUrl + "/020/createList.do"); // 등록
} }

@ -3,434 +3,337 @@
<c:set var="prefixName" scope="request">사전통지 발송 대상 상세 정보</c:set> <c:set var="prefixName" scope="request">사전통지 발송 대상 상세 정보</c:set>
<!-- inner page html --> <!-- Inner page html -->
<div class="wrapper-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 wrapper-pop">
<!-- Page Body --> <!-- 입력 영역 -->
<div class="card"> <form name="frmEdit">
<!-- 입력 영역 --> <input type="hidden" name="sggCd" />
<form id="frmEdit--${pageName}" name="frmEdit"> <input type="hidden" name="taskSeCd" />
<div class="row g-1"> <input type="hidden" name="vltnCd" />
<!-- 총 건수 -->
<div class="col-md-12 text-end px-2"> <div class="row g-1">
<label class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">총건수 / 총금액</label> <div class="col-md-12 text-end px-2">
<input type="text" class="form-control w-px-80 text-end" id="tnocs--${pageName}" name="tnocs" data-fmt-type="number" readonly /> <label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end">총건수 / 총금액</label>
<input type="text" class="form-control w-px-140 text-end" id="gramt--${pageName}" name="gramt" data-fmt-type="number" readonly /> <input is="id-input" type="text" class="form-control w-px-80 text-end" name="tnocs" data-fmt-type="number" readonly />
</div> <input is="id-input" type="text" class="form-control w-px-140 text-end" name="gramt" data-fmt-type="number" readonly />
<!-- 문서 번호 --> </div>
<div class="col-md-4"> <div class="col-md-4">
<label for="docNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">문서번호</label> <label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end" for="docNo">문서번호</label>
<input type="text" class="form-control w-55" id="docNo--${pageName}" name="docNo" autocomplete="off" /> <input is="id-input" type="text" class="form-control w-55" name="docNo" autocomplete="off" />
</div> </div>
<!-- 발송 일자 --> <div class="col-md-4">
<div class="col-md-4"> <label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end" for="sndngYmd">발송일자</label>
<label for="sndngYmd--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end required">발송일자</label> <input type="text" class="form-control form-date" name="sndngYmd"
<input type="text" class="form-control form-date" id="sndngYmd--${pageName}" name="sndngYmd" data-fmt-type="day" autocomplete="off" title="날짜 선택" required />
data-fmt-type="day" title="날짜 선택" maxlength="10" required /> <button type="button" class="bx bx-lg bx-calendar bg-white" name="btnSndngYmd"></button>
<button type="button" class="bx bx-lg bx-calendar bg-white"></button> </div>
</div> <div class="col-md-4">
<!-- 발송 종료 일자 --> <label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end" for="sndngEndYmd">납기일자</label>
<div class="col-md-4" id="divSndngEndYmd--${pageName}"> <input type="text" class="form-control form-date" name="sndngEndYmd"
<label for="sndngEndYmd--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">납기일자</label> data-fmt-type="day" autocomplete="off" title="날짜 선택" required />
<input type="text" class="form-control form-date" id="sndngEndYmd--${pageName}" name="sndngEndYmd" <button type="button" class="bx bx-lg bx-calendar bg-white" name="btnSndngEndYmd"></button>
data-fmt-type="day" title="날짜 선택" maxlength="10" /> </div>
<button type="button" id="btnSndngEndYmd--${pageName}" class="bx bx-lg bx-calendar bg-white"></button> <div class="col-md-12">
</div> <label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end" for="ttlNm">제목</label>
<!-- 제목 명 --> <input is="id-input" type="text" class="form-control w-87" name="ttlNm" autocomplete="off" />
<div class="col-md-12"> </div>
<label for="ttlNm--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">제목</label> <div class="col-md-12">
<input type="text" class="form-control w-87" id="ttlNm--${pageName}" name="ttlNm" autocomplete="off" /> <label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end align-top" for="etcCn">기타내용</label>
</div> <textarea is="id-textarea" class="form-control w-87" name="etcCn" rows="2" data-maxlengthb="1000" autocomplete="off"></textarea>
<!-- 기타 내용 --> </div>
<div class="col-md-12"> </div> <!-- <div class="row g-1"> -->
<label for="etcCn--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">기타내용</label> </form>
<textarea type="text" class="form-control w-87" id="etcCn--${pageName}" name="etcCn" rows="2" data-maxlengthb="1000" autocomplete="off"></textarea> <!-- 입력 영역 -->
</div>
</div> <!-- <div class="row g-1"> --> <!-- 업무 버튼 및 건수 표시 -->
</form> <div>
<!-- 입력 영역 --> <span class="container-page-btn" name="gridButtonArea">
<!-- 건수, 페이지 표시 -->
<!-- 업무 버튼 및 건수 표시 --> <div class="d-flex flex-row justify-content-between">
<div> <span is="paging-info" class="dataTables_info" name="dataPagingInfo" role="status" aria-live="polite"></span>
<span class="container-page-btn"> <ul class="pagination pagination-primary" name="dataPaging">
<!-- 업무 버튼 --> </ul>
<span class="container-window-btn-right"> </div>
<button type="button" class="btn btn-primary w-px-120" id="btnSave--${pageName}" title="저장"> <!-- 업무 버튼 -->
저장 <span class="container-window-btn-right">
</button> <button type="button" class="btn btn-primary w-px-120" name="btnSave" title="저장">
</span> 저장
</span> </button>
</div> <!-- 업무 버튼 및 건수 표시 --> </span>
</span>
<!-- DataTables(그리드) --> </div> <!-- 업무 버튼 및 건수 표시 -->
<div class="card-datatable text-nowrap">
<div class="dataTables_wrapper dt-bootstrap5 no-footer" id="DataTables_Table_0_wrapper--${pageName}"> <!-- DataTables(그리드) -->
<div class="table-responsive ox-scroll oy-scroll h-px-300" id="table-responsive--${pageName}"> <div class="card-datatable text-nowrap">
<table class="table-layout-fixed dataTable datatables-ajax table table-bordered no-footer" id="DataTables_Table_0--${pageName}" aria-describedby="DataTables_Table_0_info"> <div class="dataTables_wrapper dt-bootstrap5 no-footer">
<thead class="sticky-thead"> <div class="table-responsive ox-scroll oy-scroll h-px-300" name="tableRspns">
<tr id="theadTr--${pageName}" <table class="table-layout-fixed dataTable datatables-ajax table table-bordered no-footer" aria-describedby="DataTables_Table_0_info">
data-by="by--${pageName}" data-by-output="byOutput--${pageName}" data-main-option="mainOption--${pageName}" data-sub-option="subOption--${pageName}"> <thead class="sticky-thead">
<th class="cmn" style="width: 72px;">No.</th> <tr name="theadTr" data-search-target="[data-doctx='${pageName}']">
<th class="cmn" style="width: 180px;">민원신청번호</th> <th class="cmn" style="width: 72px;">No.</th>
<th class="cmn" style="width: 180px;">민원접수번호</th> <th class="cmn" style="width: 180px;">민원신청번호</th>
<th class="cmn" style="width: 120px;">민원접수일자</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: 180px;">단속일시</th> <th class="cmn" style="width: 160px;">민원처리결과</th>
<th class="cmn" style="width: 140px;">차량번호</th> <th class="cmn" style="width: 180px;">단속일시</th>
<th class="cmn" style="width: 160px;">위반항목</th> <th class="cmn" style="width: 140px;">차량번호</th>
<th class="cmn" style="width: 160px;">단속법정동</th> <th class="cmn" style="width: 160px;">위반항목</th>
<th class="cmn" style="width: 280px;">단속장소</th> <th class="cmn" style="width: 160px;">단속법정동</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: 120px;">과태료금액</th>
<th class="cmn" style="width: 120px;">처리상태</th> <th class="cmn" style="width: 120px;">사전통지금액</th>
<th class="cmn" style="width: 200px;">납부자명</th> <th class="cmn" style="width: 120px;">처리상태</th>
<th class="cmn" style="width: 120px;">납부자생일</th> <th class="cmn" style="width: 200px;">납부자명</th>
<th class="cmn" style="width: 100px;">우편번호</th> <th class="cmn" style="width: 120px;">납부자생일</th>
<th class="cmn" style="width: 280px;">주소</th> <th class="cmn" style="width: 100px;">우편번호</th>
<th class="cmn" style="width: 320px;">상세주소</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: 180px;">등록일시</th>
<th class="cmn" style="width: 180px;">수정일시</th> <th class="cmn" style="width: 140px;">등록사용자</th>
<th class="cmn" style="width: 140px;">수정사용자</th> <th class="cmn" style="width: 180px;">수정일시</th>
<th class="cmn dummy-th"></th> <th class="cmn" style="width: 140px;">수정사용자</th>
</tr> <th class="cmn dummy-th"></th>
</thead> </tr>
<tbody id="tbody--${pageName}"> </thead>
</tbody> <tbody name="tbodyList">
<template id="${infoPrefix}Row--${pageName}"> </tbody>
<tr data-key="{CRDN_ID}"> <template is="curly-brackets" name="tmpltRows">
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ROW_NUM}</td> <tr data-index="{data-index}">
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CVLCPT_APLY_NO}</td> <td class="cmn text-center" onclick ondblclick>{ROW_NUM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CVLCPT_RCPT_NO}</td> <td class="cmn text-center" onclick ondblclick>{CVLCPT_APLY_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CVLCPT_RCPT_YMD}</td> <td class="cmn text-center" onclick ondblclick>{CVLCPT_RCPT_NO}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CVLCPT_PRCS_NM}</td> <td class="cmn text-center" onclick ondblclick>{CVLCPT_RCPT_YMD}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_YMD_TM}</td> <td class="cmn text-center" onclick ondblclick>{CVLCPT_PRCS_NM}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{VHRNO}</td> <td class="cmn text-center" onclick ondblclick>{CRDN_YMD_TM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{VLTN_ARTCL}</td> <td class="cmn text-start" onclick ondblclick>{VHRNO}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_STDG_NM}</td> <td class="cmn text-center" onclick ondblclick>{VLTN_ARTCL}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_PLC}</td> <td class="cmn text-start" onclick ondblclick>{CRDN_STDG_NM}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_AMT}</td> <td class="cmn text-start" onclick ondblclick>{CRDN_PLC}</td>
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{ADVNTCE_AMT}</td> <td class="cmn text-end" onclick ondblclick>{FFNLG_AMT}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_STTS_NM}</td> <td class="cmn text-end" onclick ondblclick>{ADVNTCE_AMT}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NM}</td> <td class="cmn text-start" onclick ondblclick>{CRDN_STTS_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_BRDT_MASK}</td> <td class="cmn text-start" onclick ondblclick>{RTPYR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ZIP}</td> <td class="cmn text-center" onclick ondblclick>{RTPYR_BRDT_MASK}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ADDR}</td> <td class="cmn text-center" onclick ondblclick>{ZIP}</td>
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{DTL_ADDR}</td> <td class="cmn text-start" onclick ondblclick>{ADDR}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{REG_DT}</td> <td class="cmn text-start" onclick ondblclick>{DTL_ADDR}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RGTR_NM}</td> <td class="cmn text-center" onclick ondblclick>{REG_DT}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFCN_DT}</td> <td class="cmn text-center" onclick ondblclick>{RGTR_NM}</td>
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{MDFR_NM}</td> <td class="cmn text-center" onclick ondblclick>{MDFCN_DT}</td>
<td class="cmn dummy-td"></td> <td class="cmn text-center" onclick ondblclick>{MDFR_NM}</td>
</tr> <td class="cmn dummy-td"></td>
</template> </tr>
<template id="${infoPrefix}NotFound--${pageName}"> </template>
<tr class="odd"> <template name="tmpltNotFound">
<td valign="top" colspan="23" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td> <tr class="odd">
</tr> <td valign="top" colspan="23" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
</template> </tr>
</table> </template>
</div> </table>
</div> </div>
</div> <!-- DataTables(그리드) --> </div>
</div> <!-- <div class="card"> --> </div> <!-- DataTables(그리드) -->
<!-- Page Body --> </div> <!-- <div class="card"> -->
<!-- Page Body -->
</div> <!-- <div class="container flex-grow-1 px-0"> --> </div> <!-- <div class="container flex-grow-1 px-0"> -->
<!-- Content --> <!-- / Content -->
</div> </div>
<!-- / inner page html <div class="wrapper-pop"> --> <!-- / Inner page html -->
<script> <script>
/************************************************************************** LoadScript("sndb01060Script", wctx.url("/webjars/js/fims/sndb/sndb01060.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 의 검색 조건을 그대로 유지 // infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정)
$P.mainQuery = ${mainQuery}; $P.callPurpose = "${callPurpose}";
// 사전통지 일자 // 사전통지 일자
$P.advntceYmdInfo = ${advntceYmdInfo}; $P.advntceYmdInfo = ${advntceYmdInfo};
// datasetControl
/************************************************************************** $P.ctrl = newSndb01060Control("${pageName}", "[data-doctx=${pageName}]");
* DatasetControl // main 의 검색 조건을 그대로 유지
**************************************************************************/ $P.ctrl.query = ${mainQuery};
$P.control = new DatasetControl({
prefix: "advntceTrgt" /**************************************************************************
, prefixName: "사전통지 발송 대상" * DataTables 이벤트
, keymapper: info => info ? info.CRDN_ID : "" **************************************************************************/
, dataGetter: obj => obj.${infoPrefix}List // dataTable 클릭 이벤트
, appendData: true $P.dataTableClick = (dataIndex) => {
, formats: { if (!dataIndex) return;
TNOCS: numberFormat
, GRAMT: numberFormat $P.$findn("tbodyList").setCurrentRow(dataIndex);
, CVLCPT_RCPT_YMD: dateFormat
, CRDN_YMD_TM: datetimeFormat Apply.toDataset.current($P.ctrl.dataset, dataIndex);
, FFNLG_AMT: numberFormat }
, ADVNTCE_AMT: numberFormat
, REG_DT: datetimeFormat // dataTable 더블 클릭 이벤트 - 개별총정보 dialog
, MDFCN_DT: datetimeFormat $P.dataTableDblClick = (dataIndex) => {
} if (!dataIndex) return;
});
// $P.control 설정 // 단속 ID
$P.control.defaultFetchSize = FETCH_XS; // 1 페이지당 조회되는 자료 건수 index.jsp에서 확인 FETCH_XS = 30 let crdnId = $P.ctrl.getValue("CRDN_ID");
$P.control.query = { pageNum : 1, fetchSize : $P.control.defaultFetchSize }; if (!crdnId) return;
$P.control.beforeCurrent = null;
let params = {
callPageName: "${pageName}"
/************************************************************************** , callPurpose: "view"
* DatasetControl 이벤트 , sggCd: $P.ctrl.getValue("SGG_CD")
**************************************************************************/ , taskSeCd: $P.ctrl.getValue("TASK_SE_CD")
// Dataset 변경 이벤트 , crdnId: $P.ctrl.getValue("CRDN_ID")
$P.control.onDatasetChange = (obj, option) => { }
$P.renderList(obj.${infoPrefix}Total, option);
ajax.get({
$("#paging--${pageName}").setPagingInfo({ url: wctx.url("/sprt/sprt02/010/main.do")
list: $P.control.dataset , data: params || {}
, prefix: "paging--${pageName}" , success: (resp) => {
, start: obj.${infoPrefix}Start let dialogName = "totalInfoMainDialog";
, totalSize: obj.${infoPrefix}Total let dialogId = dialogName + "-" + uuid();
, fetchSize: obj.${infoPrefix}Fetch
, func: "pageObject['${pageName}'].control.load({index})" dialog.open({
}); id: dialogId
, title: "개별총정보"
, size: "xxl"
}; , content: resp
, init: () => {
// 현재 선택 자료 변경 이벤트 $("#" + dialogId).attr("name", dialogName);
$P.control.onCurrentChange = (item) => { $("#" + dialogId).attr("data-ref-doctx", "${pageName}");
if (!item) return;
AppSupport.setDialogZindex();
let key = item.data.CRDN_ID; }
, onClose: () => { }
$("#tbody--${pageName}").setCurrentRow(key); });
}; }
});
// 저장 callback }
$P.control.onSave = (resp) => {
let dialogTitle = $("#" + $P.control.prefix + "Dialog--${openerPageName}").find("h5.modal-title").html(); // DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, dialogTitle); $P.scrollDataList = () => {
// 페이지
// 메시지 출력 $P.ctrl.query.pageNum += 1;
dialog.alert({
content: showMessage ajax.get({
, init: () => { AppSupport.setDialogZindex(); } url: $P.ctrl.urls.load
, onOK: () => { } , headers: { Accept: "application/json; charset=utf-8" } // json
}); , data: $P.ctrl.query
, success: (resp) => {
if (resp.saved) { $P.ctrl.addData(resp);
dialog.close($P.control.prefix + "Dialog--${openerPageName}"); }
} });
} }
// 저장 /**************************************************************************
$P.control.save = (info) => { * 사용자 함수(function)
if (!info) return; **************************************************************************/
let create = ($P.callPurpose == "create");
/**************************************************************************
ajax.post({ * 버튼 clickEvent
url: !create ? $P.control.urls.update : $P.control.urls.create **************************************************************************/
, data: info // 저장
, success: resp => $P.control.onSave(resp) $P.fnSave = () => {
}); // validate 확인
} if (!AppSupport.customValidate($P.$findn("frmEdit").find("input,select,textarea"))) return;
/************************************************************************** dialog.alert({
* DataTables 이벤트 content: "현재 " + $P.ctrl.prefixName + " 정보를 저장하시겠습니까?"
**************************************************************************/ , init: () => { AppSupport.setDialogZindex(); }
// DataTables에 click, dbclick 이벤트 , onOK: () => {
$P.renderList = (totalSize, option) => { let formFields = new FimsFormFields($P.selectorn("frmEdit")).get(); // formFields
let ${infoPrefix}List = $P.control.dataset;
let empty = ${infoPrefix}List.empty; // 검색조건과 저장 파라미터 객체를 합친다.
let params = $.extend({}, $P.ctrl.query, formFields);
let trs = empty ? params.sndngRegSeCd = "01"; // 발송 등록 구분 코드(SNDNG_REG_SE_CD) - 01: 일괄
[document.getElementById("${infoPrefix}NotFound--${pageName}").innerHTML] : <%-- from template#${infoPrefix}NotFound --%> params.rsndYn = "N"; // 재발송 여부
${infoPrefix}List.inStrings( params.delYn = "N"; // 삭제 여부
document.getElementById("${infoPrefix}Row--${pageName}").innerHTML, <%-- from template#${infoPrefix}Row --%>
(str, dataItem) => str $P.ctrl.save(params);
.replace(/{onclick}/gi, "pageObject['${pageName}'].control.setCurrent('" + dataItem.getValue("CRDN_ID") + "');") }
.replace(/{ondblclick}/gi, "pageObject['${pageName}'].getTotalInfo('" + dataItem.getValue("CRDN_ID") + "');") });
); }
let noMore = (${infoPrefix}List.length >= totalSize); /**************************************************************************
let initScroll = ($P.control.query.pageNum < 2); * 초기 셋팅
if(option != null && option.reloaded){ **************************************************************************/
initScroll = false; // 이벤트 설정
} $P.setEvent = () => {
$("#table-responsive--${pageName}")[0].changeContent(trs.join(), initScroll, noMore); // 부과 일자 변경 이벤트
$P.$findn("sndngYmd").on("change", function() {
let sndngYmd = $P.$findn("sndngYmd").val();
//보안모드 sndngYmd = new Date(sndngYmd);
fn_securityModeToggle($("#securityMode--top").is(":checked")); sndngYmd.setDate(sndngYmd.getDate() + $P.advntceYmdInfo.ADVNTCE_DAY_CNT);
}
$P.$findn("sndngEndYmd").datepicker("setDate", sndngYmd);
// DataTables에 스크롤이 맨 밑으로 이동했을 때 이벤트 });
$P.scrollDataList = () => {
// 버튼 이벤트
$P.$findn("btnSave").on("click", () => $P.fnSave()); // 저장
$P.control.load($P.control.query.pageNum + 1);
} // DataTables 스크롤을 위해서 다이얼로그 화면이 생성된 후 Dataset을 설정한다.
let modalId = $(document.querySelector("[data-doctx='${pageName}']")).parents(".modal")[0].id;
// DataTables에 더블 클릭시 개별총정보 dialog $("#" + modalId).on("shown.bs.modal", function (e) {
$P.getTotalInfo = (crdnId) => { $P.ctrl.setData( {List: ${List}, Paging: ${Paging}} );
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return;
$P.$findn("tnocs").val($P.ctrl.getValue("TOT_CNT")); // 총건수
let params = { $P.$findn("gramt").val($P.ctrl.getValue("GRAMT")); // 총금액
callControlName: "pageObject['${pageName}'].control" $P.$findn("sndngYmd").datepicker("setDate", TODAY()); // 발송 일자
, callPurpose: "view" // 제목
, sggCd: $P.control.dataset.getValue("SGG_CD") let ttlNm = $P.ctrl.getValue("TASK_SE_NM");
, taskSeCd: $P.control.dataset.getValue("TASK_SE_CD") if ($P.ctrl.query.schVltnCd) { // 위반항목이 '전체'가 아니라면..
, crdnId: crdnId ttlNm = ttlNm + " " + $P.ctrl.getValue("VLTN_ARTCL");
} }
$P.$findn("ttlNm").val(ttlNm + " " + "사전통지");
ajax.get({ });
url: wctx.url("/sprt/sprt02/010/main.do")
, data: params // DataTables width 변경 조정
, success: resp => { Componentization.fnMakeResizableTable($P.findn("tableRspns"));
dialog.open({ // DataTables 스크롤 이벤트 생성
id: "totalInfoMainDialog" Componentization.fnMakeScrollableTable($P.findn("tableRspns"), $P.scrollDataList);
, title: "개별총정보" }
, content: resp
, size: "xxl" // 초기화 이벤트
}); $P.fnReset = () => {
} // 초기화
}); $P.findn("frmEdit").reset(); // 화면 초기화
} AppSupport.initDatepicker($P.findn("frmEdit")); // 달력 초기화
/************************************************************************** // 기본 데이터 설정
* 사용자 함수(function) $P.$findn("sggCd").val("${sggCd}"); // 시군구 코드
**************************************************************************/ $P.$findn("taskSeCd").val("${taskSeCd}"); // 업무 구분 코드
// 업무구분에 따른 URL 설정 $P.$findn("vltnCd").val("${vltnCd}"); // 위반 코드
$P.fnSetURL = (taskSeCd) => { $P.$findn("sndngYmd").datepicker("setDate", TODAY()); // 발송 일자
$P.control.urls.create = wctx.url("/" + taskSeCd + "${infoPrefixUrl}" + "/060/createList.do"); // 등록 $P.$findn("sndngEndYmd").datepicker("setDate", TODAY()); // 납기 일자
}
// 업무 구분에 따른 URL 설정
/************************************************************************** $P.ctrl.urls.load = wctx.url("/" + "${taskSeCd}" + $P.prefixUrl + "/060/info.do"); // 조회
* 버튼 clickEvent $P.ctrl.urls.create = wctx.url("/" + "${taskSeCd}" + $P.prefixUrl + "/060/createList.do"); // 등록
**************************************************************************/ }
// 저장
$P.fnSave = () => { /**************************************************************************
// validate 확인 * 최초 실행 함수
if (!AppSupport.customValidate($("#frmEdit--${pageName}").find("input, select, textarea"))) return; **************************************************************************/
// 1. 이벤트 설정
dialog.alert({ $P.setEvent();
content: "현재 " + $P.control.prefixName + " 정보를 저장하시겠습니까?"
, init: () => { AppSupport.setDialogZindex(); } // 2. 초기 화면 설정
, onOK: () => { $P.fnReset();
// 검색조건과 저장 파라미터 객체를 합친다.
let params = $.extend({}, $P.mainQuery, $P.formFields.get()); // 3. 보안모드
params.sndngRegSeCd = "01"; // 발송 등록 구분 코드(SNDNG_REG_SE_CD) - 01: 일괄 fn_securityModeToggle($("#securityMode--top").is(":checked"));
params.rsndYn = "N"; // 재발송 여부 });
params.delYn = "N"; // 삭제 여부
$P.control.save(params);
}
});
}
/**************************************************************************
* 초기 셋팅
**************************************************************************/
// 이벤트 설정
$P.setEvent = () => {
// form-date 항목에서 키보드로 입력시 날짜 포맷팅 적용
$("#frmEdit--${pageName}").find(".form-date").each(function() {
$(this).on("input", function() {
let value = this.value.replaceAll("-", "");
if (value.length > 7) {
this.value = value.substring(0, 4) + "-" + value.substring(4, 6) + "-" + value.substring(6);
} else if(value.length > 5) {
this.value = value.substring(0, 4) + "-" + value.substring(4);
}
});
});
// 부과 일자 변경 이벤트
$("#sndngYmd--${pageName}").on("change", function() {
let sndngYmd = $("#sndngYmd--${pageName}").val();
$("#sndngEndYmd--${pageName}").val(addDate(sndngYmd, $P.advntceYmdInfo.ADVNTCE_DAY_CNT));
});
// 업무 버튼 이벤트
$("#btnSave--${pageName}").on("click", () => $P.fnSave()); // 저장
// DataTables width 변경 조정
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: ${advntceTrgtList}
, ${infoPrefix}Start: ${advntceTrgtStart}
, ${infoPrefix}Fetch: ${advntceTrgtFetch}
, ${infoPrefix}Total: ${advntceTrgtTotal}
});
// 초기 데이터 설정
$P.initData();
});
}
// 화면 초기 설정
$P.initForm = () => {
// 화면 초기화
$("#frmEdit--${pageName}")[0].reset();
// 달력 초기화
AppSupport.initDatepicker("frmEdit--${pageName}");
$("#sndngYmd--${pageName}").datepicker("setDate", new Date());
$("#sndngEndYmd--${pageName}").datepicker("setDate", new Date());
}
// 초기 데이터 설정
$P.initData = () => {
// 총건수 / 총금액
$("#tnocs--${pageName}").val(${advntceTrgtTotal});
$("#gramt--${pageName}").val($P.control.dataset.getValue("GRAMT"));
// 발송 일자 / 발송 종료 일자
$("#sndngYmd--${pageName}").val($P.advntceYmdInfo.LEVY_YMD_MASK);
$("#sndngEndYmd--${pageName}").val($P.advntceYmdInfo.DUDT_YMD_MASK);
// 제목
let ttlNm = $P.control.dataset.getValue("TASK_SE_NM");
if ($P.mainQuery.schVltnCd != null && $P.mainQuery.schVltnCd != "") { // 위반항목이 '전체'가 아니라면..
ttlNm = ttlNm + " " + $P.control.dataset.getValue("VLTN_ARTCL");
}
$("#ttlNm--${pageName}").val(ttlNm + " " + "사전통지");
// 업무구분에 따른 URL 설정
$P.fnSetURL($P.mainQuery.taskSeCd);
}
/**************************************************************************
* 최초 실행 함수
**************************************************************************/
// 1. 이벤트 설정
$P.setEvent();
// 2. 초기 화면 설정
$P.initForm();
// 3. 보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked"));
});
</script> </script>

@ -938,10 +938,10 @@
let crdnPayerInfo = $P.ctrlCrdn.getCurrent(); let crdnPayerInfo = $P.ctrlCrdn.getCurrent();
let existVideo = false; let existVideo = false;
// 동영상 캡쳐
if (crdnPayerInfo.VIDEO_EXIST_YN == "Y") { if (crdnPayerInfo.VIDEO_EXIST_YN == "Y") {
existVideo = true; existVideo = true;
} }
// 사진 버튼 visible // 사진 버튼 visible
let showBtn = true; let showBtn = true;
if (pageObject["${pageNameMain}"].callPurpose == "view") { if (pageObject["${pageNameMain}"].callPurpose == "view") {

@ -0,0 +1,101 @@
function newSndb01060Control(pageName, doctx="[data-doctx='sndb01060']") {
let ctrl = new DatasetControl({
doctx: doctx
, prefix: "advntceTrgt"
, prefixName: "사전통지 발송 대상"
, dataGetter: obj => obj["List"]
, keys: ["CRDN_ID"]
, appendData: true
, urls: {
load: "/list.do"
, create: "/create.do"
}
, formats: {
TNOCS: numberFormat
, GRAMT: numberFormat
, CVLCPT_RCPT_YMD: dateFormat
, CRDN_YMD_TM: datetimeFormat
, FFNLG_AMT: numberFormat
, ADVNTCE_AMT: numberFormat
, REG_DT: datetimeFormat
, MDFCN_DT: datetimeFormat
}
});
// 검색 조건
ctrl.query = { pageNum: 1, fetchSize: DEFAULT_FETCH_SIZE }; // 1 페이지당 자료 건수 index.jsp에서 확인
// paging
ctrl.pagingSupport = new FimsPagingSupport({
ctrl: ctrl // DatasetControl
, ignoreCtrlPrefix: true // ctrl.prefix 가 있더라도 무시
, linkContainer: "[name='dataPaging']" // <ul class="pagination pagination-primary" name="dataPaging">
});
/**************************************************************************
* 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}');")
.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);
// dataTables(그리드)에 페이지 표시 pagingInfo
ctrl.pagingSupport.setPagingInfo(obj);
// 보안모드
fn_securityModeToggle($("#securityMode--top").is(":checked"));
};
// 현재 선택 자료 변경 이벤트
ctrl.onCurrentChange = (item) => {
Apply.fromDataset.currentRow(ctrl.dataset, item, ctrl.find("[name='tbodyList']"));
};
// 저장 callback
ctrl.onSave = (params, resp) => {
let modalId = $(document.querySelector(doctx)).parents(".modal")[0].id;
let dialogTitle = $("#" + modalId).find("h5.modal-title").html();
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, dialogTitle);
// 메시지 출력
dialog.alert({
content: showMessage
, init: () => { AppSupport.setDialogZindex(); }
, onOK: () => { }
, onClose: () => {
if (resp.saved) { dialog.close(modalId); }
}
});
}
// 저장
ctrl.save = (params) => {
if (!params) return;
ajax.post({
url: ctrl.urls.create
, data: params || {}
, success: (resp) => { ctrl.onSave(params, resp); }
});
}
return ctrl;
}
Loading…
Cancel
Save