====== Global Callback 가이드 ====== 글로벌 콜백은 아래와 같은 기능을 제공한다. |< 100% 150px - >| ^ 구분 ^ 설명 ^ | 목적 | 각 화면에서 발생하는 이벤트를 전역적으로 처리하기 위한 공통 기능을 글로벌 모듈에서 개발하기 위한 기능을 제공한다. | | 용어 정의 | “콜백”은 특정 이벤트에 개발자가 지정한 이벤트 처리용 함수를 의미한다. | | 콜백 지정 | 해당 실행 파리미터에 콜백 함수 이름을 지정한다.\\ 예: CALLBACK_FOCUSMOVE_KEY: “SYSUtil.CallbackFocusMoveKey” | | 콜백 리턴값 | 콜백 리턴값에 따라 이벤트에 대한 기본 동작 수행 여부를 제어할 수 있다. | | 일반 글로벌 콜백 | 일반 글로벌 콜백은 실행 파라미터에 지정한 경우 발생시 호출되는 콜백이다. | | 이벤트 글로벌 콜백 | 이벤트 글로벌 콜백은 실행 파라미터에 지정한 xFrame5 이벤트에 대해서 호출되는 콜백이다. | | 샘플 소스 및 형식 | “화면”→”템플릿 화면” 팝업 창에서 “/HTML5/COMMON_MODULE/global_callback(글로벌 콜백)”을 선택하면 샘플소스를 확인할 수 있다. | 템플릿 위치: /HTML5/COMMON_MODULE/global_callback 템플릿 파일 * [[xf5projecthome>template/screen/HTML5/COMMON_MODULE/global_callback.xml|global_callback.xml]] * [[xf5projecthome>template/screen/HTML5/COMMON_MODULE/global_callback.js|global_callback.js]] * [[xf5projecthome>template/template.html?xframe_screen_url=/HTML5/COMMON_MODULE/global_callback|새창으로 실행]] ===== 일반 글로벌 콜백 ===== 일반 글로벌 콜백은 특정한 이벤트 발생시 호출되는 콜백으로 지정가능한 내용은 아래와 같다. (참고: 목록은 알파벳 순이다.) 상세 내용은 아래 실행 파라미터별 샘플 소스내 주석을 참조한다. ^ 구분 ^ 내용 ^ | CALLBACK_BROWSER_DOCKING | 전용브라우저가 런타임브라우저와 탭모드로 연동한 경우 탭모드에서 도킹상태가 변경되었을때 호출된다. | | CALLBACK_EXCEL_DOWNLOAD | 엑셀 다운로드 진행시, 다른 방식으로 수행하기 위한 콜백이다. | | CALLBACK_EXCEL_UPLOAD | 엑셀 업로드 진행시, 다른 방식으로 수행하기 위한 콜백이다. | | CALLBACK_FOCUSMOVE_KEY | 키 입력에 의해서 포커스 이동전에 호출되며 콜백 리턴값을 기준으로 포커스 이동을 제어한다. | | CALLBACK_META_DATA | 메타 데이터를 이용하여 컴포넌트 생성시 호출되는 콜백이다. | | CALLBACK_META_LOAD | 메타 데이터 로드시 호출되는 콜백이다. | | CALLBACK_GRID_DOWNLOADEXCEL | 그리드 컨텍스트 메뉴의 “엑셀 저장” 또는 그리드 downloadexcel API 호출시 호출된다. | | CALLBACK_GRID_DRMFILEREAD | 전용 브라우저 환경경서 DRM_APPLY_TYPE 실행 파라미터가 2인 경우, 그리드 DRM 파일 읽기 전/후 호출된다. | | CALLBACK_GRID_EXCEL_LOAD | 그리드에 엑셀 업로드 완료 후 호출된다. | | CALLBACK_GRID_PREKEYDOWN |그리드 키 처리 전에 호출되며, 리턴값을 기준으로 그리드 키 처리 여부를 결정된다. | | CALLBACK_GRID_UPLOADEXCEL | 그리드 컨텍스트 메뉴의 “엑셀 불러오기” 또는 그리드 uploadexcel API 호출시 호출된다. | | CALLBACK_GRID_SAVECSV | 그리드 컨텍스트 메뉴의 “CSV 저장” 또는 그리드 savecsv API 호출시 호출된다. | | CALLBACK_PICKLIST_URL | 픽리스트(공통코드) URL 호출전 호출되며, 조건에 따라 픽리스트 URL 을 변경해야 할 경우에 사용된다. | | CALLBACK_SCREEN_URL | 화면 URL 호출전 호출되며, 조건에 따라 화면 URL 을 변경해야 할 경우에 사용된다. | | CALLBACK_SCRIPT_ERROR | 화면내 스크립트 동작 오류 발생시 호출된다. 스크립트 실행시 try/catch 문으로 검출 가능한 오류에 대해서만 호출된다. | | CALLBACK_VALIDATION_ALERT | 값 검증 Alert 처리 전 호출되며, 값 검증 오류시 처리할 메시지박스 또는 내용을 제어한다. | | CALLBACK_XPLUS_FILEDOWNLOAD | 전용 브라우저환경에서 파일 다운로드 완료시 호출된다. | | CALLBACK_XTRAN_DATALOG | XTRAN_DATALOG를 0이 아닌 값을 설정하고, XTRAN_DATALOG_SHOWTYPE 실행 파라미터를 2로 지정한 경우, XDataSet 통신 데이터 로깅 처리시 호출된다.\\ 자세한 내용은 [[..:studio:script:xtran_log|XTran 로깅 가이드]]를 참조한다. | | CALLBACK_REQUESTTRAN_SENDDATAFUNC | screen requesttran API를 통해 송신 처리 전에 호출된다. | | CALLBACK_REQUESTTRAN_RECVDATAFUNC | screen requesttran API를 통해 수신된 데이터 처리 전에 호출된다. | | CALLBACK_SCREEN_LOADLOG | SCREEN_LOADLOG 실행 파라미터가 true이고, SCREEN_LOADLOG_SHOWTYPE 실행 파라미터를 2로 지정한 경우, 호출된다.\\ 자세한 내용은 [[..:studio:script:screen_loadlog|화면 로딩 로깅 가이드]]를 참조한다. | ==== CALLBACK_BROWSER_DOCKING ==== /** * 실행 파라미터 - CALLBACK_BROWSER_DOCKING * 탭모드에서 도킹상태가 변경되었을때 호출된다. 런타임브라우저와 탭모드로 연동한 경우에 동작함 * @param objScreen 화면 오브젝트 * @param bDocking 도킹 여부 */ function CallbackBrowserDocking(objScreen, bDocking) { console.log("CallbackScriptError> objScreen.url = " + objScreen.getscreenurl()); console.log("CallbackScriptError> bDocking = " + bDocking); } ==== CALLBACK_EXCEL_DOWNLOAD ==== /** * 실행 파라미터 - CALLBACK_EXCEL_DOWNLOAD * 엑셀 다운로드전에 호출되는 콜백이다. * 엑셀 다운로드 진행시, 기본 방식인 xexcel5.jar 이용 방식을 사용하지 않고, 다른 방식으로 수행하기 위한 콜백이다. * (주로 XPlus5를 통한 로컬 방식의 엑셀 다운로드 수행시 사용된다.) * @param objScreen 화면 오브젝트 * @param objGrid 그리드 컴포넌트 오브젝트 * @param objExcelDownloadInfo 엑셀 다운로드 정보 오브젝트 (데이터를 포함하고 있음) */ function CallbackExcelDownload(objScreen, objGrid, objExcelDownloadInfo) { console.log("CallbackExcelDownload> objScreen.url = " + objScreen.getscreenurl()); console.log("CallbackExcelDownload> objGrid.name = " + objGrid.getname()); console.log(objExcelDownloadInfo); } ==== CALLBACK_EXCEL_UPLOAD ==== /** * 실행 파라미터 - CALLBACK_EXCEL_UPLOAD * 엑셀 업로드전에 호출되는 콜백이다. * 엑셀 업로드 진행시, 기본 방식인 xexcel5.jar 이용 방식을 사용하지 않고 다른 방식으로 수행하기 위한 콜백이다. * (주로 XPlus5를 통한 로컬 방식의 엑셀 업로드 수행시 사용된다.) * @param objScreen 화면 오브젝트 * @param objGrid 그리드 컴포넌트 오브젝트 * @param objExcelUploadInfo 엑셀 업로드 정보 오브젝트 (데이터를 포함하고 있음) */ function CallbackExcelUpload(objScreen, objGrid, objExcelUploadInfo) { console.log("CallbackExcelUpload> objScreen.url = " + objScreen.getscreenurl()); console.log("CallbackExcelUpload> objGrid.name = " + objGrid.getname()); console.log(objExcelUploadInfo); } ==== CALLBACK_FOCUSMOVE_KEY ==== /** * 실행 파라미터 - CALLBACK_FOCUSMOVE_KEY * 키보드 입력에 의한 포커스 이동 전 처리 콜백이다. * 포커스 이동 관련 키 정의는 KEYMAP_FOCUS_NEXT 실행 파라미터에서 정의한다. * @param objScreen 화면 오브젝트 * @param objComponent 컴포넌트 오브젝트 * @param nInputType 컴포넌트 input_type * @param strValue 컴포넌트 값 * @param isMoveNext 다음으로 이동 여부, false인 경우, 이전으로 이동 * @param nKeyCode 포커스 이동 발생 키 코드 * @returns * true - 포커스 이동 처리 진행 * false - 포커스 이동 처리 중지 */ function CallbackFocusMoveKey(objScreen, objComponent, nInputType, strValue, isMoveNext, nKeyCode) { console.log("CallbackFocusMoveKey> strValue = " + strValue); // 아래의 샘플은 소스는 키 값이 ENTER이고, 필수 필드이고, 값의 길이가 0인 경우, 포커스 이동 중지하는 예제임 if (nKeyCode == 13) { // 필수 필드이고, 값의 길이가 0인 경우, 포커스 이동 중지 if (nInputType == 1 && strValue.length == 0) { return false; // 포커스 이동 중지 } } // 포커스 이동 진행 return true; } ==== CALLBACK_GRID_DOWNLOADEXCEL ==== /** * 실행 파라미터 - CALLBACK_GRID_DOWNLOADEXCEL * 그리드 "엑셀 저장" 컨텍스트 메뉴 및 downloadexcel API 콜백으로 그리드 엑셀 다운로드 옵션 파라미터를 조정하기 위해 사용한다. * 콜백 함수내에서 파라미터를 설정하여 downloadexcelex API를 반드시 호출해야 함 * @param objScreen 화면 오브젝트 * @param objGrid 그리드 컴포넌트 오브젝트 * @param strFileName 엑셀 파일 이름 */ function CallbackGridDownloadExcel(objScreen, objGrid, strFileName) { var is_save_onerow, is_include_pattern; console.log("CallbackGridDownloadExcel> objScreen.url = " + objScreen.getscreenurl()); console.log("CallbackGridDownloadExcel> objGrid.name = " + objGrid.getname()); console.log("CallbackGridDownloadExcel> strFileName = " + strFileName); is_save_onerow = false; is_include_pattern = true; return objGrid.downloadexcelex(strFileName, true, is_save_onerow, is_include_pattern, true, true, false, true, false, false); } ==== CALLBACK_GRID_DRMFILEREAD ==== /** * 실행 파라미터 - CALLBACK_GRID_DRMFILEREAD * 전용 브라우저 환경경서 DRM_APPLY_TYPE 실행 파라미터가 2인 경우, 그리드 DRM 파일 읽기 전/후 콜백함수 * @param objScreen 화면 오브젝트 * @param objGrid 그리드 컴포넌트 오브젝트 * @param bIsBeforeRead 파일 읽기 전 여부 * @param strFilePath 파일 경로 * @param strCallbackFilePath bIsBeforeRead 파라미터가 true로 호출시 콜백 함수에서 리턴한 경로 * @returns strReturnFilePath bIsBeforeRead 파라미터가 true로 호출된 경우, DRM 해제된 파일 경로 또는 공백문자열 */ function CallbackGridDrmFileRead(objScreen, objGrid, bIsBeforeRead, strFilePath, strCallbackFilePath) { var strReturnFilePath; factory.consoleprint("CallbackGridDrmFileRead> Start"); factory.consoleprint("CallbackGridDrmFileRead> Screen URL = " + objScreen.getscreenurl()); factory.consoleprint("CallbackGridDrmFileRead> Grid Name = " + objGrid.getname()); factory.consoleprint("CallbackGridDrmFileRead> bIsBeforeRead = " + bIsBeforeRead); factory.consoleprint("CallbackGridDrmFileRead> strFilePath = " + strFilePath); factory.consoleprint("CallbackGridDrmFileRead> strCallbackFilePath = " + strCallbackFilePath); if (bIsBeforeRead) { // TODO: // strFilePath 파라미터 값을 기준으로 DRM 해제 처리하고, // DRM 해제된 파일 경로 리턴, 공백 문자열 리턴시 그리드에서 strFilePath 파라미터 값을 사용함 strReturnFilePath = ""; return strReturnFilePath; } else { // TODO: strCallbackFilePath 파라미터에 해당하는 파일 삭제 처리 return; } } ==== CALLBACK_GRID_EXCEL_LOAD ==== /** * 실행 파라미터 - CALLBACK_GRID_EXCEL_LOAD * 엑셀 업로드 완료후 호출되는 콜백이다. * 주로 로드된 데이터를 검증하거나, 부가적인 기능을 처리하기 위한 공통 기능을 구현하기 위해 사용된다. * 그리드의 getexceluploadresultinfo API를 사용하여 엑셀 업로드 상세 결과 정보를 구할 수 있다. * @param objScreen 화면 오브젝트 * @param objGrid 그리드 컴포넌트 오브젝트 */ function CallbackGridExcelLoad(objScreen, objGrid) { var objResult; console.log("CallbackGridExcelLoad> objScreen.url = " + objScreen.getscreenurl()); console.log("CallbackGridExcelLoad> objGrid.name = " + objGrid.getname()); objResult = objGrid.getexceluploadresultinfo(); console.log(objResult); return; } ==== CALLBACK_GRID_PREKEYDOWN ==== /** * 실행 파라미터 - CALLBACK_GRID_PREKEYDOWN * 그리드 키 전처리 콜백이다. * 그리드 단축키 처리를 위한 동작을 주로 구현한다. 반드시 1 또는 0 값을 리턴해야 한다. * @param objScreen 화면 오브젝트 * @param objGrid 그리드 컴포넌트 오브젝트 * @param keycode 키 코드 * @param bctrldown CTLR 키 눌림 상태 여부 * @param bshiftdown SHIFT 키 눌림 상태 여부 * @param baltdown ALT 키 눌림 상태 여부 * @param bnumpadkey 숫자패드 키 여부 * @param beditmode 편집모드 상태에서의 키 이벤트 발생 여부 (undefined/true/false) * @returns * 1 - 그리드에서 키 이벤트 처리 동작을 수행하지 않음 * 0 - 그리드에서 키 이벤트 처리 동작을 수행 */ function CallbackGridPreKeydown(objScreen, objGrid, keycode, bctrldown, bshiftdown, baltdown, bnumpadkey, beditmode) { var row; if (beditmode === undefined) { beditmode = false; } console.log("CallbackGridPreKeydown> objScreen.url = " + objScreen.getscreenurl()); console.log("CallbackGridPreKeydown> objGrid.name = " + objGrid.getname()); console.log("CallbackGridPreKeydown> keycode = " + keycode); console.log("CallbackGridPreKeydown> bctrldown = " + bctrldown); console.log("CallbackGridPreKeydown> bshiftdown = " + bshiftdown); console.log("CallbackGridPreKeydown> baltdown = " + baltdown); console.log("CallbackGridPreKeydown> bnumpadkey = " + bnumpadkey); console.log("CallbackGridPreKeydown> beditmode = " + beditmode); // 아래는 아래의 키 처리를 위한 예시 소스임 // Ctrl + i : 그리드 row 추가 // Ctr + Alt + i : 선택된 row 위에 추가 if (bctrldown && keycode == 73) { if (baltdown) { row = objGrid.getselectrow(); row = row - 1; if (row < 0) { row = 0; } objGrid.insertitemtext(row, 0, ""); } else { objGrid.addrow(); } return 1; } return 0; } ==== CALLBACK_GRID_SAVECSV ==== /** * 실행 파라미터 - CALLBACK_GRID_SAVECSV * 그리드 "CSV 저장" 컨텍스트 메뉴 및 savecsv API 콜백으로 그리드 CSV 다운로드 옵션 파라미터를 조정하기 위해 사용한다. * 콜백 함수내에서 파라미터를 설정하여 savecsvex API를 반드시 호출해야 함 * @param objScreen 화면 오브젝트 * @param objGrid 그리드 컴포넌트 오브젝트 */ function CallbackGridSaveCsv(objScreen, objGrid, strFileName) { var csv_file_name, is_include_pattern, is_include_header, is_close_savewnd, is_open_excel, is_prompt_overwrite, is_show_savewnd, str_data_delimiter, is_check_data, is_include_statdata, is_save_onerow; console.log("CallbackGridSaveCsv> objScreen.url = " + objScreen.getscreenurl()); console.log("CallbackGridSaveCsv> objGrid.name = " + objGrid.getname()); csv_file_name = ""; is_include_pattern = false; is_include_header = true; is_close_savewnd = true; is_open_excel = false; is_prompt_overwrite = true; is_show_savewnd = true; str_data_delimiter = ","; is_check_data = true; is_include_statdata = true; is_save_onerow = true; return objGrid.savecsvex(csv_file_name, is_include_pattern, is_include_header, is_close_savewnd, is_open_excel, is_prompt_overwrite, is_show_savewnd, str_data_delimiter, is_check_data, is_include_statdata, is_save_onerow); } ==== CALLBACK_GRID_UPLOADEXCEL ==== /** * 실행 파라미터 - CALLBACK_GRID_UPLOADEXCEL * 그리드 "엑셀 불러오기" 컨텍스트 메뉴 및 uploadexcel API 콜백으로 그리드 엑셀 업로드 옵션 파라미터를 조장하기 위해 사용한다. * 콜백 함수내에서 파라미터를 설정하여 uploadexcelex API를 반드시 호출해야 함 * @param objScreen 화면 오브젝트 * @param objGrid 그리드 컴포넌트 오브젝트 * @param bAppendMode [옵션] 데이터 Append 모드 (기본값: false) * @param objFile [옵션] 업로드할 엑셀 파일에 대한 File 오브젝트 (기본값: null) * @param strAccept [옵션] 선택 파일 유형 문자열 (기본값: 공백문자열) */ function CallbackGridUploadExcel(objScreen, objGrid, bAppendMode, objFile, strAccept) { var is_save_onerow, is_include_pattern; console.log("CallbackGridUploadExcel> objScreen.url = " + objScreen.getscreenurl()); console.log("CallbackGridUploadExcel> objGrid.name = " + objGrid.getname()); console.log("CallbackGridUploadExcel> bAppendMode = " + bAppendMode); console.log("CallbackGridUploadExcel> strAccept = " + strAccept); return objGrid.uploadexcelex(1, 1, 1, "A", 1, bAppendMode, "", objFile, strAccept, true); } ==== CALLBACK_META_DATA ==== /** * 실행 파라미터 - CALLBACK_META_DATA * 컴포넌트 생성시 메타 처리 콜백 * 자세한 내용은 doc 폴더내 다국어 개발을 위한 가이드 문서를 참조한다. * @param strMetaId 메타 ID * @param objMetaValue 메타 ID에 해당하는 값 * @param strScreenUrl 화면 URL * @param strScreenId 화면 ID * @param nObjectKind 오브젝트 유형 (XFD_OBJKIND_CONTROL/XFD_OBJKIND_SHAPE) * @param nComponentKind 오브젝트 유형 (getcontrolkind, getshapekind) * 또는 XFD_CTRLKIND_TABITEM/XFD_CTRLKIND_GRIDCOLUMNHEAD/XFD_CTRLKIND_GRIDCOLUMNDATA * @param objPropInfo 컴포넌트 속성 정보 오브젝트 (key: 속성명, value: 속성값) * @param strUserLanguage 사용자 실행 환경 언어 * @param strUserCountry 사용자 실행 환경 국가 * @returns * 1 - 메타 정보 처리함 * 0 - 메타 정보 처리 하지 않음(엔진 기본 동작 수행) */ function CallbackMetaData(strMetaId, objMetaValue, strScreenUrl, strScreenId, nObjectKind, nComponentKind, objPropInfo, strUserLanguage, strUserCountry) { if (nObjectKind == XFD_OBJKIND_CONTROL) { switch (nComponentKind) { case XFD_CTRLKIND_HYPERTEXT: case XFD_CTRLKIND_PUSHBUTTON: case XFD_CTRLKIND_CHECKBOX: case XFD_CTRLKIND_RADIOBUTTON: if (objMetaValue["text_or_title"]) { objPropInfo["text"] = objMetaValue["text_or_title"]; } if (objMetaValue["tooltip"]) { objPropInfo["tooltip"] = objMetaValue["tooltip"]; } if (objMetaValue["hint_text"]) { objPropInfo["hint_text"] = objMetaValue["hint_text"]; } if (objMetaValue["description"]) { objPropInfo["description"] = objMetaValue["description"]; } break; case XFD_CTRLKIND_FIELD: case XFD_CTRLKIND_COMBOBOX: case XFD_CTRLKIND_DATE: if (objMetaValue["tooltip"]) { objPropInfo["text"] = objMetaValue["tooltip"]; } if (objMetaValue["hint_text"]) { objPropInfo["hint_text"] = objMetaValue["hint_text"]; } if (objMetaValue["description"]) { objPropInfo["description"] = objMetaValue["description"]; } break; case XFD_CTRLKIND_MULTILINE: if (objMetaValue["tooltip"]) { objPropInfo["tooltip"] = objMetaValue["tooltip"]; } if (objMetaValue["description"]) { objPropInfo["description"] = objMetaValue["description"]; } break; case XFD_CTRLKIND_GRID: if (objMetaValue["description"]) { objPropInfo["description"] = objMetaValue["description"]; } break; case XFD_CTRLKIND_TABITEM: if (objMetaValue["text_or_title"]) { objPropInfo["title"] = objMetaValue["text_or_title"]; } if (objMetaValue["tooltip"]) { objPropInfo["tooltip"] = objMetaValue["tooltip"]; } if (objMetaValue["description"]) { objPropInfo["description"] = objMetaValue["description"]; } break; case XFD_CTRLKIND_GRIDCOLUMNHEAD: if (objMetaValue["text_or_title"]) { objPropInfo["title"] = objMetaValue["text_or_title"]; } if (objMetaValue["tooltip"]) { objPropInfo["tooltip"] = objMetaValue["tooltip"]; } break; case XFD_CTRLKIND_GRIDCOLUMNDATA: if (objMetaValue["hint_text"]) { objPropInfo["hint_text"] = objMetaValue["hint_text"]; } if (objMetaValue["description"]) { objPropInfo["description"] = objMetaValue["description"]; } break; default: break; } } else if (nObjectKind == XFD_OBJKIND_SHAPE) { switch (nComponentKind) { case XFD_SHAPEKIND_CAPTION: if (objMetaValue["text_or_title"]) { prop_info["text"] = objMetaValue["text_or_title"]; } break; default: break; } } return 1; } ==== CALLBACK_META_LOAD ==== /** * 실행 파라미터 - CALLBACK_META_LOAD * 메타 데이터 로드시 호출되는 콜백 * @param strMetaUrl 메타 URL * @param strMetaId 메타 ID * @param strMetaValue 메타 ID에 해당하는 값 * @param strUserLanguage 사용자 실행 환경 언어 * @param strUserCountry 사용자 실행 환경 국가 * @returns 메타 정보 오브젝트 */ function CallbackMetaLoad(strMetaUrl, strMetaId, strMetaValue, strUserLanguage, strUserCountry) { var meta_value_item_arr, meta_value_obj; // text/title, tooltip, hint_text, description으로 되어 있는 경우 if (strMetaValue.indexOf("^$;") != -1) { meta_value_item_arr = strMetaValue.split("^$;"); } else { meta_value_item_arr = strMetaValue.split(";"); } meta_value_obj = {}; // undefined 및 공백문자열이 아닌 경우 true if (meta_value_item_arr[0]) { meta_value_obj["text_or_title"] = meta_value_item_arr[0]; } if (meta_value_item_arr[1]) { meta_value_obj["tooltip"] = meta_value_item_arr[1]; } if (meta_value_item_arr[2]) { meta_value_obj["hint_text"] = meta_value_item_arr[2]; } if (meta_value_item_arr[3]) { meta_value_obj["description"] = meta_value_item_arr[3]; } return meta_value_obj; } ==== CALLBACK_PICKLIST_URL ==== /** * 실행 파라미터 - CALLBACK_PICKLIST_URL * 코드 파일을 로드하기 전에 코드 파일 URL에 대한 전 처리 콜백이다. * 조건에 따라 코드 파일 URL을 변경해야 할 경우에 사용된다. * @param strPicklistUrl 로드할 픽리스트 URL * @returns * strReturnPicklistUrl - 로드할 픽리스트 URL (1글자 이상의 문자열) * undefined | '' - 화면 URL 변경없이 사용 */ function CallbackPicklistUrl(strPicklistUrl) { console.log("strPicklistUrl = " + strPicklistUrl); return; } ==== CALLBACK_SCREEN_URL ==== /** * 실행 파라미터 - CALLBACK_SCREEN_URL * 화면 파일을 로드하기 전에 화면 파일 URL에 대한 전 처리 콜백이다. * 조건에 따라 화면 파일 URL을 변경해야 할 경우에 사용된다. * @param strScreenUrl 로드할 화면 URL * @param nLoadType 화면 URL을 로드 하는 유형 (0: tab link screen/portlet, 1:load popup, 2:load menu, 3:load portlet) * @param objParentScreen 로드할 화면의 부모 화면 인스턴스 (null 또는 undefined 값일 수 있음) * @param strParentScreenUrl 로드할 화면의 부모 화면 URL ("" 또는 부모 화면 URL) * @param objParentComponent 로드할 화면이 표시될 컴포넌트 (null 또는 부모 컴포넌트 오브젝트) * @returns * strReturnScreenUrl 로드할 화면 URL (1글자 이상의 문자열) * undefined | '' 화면 URL 변경없이 사용 */ function CallbackScreenUrl(strScreenUrl, nLoadType, strParentScreenUrl, objParentScreen, objParentComponent) { console.log("CallbackScreenUrl> strScreenUrl = " + strScreenUrl); console.log("CallbackScreenUrl> nLoadType = " + nLoadType); console.log("CallbackScreenUrl> strParentScreenUrl = " + strParentScreenUrl); if (objParentScreen !== undefined && objParentScreen !== null) { console.log("CallbackScreenUrl> strParentScreenId = " + objParentScreen.getscreenid()); } if (objParentComponent !== undefined && objParentComponent !== null) { console.log("CallbackScreenUrl> strParentComponentName = " + objParentComponent.getname()); } return; } ==== CALLBACK_SCRIPT_ERROR ==== /** * 실행 파라미터 - CALLBACK_SCRIPT_ERROR * 스크립트 오류 처리 콜백 * 스크립트 실행시 try/catch 문으로 검출 가능한 오류에 대해서만 호출됨 * @param objScreen 화면 오브젝트 * @param strEventName 이벤트 이름 * @param strFuncName 함수 이름 * @param strErrorName 에러 이름 * @param strErrMsg 에러 메시지 * @returns * 1 - 엔진에서 스크립트 오류 메시지 박스를 표시하지 않음 * 그외 - 엔진에서 오류 메시지 박스 표시 */ function CallbackScriptError(objScreen, strEventName, strFuncName, strErrorName, strErrMsg) { console.log("CallbackScriptError> objScreen.url = " + objScreen.getscreenurl()); console.log("CallbackScriptError> strEventName = " + strEventName); console.log("CallbackScriptError> strFuncName = " + strFuncName); console.log("CallbackScriptError> strErrorName = " + strErrorName); console.log("CallbackScriptError> strErrMsg = " + strErrMsg); // 1 - 엔진에서 스크립트 오류 메시지 박스를 표시하지 않음, 그외 - 엔진에서 오류 메시지 박스 표시 // return 1; } ==== CALLBACK_VALIDATION_ALERT ==== /** * 실행 파라미터 - CALLBACK_VALIDATION_ALERT * 값 검증 Alert 처리 전 호출되며, 값 검증 오류시 처리할 메시지박스 또는 내용을 제어한다. * @param objScreen 화면 오브젝트 * @param objComponent 컴포넌트 오브젝트 * @param strComponentValue 컴포넌트 값 * @param strValidType 검증 유형 이름 * 'required': 필수 항목에 값이 없는 경우 * 'length_min': 최소 길이보다 짧은 경우 * 'length_max': 최소 길이보다 긴 경우 * 'value_min': 최소 값보다 작은 경우 * 'value_max': 최대 값보다 큰 경우 * 'invalid_number': 값이 숫자가 아닌 경우 * 'invalid_code': 유효한 코드 값이 아닌 경우 * 'invalid_date': 유효하지 않는 날짜 * 'invalid_keyin': 유효하지 않는 글자 입력 * 'move_before': 첫번재 페이지 이전으로 이동시 * 'move_after': 마지막 페이지 이후로 이동시 * 'date_before': 유효기간 이전 날짜 선택시 * 'date_after': 유효기간 이후 날짜 선택시 * 'date_saturday': 토요일을 선택한 경우 * 'date_sunday': 일요일을 선택한 경우 * 'date_holiday': 공휴일을 선택한 경우 * 'date_unknown': 알 수 없는 날짜 관련 오류 * @param nEventType 검증 이벤트 유형 (2: API, 5: 포커스아웃(BLUR)) * @returns * undefined 기본 값 검증 메시지 박스 표시 (예시: 단순 return; 호출시) * objRetInfo 메시지 박스 제어용 오브젝트로 아래와 같은 속성을 가짐 * { * show_alert: alert 표시 여부 (true(기본값)/false) * alert_title: alert 박스 타이틀 (변경하지 않을 경우, 공백문자열 지정) * alert_message: alert 메시지 (변경하기 않을 경우, 공백 문자열 지정) * } */ function CallbackValidationAlert(objScreen, objComponent, strComponentValue, strValidType) { var i, nObjectKind, objRetetInfo; objRetInfo = { show_alert: true, alert_title: "", alert_message: "" }; console.log("CallbackValidationAlert> Screen URL = [" + objScreen.getscreenurl() + "]"); console.log("CallbackValidationAlert> Component Name = [" + objComponent.getname() + "]"); console.log("CallbackValidationAlert> strComponentValue = [" + strComponentValue + "]"); console.log("CallbackValidationAlert> strValidType = [" + strValidType + "]"); console.log("CallbackValidationAlert> nEventType = [" + nEventType + "]"); // 아래 예시 소스는 유효하지 않은 날짜에 대한 값 검증인 경우, 값을 지우는 예시 소스입니다. if (strValidType == "invalid_date") { objComponent.settext(""); } return objRetInfo; } ==== CALLBACK_XPLUS_FILEDOWNLOAD ==== /** * 실행 파라미터 - CALLBACK_XPLUS_FILEDOWNLOAD * 전용 브라우저환경에서 파일 다운로드 완료 콜백함수 * @param strFilePath 파일 경로 */ function CallbackXPlusFileDownload(strFilePath) { factory.consoleprint("CallbackXPlusFileDownload> Start"); factory.consoleprint("CallbackXPlusFileDownload> strFilePath = " + strFilePath); } ==== CALLBACK_REQUESTTRAN_SENDDATAFUNC ==== /** * 실행 파라미터 - CALLBACK_REQUESTTRAN_SENDDATAFUNC * 화면 requesttran 송신 데이터 처리 콜백 * 화면 requesttran API 함수 호출시 AJAX로 데이터를 송신하기 전에 호출됨 * 화면내에서 settranmaptraninfo 함수를 통해서 송신 데이터 및 부가 정보를 설정해야 함 * @param objScreen 화면 오브젝트 * @param strTranMapId 트랜맵 ID */ function CallbackTranSendDataFunc(objScreen, strTranMapId) { var send_data_str, optionInfo; console.log(this); console.log("CallbackTranSendDataFunc> Screen URL = " + objScreen.getscreenurl()); console.log("CallbackTranSendDataFunc> strTranMapId = " + strTranMapId); // TODO: strTranMapId에 대한 송신 데이터 문자열 생성 send_data_str = "senddata_" + strTranMapId; optionInfo = { tran_url: "terminal/jsp/" + strTranMapId + ".jsp", is_async: true, is_encode_url: true, http_header_str: "", timeout: 0, http_method: "POST" }; // requesttran 송신 데이터 및 옵션 설정 objScreen.settranmaptraninfo(strTranMapId, send_data_str, optionInfo); } ==== CALLBACK_REQUESTTRAN_RECVDATAFUNC ==== /** * 실행 파라미터 - CALLBACK_REQUESTTRAN_RECVDATAFUNC * 화면 requesttran 수신 데이터 처리 콜백 * 화면 on_trancomplete 이벤트가 호출된기 전에 호출됨 * @param objScreen 화면 오브젝트 * @param strTranMapId 트랜맵 ID * @param result 처리 결과 (1: 성공, 그외 오류) * @param recv_userheader 서버에서 수신된 사용자 정의 데이터 (기본값: "") * @param recv_code 서버에서 수신된 처리 결과 코드 (기본값: "") * @param recv_msg 서버에서 수신된 처리 결과 메시지 (기본값: "") * @param recv_data 서버에서 수신된 데이터 */ function CallbackTranRecvDataFunc(objScreen, strTranMapId, result, recv_userheader, recv_code, recv_msg, recv_data) { var tran_url, is_async, is_encode_url, http_header_str, send_data_str, timeout, http_method; console.log(this); console.log("CallbackTranRecvDataFunc> Screen URL = " + objScreen.getscreenurl()); console.log("CallbackTranRecvDataFunc> strTranMapId = " + strTranMapId); console.log("CallbackTranRecvDataFunc> result = " + result); console.log("CallbackTranRecvDataFunc> recv_userheader = " + recv_userheader); console.log("CallbackTranRecvDataFunc> recv_code = " + recv_code); console.log("CallbackTranRecvDataFunc> recv_msg = " + recv_msg); console.log("CallbackTranRecvDataFunc> recv_data = " + recv_data); // TODO: recv_data 파라미터 값을 기준으로 수신 데이터를 파싱하여 화면에 표시 처리 } ===== 이벤트 글로벌 콜백 ===== 이벤트 글로벌 콜백은 이벤트 이름을 지정하여 해당 이벤트 발생시 지정된 콜백 이전에 호출되는 콜백이다. |< 100% 250px - >| ^ 구분 ^ 내용 ^ | CALLBACK_EVENT_NAME | * 콜백 호출 대상 이벤트 이름 배열을 지정한다. * 예시: ['on_fileloadstart', 'on_fileload'] | | CALLBACK_EVENT_BEFORE | CALLBACK_EVENT_NAME 에 지정된 이벤트 발생시 호출될 함수 이름 | ==== 이벤트 글로벌 콜백 예시 ==== /** * 실행 파라미터 - CALLBACK_EVENT_BEFORE, CALLBACK_EVENT_NAME * CALLBACK_EVENT_NAME 실행 파라미터에 지정된 이벤트 발생시, 화면에서 지정한 이벤트 콜백이 호출되기 전에 호출된다. * 콜백 함수 호출시 전달되는 파라미터는 화면, 컴포넌트, 이벤트 이름, 원래 이벤트 콜백 파라미터들(가변적임)로 구성된다. * 이벤트에 따라서 콜백 함수 개발시 파라미터로 전달되는 파라미터가 가변적이기 때문에, * 함수 내에서 arguments 오브젝트를 통해서 가변 파라미터를 처리해야 한다. * arguments 오브젝트는 자바스크립트 언어에서 제공하는 기본 오브젝트로, * 함수에 전달된 파라미터에 접근하기 위한 기능을 수행하는 특별한 배열과 비슷한 기능을 제공하는 오브젝트이다. * @param objScreen 화면 오브젝트 * @param objComponent 컴포넌트 오브젝트 * @param strEventName 이벤트 이름 * @param ... 이벤트 발생시 전달되는 파라미터들 * @returns * 함수의 리턴값이 있는 경우, 화면에 지정한 이벤트 콜백이 호출되지 않고, 리턴값이 엔진에 전달된다. */ function CallbackEventBefore(objScreen, objComponent, strEventName) { var i, argument_count; console.log("CallbackEventBefore> Screen URL = [" + objScreen.getscreenurl() + "]"); // 화면인 경우, 화면 ID console.log("CallbackEventBefore> Component Name = [" + objComponent.getname() + "]"); console.log("CallbackEventBefore> strEventName = [" + strEventName + "]"); console.log("CallbackEventBefore> object_kind = [" + objComponent.getobjectkind() + "]"); // 기본 파라미터 이외에 실제 이벤트 콜백 함수 파라미터를 arguments 오브젝트를 이용하여 콘솔에 출력 argument_count = arguments.length; for (i = 3; i < argument_count; i++) { console.log("CallbackEventBefore> arguments[" + i + "] = " + arguments[i]); } } ==== 이벤트 글로벌 콜백 특징 ==== 이벤트 글로벌 콜백은 아래와 같은 특징을 가진다. |< 100% 150px - >| ^ 구분 ^ 내용 ^ | 콜백 파리미터 | * 콜백 함수 호출시 전달되는 파라미터는 화면, 컴포넌트, 이벤트 이름, 원래 이벤트 콜백 파라미터로 구성된다. * 따라서 콜백 함수 개발시 파라미터로 전달되는 파라미터가 가변적이기 때문에, 함수 내에서 arguments 오브젝트를 통해서 가변 파라미터를 처리해야한다. * arguments 오브젝트는 함수에 전달된 파라미터에 접근하기 위한 기능을 수행하는 특별한 오브젝트이며 * 자세한 설명은 “https://developer.mozilla.org”에서 arguments 를 검색하여 참고한다. | | 콜백 함수 호출 | 이벤트 글로벌 콜백은 해당 이벤트에 대한 콜백 지정 여부와 상관없이 이벤트에 지정된 콜백이 호출되기 이전에 호출됨 | | 적용 대상 | * 이벤트 이름을 기준으로 처리되기 때문에, 모든 화면에 적용된다. * //**성능에 영향을 줄 수 있는 이벤트 (예: on_keydown)에 대해서는 글로벌콜백 함수내 동작 시간 부분에 주의해야 한다.**// |