2024년 4분기 신규기능(Ver 8.2.0.3~ Ver 8.2.0.14)
Ver 8.2.0.3-20241010-14
1. (Method)doSave, getSaveJson, getSaveString 등의 저장 함수를 호출할 때, 사용자가 저장함수에서 설정한 인자(saveMode, col, validRequired)에 따라 유효성 검사를 진행하는 (Cfg)ValidCheck 추가
Cfg:{ ValidCheck: true // 저장 함수 호출 시 유효성 검사 실행 } |
2. 유효성 검사 통과 실패 시 띄울 메세지를 설정하는 (Cfg)ValidateMessage 추가
Cfg:{ ValidateMessage : "유효성 검사 실패!" // 유효성 검사 통과 실패 시 설정한 문구를 출력 } |
[실행 결과]
3. (Method)getRowValue 에 saveAttr 인자 추가
Row 내부에 기존에 선언한 컬럼값이 아닌 다른 데이터가 있는 경우 saveAttr:"추출할데이터key값" 을 선언하면 해당 데이터도 getRowValue 에서 리턴됩니다.
여러 개를 추출하고자 하는 경우 "," 를 구분자로 작성하면 됩니다.
// 현재 포커스 하고 있는 row의 값들을 가져오는데, // 선언한 컬럼은 아니지만 Test, abc 라는 이름의 데이터도 들고오겠다. sheet.getRowValue({row: sheet.getFocusedRow(), saveAttr:"Test,abc"}) |
Ver 8.2.0.4-20241017-14
1. 동적으로 Foot 과 Head를 생성하는 (Method)showFixedRows 추가
메소드의 인자로 Head,Foot 의 object 객체가 들어갑니다.
[사용 예시]
// 1. Foot 행 1개 생성 var obj1 = {Kind : 'Foot', ... }; sheet.showFixedRows(obj1); // 2. Foot 행 2개, Head 행 1개 생성 sheet.showFixedRows([ { Kind:'Foot', TextData: { 'Value' : '커스텀 Foot행1', 'TextColor': 'green', 'Span': 4 } }, { Kind:'Head', TextData: { 'Value' : '커스텀 Head행', 'TextColor': 'red', 'Span': 3, 'Color': 'yellow' } }, { Kind:'Foot', Color: 'blue' } ]); |
[예시 2번 실행 결과]
2. 동적으로 Formula를 추가하는 (Method)addFormula 추가
기존에는 동적으로 Formula를 추가하는 동작(컬럼을 추가하거나 등)을 설정하는 것이 복잡하고, 가끔은 불가능했습니다.
addFormula 를 사용 시 CanFormula 가 자동으로 true 로 설정되고, CalcOrder에 설정한 Formula 가 순차적으로 추가됩니다.
[사용 예시]
// 1. Row에 colorFormula 추가 var colorFormula = function (param) { if (param.Row && param.Row["IntData"] === 0) { return "#FFD9FA" } } // 데이터 행의 배경색을 조건에 따라 변경 sheet.addFormula(colorFormula, "", "", "Color"); // 2. Col 에 Formula 추가 var Formula = function (param) { if (param.Row["IntData"] > 100) { return true } else { return false } } // IntData의 값에 따라 체크박스 열의 체크 변경 sheet.addFormula(Formula, "", "CheckData", "", true); |
Ver 8.2.0.5-20241024-13
1. (Method)exportData 에 헤더만 머지하는 onlyHeaderMerge 옵션 추가
onlyHeaderMerge : 1(true) 로 설정 시, 시트의 데이터 영역의 머지를 강제로 제한하고 헤더 영역의 머지만을 엑셀에 반영합니다. 주의할 점은 merge 인자가 1로 설정되어야합니다.
(Method)down2Excel 의 onlyHeaderMerge 인자와 동일한 기능을 합니다.
[사용 예시]
sheet.exportData({ merge: 1, // 시트 머지 반영 onlyHeaderMerge: 1 // 헤더만 머지 }); |
[onlyHeaderMerge:0]
[onlyHeaderMerge:1]
2. 신규행 추가 시 Enum 의 값이 자동적으로 세팅되는 (Cfg)AutoSelectFirstEnum 추가
기존에 Enum 컬럼은 행 추가 시 값을 설정하지 않으면 빈값으로 추가되었습니다.
AutoSelectFirstEnum :1 설정 시 해당 셀에 값이 없다면 첫 번째 데이터로 자동 선택됩니다.
[기존]
[AutoSelectFirstEnum : 1]
Ver 8.2.0.6-20241031-13
Common.js New
1. 마우스 우클릭으로 출력되는 기본 컨텍스트 메뉴에 전체 체크, 전체 체크 해제 기능 추가
ibsheet-common.js Ver 1.0.12-20241031-13 이상 버전이 필요합니다.
ibsheet.js New
기존에는 sort 정보를 서버로 보내지 않고, 보여지는 화면에서 sort 가 이루어졌습니다.
ScrollPagingServerSort : 1 설정 시 sort 정보를 서버로 보내, 받은 응답 데이터를 출력합니다.
자세한 과정은 아래와 같습니다.
sort 정보를 담아 서버로 전송 -> sort 정보로 DB에서 쿼리 실행 -> 실행된 쿼리를 js로 보냄(재조회와 비슷한 과정)
[서버로 보내지는 파라미터]
Ver 8.2.0.7-20241107-15
1. 유효성 검사 실행 시, 사용자가 설정한대로 유효성 검사를 실행할 수 있는 onValidate 이벤트 추가
유효성 검사 실행 시 발생하는 onValidate 이벤트가 추가되었습니다.
해당 이벤트 내부에서 다른 컬럼 조건에 따라 유효성 검사를 다르게 하는 등의 작업을 할 수 있습니다.
이벤트 내부에서 false 를 리턴하면 유효성 검사를 통과합니다.
[사용 예시]
event: { onValidate: function(evtParam) { // 컬럼이 텍스트 데이터면 유효성 검사 뛰어넘기 if(evtParam.col != "TextData") return false;
// 앞 컬럼 가져오기 var prevCol = sheet.getPrevCol(evtParam.col); // 앞 컬럼 값이 100이 넘는다면 if(evtParam.row[prevCol] >= 100) { // 뒷 컬럼에 유효성 검사 실패 시 뜨는 툴팁을 넣고 evtParam.row[evtParam.col + "ValidationError"] = "정수(Int)컬럼의 값이 100보다 큽니다."; // 유효성 검사에 걸리게 하기 return true; } } } |
2. (Method)saveCurrentInfo 호출 시 시트 아이디를 대신하여 커스텀 아이디를 설정하는 (Cfg)StorageKeyId 기능 추가
saveCurrentInfo 메소드를 통해 시트의 정보를 저장하는 경우 현재 시트의 id를 기준으로 저장이 됩니다. 따라서 시트의 이름을 random 하게 생성하는 경우 saveCurrentInfo 자체를 사용하기가 불가능했습니다.
이를 보완하기 위해 (Cfg)StorageKeyId 가 추가되었습니다.
(Cfg)StorageKeyId :"원하는아이디" 를 설정하면 saveCurrentInfo 시 지정한 아이디로 저장이 됩니다.
[사용 예시]
Cfg:{ ... // 스토리지에 시트id 가 아닌 StorageKeyIdTest 로 저장 StorageKeyId: "StorageKeyIdTest", ... }, ... |
[saveCurrentInfo 로 저장 결과]
Ver 8.2.0.9-20241121-14
1.Type:Enum 의 표시 포맷을 지정할 수 있는 (Col)EnumFormat 추가
Enum 에 표시되는 포맷을 자유롭게 지정할 수 있는 (Col)EnumFormat 이 추가되었습니다.
function 으로 지정할 땐 param으로 Enum 에 현재 선택된 value 값이 들어옵니다.
[사용 예시]
{ ... Type: "Enum", Enum: "|a|b|c", EnumKeys: "|01|02|03", EnumFormat: function (param) { // ; 가 없을 땐(0~1 건 선택되었을 땐) if (param.indexOf(";") == -1 || param == " ") { // 해당 값을 그대로 return return param; } // 여러 건 선택된 경우 valArr 배열에 넣기 var valArr = param.split(";"); // 현재 선택된 개수 구함 var length = valArr.length - 1 + ""; // 'a;b'로 여러 값이 선택된 경우, 'a 외 1건'과 같은 형식으로 표시한다. return valArr[0] + " 외 " + length + "건"; }, Range: 1 ... } |
Ver 8.2.0.11-20241205-15
1.(Method)exportData 에 숨겨진 컬럼을 엑셀 숨김 처리하여 다운로드하는 hiddenColumn 인자 추가
(Method)down2Excel 에는 Visible:0 인 컬럼을 엑셀 다운 시 엑셀 숨김 처리(접힘)하여 다운 받는 hiddenColumn 인자가 있습니다.
exportData 에서도 동일한 기능을 사용할 수 있도록 hiddenColumn 인자를 추가했습니다.
주의하실 점은 downCols 인자와 함께 사용하실 수 없습니다.
[사용 예시]
sheet.exportData({ hiddenColumn : true }) |
[위 코드 사용 예시]
붉은 네모 안의 컬럼처럼 숨김 처리하여 다운로드 됩니다.
Ver 8.2.0.12-20241212-13
1.열 추가 동작이 랜더링까지 완료 된 후 호출되는 onAfterColAdd
이벤트 추가
onAfterColAdd 이벤트는 시트에 새로운 열이 추가되어 렌더링 된 후 호출되는 이벤트입니다.
[사용 예시]
options.Events = { onAfterColAdd:function(evtParam){ console.log(evtParam.col); } } |
2. 상위 헤더가 병합된 경우 하위 헤더 열의 이동을 병합된 영역 내에서만 이동할 수 있는 (Cfg) CanColMove: 2
추가
Ver 8.2.0.13-20241219-13
1. Required
를 설정한 열의 필수표시를 보여주지 않는 (Cfg)RequiredPosition: None
추가
(Col)Required 를 설정하면 무조건 해당 컬럼 헤더에 필수 입력 표시(별표)가 출력되고 해당 표시를 없애기 위해서는 무조건 CSS파일을 수정해야했었습니다.
CSS 수정보다 간단하게 변경을 위해 RequiredPosition 속성에 "None" 설정을 추가해 좌,우측 외에도 CSS 파일 수정 없이 해당 표시를 없앨 수 있습니다.
[사용 예시]
Cfg : { RequiredPositon: "None" } |
[기존]
[RequiredPosion:"None" 적용 후]
Ver 8.2.0.14-20241226-1443
1. (Method)importData 를 통해 데이터를 로드할 때, 로드할 위치를 정할 수 있는 next 인자 추가
기존에는 append 인자를 통해서 기존 데이터 밑에 추가할 지 말 지를 결정했습니다.
(Method)loadSearchData 의 next 인자처럼 해당 인자에는 데이터 로우 객체가 들어오고,
row 객체 설정 시 설정된 row 위에서부터 데이터가 append 됩니다.
해당 인자 사용 시 append 인자는 무조건 true 여야 합니다.
[사용 예시]
var param = {append:1, next:sheet.getFocusedRow()}; sheet.importData(param); |
2. Color 속성을 별도로 지정한 경우 상태 색상을 무시하고 해당 색상을 그대로 적용하는 NoColor:3 추가
[NoColor:3 편집 전 - Color 로 지정한 색상이 들어가있음]
[NoColor:3 편집 후 - 수정 상태가 되었지만 Color 지정한 색상이 들어가있음]
3. (Method)setAutoMerge 에 고정 영역의 머지를 설정하는 headMerge, footMerge, headPrevColumnMerge, footPrevColumnMerge 인자 추가
sheet.setAutoMerge({ dataMerge:1, headerMerge:2, headMerge:0, footMerge:4 }); |
4. (Method)
setAutoMergeCancel 의 mode 인자에 고정 영역을 선택하는 "Head", "Foot" 옵션 추가
각 옵션의 설명은 아래와 같습니다.
"Head"
: Head 영역에 있는 병합 해제"Foot"
: Foot 영역에 있는 병합 해제
[사용 예시]
sheet.setAutoMergeCancel( {mode:"Head"} ) |