발송반송 수정.
parent
a9bf66c975
commit
98411eaf61
@ -0,0 +1,484 @@
|
||||
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
|
||||
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
|
||||
|
||||
<!-- inner page html -->
|
||||
<div class="content-wrapper">
|
||||
<!-- Content -->
|
||||
<div class="container flex-grow-1 px-0">
|
||||
<c:set var="prefixName" scope="request">의견제출 정보</c:set>
|
||||
|
||||
<!-- Page Body -->
|
||||
<div class="card">
|
||||
<!-- 입력 영역 -->
|
||||
<form id="frmEdit--${pageName}" name="frmEdit">
|
||||
<!-- hidden -->
|
||||
<input type="hidden" id="crdnId--${pageName}" name="crdnId" data-map="CRDN_ID" />
|
||||
<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="opnnId--${pageName}" name="opnnId" data-map="OPNN_ID" />
|
||||
|
||||
<div class="row g-1">
|
||||
<!-- 차량번호 -->
|
||||
<div class="col-md-4">
|
||||
<label for="vhrno--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">차량번호</label>
|
||||
<input type="text" class="form-control w-35" id="vhrno--${pageName}" name="vhrno" data-map="VHRNO" readonly />
|
||||
</div>
|
||||
<!-- 단속일시 -->
|
||||
<div class="col-md-4">
|
||||
<label for="crdnYmd--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">단속일시</label>
|
||||
<input type="text" class="form-control w-30" id="crdnYmd--${pageName}" name="crdnYmd" data-map="CRDN_YMD" readonly />
|
||||
</div>
|
||||
<!-- 납부자 명 -->
|
||||
<div class="col-md-4">
|
||||
<label for="rtpyrNm--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">납부자</label>
|
||||
<input type="text" class="form-control w-55" id="rtpyrNm--${pageName}" name="rtpyrNm" data-map="RTPYR_NM" readonly />
|
||||
</div>
|
||||
<!-- 접수 번호 -->
|
||||
<div class="col-md-4">
|
||||
<label for="rcptNo--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">접수 번호</label>
|
||||
<input type="text" class="form-control w-35" id="rcptNo--${pageName}" name="rcptNo" data-map="RCPT_NO" />
|
||||
</div>
|
||||
<!-- 접수 일자 -->
|
||||
<div class="col-md-4">
|
||||
<label for="rcptYmd--${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" id="rcptYmd--${pageName}" name="rcptYmd" data-map="RCPT_YMD"
|
||||
data-fmt-type="day" title="날짜 선택" maxlength="10" required />
|
||||
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
|
||||
</div>
|
||||
<!-- 접수 구분 -->
|
||||
<div class="col-md-4">
|
||||
<label for="rcptSeCd--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end required">접수 구분</label>
|
||||
<select class="form-select" id="rcptSeCd--${pageName}" name="rcptSeCd" data-map="RCPT_SE_CD" required>
|
||||
<option value="">선택하세요</option>
|
||||
<c:forEach items="${FIM029List}" var="item">
|
||||
<option value="${item.code}">${item.value}</option>
|
||||
</c:forEach>
|
||||
</select>
|
||||
</div>
|
||||
<!-- 진술자 이름 -->
|
||||
<div class="col-md-4">
|
||||
<label for="sttrNm--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end required">성명</label>
|
||||
<input type="text" class="form-control w-40" id="sttrNm--${pageName}" name="sttrNm" data-map="STTR_NM" required />
|
||||
<button type="button" class="btn btn-sm btn-outline-dark" id="btnPayer--${pageName}" title="납부자 정보 적용" onclick="fnPayer${pageName}();">
|
||||
납부자
|
||||
</button>
|
||||
</div>
|
||||
<!-- 진술자 생년월일 -->
|
||||
<div class="col-md-4">
|
||||
<label for="sttrBrdt--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">생년월일</label>
|
||||
<input type="text" class="form-control w-25" id="sttrBrdt--${pageName}" name="sttrBrdt" data-map="STTR_BRDT" placeholder="YY-MM-DD" />
|
||||
</div>
|
||||
<!-- 소유주 관계 구분 코드 -->
|
||||
<div class="col-md-4">
|
||||
<label for="ownrRelCd--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">소유주 관계 구분</label>
|
||||
<select class="form-select" id="ownrRelCd--${pageName}" name="ownrRelCd" data-map="OWNR_REL_CD">
|
||||
<option value="">선택하세요</option>
|
||||
<c:forEach items="${FIM032List}" var="item">
|
||||
<option value="${item.code}">${item.value}</option>
|
||||
</c:forEach>
|
||||
</select>
|
||||
</div>
|
||||
<!-- 진술자 주소 --><!-- 진술자 우편번호 -->
|
||||
<div class="col-md-12">
|
||||
<label for="sttrAddr--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">주소</label>
|
||||
<input type="text" class="form-control w-75" id="sttrAddr--${pageName}" name="sttrAddr" data-map="STTR_ADDR" />
|
||||
<input type="text" class="form-control w-px-75" id="sttrZip--${pageName}" name="sttrZip" data-map="STTR_ZIP" />
|
||||
<button type="button" class="btn btn-sm btn-outline-dark" id="btnZip--${pageName}" title="우편번호 검색" onclick="fnZip${pageName}();">
|
||||
검색
|
||||
</button>
|
||||
</div>
|
||||
<!-- 진술자 상세주소 -->
|
||||
<div class="col-md-12">
|
||||
<label for="sttrDaddr--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">상세 주소</label>
|
||||
<input type="text" class="form-control w-87" id="sttrDaddr--${pageName}" name="sttrDaddr" data-map="STTR_DADDR" />
|
||||
</div>
|
||||
<!-- 진술자 연락처 -->
|
||||
<div class="col-md-4">
|
||||
<label for="sttrCttpc--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">연락처</label>
|
||||
<input type="text" class="form-control w-35" id="sttrCttpc--${pageName}" name="sttrCttpc" data-map="STTR_CTTPC" />
|
||||
</div>
|
||||
<!-- 진술자 이메일 -->
|
||||
<div class="col-md-8">
|
||||
<label for="sttrEml--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">이메일</label>
|
||||
<input type="text" class="form-control w-35" id="sttrEml--${pageName}" name="sttrEml" data-map="STTR_EML" />
|
||||
</div>
|
||||
<!-- 의견 제출 내용 -->
|
||||
<div class="col-md-12">
|
||||
<label for="opnnSbmsnCn--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">의견제출 내용</label>
|
||||
<textarea type="text" class="form-control w-87" id="opnnSbmsnCn--${pageName}" name="opnnSbmsnCn" data-map="OPNN_SBMSN_CN" rows="5" data-maxlengthb="4000"></textarea>
|
||||
</div>
|
||||
<!-- 의견 제출 구분 코드 -->
|
||||
<div class="col-md-4">
|
||||
<label for="opnnSbmsnSeCd--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end required">의견제출 구분</label>
|
||||
<select class="form-select" id="opnnSbmsnSeCd--${pageName}" name="opnnSbmsnSeCd" data-map="OPNN_SBMSN_SE_CD" required>
|
||||
<option value="">선택하세요</option>
|
||||
<c:forEach items="${FIM033List}" var="item">
|
||||
<option value="${item.code}">${item.value}</option>
|
||||
</c:forEach>
|
||||
</select>
|
||||
</div>
|
||||
<!-- 의견 제출 요지 -->
|
||||
<div class="col-md-8">
|
||||
<label for="opnnSbmsnGist--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">의견제출 요지</label>
|
||||
<input type="text" class="form-control w-80" id="opnnSbmsnGist--${pageName}" name="opnnSbmsnGist" data-map="OPNN_SBMSN_GIST" data-maxlengthb="300" />
|
||||
</div>
|
||||
<!-- 담당자 검토 의견 -->
|
||||
<div class="col-md-12">
|
||||
<label for="picRvwOpnn--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end">검토 의견</label>
|
||||
<textarea class="form-control w-87" id="picRvwOpnn--${pageName}" name="picRvwOpnn" data-map="PIC_RVW_OPNN" rows="3" data-maxlengthb="1000">
|
||||
</textarea>
|
||||
</div>
|
||||
</div>
|
||||
</form>
|
||||
<!-- /입력 영역 -->
|
||||
|
||||
<!-- 첨부 파일 -->
|
||||
<div class="card">
|
||||
<form id="frmFile--${pageName}" method="post" enctype="multipart/form-data" >
|
||||
<input type="file" id="uploadFiles--${pageName}" name="uploadFiles" multiple="multiple" onchange="fnAddFiles(this);" hidden />
|
||||
</form>
|
||||
<div class="row g-1">
|
||||
<div class="col-md-12">
|
||||
<button type="button" class="btn btn-blue" id="btnAddFile--${pageName}" title="첨부파일 추가">파일 추가</button>
|
||||
</div>
|
||||
</div>
|
||||
<!-- 첨부 파일 테이블 -->
|
||||
<div class="table-responsive">
|
||||
<table class="table table-bordered table-hover table-striped" id="fileList--${pageName}">
|
||||
<thead>
|
||||
<th class="text-center" style="width: 24px">NO.</th>
|
||||
<th class="text-center" style="width: 200px">파일 번호</th>
|
||||
<th class="text-center">파일 이름</th>
|
||||
<th class="text-center" style="width: 200px">파일 크기</th>
|
||||
<th class="text-center" style="width: 120px">다운로드</th>
|
||||
<th class="text-center" style="width: 120px">삭제</th>
|
||||
</thead>
|
||||
<tbody></tbody>
|
||||
</table>
|
||||
</div> <!-- 첨부 파일 테이블 <div class="table-responsive"> -->
|
||||
</div> <!-- 첨부 파일 <div class="card"> -->
|
||||
</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-80" id="btnSave--${pageName}" title="저장" onclick="fnSave${pageName}()">저장</button>
|
||||
</span>
|
||||
</span>
|
||||
</div>
|
||||
<!-- / 업무 버튼 표시 -->
|
||||
|
||||
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
|
||||
</div> <!-- / inner page html <div class="content-wrapper"> -->
|
||||
|
||||
<script>
|
||||
/**************************************************************************
|
||||
* Global Variable
|
||||
**************************************************************************/
|
||||
// URL
|
||||
var ${pageName}PrefixUrl = "/excl/excl02";
|
||||
// 호출 용도
|
||||
var ${pageName}CallPurpose = "${callPurpose}";
|
||||
// FormFields
|
||||
var ${pageName}Fields = new FormFields("#frmEdit--${pageName}");
|
||||
// 파일 리스트
|
||||
var $fileListArr = new Array();
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl
|
||||
**************************************************************************/
|
||||
var ${pageName}Control = new DatasetControl({
|
||||
prefix : "opnn"
|
||||
, prefixName : "의견제출"
|
||||
, keymapper : info => info ? info.OPNN_ID : ""
|
||||
, dataGetter : obj => obj.opnnSbmsnInfo
|
||||
, formats : {
|
||||
CRDN_YMD : dateFormat
|
||||
, RCPT_YMD : dateFormat
|
||||
}
|
||||
});
|
||||
|
||||
${pageName}Control.onCurrentChange = item => {
|
||||
// Dataset 셋팅
|
||||
${pageName}Fields.set(item);
|
||||
|
||||
// 업무구분에 따른 url 변경
|
||||
${pageName}Control.urls.create = wctx.url(item.data.TASK_SE_CD + ${pageName}PrefixUrl + "/020/create.do");
|
||||
${pageName}Control.urls.update = wctx.url(item.data.TASK_SE_CD + ${pageName}PrefixUrl + "/020/update.do");
|
||||
|
||||
if (${pageName}CallPurpose == "create") {
|
||||
$("#rcptNo--${pageName}").prop("readonly", true);
|
||||
|
||||
setForm${pageName}(); // 화면 초기화
|
||||
} else {
|
||||
fnSearchFileList${pageName}(item.data.OPNN_ID); // 첨부파일 조회
|
||||
}
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl 이벤트
|
||||
**************************************************************************/
|
||||
// 저장 callback
|
||||
${pageName}Control.onSave = (resp) => {
|
||||
let dialogTitle = $("#" + ${pageName}Control.prefix + "Dialog").find("h5.modal-title").html();
|
||||
let showMessage = resp.retMessage.replace(/[S]|[F]/g, dialogTitle);
|
||||
|
||||
dialog.alert(showMessage);
|
||||
|
||||
if (resp.saved) {
|
||||
// 폼을 리셋해서 uploadFiles에 출력된 선택 파일을 초기화시킨다.
|
||||
document.getElementById("frmFile--${pageName}").reset();
|
||||
|
||||
dialog.close(${pageName}Control.prefix + "Dialog");
|
||||
}
|
||||
}
|
||||
|
||||
// 저장
|
||||
${pageName}Control.save = (info) => {
|
||||
if (!info) return;
|
||||
|
||||
let formData = new FormData();
|
||||
let create = isEmpty(info.opnnId);
|
||||
|
||||
// 첨부파일 배열에 있는 내용을 등록
|
||||
for (let iLoop = 0; iLoop < $fileListArr.length; iLoop++) {
|
||||
formData.append("uploadFiles" , $fileListArr[iLoop]);
|
||||
}
|
||||
|
||||
for (let key in info) {
|
||||
let value = info[key];
|
||||
|
||||
formData.append(key, value);
|
||||
}
|
||||
|
||||
ajax.post({
|
||||
url : !create ? ${pageName}Control.urls.update : ${pageName}Control.urls.create
|
||||
, data : formData
|
||||
, contentType : false
|
||||
, processData : false
|
||||
, success : resp => ${pageName}Control.onSave(resp)
|
||||
});
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 초기 셋팅
|
||||
**************************************************************************/
|
||||
// 이벤트 설정
|
||||
setEvent${pageName} = () => {
|
||||
// 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);
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
$("#btnAddFile--${pageName}").on('click', () => { $("#uploadFiles--${pageName}").trigger("click"); });
|
||||
}
|
||||
|
||||
// 화면 초기값 셋팅
|
||||
setForm${pageName} = () => {
|
||||
// 달력 초기화
|
||||
initDatepicker("frmEdit--${pageName}");
|
||||
$("#rcptYmd--${pageName}").datepicker("setDate", new Date());
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 버튼 clickEvent
|
||||
**************************************************************************/
|
||||
// 납부자 정보를 진술자 정보로 입력한다.
|
||||
fnPayer${pageName} = () => {
|
||||
// 수정이라면 동작하지 않게 한다.
|
||||
if (${pageName}Control.getValue("OPNN_ID") != "") {
|
||||
return;
|
||||
}
|
||||
|
||||
$("select[name='ownrRelCd'] option:contains('본인')").attr("selected", "selected");
|
||||
$("#sttrNm--${pageName}").val(${pageName}Control.getValue("RTPYR_NM"));
|
||||
$("#sttrBrdt--${pageName}").val(${pageName}Control.getValue("RTPYR_BRDT"));
|
||||
$("#sttrAddr--${pageName}").val(${pageName}Control.getValue("ADDR"));
|
||||
$("#sttrZip--${pageName}").val(${pageName}Control.getValue("ZIP"));
|
||||
$("#sttrDaddr--${pageName}").val(${pageName}Control.getValue("DTL_ADDR"));
|
||||
|
||||
if (${pageName}Control.getValue("RTPYR_MBL_TELNO") != "")
|
||||
$("#sttrCttpc--${pageName}").val(${pageName}Control.getValue("RTPYR_MBL_TELNO"));
|
||||
else
|
||||
$("#sttrCttpc--${pageName}").val(${pageName}Control.getValue("RTPYR_TELNO"));
|
||||
|
||||
$("#sttrEml--${pageName}").val(${pageName}Control.getValue("RTPYR_EML"));
|
||||
}
|
||||
|
||||
// 우편번호 검색
|
||||
fnZip${pageName} = () => {
|
||||
let callbackFuncName = "fnZipReturn${pageName}";
|
||||
|
||||
let popupWidth = 900;
|
||||
let popupHeight = 700;
|
||||
|
||||
let popupX = (window.screen.width / 2) - (popupWidth / 2);
|
||||
let popupY= (window.screen.height / 2) - (popupHeight / 2);
|
||||
|
||||
window.open(
|
||||
wctx.url("/resources/html/searchAddr.html"+"?callbackFuncName="+callbackFuncName)
|
||||
,"searchAddr"
|
||||
,'status=no, height=' + popupHeight + ', width=' + popupWidth + ', left='+ popupX + ', top='+ popupY
|
||||
);
|
||||
}
|
||||
|
||||
// 우편번호 검색 결과
|
||||
fnZipReturn${pageName} = (obj) => {
|
||||
$("#sttrAddr--${pageName}").val(obj.ADDR); // 주소
|
||||
$("#sttrZip--${pageName}").val(obj.ZIP); // 우편번호
|
||||
$("#sttrDaddr--${pageName}").val(obj.DTL_ADDR); // 상세 주소
|
||||
}
|
||||
|
||||
// 저장
|
||||
fnSave${pageName} = () => {
|
||||
// validate 확인
|
||||
if (!customValidate($("#frmEdit--${pageName}").find("input, select, textarea"))) return;
|
||||
|
||||
dialog.alert({
|
||||
content : "현재 " + ${pageName}Control.prefixName + " 정보를 저장하시겠습니까?"
|
||||
, onOK : () => {
|
||||
${pageName}Control.save(${pageName}Fields.get());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 첨부파일 조회
|
||||
fnSearchFileList${pageName} = (opnnId) => {
|
||||
// 의견제출 등록일 경우에는 첨부파일을 조회하지 안는다..
|
||||
if (opnnId == null || opnnId == "") {
|
||||
return;
|
||||
}
|
||||
|
||||
// 첨부파일 리스트
|
||||
ajax.get({
|
||||
url : "file/list.do"
|
||||
, data : {
|
||||
infoType : "110"
|
||||
, infoKeys : opnnId
|
||||
, fetchSize : 0
|
||||
}
|
||||
, success : resp => {
|
||||
let fileNo = 0;
|
||||
let fileList = resp.fileList;
|
||||
|
||||
fileList.forEach(function (item, index, array) {
|
||||
fileNo = index + 1;
|
||||
|
||||
let innerHtml = "";
|
||||
|
||||
innerHtml += "<tr>";
|
||||
innerHtml += "<td class='text-center'>" + fileNo + "</td>";
|
||||
innerHtml += "<td class='text-center'>" + item.FILE_ID + "</td>";
|
||||
innerHtml += "<td class='text-center'>" + item.FILE_NM + "</td>";
|
||||
innerHtml += "<td class='text-center'>" + item.FILE_SIZE + " byte</td>";
|
||||
innerHtml += "<td class='text-center'>" + "<button type='button' class='btn' onclick='fnFileDownload${pageName}(" + item.FILE_ID + ");'><i class='bx bx-download me-1'></i></button>" + "</td>";
|
||||
innerHtml += "<td class='text-center'>" + "<button type='button' class='btn' onclick='fnFileRemove${pageName}(this);'><i class='bx bx-trash me-1'></i></button>" + "</td>";
|
||||
innerHtml += "</tr>";
|
||||
|
||||
$("#fileList--${pageName} > tbody:last").append(innerHtml);
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 첨부파일 등록
|
||||
fnAddFiles = (obj) => {
|
||||
let fileNo = $("#fileList--${pageName} > tbody tr").length; // table의 tr 개수
|
||||
|
||||
let maxFileCnt = 3; // 첨부파일 최대 개수
|
||||
let attFileCnt = obj.files.length; // 선택한 파일 개수 + 기존 파일 개수
|
||||
let fileArr = new Array(); // 파일 배열
|
||||
|
||||
fileArr = $fileListArr;
|
||||
|
||||
// 등록할 파일 개수 확인
|
||||
if (attFileCnt + fileNo > maxFileCnt) {
|
||||
dialog.alert({
|
||||
content : "첨부파일은 최대 " + maxFileCnt + "개 까지 첨부 가능합니다."
|
||||
});
|
||||
|
||||
return;
|
||||
}
|
||||
|
||||
// 첨부파일을 table에 추가.
|
||||
for (let iLoop = 0; iLoop < attFileCnt; iLoop++) {
|
||||
let selectedFile = obj.files[iLoop];
|
||||
let innerHtml = "";
|
||||
|
||||
fileNo += 1;
|
||||
|
||||
innerHtml += "<tr>";
|
||||
innerHtml += "<td class='text-center'>" + fileNo + "</td>";
|
||||
innerHtml += "<td class='text-center'>" + "</td>";
|
||||
innerHtml += "<td class='text-center'>" + selectedFile.name + "</td>";
|
||||
innerHtml += "<td class='text-center'>" + selectedFile.size + " byte</td>";
|
||||
innerHtml += "<td class='text-center'>" + "</td>";
|
||||
innerHtml += "<td class='text-center'>" + "<button type='button' class='btn' onclick='fnFileRemove${pageName}(this);'><i class='bx bx-trash me-1'></i></button>" + "</td>";
|
||||
innerHtml += "</tr>";
|
||||
|
||||
$("#fileList--${pageName} > tbody:last").append(innerHtml);
|
||||
|
||||
fileArr.push(obj.files[iLoop]);
|
||||
}
|
||||
}
|
||||
|
||||
// 파일 삭제
|
||||
fnFileRemove${pageName} = (obj) => {
|
||||
let tr = $(obj).parent().parent(); // 클릭한 버튼이 속한 tr 요소
|
||||
let td = tr.children();
|
||||
|
||||
let fileNo = td.eq(0).text(); // 삭제할 파일 번호
|
||||
let fileId = td.eq(1).text();
|
||||
|
||||
if (fileId != null && fileId != "") {
|
||||
ajax.post({
|
||||
url : "file/remove.do"
|
||||
, data : { fileIDs : fileId }
|
||||
, success : resp => {
|
||||
// 성공
|
||||
}
|
||||
});
|
||||
} else {
|
||||
// 배열에서 삭제한다. 배열은 0부터 시작하기 때문에 -1 해준다.
|
||||
$fileListArr.splice(fileNo - 1);
|
||||
}
|
||||
|
||||
$(obj).closest("tr").remove(); // table 에서 제거
|
||||
}
|
||||
|
||||
// 첨부파일 삭제 버튼 클릭
|
||||
fnFileRemove${pageName} = (obj) => {
|
||||
dialog.alert({
|
||||
content : "선택한 파일을 삭제하시겠습니까?"
|
||||
, onOK : () => {
|
||||
fnFileRemove${pageName}(obj);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 첨부파일 다운로드
|
||||
fnFileDownload${pageName} = (fileID) => {
|
||||
top.location.href = "/file/download.do?fileID=" + fileID;
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* script 진입
|
||||
**************************************************************************/
|
||||
$(document).ready(function() {
|
||||
// 이벤트 설정
|
||||
setEvent${pageName}();
|
||||
|
||||
${pageName}Control.setData([${opnnSbmsnInfo}]); // Dataset 셋팅 - 단건일 경우 setData
|
||||
});
|
||||
|
||||
</script>
|
@ -1,210 +0,0 @@
|
||||
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
|
||||
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
|
||||
|
||||
<!-- inner page html -->
|
||||
<div class="content-wrapper">
|
||||
<!-- Content -->
|
||||
<div class="container flex-grow-1 px-0">
|
||||
<c:set var="prefixName" scope="request">부과제외 정보</c:set>
|
||||
|
||||
<!-- Page Body -->
|
||||
<div class="card">
|
||||
<!-- 입력 영역 -->
|
||||
<form id="frmEdit--${pageName}" name="frmEdit">
|
||||
<!-- hidden -->
|
||||
<input type="hidden" id="crdnId--${pageName}" name="crdnId" data-map="CRDN_ID" />
|
||||
<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="sndngDtlId--${pageName}" name="sndngDtlId" data-map="SNDNG_DTL_ID" />
|
||||
|
||||
<div class="row g-1">
|
||||
<!-- 배달 일자 -->
|
||||
<div class="col-md-12">
|
||||
<label for="dlvrYmd--${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" id="dlvrYmd--${pageName}" name="dlvrYmd" data-map="DLVR_YMD"
|
||||
data-fmt-type="day" title="날짜 선택" maxlength="10" required />
|
||||
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
|
||||
</div>
|
||||
<!-- 미배달 사유 -->
|
||||
<div class="col-md-12">
|
||||
<label for="undlvrRsnCd--${pageName}" class="w-px-120 bg-lighter pe-2 col-form-label text-sm-end required">미배달 사유</label>
|
||||
<select class="form-select" id="undlvrRsnCd--${pageName}" name="undlvrRsnCd" data-map="UNDLVR_RSN_CD" onchange="changeUndlvrRsnCd(this.value);" required>
|
||||
<option value="">선택하세요</option>
|
||||
<c:forEach items="${EGP010List}" var="item">
|
||||
<option value="${item.code}">${item.value}</option>
|
||||
</c:forEach>
|
||||
</select>
|
||||
<input type="text" class="form-control w-px-150" id="undlvrRsnNm--${pageName}" name="undlvrRsnNm" data-map="UNDLVR_RSN_NM" autocomplete="off" />
|
||||
</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-80" id="btnSave--${pageName}" title="저장" onclick="fnSave${pageName}()">저장</button>
|
||||
</span>
|
||||
</span>
|
||||
</div>
|
||||
<!-- / 업무 버튼 표시 -->
|
||||
|
||||
</div> <!-- / Content <div class="container flex-grow-1 px-0"> -->
|
||||
</div> <!-- / inner page html <div class="content-wrapper"> -->
|
||||
|
||||
<script>
|
||||
/**************************************************************************
|
||||
* Global Variable
|
||||
**************************************************************************/
|
||||
// URL
|
||||
var ${pageName}PrefixUrl = "/sndb/sndb01";
|
||||
// FormFields
|
||||
var ${pageName}Fields = new FormFields("#frmEdit--${pageName}");
|
||||
// 호출용도
|
||||
var ${pageName}CallPurpose = "${callPurpose}"
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl
|
||||
**************************************************************************/
|
||||
var ${pageName}Control = new DatasetControl({
|
||||
prefix : "sndbkInfo"
|
||||
, prefixName : "발송상세"
|
||||
, keymapper : info => info ? info.SNDNG_DTL_ID : ""
|
||||
, dataGetter : obj => obj.sndngDtlId
|
||||
, formats : {
|
||||
DLVR_YMD : dateFormat
|
||||
}
|
||||
});
|
||||
|
||||
${pageName}Control.onCurrentChange = item => {
|
||||
// Dataset 셋팅
|
||||
${pageName}Fields.set(item);
|
||||
|
||||
// 업무구분에 따른 url 변경
|
||||
${pageName}Control.urls.create = wctx.url(item.data.TASK_SE_CD + ${pageName}PrefixUrl + "/220/create.do");
|
||||
${pageName}Control.urls.update = wctx.url(item.data.TASK_SE_CD + ${pageName}PrefixUrl + "/220/update.do");
|
||||
|
||||
// 배달일자
|
||||
if (item.data.DLVR_YMD == "") {
|
||||
$("#dlvrYmd--${pageName}").datepicker("setDate", new Date());
|
||||
}
|
||||
|
||||
// 미배달 사유
|
||||
if (item.data.UNDLVR_RSN_CD != null && item.data.UNDLVR_RSN_CD != "") {
|
||||
$("#undlvrRsnCd--${pageName}").val(item.data.UNDLVR_RSN_CD).prop("selected", true);
|
||||
} else {
|
||||
$("#undlvrRsnCd--${pageName}").val("7").prop("selected", true);
|
||||
}
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl 이벤트
|
||||
**************************************************************************/
|
||||
// 저장 callback
|
||||
${pageName}Control.onSave = (resp) => {
|
||||
let dialogTitle = $("#" + ${pageName}Control.prefix + "Dialog").find("h5.modal-title").html();
|
||||
let showMessage = resp.retMessage.replace(/[S]|[F]/g, dialogTitle);
|
||||
|
||||
dialog.alert(showMessage);
|
||||
|
||||
if (resp.saved) {
|
||||
dialog.close(${pageName}Control.prefix + "Dialog");
|
||||
}
|
||||
}
|
||||
|
||||
// 저장
|
||||
${pageName}Control.save = (info) => {
|
||||
if (!info) return;
|
||||
|
||||
info.sndngDtlSttsCd = "10"; // 발송 상세 상태 코드(SNDNG_DTL_STTS_CD) FIM050 - 10 반송(개별등록)
|
||||
|
||||
ajax.post({
|
||||
url : ${pageName}CallPurpose == "create" ? ${pageName}Control.urls.create : ${pageName}Control.urls.update
|
||||
, data : info
|
||||
, success : resp => ${pageName}Control.onSave(resp)
|
||||
});
|
||||
}
|
||||
|
||||
// 미배달사유 변경 이벤트
|
||||
changeUndlvrRsnCd = (obj) => {
|
||||
if (obj == "7") {
|
||||
$("#undlvrRsnNm--${pageName}").prop("readonly", false);
|
||||
$("#undlvrRsnNm--${pageName}").val(${pageName}Control.dataset.getValue("UNDLVR_RSN_NM"));
|
||||
} else {
|
||||
$("#undlvrRsnNm--${pageName}").prop("readonly", true);
|
||||
$("#undlvrRsnNm--${pageName}").val($("#undlvrRsnCd--${pageName} option:selected").text());
|
||||
}
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
*
|
||||
**************************************************************************/
|
||||
|
||||
|
||||
/**************************************************************************
|
||||
* 초기 셋팅
|
||||
**************************************************************************/
|
||||
// 화면 초기화
|
||||
initForm${pageName} = () => {
|
||||
|
||||
}
|
||||
|
||||
// 이벤트 설정
|
||||
setEvent${pageName} = () => {
|
||||
// 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);
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
|
||||
// 화면 초기값 셋팅
|
||||
setForm${pageName} = () => {
|
||||
// 달력 초기화
|
||||
initDatepicker("frmEdit--${pageName}");
|
||||
$("#dlvrYmd--${pageName}").datepicker("setDate", new Date());
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* function
|
||||
**************************************************************************/
|
||||
// 저장
|
||||
fnSave${pageName} = () => {
|
||||
// validate 확인
|
||||
if (!customValidate($("#frmEdit--${pageName}").find("input, select, textarea"))) return;
|
||||
|
||||
dialog.alert({
|
||||
content : "현재 " + ${pageName}Control.prefixName + " 정보를 저장하시겠습니까?"
|
||||
, onOK : () => {
|
||||
${pageName}Control.save(${pageName}Fields.get());
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* script 진입
|
||||
**************************************************************************/
|
||||
$(document).ready(function() {
|
||||
// 화면 초기화
|
||||
initForm${pageName}();
|
||||
|
||||
// 이벤트 설정
|
||||
setEvent${pageName}();
|
||||
|
||||
// 화면 초기값 설정
|
||||
setForm${pageName}();
|
||||
|
||||
// Dataset 셋팅 - 단건일 경우 setData
|
||||
${pageName}Control.setData([${sndbkInfo}]);
|
||||
});
|
||||
|
||||
</script>
|
@ -0,0 +1,687 @@
|
||||
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
|
||||
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
|
||||
|
||||
<!-- inner page html -->
|
||||
<div class="content-wrapper">
|
||||
<!-- Content -->
|
||||
<div class="container-xxl flex-grow-1 px-0">
|
||||
<c:set var="prefixName" scope="request">반송 현황</c:set>
|
||||
|
||||
<!-- Page Body -->
|
||||
<div class="card">
|
||||
<div class="wrapper-list">
|
||||
<div>
|
||||
<!-- 상단 버튼 -->
|
||||
<div class="container-page-btn">
|
||||
<button type="button" class="btn btn-outline-dark" id="btnReset--${pageName}" title="초기화" onclick="fnReset${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 type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀" onclick="fnExcel${pageName}();">
|
||||
엑셀
|
||||
</button>
|
||||
</span>
|
||||
</div>
|
||||
<!-- / 상단 버튼 -->
|
||||
|
||||
<!-- 검색 조건 영역 -->
|
||||
<form id="frmSearch--${pageName}" name="frmSearch">
|
||||
<!-- hidden -->
|
||||
<input type="hidden" id="sggCd--${pageName}" name="sggCd" data-map="SGG_CD" />
|
||||
|
||||
<!-- 메인 조건 -->
|
||||
<div class="container-search">
|
||||
<div class="row g-1">
|
||||
<!-- 업무구분 -->
|
||||
<div class="col-12">
|
||||
<label class="form-label fw-bold form-search-title text-end">업무구분</label>
|
||||
<span class="form-search-linebox">
|
||||
<c:forEach items="${FIM054List}" var="item">
|
||||
<label>
|
||||
<input type="radio" class="form-check-input" name="taskSeCd" alt="업무구분"
|
||||
value="${item.code}" onchange="fnResetAndChangeBiz${pageName}(this.value);">
|
||||
${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="schRcptYmdFrom--${pageName}" name="schRcptYmdFrom"
|
||||
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="schRcptYmdTo--${pageName}" name="schRcptYmdTo"
|
||||
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" id="schVltnCd--${pageName}" name="schVltnCd">
|
||||
<option value="">전체</option>
|
||||
<c:forEach items="${FIM004List}" 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>
|
||||
<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="schVhrno--${pageName}" name="schVhrno" />
|
||||
</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="schCrdnYmdFrom--${pageName}" name="schCrdnYmdFrom"
|
||||
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="schCrdnYmdTo--${pageName}" name="schCrdnYmdTo"
|
||||
data-fmt-type="day" title="종료 날짜 선택" />
|
||||
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
|
||||
</span>
|
||||
</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 id="searchDetail--${pageName}" class="container-search container-search-detail collapse">
|
||||
<div class="row g-1">
|
||||
<!-- 진술자명 -->
|
||||
<div class="col-6">
|
||||
<label class="form-label fw-bold form-search-title text-end">진술자명</label>
|
||||
<input type="text" class="form-control w-px-150" id="schSttrNm--${pageName}" name="schSttrNm" />
|
||||
</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-150" id="schRtpyrNm--${pageName}" name="schRtpyrNm" />
|
||||
</div>
|
||||
<!-- 등록일자, 수정일자 -->
|
||||
<div class="col-6">
|
||||
<select class="form-select text-center" id="schDetailRegDtOpt--${pageName}" name="schDetailRegDtOpt">
|
||||
<option value="regDt">등록일자</option>
|
||||
<option value="mdfcnDt">수정일자</option>
|
||||
</select>
|
||||
<span class="form-search-linebox">
|
||||
<input type="text" class="form-control form-date" id="schDetailRegDtFrom--${pageName}" name="schDetailRegDtFrom"
|
||||
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="schDetailRegDtTo--${pageName}" name="schDetailRegDtTo"
|
||||
data-fmt-type="day" title="종료 날짜 선택">
|
||||
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
|
||||
</span>
|
||||
</div>
|
||||
<!-- 등록자명, 수정자명 -->
|
||||
<div class="col-6">
|
||||
<select class="form-select text-center" id="schDetailRgtrOpt--${pageName}" name="schDetailRgtrOpt">
|
||||
<option value="rgtr">등록자</option>
|
||||
<option value="mdfr">수정자</option>
|
||||
</select>
|
||||
<input type="text" class="form-control" id="schDetailRgtrNm--${pageName}" name="schDetailRgtrNm" />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- / 상세 조건 -->
|
||||
</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="btnSndngLinkCreate--${pageName}" title="우편통합 발송" onclick="createSndngLink${pageName}();">
|
||||
우편통합 발송
|
||||
</button>
|
||||
<button type="button" class="btn btn-primary w-px-120" id="btnSvbtcInfo--${pageName}" title="공시송달 등록" onclick="svbtcInfo${pageName}();">
|
||||
공시송달 등록
|
||||
</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;" onclick="searchFromGridTitle('TASK_SE_CD', this.innerText, 'codeValue', 'FIM054');">업무구분</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RCPT_YMD', this.innerText, 'ymd', '');">접수일자</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RCPT_NO', this.innerText, 'match', 'part');">접수번호</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RCPT_SE_CD', this.innerText, 'codeValue', 'FIM029');">접수구분</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('NTFCTN_SE_CD', this.innerText, 'codeValue', 'FIM030');">통보구분</th>
|
||||
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('STTR_NM', this.innerText, 'match', 'part');">진술자명</th>
|
||||
<th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('OPNN_SBMSN_STTS_CD', this.innerText, 'codeValue', 'FIM031');">의견제출상태</th>
|
||||
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('OPNN_SBMSN_SE_CD', this.innerText, 'codeValue', 'FIM033');">의견제출분류</th>
|
||||
<th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('OPNN_SBMSN_GIST', this.innerText, 'match', 'part');">의견제출요지</th>
|
||||
<th class="cmn" style="width: 180px;" onclick="searchFromGridTitle('CRDN_YMD', this.innerText, 'ymd', '');">단속일시</th>
|
||||
<th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('VHRNO', this.innerText, 'match', 'part');">차량번호</th>
|
||||
<th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('CRDN_PLC', this.innerText, 'match', 'part');">단속장소</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('FFNLG_AMT', this.innerText, 'match', 'part');">과태료금액</th>
|
||||
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('CRDN_STTS_CD', this.innerText, 'codeValue', 'FIM010');">처리상태</th>
|
||||
<th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('DOC_NO', this.innerText, 'ymd', '');">문서번호</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('ANS_YMD', this.innerText, 'ymd', '');">답변일자</th>
|
||||
<th class="cmn" style="width: 240px;" onclick="searchFromGridTitle('ANS_CN', this.innerText, 'match', 'part');">답변내용</th>
|
||||
<th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('RTPYR_NM', this.innerText, 'match', 'part');">납부자명</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RTPYR_BRDT', 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="{OPNN_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="{OPNN_ID}" onchange="${pageName}Control.select('{OPNN_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}">{RCPT_YMD}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RCPT_NO}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RCPT_SE_NM}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{NTFCTN_SE_NM}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{STTR_NM}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{OPNN_SBMSN_STTS_NM}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{OPNN_SBMSN_SE_NM}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{OPNN_SBMSN_GIST}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_YMD_TM}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{VHRNO}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_PLC}</td>
|
||||
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_AMT}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_STTS_NM}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DOC_NO}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ANS_YMD}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ANS_CN}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NM}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_BRDT}</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="26" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
|
||||
</tr>
|
||||
</template>
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- / DataTables(그리드) -->
|
||||
</div>
|
||||
</div> <!-- / Wrapper-list -->
|
||||
</div> <!-- / Card -->
|
||||
</div>
|
||||
<!-- / Content -->
|
||||
|
||||
<jsp:include page="/WEB-INF/jsp/include/bottom.jsp" />
|
||||
|
||||
<div class="content-backdrop fade"></div>
|
||||
</div>
|
||||
<!-- / inner page html <div class="content-wrapper"> -->
|
||||
|
||||
<script>
|
||||
/**************************************************************************
|
||||
* Global Variable
|
||||
**************************************************************************/
|
||||
// URL
|
||||
var ${pageName}PrefixUrl = "/excl/excl02";
|
||||
// FormFields
|
||||
var ${pageName}Fields = new FormFields("#frmSearch--${pageName}");
|
||||
// 공통 코드
|
||||
var FIM004 = new CommonCodes(${FIM004}, true);
|
||||
var FIM005 = new CommonCodes(${FIM005}, true);
|
||||
var FIM006 = new CommonCodes(${FIM006}, true);
|
||||
var FIM061 = new CommonCodes(${FIM061}, true);
|
||||
var FIM064 = new CommonCodes(${FIM064}, true);
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl
|
||||
**************************************************************************/
|
||||
var ${pageName}Control = new DatasetControl({
|
||||
prefix : "opnn"
|
||||
, prefixName : "의견제출"
|
||||
, infoSize : "xl"
|
||||
, keymapper : info => info ? info.OPNN_ID : ""
|
||||
, dataGetter : obj => obj.opnnSbmsnList
|
||||
, appendData : true
|
||||
, tableRenderComplete : false // dataTables 에 자료 추가 완료 여부
|
||||
, formats : {
|
||||
RCPT_YMD : dateFormat
|
||||
, ANS_YMD : dateFormat
|
||||
, ANS_YMD_TM : datetimeFormat
|
||||
, CRDN_YMD_TM : datetimeFormat
|
||||
, FFNLG_CRDN_AMT : numberFormat
|
||||
, FFNLG_AMT : numberFormat
|
||||
, REG_DT : datetimeFormat
|
||||
, MDFCN_DT : datetimeFormat
|
||||
}
|
||||
});
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl 이벤트
|
||||
**************************************************************************/
|
||||
// Dataset 변경
|
||||
${pageName}Control.onDatasetChange = obj => {
|
||||
renderList${pageName}();
|
||||
|
||||
$("#paging--${pageName}").setPagingInfo({
|
||||
list : ${pageName}Control.dataset
|
||||
, prefix : "paging--${pageName}"
|
||||
, start : obj.${infoPrefix}Start
|
||||
, totalSize : obj.${infoPrefix}Total
|
||||
, fetchSize : obj.${infoPrefix}Fetch
|
||||
, func : "${pageName}Control.load({index})"
|
||||
});
|
||||
|
||||
${pageName}Control.tableRenderComplete = true; // dataTables 에 자료 추가 완료
|
||||
};
|
||||
|
||||
// 현재 선택 자료 변경 이벤트
|
||||
${pageName}Control.onCurrentChange = item => {
|
||||
if (!item) return;
|
||||
|
||||
let key = item.data.OPNN_ID;
|
||||
|
||||
$("#tbody--${pageName}").setCurrentRow(key);
|
||||
};
|
||||
|
||||
// 선택(체크) 변경 이벤트
|
||||
${pageName}Control.onSelectionChange = selected => {
|
||||
let ${infoPrefix}List = ${pageName}Control.dataset;
|
||||
let keys = selected.map(e => ${infoPrefix}List.getKey(e));
|
||||
|
||||
$("#tbody--${pageName} input[type='checkbox']").each(function() {
|
||||
let checkbox = $(this);
|
||||
|
||||
checkbox.prop("checked", keys.includes(checkbox.val()));
|
||||
});
|
||||
|
||||
$("#btn${infoPrefix}Remove--${pageName}").prop("disabled", keys.length < 1);
|
||||
};
|
||||
|
||||
// 개별총정보 dialog
|
||||
${pageName}Control.getInfo = (crdnId) => {
|
||||
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return;
|
||||
|
||||
let params = {
|
||||
callControlName : "${pageName}Control"
|
||||
, crdnId : crdnId
|
||||
}
|
||||
|
||||
ajax.get({
|
||||
url : ${pageName}Control.urls.getInfo
|
||||
, data : params
|
||||
, success : resp => {
|
||||
dialog.open({
|
||||
id : "totalInfoMainDialog"
|
||||
, title : "개별총정보"
|
||||
, content : resp
|
||||
, size : "xxl"
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 삭제 callback
|
||||
${pageName}Control.onRemove = (selected, resp) => {
|
||||
let btnTitle = $("#btn${infoPrefix}Remove--${pageName}").attr("title");
|
||||
let showMessage = resp.retMessage.replace(/[S]|[F]/g, btnTitle);
|
||||
|
||||
dialog.alert(showMessage);
|
||||
|
||||
if (resp.saved) {
|
||||
${pageName}Control._load();
|
||||
}
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
*
|
||||
**************************************************************************/
|
||||
// DataTables에 click, dbclick 이벤트
|
||||
renderList${pageName} = () => {
|
||||
let ${infoPrefix}List = ${pageName}Control.dataset;
|
||||
let empty = ${infoPrefix}List.empty;
|
||||
|
||||
let trs = empty ?
|
||||
[document.getElementById("${infoPrefix}NotFound--${pageName}").innerHTML] : <%-- from template#${infoPrefix}NotFound --%>
|
||||
${infoPrefix}List.inStrings(
|
||||
document.getElementById("${infoPrefix}Row--${pageName}").innerHTML, <%-- from template#${infoPrefix}Row --%>
|
||||
(str, dataItem) => str
|
||||
.replace(/{onclick}/gi, "${pageName}Control.setCurrent('" + dataItem.getValue("OPNN_ID") + "');")
|
||||
.replace(/{ondblclick}/gi, "${pageName}Control.getInfo('" + dataItem.getValue("CRDN_ID") + "');")
|
||||
);
|
||||
|
||||
$("#tbody--${pageName}").html(trs.join());
|
||||
$("th input[type='checkbox']").prop("checked", false);
|
||||
|
||||
//보안모드
|
||||
fn_securityModeToggle($("#securityMode--top").is(":checked"));
|
||||
}
|
||||
|
||||
// 수정 dialog -> callback 추가
|
||||
getInfo${pageName} = (params) => {
|
||||
if (!params) return;
|
||||
|
||||
ajax.get({
|
||||
url : wctx.url("/" + params.taskSeCd + ${pageName}PrefixUrl + "/020/info.do")
|
||||
, data : params || {}
|
||||
, success : resp => {
|
||||
dialog.open({
|
||||
id : ${pageName}Control.prefixed("Dialog")
|
||||
, title : ${pageName}Control.prefixName + " 정보"
|
||||
, content : resp
|
||||
, size : ${pageName}Control.infoSize
|
||||
, onClose : () => { ${pageName}Control.load(${pageName}Control.query.pageNum); } // callback
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 심의 dialog
|
||||
getDlbrInfo${pageName} = (params) => {
|
||||
if (!params) return;
|
||||
|
||||
ajax.get({
|
||||
url : wctx.url("/" + params.taskSeCd + ${pageName}PrefixUrl + "/030/info.do")
|
||||
, data : params || {}
|
||||
, success : resp => {
|
||||
dialog.open({
|
||||
id : ${pageName}Control.prefixed("SbmsnDialog")
|
||||
, title : ${pageName}Control.prefixName + " 심의 처리"
|
||||
, content : resp
|
||||
, size : "lg"
|
||||
, onClose : () => { ${pageName}Control.load(${pageName}Control.query.pageNum); } // callback
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 초기 셋팅
|
||||
**************************************************************************/
|
||||
// 초기화
|
||||
initForm${pageName} = () => {
|
||||
// 화면 초기화
|
||||
$("#frmSearch--${pageName}")[0].reset();
|
||||
|
||||
// dataset 초기화
|
||||
${pageName}Control.dataset.clear();
|
||||
}
|
||||
|
||||
// 이벤트
|
||||
setEvent${pageName} = () => {
|
||||
// form-date 항목에서 키보드로 입력시 날짜 포맷팅 적용
|
||||
$("#frmSearch--${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);
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
// DataTables width 변경 조정
|
||||
$("#DataTables_Table_0--${pageName}").find("th").resizable( {handles : "e"} );
|
||||
|
||||
// DataTables 스크롤 이벤트
|
||||
$("#table-responsive--${pageName}").scroll(function() {
|
||||
let el = $(this);
|
||||
|
||||
if (el.scrollTop() == 0) {
|
||||
return;
|
||||
}
|
||||
if (!${pageName}Control.tableRenderComplete) {
|
||||
return;
|
||||
}
|
||||
|
||||
let itemsCnt = ${pageName}Control.dataset._items.length;
|
||||
let totCnt = ${pageName}Control.dataset.getValue("TOT_CNT");
|
||||
|
||||
if (itemsCnt >= totCnt) {
|
||||
return;
|
||||
}
|
||||
|
||||
if ((el[0].scrollHeight - el.scrollTop() + VERTICAL_SCROLL_HEIGHT) <= el.outerHeight()) {
|
||||
${pageName}Control.tableRenderComplete = false; // dataTables 에 자료 추가 완료
|
||||
|
||||
${pageName}Control.load(${pageName}Control.query.pageNum + 1);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 화면 초기값 셋팅
|
||||
setForm${pageName} = (taskSeCd) => {
|
||||
// 업무 구분 코드
|
||||
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + taskSeCd + "']").prop("checked", true);
|
||||
|
||||
// 최고 관리자 경우 업무구분을 선택할 수 있도록 하자.
|
||||
$("#frmSearch--${pageName} input[name='taskSeCd']").each(function(i) {
|
||||
$(this).prop("disabled", "true");
|
||||
});
|
||||
|
||||
// 업무에 따른 위반 내용
|
||||
let vltnCode = [];
|
||||
if (taskSeCd == "PVS") { // 주정차 위반
|
||||
vltnCode = FIM004.list();
|
||||
} else if (taskSeCd == "BPV") { // 전용차로 위반
|
||||
vltnCode = FIM005.list();
|
||||
} else if (taskSeCd == "DPV") { // 장애인 전용
|
||||
vltnCode = FIM006.list();
|
||||
} else if (taskSeCd == "ECA") { // 전기차 주차 위반
|
||||
vltnCode = FIM061.list();
|
||||
} else if (taskSeCd == "TPV") { // 밤샘 주차 위반
|
||||
vltnCode = FIM064.list();
|
||||
} else {
|
||||
return;
|
||||
}
|
||||
|
||||
// 위반 항목
|
||||
$("#schVltnCd--${pageName}").empty();
|
||||
|
||||
$("#schVltnCd--${pageName}").append("<option value=''>" + "전체" + "</option>");
|
||||
$(vltnCode).each(function(index, item) {
|
||||
$("#schVltnCd--${pageName}").append("<option value='" + vltnCode[index].code +"'>" + vltnCode[index].value + "</option>");
|
||||
})
|
||||
|
||||
// 달력 초기화
|
||||
initDatepicker("frmSearch--${pageName}");
|
||||
|
||||
$("#schRcptYmdFrom--${pageName}").datepicker("setDate", DateUtil.getDateDay(-365).date);
|
||||
$("#schRcptYmdTo--${pageName}").datepicker("setDate", new Date());
|
||||
|
||||
// 업무별 조회조건
|
||||
let clsForTask = taskSeCd.toLowerCase();
|
||||
|
||||
renderForTask("frmSearch--${pageName}", clsForTask);
|
||||
|
||||
// 업무별 그리드 th
|
||||
$("#DataTables_Table_0--${pageName}").find("th").resizable( "destroy" );
|
||||
|
||||
let colContent = document.getElementById("${infoPrefix}Col--${pageName}").content;
|
||||
let cols = $(colContent).find("." + clsForTask + ",.cmn");
|
||||
let colsOuterHTML = "";
|
||||
|
||||
cols.each(function() {
|
||||
colsOuterHTML += this.outerHTML;
|
||||
});
|
||||
|
||||
$("#theadTr--${pageName}").html(colsOuterHTML);
|
||||
$("#DataTables_Table_0--${pageName}").find("th").resizable( {handles : "e"} );
|
||||
}
|
||||
|
||||
// URL 설정
|
||||
setURL${pageName} = (taskSeCd) => {
|
||||
${pageName}Control.urls.load = wctx.url("/" + taskSeCd + ${pageName}PrefixUrl + "/010/list.do"); // 조회
|
||||
${pageName}Control.urls.remove = wctx.url("/" + taskSeCd + ${pageName}PrefixUrl + "/010/removes.do"); // 삭제
|
||||
${pageName}Control.urls.getInfo = wctx.url("/" + taskSeCd + "/sprt/sprt02/010/main.do"); // 개별총정보
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 버튼 clickEvent
|
||||
**************************************************************************/
|
||||
// 업무 구분 변경
|
||||
fnResetAndChangeBiz${pageName} = (taskSeCd) => {
|
||||
// 초기화
|
||||
initForm${pageName}();
|
||||
|
||||
// 업무 구분 코드
|
||||
if (typeof taskSeCd == "undefined" || taskSeCd == null || taskSeCd == "") {
|
||||
taskSeCd = $("#layout-navbar input[name='taskSeCd']:checked").val();
|
||||
}
|
||||
|
||||
// 화면 초기값 설정
|
||||
setForm${pageName}(taskSeCd);
|
||||
|
||||
// URL 설정
|
||||
setURL${pageName}(taskSeCd);
|
||||
}
|
||||
|
||||
// 초기화 버튼 이벤트
|
||||
fnReset${pageName} = () => {
|
||||
fnResetAndChangeBiz${pageName}();
|
||||
}
|
||||
|
||||
// 검색 버튼 이벤트
|
||||
fnSearchList${pageName} = () => {
|
||||
// 검색조건
|
||||
${pageName}Control.query = ${pageName}Fields.get();
|
||||
|
||||
${pageName}Control.query.fetchSize = FETCH_XS; // 한번에 조회되는 자료 건수 FETCH_XS = 30
|
||||
${pageName}Control.query.delYn = "N"; // 삭제 여부
|
||||
${pageName}Control.query.crdnDelYn = "N"; // 단속 대장 삭제 여부
|
||||
|
||||
${pageName}Control.load();
|
||||
}
|
||||
|
||||
// 엑셀 버튼 이벤트
|
||||
fnExcel${pageName} = () => {
|
||||
|
||||
}
|
||||
|
||||
// 수정 버튼 이벤트
|
||||
${infoPrefix}Info${pageName} = () => {
|
||||
let = ${pageName}Control.dataset.getValue("OPNN_ID");
|
||||
|
||||
// 의견제출 ID 가 없다면.. return
|
||||
if (!opnnId) return;
|
||||
|
||||
let params = {
|
||||
callPurpose : "update"
|
||||
, sggCd : ${pageName}Control.dataset.getValue("SGG_CD") // 시군구 코드
|
||||
, taskSeCd : ${pageName}Control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
|
||||
, opnnId : opnnId
|
||||
};
|
||||
|
||||
getInfo${pageName}(params);
|
||||
}
|
||||
|
||||
// 심의 버튼 이벤트
|
||||
${infoPrefix}DlbrInfo${pageName} = () => {
|
||||
let opnnId = ${pageName}Control.dataset.getValue("OPNN_ID");
|
||||
|
||||
// 의견제출 ID 가 없다면.. return
|
||||
if (!opnnId) return;
|
||||
|
||||
let params = {
|
||||
callPurpose : "update"
|
||||
, sggCd : ${pageName}Control.dataset.getValue("SGG_CD") // 시군구 코드
|
||||
, taskSeCd : ${pageName}Control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
|
||||
, opnnId : opnnId
|
||||
};
|
||||
|
||||
getDlbrInfo${pageName}(params);
|
||||
}
|
||||
|
||||
// 삭제 버튼 이벤트
|
||||
${infoPrefix}Remove${pageName} = () => {
|
||||
dialog.alert({
|
||||
content : "선택한 의견제출 정보를 삭제하시겠습니까?"
|
||||
, onOK : () => {
|
||||
${pageName}Control.remove();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* script 진입
|
||||
**************************************************************************/
|
||||
$(document).ready(function() {
|
||||
// 기본 데이터 설정
|
||||
$("#sggCd--${pageName}").val("${sggCd}"); // 시군구 코드
|
||||
|
||||
// 이벤트 설정
|
||||
setEvent${pageName}();
|
||||
|
||||
// 보안모드
|
||||
fn_securityModeToggle($("#securityMode--top").is(":checked"));
|
||||
|
||||
// 업무 구분 설정
|
||||
let defaultBizValue = $("#layout-navbar input[name='taskSeCd']:checked").val();
|
||||
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + defaultBizValue + "']").prop("checked", true);
|
||||
|
||||
// 화면 초기 설정 및 업무 구분 변경
|
||||
fnResetAndChangeBiz${pageName}(defaultBizValue);
|
||||
});
|
||||
|
||||
</script>
|
@ -0,0 +1,644 @@
|
||||
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" isELIgnored="false" session="false"%>
|
||||
<%@ include file="/WEB-INF/jsp/include/taglib.jsp"%>
|
||||
|
||||
<!-- inner page html -->
|
||||
<div class="content-wrapper">
|
||||
<!-- Content -->
|
||||
<div class="container-xxl flex-grow-1 px-0">
|
||||
<c:set var="prefixName" scope="request">공시송달 현황</c:set>
|
||||
|
||||
<!-- Page Body -->
|
||||
<div class="card">
|
||||
<div class="wrapper-list">
|
||||
<div>
|
||||
<!-- 상단 버튼 -->
|
||||
<div class="container-page-btn">
|
||||
<button type="button" class="btn btn-outline-dark" id="btnReset--${pageName}" title="초기화" onclick="fnReset${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 type="button" class="btn btn-excel w-px-120" id="btnExcel--${pageName}" title="엑셀" onclick="fnExcel${pageName}();">
|
||||
엑셀
|
||||
</button>
|
||||
</span>
|
||||
</div>
|
||||
<!-- / 상단 버튼 -->
|
||||
|
||||
<!-- 검색 조건 영역 -->
|
||||
<form id="frmSearch--${pageName}" name="frmSearch">
|
||||
<!-- hidden -->
|
||||
<input type="hidden" id="sggCd--${pageName}" name="sggCd" data-map="SGG_CD" />
|
||||
|
||||
<!-- 메인 조건 -->
|
||||
<div class="container-search">
|
||||
<div class="row g-1">
|
||||
<!-- 업무구분 -->
|
||||
<div class="col-12">
|
||||
<label class="form-label fw-bold form-search-title text-end">업무구분</label>
|
||||
<span class="form-search-linebox">
|
||||
<c:forEach items="${FIM054List}" var="item">
|
||||
<label>
|
||||
<input type="radio" class="form-check-input" name="taskSeCd" alt="업무구분"
|
||||
value="${item.code}" onchange="fnResetAndChangeBiz${pageName}(this.value);">
|
||||
${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="schRcptYmdFrom--${pageName}" name="schRcptYmdFrom"
|
||||
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="schRcptYmdTo--${pageName}" name="schRcptYmdTo"
|
||||
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>
|
||||
<span class="form-search-linebox">
|
||||
<input type="text" class="form-control form-date" id="schAnsYmdFrom--${pageName}" name="schAnsYmdFrom"
|
||||
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="schAnsYmdTo--${pageName}" name="schAnsYmdTo"
|
||||
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="schOpnnSbmsnSttsCd--${pageName}" name="schOpnnSbmsnSttsCd">
|
||||
<option value="">전체</option>
|
||||
<c:forEach items="${FIM031List}" 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="schVhrno--${pageName}" name="schVhrno" />
|
||||
</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="schCrdnYmdFrom--${pageName}" name="schCrdnYmdFrom"
|
||||
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="schCrdnYmdTo--${pageName}" name="schCrdnYmdTo"
|
||||
data-fmt-type="day" title="종료 날짜 선택" />
|
||||
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
|
||||
</span>
|
||||
</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 id="searchDetail--${pageName}" class="container-search container-search-detail collapse">
|
||||
<div class="row g-1">
|
||||
<!-- 진술자명 -->
|
||||
<div class="col-6">
|
||||
<label class="form-label fw-bold form-search-title text-end">진술자명</label>
|
||||
<input type="text" class="form-control w-px-150" id="schSttrNm--${pageName}" name="schSttrNm" />
|
||||
</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-150" id="schRtpyrNm--${pageName}" name="schRtpyrNm" />
|
||||
</div>
|
||||
<!-- 등록일자, 수정일자 -->
|
||||
<div class="col-6">
|
||||
<select class="form-select text-center" id="schDetailRegDtOpt--${pageName}" name="schDetailRegDtOpt">
|
||||
<option value="regDt">등록일자</option>
|
||||
<option value="mdfcnDt">수정일자</option>
|
||||
</select>
|
||||
<span class="form-search-linebox">
|
||||
<input type="text" class="form-control form-date" id="schDetailRegDtFrom--${pageName}" name="schDetailRegDtFrom"
|
||||
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="schDetailRegDtTo--${pageName}" name="schDetailRegDtTo"
|
||||
data-fmt-type="day" title="종료 날짜 선택">
|
||||
<button type="button" class="bx bx-sm bx-calendar bg-white"></button>
|
||||
</span>
|
||||
</div>
|
||||
<!-- 등록자명, 수정자명 -->
|
||||
<div class="col-6">
|
||||
<select class="form-select text-center" id="schDetailRgtrOpt--${pageName}" name="schDetailRgtrOpt">
|
||||
<option value="rgtr">등록자</option>
|
||||
<option value="mdfr">수정자</option>
|
||||
</select>
|
||||
<input type="text" class="form-control" id="schDetailRgtrNm--${pageName}" name="schDetailRgtrNm" />
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- / 상세 조건 -->
|
||||
</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="btnOpnnInfo--${pageName}" title="의견제출 정보" onclick="${infoPrefix}Info${pageName}();">
|
||||
의견제출 정보
|
||||
</button>
|
||||
<button type="button" class="btn btn-primary w-px-120" id="btnOpnnRemove--${pageName}" title="의견제출 삭제" onclick="${infoPrefix}Remove${pageName}();">
|
||||
의견제출 삭제
|
||||
</button>
|
||||
<button type="button" class="btn btn-primary w-px-120" id="btnOpnnDlbrInfo--${pageName}" title="심의 정보" onclick="${infoPrefix}DlbrInfo${pageName}();">
|
||||
심의 정보
|
||||
</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;" onclick="searchFromGridTitle('TASK_SE_CD', this.innerText, 'codeValue', 'FIM054');">업무구분</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RCPT_YMD', this.innerText, 'ymd', '');">접수일자</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RCPT_NO', this.innerText, 'match', 'part');">접수번호</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RCPT_SE_CD', this.innerText, 'codeValue', 'FIM029');">접수구분</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('NTFCTN_SE_CD', this.innerText, 'codeValue', 'FIM030');">통보구분</th>
|
||||
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('STTR_NM', this.innerText, 'match', 'part');">진술자명</th>
|
||||
<th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('OPNN_SBMSN_STTS_CD', this.innerText, 'codeValue', 'FIM031');">의견제출상태</th>
|
||||
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('OPNN_SBMSN_SE_CD', this.innerText, 'codeValue', 'FIM033');">의견제출분류</th>
|
||||
<th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('OPNN_SBMSN_GIST', this.innerText, 'match', 'part');">의견제출요지</th>
|
||||
<th class="cmn" style="width: 180px;" onclick="searchFromGridTitle('CRDN_YMD', this.innerText, 'ymd', '');">단속일시</th>
|
||||
<th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('VHRNO', this.innerText, 'match', 'part');">차량번호</th>
|
||||
<th class="cmn" style="width: 280px;" onclick="searchFromGridTitle('CRDN_PLC', this.innerText, 'match', 'part');">단속장소</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('FFNLG_AMT', this.innerText, 'match', 'part');">과태료금액</th>
|
||||
<th class="cmn" style="width: 160px;" onclick="searchFromGridTitle('CRDN_STTS_CD', this.innerText, 'codeValue', 'FIM010');">처리상태</th>
|
||||
<th class="cmn" style="width: 140px;" onclick="searchFromGridTitle('DOC_NO', this.innerText, 'ymd', '');">문서번호</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('ANS_YMD', this.innerText, 'ymd', '');">답변일자</th>
|
||||
<th class="cmn" style="width: 240px;" onclick="searchFromGridTitle('ANS_CN', this.innerText, 'match', 'part');">답변내용</th>
|
||||
<th class="cmn" style="width: 200px;" onclick="searchFromGridTitle('RTPYR_NM', this.innerText, 'match', 'part');">납부자명</th>
|
||||
<th class="cmn" style="width: 120px;" onclick="searchFromGridTitle('RTPYR_BRDT', 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="{OPNN_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="{OPNN_ID}" onchange="${pageName}Control.select('{OPNN_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}">{RCPT_YMD}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RCPT_NO}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RCPT_SE_NM}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{NTFCTN_SE_NM}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{STTR_NM}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{OPNN_SBMSN_STTS_NM}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{OPNN_SBMSN_SE_NM}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{OPNN_SBMSN_GIST}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_YMD_TM}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{VHRNO}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_PLC}</td>
|
||||
<td class="cmn text-end" onclick="{onclick}" ondblclick="{ondblclick}">{FFNLG_AMT}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{CRDN_STTS_NM}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{DOC_NO}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{ANS_YMD}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{ANS_CN}</td>
|
||||
<td class="cmn text-start" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_NM}</td>
|
||||
<td class="cmn text-center" onclick="{onclick}" ondblclick="{ondblclick}">{RTPYR_BRDT}</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="26" class="dataTables_empty text-center">${prefixName} 정보를 찾지 못했습니다.</td>
|
||||
</tr>
|
||||
</template>
|
||||
</table>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
<!-- / DataTables(그리드) -->
|
||||
</div>
|
||||
</div> <!-- / Wrapper-list -->
|
||||
</div> <!-- / Card -->
|
||||
</div>
|
||||
<!-- / Content -->
|
||||
|
||||
<jsp:include page="/WEB-INF/jsp/include/bottom.jsp" />
|
||||
|
||||
<div class="content-backdrop fade"></div>
|
||||
</div>
|
||||
<!-- / inner page html <div class="content-wrapper"> -->
|
||||
|
||||
<script>
|
||||
/**************************************************************************
|
||||
* Global Variable
|
||||
**************************************************************************/
|
||||
// URL
|
||||
var ${pageName}PrefixUrl = "/excl/excl02";
|
||||
// FormFields
|
||||
var ${pageName}Fields = new FormFields("#frmSearch--${pageName}");
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl
|
||||
**************************************************************************/
|
||||
var ${pageName}Control = new DatasetControl({
|
||||
prefix : "opnn"
|
||||
, prefixName : "의견제출"
|
||||
, infoSize : "xl"
|
||||
, keymapper : info => info ? info.OPNN_ID : ""
|
||||
, dataGetter : obj => obj.opnnSbmsnList
|
||||
, appendData : true
|
||||
, tableRenderComplete : false // dataTables 에 자료 추가 완료 여부
|
||||
, formats : {
|
||||
RCPT_YMD : dateFormat
|
||||
, ANS_YMD : dateFormat
|
||||
, ANS_YMD_TM : datetimeFormat
|
||||
, CRDN_YMD_TM : datetimeFormat
|
||||
, FFNLG_CRDN_AMT : numberFormat
|
||||
, FFNLG_AMT : numberFormat
|
||||
, REG_DT : datetimeFormat
|
||||
, MDFCN_DT : datetimeFormat
|
||||
}
|
||||
});
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl 이벤트
|
||||
**************************************************************************/
|
||||
// Dataset 변경
|
||||
${pageName}Control.onDatasetChange = obj => {
|
||||
renderList${pageName}();
|
||||
|
||||
$("#paging--${pageName}").setPagingInfo({
|
||||
list : ${pageName}Control.dataset
|
||||
, prefix : "paging--${pageName}"
|
||||
, start : obj.${infoPrefix}Start
|
||||
, totalSize : obj.${infoPrefix}Total
|
||||
, fetchSize : obj.${infoPrefix}Fetch
|
||||
, func : "${pageName}Control.load({index})"
|
||||
});
|
||||
|
||||
${pageName}Control.tableRenderComplete = true; // dataTables 에 자료 추가 완료
|
||||
};
|
||||
|
||||
// 현재 선택 자료 변경 이벤트
|
||||
${pageName}Control.onCurrentChange = item => {
|
||||
if (!item) return;
|
||||
|
||||
let key = item.data.OPNN_ID;
|
||||
|
||||
$("#tbody--${pageName}").setCurrentRow(key);
|
||||
};
|
||||
|
||||
// 선택(체크) 변경 이벤트
|
||||
${pageName}Control.onSelectionChange = selected => {
|
||||
let ${infoPrefix}List = ${pageName}Control.dataset;
|
||||
let keys = selected.map(e => ${infoPrefix}List.getKey(e));
|
||||
|
||||
$("#tbody--${pageName} input[type='checkbox']").each(function() {
|
||||
let checkbox = $(this);
|
||||
|
||||
checkbox.prop("checked", keys.includes(checkbox.val()));
|
||||
});
|
||||
|
||||
$("#btn${infoPrefix}Remove--${pageName}").prop("disabled", keys.length < 1);
|
||||
};
|
||||
|
||||
// 개별총정보 dialog
|
||||
${pageName}Control.getInfo = (crdnId) => {
|
||||
if (typeof crdnId == "undefined" || crdnId == null || crdnId == "") return;
|
||||
|
||||
let params = {
|
||||
callControlName : "${pageName}Control"
|
||||
, crdnId : crdnId
|
||||
}
|
||||
|
||||
ajax.get({
|
||||
url : ${pageName}Control.urls.getInfo
|
||||
, data : params
|
||||
, success : resp => {
|
||||
dialog.open({
|
||||
id : "totalInfoMainDialog"
|
||||
, title : "개별총정보"
|
||||
, content : resp
|
||||
, size : "xxl"
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 삭제 callback
|
||||
${pageName}Control.onRemove = (selected, resp) => {
|
||||
let btnTitle = $("#btn${infoPrefix}Remove--${pageName}").attr("title");
|
||||
let showMessage = resp.retMessage.replace(/[S]|[F]/g, btnTitle);
|
||||
|
||||
dialog.alert(showMessage);
|
||||
|
||||
if (resp.saved) {
|
||||
${pageName}Control._load();
|
||||
}
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
*
|
||||
**************************************************************************/
|
||||
// DataTables에 click, dbclick 이벤트
|
||||
renderList${pageName} = () => {
|
||||
let ${infoPrefix}List = ${pageName}Control.dataset;
|
||||
let empty = ${infoPrefix}List.empty;
|
||||
|
||||
let trs = empty ?
|
||||
[document.getElementById("${infoPrefix}NotFound--${pageName}").innerHTML] : <%-- from template#${infoPrefix}NotFound --%>
|
||||
${infoPrefix}List.inStrings(
|
||||
document.getElementById("${infoPrefix}Row--${pageName}").innerHTML, <%-- from template#${infoPrefix}Row --%>
|
||||
(str, dataItem) => str
|
||||
.replace(/{onclick}/gi, "${pageName}Control.setCurrent('" + dataItem.getValue("OPNN_ID") + "');")
|
||||
.replace(/{ondblclick}/gi, "${pageName}Control.getInfo('" + dataItem.getValue("CRDN_ID") + "');")
|
||||
);
|
||||
|
||||
$("#tbody--${pageName}").html(trs.join());
|
||||
$("th input[type='checkbox']").prop("checked", false);
|
||||
|
||||
//보안모드
|
||||
fn_securityModeToggle($("#securityMode--top").is(":checked"));
|
||||
}
|
||||
|
||||
// 수정 dialog -> callback 추가
|
||||
getInfo${pageName} = (params) => {
|
||||
if (!params) return;
|
||||
|
||||
ajax.get({
|
||||
url : wctx.url("/" + params.taskSeCd + ${pageName}PrefixUrl + "/020/info.do")
|
||||
, data : params || {}
|
||||
, success : resp => {
|
||||
dialog.open({
|
||||
id : ${pageName}Control.prefixed("Dialog")
|
||||
, title : ${pageName}Control.prefixName + " 정보"
|
||||
, content : resp
|
||||
, size : ${pageName}Control.infoSize
|
||||
, onClose : () => { ${pageName}Control.load(${pageName}Control.query.pageNum); } // callback
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 심의 dialog
|
||||
getDlbrInfo${pageName} = (params) => {
|
||||
if (!params) return;
|
||||
|
||||
ajax.get({
|
||||
url : wctx.url("/" + params.taskSeCd + ${pageName}PrefixUrl + "/030/info.do")
|
||||
, data : params || {}
|
||||
, success : resp => {
|
||||
dialog.open({
|
||||
id : ${pageName}Control.prefixed("SbmsnDialog")
|
||||
, title : ${pageName}Control.prefixName + " 심의 처리"
|
||||
, content : resp
|
||||
, size : "lg"
|
||||
, onClose : () => { ${pageName}Control.load(${pageName}Control.query.pageNum); } // callback
|
||||
});
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 초기 셋팅
|
||||
**************************************************************************/
|
||||
// 초기화
|
||||
initForm${pageName} = () => {
|
||||
// 화면 초기화
|
||||
$("#frmSearch--${pageName}")[0].reset();
|
||||
|
||||
// dataset 초기화
|
||||
${pageName}Control.dataset.clear();
|
||||
}
|
||||
|
||||
// 이벤트
|
||||
setEvent${pageName} = () => {
|
||||
// form-date 항목에서 키보드로 입력시 날짜 포맷팅 적용
|
||||
$("#frmSearch--${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);
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
// DataTables width 변경 조정
|
||||
$("#DataTables_Table_0--${pageName}").find("th").resizable( {handles : "e"} );
|
||||
|
||||
// DataTables 스크롤 이벤트
|
||||
$("#table-responsive--${pageName}").scroll(function() {
|
||||
let el = $(this);
|
||||
|
||||
if (el.scrollTop() == 0) {
|
||||
return;
|
||||
}
|
||||
if (!${pageName}Control.tableRenderComplete) {
|
||||
return;
|
||||
}
|
||||
|
||||
let itemsCnt = ${pageName}Control.dataset._items.length;
|
||||
let totCnt = ${pageName}Control.dataset.getValue("TOT_CNT");
|
||||
|
||||
if (itemsCnt >= totCnt) {
|
||||
return;
|
||||
}
|
||||
|
||||
if ((el[0].scrollHeight - el.scrollTop() + VERTICAL_SCROLL_HEIGHT) <= el.outerHeight()) {
|
||||
${pageName}Control.tableRenderComplete = false; // dataTables 에 자료 추가 완료
|
||||
|
||||
${pageName}Control.load(${pageName}Control.query.pageNum + 1);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
// 화면 초기값 셋팅
|
||||
setForm${pageName} = (taskSeCd) => {
|
||||
// 업무 구분 코드
|
||||
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + taskSeCd + "']").prop("checked", true);
|
||||
|
||||
// 최고 관리자 경우 업무구분을 선택할 수 있도록 하자.
|
||||
$("#frmSearch--${pageName} input[name='taskSeCd']").each(function(i) {
|
||||
$(this).prop("disabled", "true");
|
||||
});
|
||||
|
||||
// 달력 초기화
|
||||
initDatepicker("frmSearch--${pageName}");
|
||||
|
||||
$("#schRcptYmdFrom--${pageName}").datepicker("setDate", DateUtil.getDateDay(-365).date);
|
||||
$("#schRcptYmdTo--${pageName}").datepicker("setDate", new Date());
|
||||
}
|
||||
|
||||
// URL 설정
|
||||
setURL${pageName} = (taskSeCd) => {
|
||||
${pageName}Control.urls.load = wctx.url("/" + taskSeCd + ${pageName}PrefixUrl + "/010/list.do"); // 조회
|
||||
${pageName}Control.urls.remove = wctx.url("/" + taskSeCd + ${pageName}PrefixUrl + "/010/removes.do"); // 삭제
|
||||
${pageName}Control.urls.getInfo = wctx.url("/" + taskSeCd + "/sprt/sprt02/010/main.do"); // 개별총정보
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* 버튼 clickEvent
|
||||
**************************************************************************/
|
||||
// 업무 구분 변경
|
||||
fnResetAndChangeBiz${pageName} = (taskSeCd) => {
|
||||
// 초기화
|
||||
initForm${pageName}();
|
||||
|
||||
// 업무 구분 코드
|
||||
if (typeof taskSeCd == "undefined" || taskSeCd == null || taskSeCd == "") {
|
||||
taskSeCd = $("#layout-navbar input[name='taskSeCd']:checked").val();
|
||||
}
|
||||
|
||||
// 화면 초기값 설정
|
||||
setForm${pageName}(taskSeCd);
|
||||
|
||||
// URL 설정
|
||||
setURL${pageName}(taskSeCd);
|
||||
}
|
||||
|
||||
// 초기화 버튼 이벤트
|
||||
fnReset${pageName} = () => {
|
||||
fnResetAndChangeBiz${pageName}();
|
||||
}
|
||||
|
||||
// 검색 버튼 이벤트
|
||||
fnSearchList${pageName} = () => {
|
||||
// 검색조건
|
||||
${pageName}Control.query = ${pageName}Fields.get();
|
||||
|
||||
${pageName}Control.query.fetchSize = FETCH_XS; // 한번에 조회되는 자료 건수 FETCH_XS = 30
|
||||
${pageName}Control.query.delYn = "N"; // 삭제 여부
|
||||
${pageName}Control.query.crdnDelYn = "N"; // 단속 대장 삭제 여부
|
||||
|
||||
${pageName}Control.load();
|
||||
}
|
||||
|
||||
// 엑셀 버튼 이벤트
|
||||
fnExcel${pageName} = () => {
|
||||
|
||||
}
|
||||
|
||||
// 수정 버튼 이벤트
|
||||
${infoPrefix}Info${pageName} = () => {
|
||||
let = ${pageName}Control.dataset.getValue("OPNN_ID");
|
||||
|
||||
// 의견제출 ID 가 없다면.. return
|
||||
if (!opnnId) return;
|
||||
|
||||
let params = {
|
||||
callPurpose : "update"
|
||||
, sggCd : ${pageName}Control.dataset.getValue("SGG_CD") // 시군구 코드
|
||||
, taskSeCd : ${pageName}Control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
|
||||
, opnnId : opnnId
|
||||
};
|
||||
|
||||
getInfo${pageName}(params);
|
||||
}
|
||||
|
||||
// 심의 버튼 이벤트
|
||||
${infoPrefix}DlbrInfo${pageName} = () => {
|
||||
let opnnId = ${pageName}Control.dataset.getValue("OPNN_ID");
|
||||
|
||||
// 의견제출 ID 가 없다면.. return
|
||||
if (!opnnId) return;
|
||||
|
||||
let params = {
|
||||
callPurpose : "update"
|
||||
, sggCd : ${pageName}Control.dataset.getValue("SGG_CD") // 시군구 코드
|
||||
, taskSeCd : ${pageName}Control.dataset.getValue("TASK_SE_CD") // 업무 구분 코드
|
||||
, opnnId : opnnId
|
||||
};
|
||||
|
||||
getDlbrInfo${pageName}(params);
|
||||
}
|
||||
|
||||
// 삭제 버튼 이벤트
|
||||
${infoPrefix}Remove${pageName} = () => {
|
||||
dialog.alert({
|
||||
content : "선택한 의견제출 정보를 삭제하시겠습니까?"
|
||||
, onOK : () => {
|
||||
${pageName}Control.remove();
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
/**************************************************************************
|
||||
* script 진입
|
||||
**************************************************************************/
|
||||
$(document).ready(function() {
|
||||
// 기본 데이터 설정
|
||||
$("#sggCd--${pageName}").val("${sggCd}"); // 시군구 코드
|
||||
|
||||
// 이벤트 설정
|
||||
setEvent${pageName}();
|
||||
|
||||
// 보안모드
|
||||
fn_securityModeToggle($("#securityMode--top").is(":checked"));
|
||||
|
||||
// 업무 구분 설정
|
||||
let defaultBizValue = $("#layout-navbar input[name='taskSeCd']:checked").val();
|
||||
$("#frmSearch--${pageName} input[name='taskSeCd'][value='" + defaultBizValue + "']").prop("checked", true);
|
||||
|
||||
// 화면 초기 설정 및 업무 구분 변경
|
||||
fnResetAndChangeBiz${pageName}(defaultBizValue);
|
||||
});
|
||||
|
||||
</script>
|
Loading…
Reference in New Issue