From 6c43799f2b13bd1f9af1f43c5fd4b7d72abe7241 Mon Sep 17 00:00:00 2001 From: hehih Date: Thu, 19 Sep 2024 12:02:22 +0900 Subject: [PATCH] =?UTF-8?q?=EB=AC=B8=EC=9E=90=EC=A0=84=EC=86=A1=20>=20?= =?UTF-8?q?=EC=97=91=EC=85=80=EB=B6=88=EB=9F=AC=EC=98=A4=EA=B8=B0=20>=20?= =?UTF-8?q?=ED=83=80=EC=9D=B4=ED=8B=80=20=EA=B0=84=EA=B2=A9=20=EB=A7=9E?= =?UTF-8?q?=EC=B6=A4?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../msgdata/include/msgDataIncludeExcel.jsp | 38 +- src/main/webapp/js/web/addr/init.js | 528 +++++++++--------- 2 files changed, 300 insertions(+), 266 deletions(-) diff --git a/src/main/webapp/WEB-INF/jsp/web/msgdata/include/msgDataIncludeExcel.jsp b/src/main/webapp/WEB-INF/jsp/web/msgdata/include/msgDataIncludeExcel.jsp index a1979d63..06e837f6 100644 --- a/src/main/webapp/WEB-INF/jsp/web/msgdata/include/msgDataIncludeExcel.jsp +++ b/src/main/webapp/WEB-INF/jsp/web/msgdata/include/msgDataIncludeExcel.jsp @@ -49,7 +49,7 @@ $(document).ready(function(){ cell.getRow().toggleSelect(); } }, - {formatter:"rownum", align:"center" ,title:"No", hozAlign:"center", headerHozAlign:"center", width:60}, + {formatter:"rownum", align:"center" ,title:"No", hozAlign:"center", headerHozAlign:"center", width:40}, {title:"A", field:"A", hozAlign:"center", headerHozAlign: "center", width:140, validator:["maxLength:100", "string"]}, {title:"B", field:"B", hozAlign:"center", headerHozAlign: "center", width:140, validator:["maxLength:100", "string"]}, {title:"C", field:"C", hozAlign:"center", headerHozAlign: "center", width:140, validator:["maxLength:100", "string"]}, @@ -68,6 +68,34 @@ $(document).ready(function(){ return value % parameters.phone; }, }); + + + + + // 타뷸레이터 width값 변경 시 위에 select width 값 변경 + var titleArray = ["A","B","C","D","E","F"]; + + $tableExcel.on("columnWidth",function(column){ + var titleIndex = titleArray.indexOf(column._column.definition.title); + titleIndex += 1; + if(titleIndex != 0){ + $('.select_adr_hd>div').eq(titleIndex).css('width', column._column.width); + }else{ + $('.select_adr_hd>div').eq(0).css('width', column._column.width + 40); + } + }); + + $tableExcel.on("scrollHorizontal",function(left){ + $(".adr_excel").scrollLeft(left); + }) + + + $(".adr_excel").on("scroll",function(){ + $(".tabulator-tableholder").scrollLeft($(this).scrollLeft()); + }); + + + $("#excelFile").on("change", function(event) { var fileInfo = event.target.files; @@ -93,6 +121,8 @@ $(document).ready(function(){ }); + + // 엑셀등록 닫기 function setAddrMassClose() { $tableExcel.clearData(); @@ -643,6 +673,9 @@ function popMore(e){ } } + + + @@ -775,7 +808,8 @@ function popMore(e){ -
+
+
diff --git a/src/main/webapp/js/web/addr/init.js b/src/main/webapp/js/web/addr/init.js index e8da0fb2..aa73bd71 100644 --- a/src/main/webapp/js/web/addr/init.js +++ b/src/main/webapp/js/web/addr/init.js @@ -1,264 +1,264 @@ - - -var tableErrorData = []; -var tableErrorCheckData = []; -var addrMassDupliSaveList = null; - -var gArrRestartIndex = 0; //배열 재시작카운드 -var gNameList = []; //치환문자 이름 -var gPhoneList = []; //받는사람 -var gInfo1List = []; //치환문자1 -var gInfo2List = []; //치환문자2 -var gInfo3List = []; //치환문자3 -var gInfo4List = []; //치환문자4 -var gMemoList = []; //메모 - - -var $tableExcel = null; //엑셀입력 탭 -var $tableClip = null; //붙여넣기 탭 -var $tableSelf = null; //붙여넣기 탭 - -var $tableError = null; //에러 팝업 영역 - -$(document).ready(function(){ - - //Tabulator AJAX Data Loading - $tableExcel = new Tabulator("#tabulator_excel", { - height:"255px", - width:"100%", - layout:"fitColumns", - autoColumns:false, - headerHozAlign:"center", - validationMode:"highlight", - clipboard:false, - clipboardCopySelector:"table", - clipboardPasteAction:"insert", // insert, update, replace - placeholder:"Excel 파일을 업로드 해주세요.", //fit columns to width of table (optional) - columns:[ //Define Table Columns - {formatter:"rowSelection", titleFormatter:"rowSelection",clipboard:false, hozAlign:"center", headerSort:false, cellClick:function(e, cell){ - cell.getRow().toggleSelect(); - } - }, - {formatter:"rownum", hozAlign:"center" ,title:"No", hozAlign:"center", headerHozAlign:"center", width:40}, - {title:"A", field:"A", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"B", field:"B", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"C", field:"C", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"D", field:"D", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"E", field:"E", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"F", field:"F", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"G", field:"G", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]} - ], - validationFailed:function(cell, value, parameters){ // 유효성 체크 함수 - var valid = cell.isValid(); - if(!valid){ - alert("양식에 맞지 않는 정보가 입력되었습니다."); - - //해당 셀 데이터 삭제 - cell.setValue(""); - } - return value % parameters.phone; - }, - }); - - - - - - $tableClip = new Tabulator("#tabulator_clip", { - height:"255px", - width:"100%", - layout:"fitColumns", - editor:true, - headerHozAlign:"center", - validationMode:"highlight", - placeholder:"복사(Ctrl+C)한 내용을 여기에 붙여넣기(Ctrl+V) 해주세요.", //fit columns to width of table (optional) -// clipboard:true, // 클립보드 기능 활성화 - clipboardPasteAction:"update", // insert, update, replace - columns: [ - {formatter: "rowSelection", titleFormatter: "rowSelection", clipboard: false, hozAlign: "center", headerHozAlign: "center", headerSort: false, cellClick: function(e, cell) { - cell.getRow().toggleSelect(); - }}, - {formatter:"rownum", hozAlign:"center" ,title:"No", hozAlign:"center", headerHozAlign:"center", width:40}, - {title:"A", field:"A", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"B", field:"B", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"C", field:"C", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"D", field:"D", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"E", field:"E", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"F", field:"F", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, - {title:"G", field:"G", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]} - ], - validationFailed: function(cell, value, parameters) { - var valid = cell.isValid(); - if (!valid) { - alert("양식에 맞지 않는 정보가 입력되었습니다."); - cell.setValue(""); // 해당 셀 데이터 삭제 - } - return false; // 유효하지 않은 경우 false 반환 - }, - }); - - - - // 사용자 정의 필터 설정: addrPhoneNo가 빈 값이나 undefined가 아닌 경우 -// $tableSelf.setFilter(function(data, filterParams) { -// var value = data.addrPhoneNo; -// return value !== "" && value !== undefined; // 빈 문자열과 undefined가 아닌 경우 -// }); - -// // 테이블의 셀 편집 후 이벤트를 등록 -// document.addEventListener('keydown', function(e) { -// if(e.key === "Tab") { -// e.preventDefault(); -// let selectedCells = $tableSelf.getSelectedCells(); -// let cell = selectedCells[selectedCells.length - 1]; // 현재 선택된 셀 가져오기 -// -// if (cell) { -// let row = cell.getRow(); -// let table = cell.getTable(); -// let nextCell = cell.getNextCell("tab"); -// -// if (!nextCell && row === table.getRows().slice(-1)[0]) { -// // 현재 셀이 마지막 행의 마지막 셀인 경우 -// table.addRow({A: "", B: "", C: "", D: "", E: "", F: "", G: ""}, false).then(function() { -// table.scrollToRow(table.getRows().slice(-1)[0]); // 새로 추가된 행으로 스크롤 -// table.setActiveCell(table.getRows().slice(-1)[0].getCell("A")); // 새로운 행의 첫 번째 셀에 포커스 -// }); -// } -// } -// } -// }); -// - - //Tabulator AJAX Data Loading - $tableError = new Tabulator("#tabulator_error", { - height:"255px", - width:"100%", - layout:"fitColumns", - autoColumns:false, - headerHozAlign:"center", - validationMode:"highlight", - clipboard:false, - clipboardCopySelector:"table", - clipboardPasteAction:"insert", // insert, update, replace - placeholder:"등록 팝업에서 휴대폰을 선택 후 확인해주세요.", //fit columns to width of table (optional) - columns:[ //Define Table Columns - {title:"이름", field:"name", hozAlign:"center", headerHozAlign: "center", width:125}, - {title:"휴대폰", field:"phone", hozAlign:"center", headerHozAlign: "center", width:158}, - {title:"미등록 결과", field:"result", hozAlign:"center", headerHozAlign: "center", width:125} - ] - }); - - // 직접입력 타블레이터 - fn_selfmakeTable() - - - // 타뷸레이터 width값 변경 시 위에 select width 값 변경 - var titleArray = ["A","B","C","D","E","F","G"]; - - $tableExcel.on("columnWidth",function(column){ - var titleIndex = titleArray.indexOf(column._column.definition.title); - titleIndex += 1; - if(titleIndex != 0){ - $('.tableExcel .select_adr_hd>div').eq(titleIndex).css('width', column._column.width); - }else{ - $('.tableExcel .select_adr_hd>div').eq(0).css('width', column._column.width + 40); - } - }); - - $tableExcel.on("scrollHorizontal",function(left){ - $(".tableExcel .adr_excel").scrollLeft(left); - }) - - - $(".tableExcel .adr_excel").on("scroll",function(){ - $(".tableExcel .tabulator-tableholder").scrollLeft($(this).scrollLeft()); - }); - - - - - $tableClip.on("columnWidth",function(column){ - var titleIndex = titleArray.indexOf(column._column.definition.title); - titleIndex += 1; - if(titleIndex != 0){ - $('.tableClip .select_adr_hd>div').eq(titleIndex).css('width', column._column.width); - }else{ - $('.tableClip .select_adr_hd>div').eq(0).css('width', column._column.width + 40); - } - }); - - $tableClip.on("scrollHorizontal",function(left){ - $(".tableClip .adr_excel").scrollLeft(left); - }) - - $(".tableClip .adr_excel").on("scroll",function(){ - $(".tableClip .tabulator-tableholder").scrollLeft($(this).scrollLeft()); - }); - - - -}); - - -function fn_ClipMakeTable(){ -} - - -function fn_selfmakeTable(){ - - var tableData = []; - for (var i = 0; i < 1000; i++) { - tableData.push({addrNm: "", addrPhoneNo: "", addrInfo1: "", addrInfo2: "", addrInfo3: "", addrInfo4: "", addrComment: ""}); - } - - // 테이블 초기화 - $tableSelf = new Tabulator("#tabulator_self", { - height: "255px", - width: "100%", - layout: "fitColumns", - clipboardPasteAction: "update", - keybindings: { - "navRight": "tab", // Tab 키를 누르면 오른쪽 셀로 이동 - "navLeft": "shift+tab", - "editNext": false // Tab 키를 누를 때 편집 모드를 종료하지 않도록 설정 - }, - data: tableData, - columns: [ - {formatter: "rowSelection", titleFormatter: "rowSelection", clipboard: false, hozAlign: "center", headerHozAlign: "center", headerSort: false, cellClick: function(e, cell) { - cell.getRow().toggleSelect(); - }}, - {formatter:"rownum", hozAlign:"center" ,title:"No", headerHozAlign:"center", width:40}, - {title:"이름", field:"addrNm", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, - {title:"휴대폰", field:"addrPhoneNo", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input" - , cellEdited:function(cell){ - var currentValue = cell.getValue(); - console.log('cell.getValue() : ', currentValue); - - // 현재 값이 null 또는 undefined가 아니고, 값이 변경된 경우에만 처리 - if (currentValue !== null - && currentValue !== '' - ) { - var newValue = fn_selfUpdataCount(currentValue); - - // 값이 실제로 변경된 경우에만 setValue 호출 - if (currentValue !== newValue) { - cell.setValue(newValue); - } - } - } - }, - {title:"[*1*]", field:"addrInfo1", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, - {title:"[*2*]", field:"addrInfo2", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, - {title:"[*3*]", field:"addrInfo3", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, - {title:"[*4*]", field:"addrInfo4", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, - {title:"메모", field:"addrComment", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"} - ], - navigation: true // 키보드 탐색 활성화 - }); -} - - - - - - + + +var tableErrorData = []; +var tableErrorCheckData = []; +var addrMassDupliSaveList = null; + +var gArrRestartIndex = 0; //배열 재시작카운드 +var gNameList = []; //치환문자 이름 +var gPhoneList = []; //받는사람 +var gInfo1List = []; //치환문자1 +var gInfo2List = []; //치환문자2 +var gInfo3List = []; //치환문자3 +var gInfo4List = []; //치환문자4 +var gMemoList = []; //메모 + + +var $tableExcel = null; //엑셀입력 탭 +var $tableClip = null; //붙여넣기 탭 +var $tableSelf = null; //붙여넣기 탭 + +var $tableError = null; //에러 팝업 영역 + +$(document).ready(function(){ + + //Tabulator AJAX Data Loading + $tableExcel = new Tabulator("#tabulator_excel", { + height:"255px", + width:"100%", + layout:"fitColumns", + autoColumns:false, + headerHozAlign:"center", + validationMode:"highlight", + clipboard:false, + clipboardCopySelector:"table", + clipboardPasteAction:"insert", // insert, update, replace + placeholder:"Excel 파일을 업로드 해주세요.", //fit columns to width of table (optional) + columns:[ //Define Table Columns + {formatter:"rowSelection", titleFormatter:"rowSelection",clipboard:false, hozAlign:"center", headerSort:false, cellClick:function(e, cell){ + cell.getRow().toggleSelect(); + } + }, + {formatter:"rownum", hozAlign:"center" ,title:"No", hozAlign:"center", headerHozAlign:"center", width:40}, + {title:"A", field:"A", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"B", field:"B", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"C", field:"C", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"D", field:"D", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"E", field:"E", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"F", field:"F", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"G", field:"G", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]} + ], + validationFailed:function(cell, value, parameters){ // 유효성 체크 함수 + var valid = cell.isValid(); + if(!valid){ + alert("양식에 맞지 않는 정보가 입력되었습니다."); + + //해당 셀 데이터 삭제 + cell.setValue(""); + } + return value % parameters.phone; + }, + }); + + + + + + $tableClip = new Tabulator("#tabulator_clip", { + height:"255px", + width:"100%", + layout:"fitColumns", + editor:true, + headerHozAlign:"center", + validationMode:"highlight", + placeholder:"복사(Ctrl+C)한 내용을 여기에 붙여넣기(Ctrl+V) 해주세요.", //fit columns to width of table (optional) +// clipboard:true, // 클립보드 기능 활성화 + clipboardPasteAction:"update", // insert, update, replace + columns: [ + {formatter: "rowSelection", titleFormatter: "rowSelection", clipboard: false, hozAlign: "center", headerHozAlign: "center", headerSort: false, cellClick: function(e, cell) { + cell.getRow().toggleSelect(); + }}, + {formatter:"rownum", hozAlign:"center" ,title:"No", hozAlign:"center", headerHozAlign:"center", width:40}, + {title:"A", field:"A", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"B", field:"B", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"C", field:"C", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"D", field:"D", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"E", field:"E", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"F", field:"F", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]}, + {title:"G", field:"G", hozAlign:"center", headerHozAlign: "center", width:125, validator:["maxLength:100", "string"]} + ], + validationFailed: function(cell, value, parameters) { + var valid = cell.isValid(); + if (!valid) { + alert("양식에 맞지 않는 정보가 입력되었습니다."); + cell.setValue(""); // 해당 셀 데이터 삭제 + } + return false; // 유효하지 않은 경우 false 반환 + }, + }); + + + + // 사용자 정의 필터 설정: addrPhoneNo가 빈 값이나 undefined가 아닌 경우 +// $tableSelf.setFilter(function(data, filterParams) { +// var value = data.addrPhoneNo; +// return value !== "" && value !== undefined; // 빈 문자열과 undefined가 아닌 경우 +// }); + +// // 테이블의 셀 편집 후 이벤트를 등록 +// document.addEventListener('keydown', function(e) { +// if(e.key === "Tab") { +// e.preventDefault(); +// let selectedCells = $tableSelf.getSelectedCells(); +// let cell = selectedCells[selectedCells.length - 1]; // 현재 선택된 셀 가져오기 +// +// if (cell) { +// let row = cell.getRow(); +// let table = cell.getTable(); +// let nextCell = cell.getNextCell("tab"); +// +// if (!nextCell && row === table.getRows().slice(-1)[0]) { +// // 현재 셀이 마지막 행의 마지막 셀인 경우 +// table.addRow({A: "", B: "", C: "", D: "", E: "", F: "", G: ""}, false).then(function() { +// table.scrollToRow(table.getRows().slice(-1)[0]); // 새로 추가된 행으로 스크롤 +// table.setActiveCell(table.getRows().slice(-1)[0].getCell("A")); // 새로운 행의 첫 번째 셀에 포커스 +// }); +// } +// } +// } +// }); +// + + //Tabulator AJAX Data Loading + $tableError = new Tabulator("#tabulator_error", { + height:"255px", + width:"100%", + layout:"fitColumns", + autoColumns:false, + headerHozAlign:"center", + validationMode:"highlight", + clipboard:false, + clipboardCopySelector:"table", + clipboardPasteAction:"insert", // insert, update, replace + placeholder:"등록 팝업에서 휴대폰을 선택 후 확인해주세요.", //fit columns to width of table (optional) + columns:[ //Define Table Columns + {title:"이름", field:"name", hozAlign:"center", headerHozAlign: "center", width:125}, + {title:"휴대폰", field:"phone", hozAlign:"center", headerHozAlign: "center", width:158}, + {title:"미등록 결과", field:"result", hozAlign:"center", headerHozAlign: "center", width:125} + ] + }); + + // 직접입력 타블레이터 + fn_selfmakeTable() + + + // 타뷸레이터 width값 변경 시 위에 select width 값 변경 + var titleArray = ["A","B","C","D","E","F","G"]; + + $tableExcel.on("columnWidth",function(column){ + var titleIndex = titleArray.indexOf(column._column.definition.title); + titleIndex += 1; + if(titleIndex != 0){ + $('.tableExcel .select_adr_hd>div').eq(titleIndex).css('width', column._column.width); + }else{ + $('.tableExcel .select_adr_hd>div').eq(0).css('width', column._column.width + 40); + } + }); + + $tableExcel.on("scrollHorizontal",function(left){ + $(".tableExcel .adr_excel").scrollLeft(left); + }) + + + $(".tableExcel .adr_excel").on("scroll",function(){ + $(".tableExcel .tabulator-tableholder").scrollLeft($(this).scrollLeft()); + }); + + + + + $tableClip.on("columnWidth",function(column){ + var titleIndex = titleArray.indexOf(column._column.definition.title); + titleIndex += 1; + if(titleIndex != 0){ + $('.tableClip .select_adr_hd>div').eq(titleIndex).css('width', column._column.width); + }else{ + $('.tableClip .select_adr_hd>div').eq(0).css('width', column._column.width + 40); + } + }); + + $tableClip.on("scrollHorizontal",function(left){ + $(".tableClip .adr_excel").scrollLeft(left); + }) + + $(".tableClip .adr_excel").on("scroll",function(){ + $(".tableClip .tabulator-tableholder").scrollLeft($(this).scrollLeft()); + }); + + + +}); + + +function fn_ClipMakeTable(){ +} + + +function fn_selfmakeTable(){ + + var tableData = []; + for (var i = 0; i < 1000; i++) { + tableData.push({addrNm: "", addrPhoneNo: "", addrInfo1: "", addrInfo2: "", addrInfo3: "", addrInfo4: "", addrComment: ""}); + } + + // 테이블 초기화 + $tableSelf = new Tabulator("#tabulator_self", { + height: "255px", + width: "100%", + layout: "fitColumns", + clipboardPasteAction: "update", + keybindings: { + "navRight": "tab", // Tab 키를 누르면 오른쪽 셀로 이동 + "navLeft": "shift+tab", + "editNext": false // Tab 키를 누를 때 편집 모드를 종료하지 않도록 설정 + }, + data: tableData, + columns: [ + {formatter: "rowSelection", titleFormatter: "rowSelection", clipboard: false, hozAlign: "center", headerHozAlign: "center", headerSort: false, cellClick: function(e, cell) { + cell.getRow().toggleSelect(); + }}, + {formatter:"rownum", hozAlign:"center" ,title:"No", headerHozAlign:"center", width:40}, + {title:"이름", field:"addrNm", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, + {title:"휴대폰", field:"addrPhoneNo", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input" + , cellEdited:function(cell){ + var currentValue = cell.getValue(); + console.log('cell.getValue() : ', currentValue); + + // 현재 값이 null 또는 undefined가 아니고, 값이 변경된 경우에만 처리 + if (currentValue !== null + && currentValue !== '' + ) { + var newValue = fn_selfUpdataCount(currentValue); + + // 값이 실제로 변경된 경우에만 setValue 호출 + if (currentValue !== newValue) { + cell.setValue(newValue); + } + } + } + }, + {title:"[*1*]", field:"addrInfo1", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, + {title:"[*2*]", field:"addrInfo2", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, + {title:"[*3*]", field:"addrInfo3", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, + {title:"[*4*]", field:"addrInfo4", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"}, + {title:"메모", field:"addrComment", hozAlign:"center", headerHozAlign: "center", width:119, validator:["maxLength:100"], editor:"input"} + ], + navigation: true // 키보드 탐색 활성화 + }); +} + + + + + +