우편통합 안내문 수정.
parent
4eef8a961f
commit
dee17927e6
File diff suppressed because it is too large
Load Diff
@ -1,207 +1,140 @@
|
||||
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
|
||||
<%@ 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 -->
|
||||
<div class="content-pop">
|
||||
<!-- Content -->
|
||||
<div class="container flex-grow-1 px-0">
|
||||
<div class="card">
|
||||
<!-- 입력 영역 -->
|
||||
<form id="frmEdit--${pageName}" name="frmEdit">
|
||||
<!-- hidden -->
|
||||
<input type="hidden" id="sggCd--${pageName}" name="sggCd" data-map="SGG_CD" />
|
||||
<input type="hidden" id="taskSeCd--${pageName}" name="taskSeCd" data-map="TASK_SE_CD" />
|
||||
<input type="hidden" id="gdntcId--${pageName}" name="gdntcId" data-map="GDNTC_ID" />
|
||||
|
||||
<div class="row g-1">
|
||||
<!-- 발송 구분 코드 -->
|
||||
<div class="col-md-12">
|
||||
<label for="sndngSeCd--${pageName}" class="w-px-100 bg-lighter pe-2 col-form-label text-sm-end required">발송구분</label>
|
||||
<select class="form-select" id="sndngSeCd--${pageName}" name="sndngSeCd" data-map="SNDNG_SE_CD" required>
|
||||
<option value="">선택하세요</option>
|
||||
<c:forEach items="${FIM047List}" var="item">
|
||||
<option value="${item.code}">${item.value}</option>
|
||||
</c:forEach>
|
||||
</select>
|
||||
</div>
|
||||
<!-- 제목 명 -->
|
||||
<div class="col-md-12">
|
||||
<label for="ttlNm--${pageName}" class="w-px-100 bg-lighter pe-2 col-form-label text-sm-end required">제목</label>
|
||||
<input type="text" class="form-control w-75" id="ttlNm--${pageName}" name="ttlNm" data-map="TTL_NM" required autocomplete="off" />
|
||||
</div>
|
||||
<!-- 문구 내용 -->
|
||||
<div class="col-md-12">
|
||||
<label for="wordsCn--${pageName}" class="w-px-100 bg-lighter pe-2 col-form-label text-sm-end">문구내용</label>
|
||||
</div>
|
||||
<div class="col-md-12">
|
||||
<textarea class="form-control w-100" id="wordsCn--${pageName}" name="wordsCn" data-map="WORDS_CN" rows="15" data-maxlengthb="4000" autocomplete="off"></textarea>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
<!-- 입력 영역 -->
|
||||
|
||||
<!-- 업무 버튼 및 건수 표시 -->
|
||||
<div>
|
||||
<span class="container-page-btn">
|
||||
<!-- 업무 버튼 -->
|
||||
<span class="container-window-btn-right">
|
||||
<button type="button" class="btn btn-primary w-px-80" id="btnSave--${pageName}" title="저장">
|
||||
저장
|
||||
</button>
|
||||
</span>
|
||||
</span>
|
||||
</div>
|
||||
<!-- 업무 버튼 및 건수 표시 -->
|
||||
</div> <!-- <div class="card"> -->
|
||||
</div> <!-- <div class="container flex-grow-1 px-0"> -->
|
||||
<!-- Content -->
|
||||
<div class="content-pop" data-doctx="${pageName}">
|
||||
<!-- Content -->
|
||||
<div class="container flex-grow-1 px-0">
|
||||
<div class="card">
|
||||
<!-- 입력 영역 -->
|
||||
<form name="frmEdit">
|
||||
<!-- hidden -->
|
||||
<input type="hidden" name="sggCd" data-map="SGG_CD" />
|
||||
<input type="hidden" name="taskSeCd" data-map="TASK_SE_CD" />
|
||||
<input type="hidden" name="gdntcId" data-map="GDNTC_ID" />
|
||||
|
||||
<div class="row g-1">
|
||||
<div class="col-md-12">
|
||||
<label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end required" for="sndngSeCdsndngSeCd">발송구분</label>
|
||||
<select is="id-select" class="form-select" name="sndngSeCd" data-map="SNDNG_SE_CD" required>
|
||||
<option value="">선택하세요</option>
|
||||
<c:forEach items="${FIM047List}" var="item">
|
||||
<option value="${item.code}">${item.value}</option>
|
||||
</c:forEach>
|
||||
</select>
|
||||
</div>
|
||||
<div class="col-md-12">
|
||||
<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-70" name="ttlNm" data-map="TTL_NM" required autocomplete="off" />
|
||||
</div>
|
||||
<!-- 문구 내용 -->
|
||||
<div class="col-md-12">
|
||||
<label is="name-label" class="col-form-label bg-lighter pe-2 w-px-120 text-sm-end" for="wordsCn">문구내용</label>
|
||||
</div>
|
||||
<div class="col-md-12">
|
||||
<textarea is="id-textarea" class="form-control w-100" name="wordsCn" data-map="WORDS_CN" rows="15" data-maxlengthb="4000" autocomplete="off"></textarea>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
<!-- 입력 영역 -->
|
||||
</div> <!-- <div class="card"> -->
|
||||
|
||||
<!-- 업무 버튼 및 건수 표시 -->
|
||||
<div>
|
||||
<span class="container-page-btn">
|
||||
<!-- 업무 버튼 -->
|
||||
<span class="container-window-btn-right">
|
||||
<button type="button" class="btn btn-primary w-px-120" name="btnSave" title="저장">
|
||||
저장
|
||||
</button>
|
||||
</span>
|
||||
</span>
|
||||
</div>
|
||||
<!-- 업무 버튼 및 건수 표시 -->
|
||||
</div> <!-- <div class="container flex-grow-1 px-0"> -->
|
||||
<!-- Content -->
|
||||
</div>
|
||||
<!-- / inner page html <div class="content-pop"> -->
|
||||
|
||||
<script>
|
||||
/**************************************************************************
|
||||
* Global Variable
|
||||
**************************************************************************/
|
||||
pageObject["${pageName}"] = {};
|
||||
|
||||
/**************************************************************************
|
||||
* script 진입
|
||||
**************************************************************************/
|
||||
$(document).ready(function() {
|
||||
// pageObject
|
||||
let $P = pageObject["${pageName}"];
|
||||
|
||||
// infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정)
|
||||
$P.callPurpose = "${callPurpose}";
|
||||
// FormFields
|
||||
$P.formFields = new FimsFormFields("#frmEdit--${pageName}");
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl
|
||||
**************************************************************************/
|
||||
$P.control = new DatasetControl({
|
||||
prefix: "epostGdntc"
|
||||
, prefixName: "안내문 정보"
|
||||
, keymapper: info => info ? info.GDNTC_ID : ""
|
||||
, dataGetter: obj => obj.${infoPrefix}Info
|
||||
});
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl 이벤트
|
||||
**************************************************************************/
|
||||
// 현재 선택 자료 변경 이벤트
|
||||
$P.control.onCurrentChange = (item) => {
|
||||
if (!item) return;
|
||||
|
||||
// Dataset 셋팅
|
||||
$P.formFields.set($P.control, item);
|
||||
|
||||
// 업무구분에 따른 URL 변경
|
||||
$P.fnSetURL(item.data.TASK_SE_CD);
|
||||
}
|
||||
|
||||
// 저장 callback
|
||||
$P.control.onSave = (resp) => {
|
||||
let dialogTitle = $("#" + $P.control.prefix + "Dialog--${openerPageName}").find("h5.modal-title").html();
|
||||
let showMessage = resp.rtnMsg.replace(/[S]|[F]/g, dialogTitle);
|
||||
|
||||
// 메시지 출력
|
||||
dialog.alert({
|
||||
content: showMessage
|
||||
, init: () => { AppSupport.setDialogZindex(); }
|
||||
, onOK: () => { }
|
||||
});
|
||||
|
||||
if (resp.saved) {
|
||||
dialog.close($P.control.prefix + "Dialog--${openerPageName}");
|
||||
}
|
||||
}
|
||||
|
||||
// 저장
|
||||
$P.control.save = (info) => {
|
||||
if (!info) return;
|
||||
|
||||
let create = ($P.callPurpose == "create");
|
||||
|
||||
ajax.post({
|
||||
url: !create ? $P.control.urls.update : $P.control.urls.create
|
||||
, data: info
|
||||
, success: resp => $P.control.onSave(resp)
|
||||
});
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 사용자 함수(function)
|
||||
**************************************************************************/
|
||||
// 업무구분에 따른 URL 설정
|
||||
$P.fnSetURL = (taskSeCd) => {
|
||||
$P.control.urls.create = wctx.url("/" + taskSeCd + "${infoPrefixUrl}" + "/020/create.do"); // 등록
|
||||
$P.control.urls.update = wctx.url("/" + taskSeCd + "${infoPrefixUrl}" + "/020/update.do"); // 수정
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 버튼 clickEvent
|
||||
**************************************************************************/
|
||||
// 저장
|
||||
$P.fnSave = () => {
|
||||
// validate 확인
|
||||
if (!AppSupport.customValidate($("#frmEdit--${pageName}").find("input, select, textarea"))) return;
|
||||
|
||||
dialog.alert({
|
||||
content: "현재 " + $P.control.prefixName + " 정보를 저장하시겠습니까?"
|
||||
, init: () => { AppSupport.setDialogZindex(); }
|
||||
, onOK: () => {
|
||||
$P.control.save($P.formFields.get()); // formFields
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 초기 셋팅
|
||||
**************************************************************************/
|
||||
// 이벤트 설정
|
||||
$P.setEvent = () => {
|
||||
// form-date 항목에서 키보드로 입력시 날짜 포맷팅 적용
|
||||
$("#frmEdit--${pageName}").find(".form-date").each(function() {
|
||||
$(this).on("input", function() {
|
||||
let value = this.value.replaceAll("-","");
|
||||
|
||||
if (value.length > 7) {
|
||||
this.value = value.substring(0, 4) + "-" + value.substring(4, 6) + "-" + value.substring(6);
|
||||
} else if(value.length > 5) {
|
||||
this.value = value.substring(0, 4) + "-" + value.substring(4);
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
// 버튼 이벤트
|
||||
$("#btnSave--${pageName}").on("click", () => $P.fnSave()); // 저장
|
||||
}
|
||||
|
||||
// 초기 화면 설정
|
||||
$P.initForm = () => {
|
||||
// View로 호출
|
||||
if ($P.callPurpose == "view") {
|
||||
// input 요소들을 disabled
|
||||
$("#frmEdit--${pageName}").find("input,textarea,select").prop("disabled", true);
|
||||
// button 요소들을 disabled
|
||||
$("#btnSave--${pageName}").prop("disabled", true); // 저장 버튼
|
||||
}
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 최초 실행 함수
|
||||
**************************************************************************/
|
||||
// 1. 이벤트 설정
|
||||
$P.setEvent();
|
||||
|
||||
// 2. 초기 화면 설정
|
||||
$P.initForm();
|
||||
|
||||
// 3. Dataset 설정
|
||||
$P.control.setData([${epostGdntcInfo}]);
|
||||
});
|
||||
LoadScript("epst02020Script", wctx.url("/webjars/js/fims/epst/epst02020.js?ver=${ver}"));
|
||||
|
||||
/**************************************************************************
|
||||
* Global Variable
|
||||
**************************************************************************/
|
||||
pageObject["${pageName}"] = newDoctxFinder("${pageName}");
|
||||
|
||||
/**************************************************************************
|
||||
* script 진입
|
||||
**************************************************************************/
|
||||
$(document).ready(function() {
|
||||
// pageObject
|
||||
let $P = pageObject["${pageName}"];
|
||||
|
||||
// URL
|
||||
$P.prefixUrl = "${prefixUrl}"
|
||||
// infoDialog 호출 용도(view 조회(편집불가), create 등록, update 수정)
|
||||
$P.callPurpose = "${callPurpose}";
|
||||
// datasetControl
|
||||
$P.ctrl = newEpst02020Control("${pageName}", "[data-doctx=${pageName}]");
|
||||
|
||||
/**************************************************************************
|
||||
* 사용자 함수(function)
|
||||
**************************************************************************/
|
||||
|
||||
|
||||
/**************************************************************************
|
||||
* 버튼 clickEvent
|
||||
**************************************************************************/
|
||||
// 저장
|
||||
$P.fnSave = () => {
|
||||
// validate 확인
|
||||
if (!AppSupport.customValidate($P.$findn("frmEdit").find("input,select,textarea"))) return;
|
||||
|
||||
// formFields
|
||||
let params = new FimsFormFields($P.selectorn("frmEdit")).get();
|
||||
|
||||
dialog.alert({
|
||||
content: "현재 " + $P.ctrl.prefixName + " 정보를 저장하시겠습니까?"
|
||||
, init: () => { AppSupport.setDialogZindex(); }
|
||||
, onOK: () => { $P.ctrl.save(params); } // formFields
|
||||
});
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 초기 셋팅
|
||||
**************************************************************************/
|
||||
// 이벤트 설정
|
||||
$P.setEvent = () => {
|
||||
// 버튼 이벤트
|
||||
$P.$findn("btnSave").on("click", () => { $P.fnSave() }); // 저장
|
||||
}
|
||||
|
||||
// 초기 화면 설정
|
||||
$P.fnReset = () => {
|
||||
// View로 호출
|
||||
if ($P.callPurpose == "view") {
|
||||
// input 요소들을 disabled
|
||||
$P.$findn("frmEdit").find("input,textarea,select").prop("disabled", true);
|
||||
|
||||
// button 요소들을 disabled
|
||||
$P.$findn("btnSave").prop("disabled", true); // 저장 버튼
|
||||
}
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 최초 실행 함수
|
||||
**************************************************************************/
|
||||
// 1. 이벤트 설정
|
||||
$P.setEvent();
|
||||
|
||||
// 2. 초기 화면 설정
|
||||
$P.fnReset();
|
||||
|
||||
// 3. Dataset 설정
|
||||
$P.ctrl.setData([${info}]);
|
||||
});
|
||||
|
||||
</script>
|
||||
|
@ -0,0 +1,130 @@
|
||||
function newEpst02010Script(pageName, doctx="[data-doctx='epst02010']") {
|
||||
let ctrl = new DatasetControl({
|
||||
doctx: doctx
|
||||
, prefix: "epostGdntc"
|
||||
, prefixName: "전자우편 안내문"
|
||||
, dataGetter: obj => obj["List"]
|
||||
, keys: ["GDNTC_ID"]
|
||||
, appendData: true
|
||||
, infoSize: "md"
|
||||
, urls: {
|
||||
load: "/list.do"
|
||||
, getInfo: "/info.do"
|
||||
, remove: "/remove.do"
|
||||
}
|
||||
, formats: {
|
||||
LAST_USE_DT: datetimeFormat
|
||||
, 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: () => { ctrl.reload({all : true}); } // 자료 재조회
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 삭제 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); }
|
||||
});
|
||||
}
|
||||
|
||||
return ctrl;
|
||||
}
|
@ -0,0 +1,61 @@
|
||||
function newEpst02020Control(pageName, doctx="[data-doctx='epst02020']") {
|
||||
let ctrl = new DatasetControl({
|
||||
doctx: doctx
|
||||
, prefix: "epostGdntc"
|
||||
, prefixName: "안내문"
|
||||
, dataGetter: obj => obj["info"]
|
||||
, keys: ["GDNTC_ID"]
|
||||
, urls: {
|
||||
create: "/create.do"
|
||||
, update: "/update.do"
|
||||
}
|
||||
});
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl Events
|
||||
**************************************************************************/
|
||||
// 현재 선택 자료 변경 이벤트
|
||||
ctrl.onCurrentChange = (item) => {
|
||||
if (!item) return;
|
||||
|
||||
// 화면에 단속 Dataset 셋팅
|
||||
let formFields = new FimsFormFields(ctrl.selector("[name='frmEdit']"));
|
||||
formFields.set(ctrl, item);
|
||||
|
||||
// 업무구분에 따른 URL 변경
|
||||
ctrl.urls.create = wctx.url("/" + item.data.TASK_SE_CD + pageObject[pageName].prefixUrl + "/020/create.do"); // 등록
|
||||
ctrl.urls.update = wctx.url("/" + item.data.TASK_SE_CD + pageObject[pageName].prefixUrl + "/020/update.do"); // 수정
|
||||
};
|
||||
|
||||
// 저장 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;
|
||||
|
||||
let create = (params.gdntcId == "");
|
||||
|
||||
ajax.post({
|
||||
url: !create ? ctrl.urls.update : ctrl.urls.create
|
||||
, data: params || {}
|
||||
, success: (resp) => { ctrl.onSave(params, resp); }
|
||||
});
|
||||
}
|
||||
|
||||
return ctrl;
|
||||
}
|
Loading…
Reference in New Issue