부과 수정.
parent
47b30f92b2
commit
913b29e4d2
@ -0,0 +1,150 @@
|
||||
function newLevy01010Control(pageName, doctx="[data-doctx='levy01010']") {
|
||||
let ctrl = new DatasetControl({
|
||||
doctx: doctx
|
||||
, prefix: "rdctLevyTrgt"
|
||||
, prefixName: "감경부과 대상"
|
||||
, dataGetter: obj => obj["List"]
|
||||
, keys: ["CRDN_ID"]
|
||||
, appendData: true
|
||||
, infoSize: "md"
|
||||
, urls: {
|
||||
load: "/list.do"
|
||||
, getInfo: "/info.do"
|
||||
}
|
||||
, formats: {
|
||||
CRDN_YMD_TM: datetimeFormat
|
||||
, CVLCPT_RCPT_YMD: dateFormat
|
||||
, FFNLG_CRDN_AMT: numberFormat
|
||||
, FFNLG_AMT: numberFormat
|
||||
, CVLCPT_PRCS_CMPTN_DT: datetimeFormat
|
||||
, REG_DT: datetimeFormat
|
||||
, MDFCN_DT: datetimeFormat
|
||||
}
|
||||
});
|
||||
|
||||
// 검색 조건
|
||||
ctrl.query = { pageNum: 1, fetchSize: DEFAULT_FETCH_SIZE }; // 1 페이지당 자료 건수 index.jsp에서 확인
|
||||
|
||||
// paging
|
||||
ctrl.pagingSupport = new FimsPagingSupport({
|
||||
ctrl: ctrl // DatasetControl
|
||||
, ignoreCtrlPrefix: true // ctrl.prefix 가 있더라도 무시
|
||||
, linkContainer: "[name='dataPaging']" // <ul class="pagination pagination-primary" name="dataPaging">
|
||||
});
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl Events
|
||||
**************************************************************************/
|
||||
// Dataset 변경 이벤트
|
||||
ctrl.onDatasetChange = (obj, option) => {
|
||||
// 데이터 셋
|
||||
let dataList = ctrl.dataset;
|
||||
let empty = dataList.empty;
|
||||
let clsForTask = $(ctrl.find("[name='frmSearch']")).find("[name='taskSeCd']:checked").val().toLowerCase();
|
||||
|
||||
// 업무별 dataTables(그리드) tr, td
|
||||
let foundContent = ctrl.find("[name='tmpltRows']").content;
|
||||
let foundTr = $(foundContent).find("tr")[0].cloneNode(false);
|
||||
let foundTds = $(foundContent).find("." + clsForTask + ",.cmn");
|
||||
|
||||
foundTds.each(function() {
|
||||
foundTr.appendChild(this.cloneNode(true));
|
||||
});
|
||||
|
||||
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']").content.querySelector("." + clsForTask + ",.cmn").outerHTML]
|
||||
: dataList.inStrings(foundTr.outerHTML, 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
|
||||
ctrl.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='btnCreateSlctnTrgt']"), 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,63 @@
|
||||
function newLevy01020Control(pageName, doctx="[data-doctx='levy01020']") {
|
||||
let ctrl = new DatasetControl({
|
||||
doctx: doctx
|
||||
, prefix: "rdctLevyTrgt"
|
||||
, prefixName: "감경부과"
|
||||
, dataGetter: obj => obj["Info"]
|
||||
, keys: ["CRDN_ID"]
|
||||
, urls: {
|
||||
create: "/create.do"
|
||||
, update: "/update.do"
|
||||
}
|
||||
, formats: {
|
||||
TNOCS: numberFormat
|
||||
, GRAMT_FFNLG_AMT: numberFormat
|
||||
, GRAMT_ADVNTCE_AMT: numberFormat
|
||||
}
|
||||
});
|
||||
|
||||
/**************************************************************************
|
||||
* 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/createRdctLevyList.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;
|
||||
|
||||
ajax.post({
|
||||
url: ctrl.urls.create
|
||||
, data: params || {}
|
||||
, success: (resp) => { ctrl.onSave(params, resp); }
|
||||
});
|
||||
}
|
||||
|
||||
return ctrl;
|
||||
}
|
@ -0,0 +1,161 @@
|
||||
function newLevy01050Control(pageName, doctx="[data-doctx='levy01050']") {
|
||||
let ctrl = new DatasetControl({
|
||||
doctx: doctx
|
||||
, prefix: "levy"
|
||||
, prefixName: "부과"
|
||||
, dataGetter: obj => obj["List"]
|
||||
, keys: ["LEVY_ID"]
|
||||
, appendData: true
|
||||
, infoSize: "xl"
|
||||
, urls: {
|
||||
load: "/list.do"
|
||||
, getInfo: "/info.do"
|
||||
}
|
||||
, formats: {
|
||||
LEVY_YMD: dateFormat
|
||||
, FRST_DUDT_YMD: dateFormat
|
||||
, DUDT_YMD: dateFormat
|
||||
, RCVMT_YMD: dateFormat
|
||||
, SZR_YMD: dateFormat
|
||||
, SZR_RMV_YMD: dateFormat
|
||||
, FFNLG_AMT: numberFormat
|
||||
, LEVY_PCPTAX: numberFormat
|
||||
, LEVY_ADAMT: numberFormat
|
||||
, ISPY_INT: numberFormat
|
||||
, RCVMT_PCPTAX: numberFormat
|
||||
, RCVMT_ADAMT: numberFormat
|
||||
, RDAMT_PCPTAX: numberFormat
|
||||
, RDAMT_ADAMT: numberFormat
|
||||
, SUM_AMT: numberFormat
|
||||
, CRDN_YMD_TM: datetimeFormat
|
||||
, FFNLG_CRDN_AMT: numberFormat
|
||||
, REG_DT: datetimeFormat
|
||||
, MDFCN_DT: datetimeFormat
|
||||
}
|
||||
});
|
||||
|
||||
// 검색 조건
|
||||
ctrl.query = { pageNum: 1, fetchSize: DEFAULT_FETCH_SIZE }; // 1 페이지당 자료 건수 index.jsp에서 확인
|
||||
// paging
|
||||
ctrl.pagingSupport = new FimsPagingSupport({
|
||||
ctrl: ctrl // DatasetControl
|
||||
, ignoreCtrlPrefix: true // ctrl.prefix 가 있더라도 무시
|
||||
, linkContainer: "[name='dataPaging']" // <ul class="pagination pagination-primary" name="dataPaging">
|
||||
});
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl Events
|
||||
**************************************************************************/
|
||||
// Dataset 변경 이벤트
|
||||
ctrl.onDatasetChange = (obj, option) => {
|
||||
// 데이터 셋
|
||||
let dataList = ctrl.dataset;
|
||||
let empty = dataList.empty;
|
||||
let clsForTask = $(ctrl.find("[name='frmSearch']")).find("[name='taskSeCd']:checked").val().toLowerCase();
|
||||
|
||||
// 업무별 dataTables(그리드) tr, td
|
||||
let foundContent = ctrl.find("[name='tmpltRows']").content;
|
||||
let foundTr = $(foundContent).find("tr")[0].cloneNode(false);
|
||||
let foundTds = $(foundContent).find("." + clsForTask + ",.cmn");
|
||||
|
||||
foundTds.each(function() {
|
||||
foundTr.appendChild(this.cloneNode(true));
|
||||
});
|
||||
|
||||
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']").content.querySelector("." + clsForTask + ",.cmn").outerHTML]
|
||||
: dataList.inStrings(foundTr.outerHTML, 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
|
||||
ctrl.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,151 @@
|
||||
function newLevy02010Control(pageName, doctx="[data-doctx='levy02010']") {
|
||||
let ctrl = new DatasetControl({
|
||||
doctx: doctx
|
||||
, prefix: "rdct"
|
||||
, prefixName: "과태료 감경"
|
||||
, dataGetter: obj => obj["List"]
|
||||
, keys: ["RDCT_ID"]
|
||||
, appendData: true
|
||||
, infoSize: "md"
|
||||
, urls: {
|
||||
load: "/list.do"
|
||||
, getInfo: "/info.do"
|
||||
}
|
||||
, formats: {
|
||||
RDCT_YMD: dateFormat
|
||||
, CRDN_YMD_TM: datetimeFormat
|
||||
, FFNLG_CRDN_AMT: numberFormat
|
||||
, RDCT_AMT: numberFormat
|
||||
, FFNLG_AMT: numberFormat
|
||||
, SUM_AMT: numberFormat
|
||||
, REG_DT: datetimeFormat
|
||||
, MDFCN_DT: datetimeFormat
|
||||
}
|
||||
});
|
||||
|
||||
// 검색 조건
|
||||
ctrl.query = { pageNum: 1, fetchSize: DEFAULT_FETCH_SIZE }; // 1 페이지당 자료 건수 index.jsp에서 확인
|
||||
|
||||
// paging
|
||||
ctrl.pagingSupport = new FimsPagingSupport({
|
||||
ctrl: ctrl // DatasetControl
|
||||
, ignoreCtrlPrefix: true // ctrl.prefix 가 있더라도 무시
|
||||
, linkContainer: "[name='dataPaging']" // <ul class="pagination pagination-primary" name="dataPaging">
|
||||
});
|
||||
|
||||
/**************************************************************************
|
||||
* DatasetControl Events
|
||||
**************************************************************************/
|
||||
// Dataset 변경 이벤트
|
||||
ctrl.onDatasetChange = (obj, option) => {
|
||||
// 데이터 셋
|
||||
let dataList = ctrl.dataset;
|
||||
let empty = dataList.empty;
|
||||
let clsForTask = $(ctrl.find("[name='frmSearch']")).find("[name='taskSeCd']:checked").val().toLowerCase();
|
||||
|
||||
// 업무별 dataTables(그리드) tr, td
|
||||
let foundContent = ctrl.find("[name='tmpltRows']").content;
|
||||
let foundTr = $(foundContent).find("tr")[0].cloneNode(false);
|
||||
let foundTds = $(foundContent).find("." + clsForTask + ",.cmn");
|
||||
|
||||
foundTds.each(function() {
|
||||
foundTr.appendChild(this.cloneNode(true));
|
||||
});
|
||||
|
||||
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']").content.querySelector("." + clsForTask + ",.cmn").outerHTML]
|
||||
: dataList.inStrings(foundTr.outerHTML, 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
|
||||
ctrl.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,66 @@
|
||||
function newLevy02020Control(pageName, doctx="[data-doctx='levy02020']") {
|
||||
let ctrl = new DatasetControl({
|
||||
doctx: doctx
|
||||
, prefix: "rdct"
|
||||
, prefixName: "과태료 감경"
|
||||
, dataGetter: obj => obj["Info"]
|
||||
, keys: ["RDCT_ID"]
|
||||
, urls: {
|
||||
create: "/create.do"
|
||||
, update: "/update.do"
|
||||
}
|
||||
, formats: {
|
||||
FFNLG_CRDN_AMT: numberFormat // 과태료 단속 금액
|
||||
, WKSN_RDCRT: numberFormat // 사회적약자 감경율
|
||||
, RDCT_AMT: numberFormat // 감경 금액
|
||||
}
|
||||
});
|
||||
|
||||
/**************************************************************************
|
||||
* 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.rdctId);
|
||||
|
||||
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