//////////////////////////////////////////////////////////////////////////////////////// //Page 전역 변수 //////////////////////////////////////////////////////////////////////////////////////// var selectId; // 제품 아이디 var selectName; // 제품 이름 var selectedIndex; // 데이터테이블 선택한 인덱스 var selectedPage; // 데이터테이블 선택한 인덱스 var selectVersion; // 선택한 버전 아이디 var dataTableRef; // 데이터테이블 참조 변수 //////////////////////////////////////////////////////////////////////////////////////// //Document Ready //////////////////////////////////////////////////////////////////////////////////////// function execDocReady() { var pluginGroups = [ [ "../reference/light-blue/lib/vendor/jquery.ui.widget.js", "../reference/light-blue/lib/vendor/http_blueimp.github.io_JavaScript-Templates_js_tmpl.js", "../reference/light-blue/lib/vendor/http_blueimp.github.io_JavaScript-Load-Image_js_load-image.js", "../reference/light-blue/lib/vendor/http_blueimp.github.io_JavaScript-Canvas-to-Blob_js_canvas-to-blob.js", "../reference/light-blue/lib/jquery.iframe-transport.js", "../reference/light-blue/lib/jquery.fileupload.js", "../reference/light-blue/lib/jquery.fileupload-fp.js", "../reference/light-blue/lib/jquery.fileupload-ui.js" ], [ "../reference/jquery-plugins/select2-4.0.2/dist/css/select2_lightblue4.css", "../reference/jquery-plugins/lou-multi-select-0.9.12/css/multiselect-lightblue4.css", "../reference/jquery-plugins/multiple-select-1.5.2/dist/multiple-select-bluelight.css", "../reference/jquery-plugins/select2-4.0.2/dist/js/select2.min.js", "../reference/jquery-plugins/lou-multi-select-0.9.12/js/jquery.quicksearch.js", "../reference/jquery-plugins/lou-multi-select-0.9.12/js/jquery.multi-select.js", "../reference/jquery-plugins/multiple-select-1.5.2/dist/multiple-select.min.js" ], [ "../reference/jquery-plugins/datetimepicker-2.5.20/build/jquery.datetimepicker.min.css", "../reference/light-blue/lib/bootstrap-datepicker.js", "../reference/jquery-plugins/datetimepicker-2.5.20/build/jquery.datetimepicker.full.min.js", "../reference/lightblue4/docs/lib/widgster/widgster.js", "../reference/lightblue4/docs/lib/slimScroll/jquery.slimscroll.min.js", "../reference/lightblue4/docs/lib/jquery.sparkline/index.js", "../reference/lightblue4/docs/js/charts.js" ], [ "../reference/jquery-plugins/dataTables-1.10.16/media/css/jquery.dataTables_lightblue4.css", "../reference/jquery-plugins/dataTables-1.10.16/extensions/Responsive/css/responsive.dataTables_lightblue4.css", "../reference/jquery-plugins/dataTables-1.10.16/extensions/Select/css/select.dataTables_lightblue4.css", "../reference/jquery-plugins/dataTables-1.10.16/media/js/jquery.dataTables.min.js", "../reference/jquery-plugins/dataTables-1.10.16/extensions/Responsive/js/dataTables.responsive.min.js", "../reference/jquery-plugins/dataTables-1.10.16/extensions/Select/js/dataTables.select.min.js", "../reference/jquery-plugins/dataTables-1.10.16/extensions/RowGroup/js/dataTables.rowsGroup.min.js", "../reference/jquery-plugins/dataTables-1.10.16/extensions/Buttons/js/dataTables.buttons.min.js", "../reference/jquery-plugins/dataTables-1.10.16/extensions/Buttons/js/buttons.html5.js", "../reference/jquery-plugins/dataTables-1.10.16/extensions/Buttons/js/buttons.print.js", "../reference/jquery-plugins/dataTables-1.10.16/extensions/Buttons/js/jszip.min.js", // timezone-picker "../reference/jquery-plugins/kevalbhatt-timezone-picker-2.0.0/dist/timezone-picker.min.js", "../reference/jquery-plugins/kevalbhatt-timezone-picker-2.0.0/dist/styles/timezone-picker.css", //날짜 검색 "../reference/light-blue/lib/bootstrap-datepicker.js", "../reference/jquery-plugins/datetimepicker-2.5.20/build/jquery.datetimepicker.min.css", "../reference/jquery-plugins/datetimepicker-2.5.20/build/jquery.datetimepicker.full.min.js" ] // 추가적인 플러그인 그룹들을 이곳에 추가하면 됩니다. ]; loadPluginGroupsParallelAndSequential(pluginGroups) .then(function () { console.log("모든 플러그인 로드 완료"); //vfs_fonts 파일이 커서 defer 처리 함. setTimeout(function () { var script = document.createElement("script"); script.src = "../reference/jquery-plugins/dataTables-1.10.16/extensions/Buttons/js/vfs_fonts.js"; script.defer = true; // defer 속성 설정 document.head.appendChild(script); }, 5000); // 5초 후에 실행됩니다. //pdfmake 파일이 커서 defer 처리 함. setTimeout(function () { var script = document.createElement("script"); script.src = "../reference/jquery-plugins/dataTables-1.10.16/extensions/Buttons/js/pdfmake.min.js"; script.defer = true; // defer 속성 설정 document.head.appendChild(script); }, 5000); // 5초 후에 실행됩니다. // 사이드 메뉴 색상 설정 $(".widget").widgster(); setSideMenu("sidebar_menu_system", "sidebar_menu_system_info"); // TimeZonePicker 그리기 $("#globe").timezonePicker({ // initialValue: "Asia/Seoul", defaultValue: { value: "Asia/Seoul", attribute: "timezone" }, hoverText: function(e, data){ if (data.offset < 0 ) { return (data.timezone + " (" + data.zonename + ", UTC"+data.offset+")"); } else { return (data.timezone + " (" + data.zonename + ", UTC+"+data.offset+")"); } }, quickLink: [{}], selectBox: true, showHoverText: true }); $(".quick-link").css("display","none"); excludeTimeZone(); $("#globe .select2-selection__rendered").text("Asia/Seoul (KST, UTC+9)"); timeZonePickerEvent(); dateTimePicker(); }) .catch(function (error) { console.error("플러그인 로드 중 오류 발생"); console.log(error); }); } //////////////////////////////////////////////////////////////////////////////////////// // TimeZonePicker 관련 함수 //////////////////////////////////////////////////////////////////////////////////////// function excludeTimeZone() { // 필터링할 타임존 목록 const excludedTimezones = [ //Atlantic (10) "Atlantic/Azores", "Atlantic/Bermuda", "Atlantic/Canary", "Atlantic/Cape_Verde", "Atlantic/Faroe", "Atlantic/Madeira", "Atlantic/Reykjavik","Atlantic/South_Georgia", 'Atlantic/St_Helena', "Atlantic/Stanley", //Indian(11) "Indian/Antananarivo","Indian/Chagos","Indian/Christmas","Indian/Cocos","Indian/Comoro", "Indian/Kerguelen", "Indian/Mahe", "Indian/Maldives", "Indian/Mauritius", "Indian/Mayotte", "Indian/Reunion", //Pacific (37) "Pacific/Apia", "Pacific/Chatham", "Pacific/Chuuk", "Pacific/Easter", "Pacific/Enderbury", "Pacific/Fakaofo", "Pacific/Efate", "Pacific/Fiji", "Pacific/Funafuti", "Pacific/Galapagos", "Pacific/Gambier", "Pacific/Kwajalein", "Pacific/Guadalcanal", "Pacific/Guam", "Pacific/Honolulu", "Pacific/Johnston", "Pacific/Kiritimati", "Pacific/Kosrae", "Pacific/Majuro", "Pacific/Midway", "Pacific/Marquesas", "Pacific/Nauru", "Pacific/Niue", "Pacific/Norfolk", "Pacific/Noumea", "Pacific/Pago_Pago", "Pacific/Palau", "Pacific/Pitcairn", "Pacific/Pohnpei", "Pacific/Port_Moresby", "Pacific/Rarotonga", "Pacific/Saipan", "Pacific/Tahiti", "Pacific/Tarawa", "Pacific/Tongatapu", "Pacific/Wake", "Pacific/Wallis" ]; // DOM 에서 제외할 타임존에 해당하는 SVG 폴리곤 요소를 찾고 제거 또는 숨기기 excludedTimezones.forEach(timezone => { // data-timezone 속성이 특정 시간대와 일치하는 폴리곤 요소를 제거 // $(`svg polygon[data-timezone="${timezone}"]`).remove(); // 또는 숨기기 $(`svg polygon[data-timezone="${timezone}"]`).hide(); $(`select.country-lov option[value="${timezone}"]`).remove(); }); // Select2를 업데이트하여 제거된 옵션 반영 $('select.country-lov').trigger('change'); } //////////////////////////////////////////////////////////////////////////////////////// // 탭 클릭 이벤트 처리 //////////////////////////////////////////////////////////////////////////////////////// function updateTimeZoneText() { let zoneText = ""; let selectedTZ = $("#globe").data('timezonePicker').getValue()[0]; if (selectedTZ.offset <0) { zoneText = selectedTZ.timezone + " ("+selectedTZ.zonename+", UTC"+selectedTZ.offset+")"; } else { zoneText = selectedTZ.timezone + " ("+selectedTZ.zonename+", UTC+"+selectedTZ.offset+")"; } $("#globe .select2-selection__rendered").val(zoneText); $("#globe .select2-selection__rendered").text(zoneText); } function timeZonePickerEvent() { // TimeZonePicker 이벤트 핸들러 설정 $("#globe").on("map:option:changed", updateTimeZoneText); $("#globe").on("click", updateTimeZoneText); } ////////////////////////////////////////////////////////// // License Information - (Purchase Date, Expiration Date) ////////////////////////////////////////////////////////// function dateTimePicker() { $("#purchase-date").datetimepicker({ format: "Y-m-d", // 날짜 및 시간 형식 지정 formatDate: "Y/m/d", timepicker: false, theme: "dark", lang: "kr", onSelectTime: function (current_time, $input) { $("#date_timepicker_end").datetimepicker("setOptions", { minDate: current_time }); }, onShow: function (ct) { this.setOptions({ maxDate: $("#date_timepicker_end").val() ? $("#date_timepicker_end").val() : false }); } }); // $("#expiration-date").datetimepicker({ format: "Y-m-d", // 날짜 및 시간 형식 지정 formatDate: "Y/m/d", timepicker: false, theme: "dark", lang: "kr", onSelectTime: function (current_time, $input) { $("#date_timepicker_start").datetimepicker("setOptions", { maxDate: current_time }); }, onShow: function (ct) { this.setOptions({ minDate: $("#date_timepicker_start").val() ? $("#date_timepicker_start").val() : false }); } }); } //////////////////////////////////////////////////////////////////////////////////////// // 탭 클릭 이벤트 처리 //////////////////////////////////////////////////////////////////////////////////////// function tab_click_event() { $('a[data-toggle="tab"]').on("shown.bs.tab", function (e) { var target = $(e.target).attr("href"); // activated tab console.log(target); if (target == "#dropdown1") { $("#pdservice_details_popup_div").addClass("hidden"); $("#pdservice_update_div").addClass("hidden"); $("#pdservice_delete_div").removeClass("hidden"); $(".body-middle").hide(); $(".pdservice-image-row").hide(); $(".file-delete-btn").hide(); if (isEmpty(selectId)) { jError("선택된 제품(서비스)가 없습니다. 오류는 무시됩니다."); } else { $("#delete_text").text($("#pdservice_table").DataTable().rows(".selected").data()[0].c_title); } } else if (target == "#report") { $(".pdservice-image-row").show(); $(".file-delete-btn").show(); $("#pdservice_details_popup_div").addClass("hidden"); $("#pdservice_delete_div").addClass("hidden"); $("#pdservice_update_div").removeClass("hidden"); } else { $("#pdservice_details_popup_div").removeClass("hidden"); $("#pdservice_update_div").addClass("hidden"); $("#pdservice_delete_div").addClass("hidden"); $(".pdservice-image-row").hide(); $(".file-delete-btn").hide(); if (selectId == undefined) { $(".body-middle").hide(); } else { $(".body-middle").show(); } } }); } //////////////////////////////////////////////////////////////////////////////////////// // --- 신규 제품(서비스) 등록 팝업 및 팝업 띄울때 사이즈 조정 -- // //////////////////////////////////////////////////////////////////////////////////////// function popup_size_setting() { console.log("popup_size_setting() is activated"); $("#modal_popup_id").click(function () { console.log("modal_popup_id clicked"); var height = $(document).height() - 600; //모달 초기화 $("#my_modal2").on("hidden.bs.modal", function (e) { $(this).find("form")[0].reset(); $("#popup_editview_pdservice_owner").val(null).trigger("change"); $("#popup_editview_pdservice_reviewers").val(null).trigger("change"); CKEDITOR.instances.modal_editor.setData("
제품(서비스)의 기획서 및 Project Charter 의 내용을 기록합니다.
"); //에디터 초기화 }); $(".modal-body") .find(".cke_contents:eq(0)") .css("height", height + "px"); }); // 팝업하여 편집 $("#extend_modal_popup_id").click(function () { var height = $(document).height() - 1000; $(".modal-body") .find(".cke_contents:eq(0)") .css("height", height + "px"); // 데이터 셋팅 var editorData = CKEDITOR.instances.input_pdservice_editor.getData(); console.log(editorData); CKEDITOR.instances.extend_modal_editor.setData(editorData); CKEDITOR.instances.extend_modal_editor.setReadOnly(false); var selectedId = $("#pdservice_table").DataTable().rows(".selected").data()[0].c_id; console.log("selectedId →" + selectedId); // 제품(서비스) 이름 $("#extend_editview_pdservice_name").val($("#editview_pdservice_name").val()); // 오너 // clear $("#extend_editview_pdservice_owner").val(null).trigger("change"); // 부모 페이지에서 데이터 로드 var owner = "none"; if ($("#editview_pdservice_owner").select2("data")[0] != undefined) { owner = $("#editview_pdservice_owner").select2("data")[0].text; } // Modal 창에 데이터 셋팅 if (owner == null || owner == "none") { console.log("pdServiceDataTableClick :: json.c_pdservice_owner empty"); } else { var newOption = new Option(owner, owner, true, true); $("#extend_editview_pdservice_owner").append(newOption).trigger("change"); } // 리뷰어 //clear $("#extend_editview_pdservice_reviewers").val(null).trigger("change"); var reviewer01 = "none"; var reviewer02 = "none"; var reviewer03 = "none"; var reviewer04 = "none"; var reviewer05 = "none"; if ($("#editview_pdservice_reviewers").select2("data")[0] != undefined) { reviewer01 = $("#editview_pdservice_reviewers").select2("data")[0].text; } if ($("#editview_pdservice_reviewers").select2("data")[1] != undefined) { reviewer02 = $("#editview_pdservice_reviewers").select2("data")[1].text; } if ($("#editview_pdservice_reviewers").select2("data")[2] != undefined) { reviewer03 = $("#editview_pdservice_reviewers").select2("data")[2].text; } if ($("#editview_pdservice_reviewers").select2("data")[3] != undefined) { reviewer04 = $("#editview_pdservice_reviewers").select2("data")[3].text; } if ($("#editview_pdservice_reviewers").select2("data")[4] != undefined) { reviewer05 = $("#editview_pdservice_reviewers").select2("data")[4].text; } var reviewer01Option = new Option(reviewer01, reviewer01, true, true); var reviewer02Option = new Option(reviewer02, reviewer02, true, true); var reviewer03Option = new Option(reviewer03, reviewer03, true, true); var reviewer04Option = new Option(reviewer04, reviewer04, true, true); var reviewer05Option = new Option(reviewer05, reviewer05, true, true); var multifyValue = 1; if (reviewer01 == null || reviewer01 == "none") { console.log("extend_modal_popup_id Click :: reviewer01 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer01Option); } if (reviewer02 == null || reviewer02 == "none") { console.log("extend_modal_popup_id Click :: reviewer02 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer02Option); } if (reviewer03 == null || reviewer03 == "none") { console.log("extend_modal_popup_id Click :: reviewer03 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer03Option); } if (reviewer04 == null || reviewer04 == "none") { console.log("extend_modal_popup_id Click :: reviewer04 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer04Option); } if (reviewer05 == null || reviewer05 == "none") { console.log("extend_modal_popup_id Click :: reviewer05 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer05Option); } $("#extend_editview_pdservice_reviewers").trigger("change"); $("#extend_editview_pdservice_reviewer").css("height", "20px"); setTimeout(function () { var heightValue = $("#extend_editview_pdservice_reviewer").height(); var resultValue = heightValue + 20 * multifyValue; $("#extend_editview_pdservice_reviewer").css("height", resultValue + "px"); }, 250); }); // 팝업 - readOnly $("#extend_modal_readOnly").click(function () { var height = $(document).height() - 1000; $(".modal-body") .find(".cke_contents:eq(0)") .css("height", height + "px"); // 데이터 셋팅 var editorData = CKEDITOR.instances.input_pdservice_editor.getData(); CKEDITOR.instances.extend_modal_editor.setData(editorData); CKEDITOR.instances.extend_modal_editor.setReadOnly(true); // 읽기전용 var selectedId = $("#pdservice_table").DataTable().rows(".selected").data()[0].c_id; console.log("selectedId →" + selectedId); // 제품(서비스) 이름 $("#extend_editview_pdservice_name").val($("#editview_pdservice_name").val()); // 오너 // clear $("#extend_editview_pdservice_owner").val(null).trigger("change"); // 부모 페이지에서 데이터 로드 var owner = "none"; if ($("#editview_pdservice_owner").select2("data")[0] != undefined) { owner = $("#editview_pdservice_owner").select2("data")[0].text; } // Modal 창에 데이터 셋팅 if (owner == null || owner == "none") { console.log("pdServiceDataTableClick :: json.c_pdservice_owner empty"); } else { var newOption = new Option(owner, owner, true, true); $("#extend_editview_pdservice_owner").append(newOption).trigger("change"); } // 리뷰어 //clear $("#extend_editview_pdservice_reviewers").val(null).trigger("change"); var reviewer01 = "none"; var reviewer02 = "none"; var reviewer03 = "none"; var reviewer04 = "none"; var reviewer05 = "none"; if ($("#editview_pdservice_reviewers").select2("data")[0] != undefined) { reviewer01 = $("#editview_pdservice_reviewers").select2("data")[0].text; } if ($("#editview_pdservice_reviewers").select2("data")[1] != undefined) { reviewer02 = $("#editview_pdservice_reviewers").select2("data")[1].text; } if ($("#editview_pdservice_reviewers").select2("data")[2] != undefined) { reviewer03 = $("#editview_pdservice_reviewers").select2("data")[2].text; } if ($("#editview_pdservice_reviewers").select2("data")[3] != undefined) { reviewer04 = $("#editview_pdservice_reviewers").select2("data")[3].text; } if ($("#editview_pdservice_reviewers").select2("data")[4] != undefined) { reviewer05 = $("#editview_pdservice_reviewers").select2("data")[4].text; } var reviewer01Option = new Option(reviewer01, reviewer01, true, true); var reviewer02Option = new Option(reviewer02, reviewer02, true, true); var reviewer03Option = new Option(reviewer03, reviewer03, true, true); var reviewer04Option = new Option(reviewer04, reviewer04, true, true); var reviewer05Option = new Option(reviewer05, reviewer05, true, true); var multifyValue = 1; if (reviewer01 == null || reviewer01 == "none") { console.log("extend_modal_popup_id Click :: reviewer01 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer01Option); } if (reviewer02 == null || reviewer02 == "none") { console.log("extend_modal_popup_id Click :: reviewer02 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer02Option); } if (reviewer03 == null || reviewer03 == "none") { console.log("extend_modal_popup_id Click :: reviewer03 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer03Option); } if (reviewer04 == null || reviewer04 == "none") { console.log("extend_modal_popup_id Click :: reviewer04 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer04Option); } if (reviewer05 == null || reviewer05 == "none") { console.log("extend_modal_popup_id Click :: reviewer05 empty"); } else { multifyValue = multifyValue + 1; $("#extend_editview_pdservice_reviewers").append(reviewer05Option); } $("#extend_editview_pdservice_reviewers").trigger("change"); $("#extend_editview_pdservice_reviewer").css("height", "20px"); setTimeout(function () { var heightValue = $("#extend_editview_pdservice_reviewer").height(); var resultValue = heightValue + 20 * multifyValue; $("#extend_editview_pdservice_reviewer").css("height", resultValue + "px"); }, 250); }); } //////////////////////////////////////////////////////////////////////////////////////// // --- select2 (사용자 자동완성 검색 ) 설정 --- // //////////////////////////////////////////////////////////////////////////////////////// function select2_setting() { $(".js-data-example-ajax").select2({ maximumSelectionLength: 5, width: "resolve", ajax: { url: function (params) { return "/auth-user/search-user/" + params.term; }, dataType: "json", delay: 250, //data: function (params) { // return { // q: params.term, // search term // page: params.page, // }; //}, processResults: function (data, params) { // parse the results into the format expected by Select2 // since we are using custom formatting functions we do not need to // alter the remote JSON data, except to indicate that infinite // scrolling can be used params.page = params.page || 1; return { results: data, pagination: { more: params.page * 30 < data.total_count } }; }, cache: true }, placeholder: "리뷰어 설정을 위한 계정명을 입력해 주세요", minimumInputLength: 1, templateResult: formatUser, templateSelection: formatUserSelection }); } ////////////////////////////////////////////////////////////////////¸//////////////////// // --- select2 (사용자 자동완성 검색 ) templateResult 설정 --- // //////////////////////////////////////////////////////////////////////////////////////// function formatUser(jsonData) { console.log("formatUser"); console.log(jsonData); var $container = $( "