function getUrlParameter(sParam) { var sPageURL = window.location.search.substring(1), sURLVariables = sPageURL.split('&'), sParameterName, i; for (i = 0; i < sURLVariables.length; i++) { sParameterName = sURLVariables[i].split('='); if (sParameterName[0] === sParam) { return sParameterName[1] === undefined ? true : decodeURIComponent(sParameterName[1]); } } return false; }; function getCodeLinkByType(type) { type = parseInt(type); switch (type) { case 1: return "SS"; break; case 2: return "FF"; break; case 3: return "SF"; break; default: return "FS"; break; } } var getInput = function(node){ return node.querySelector("input"); }; gantt.config.editor_types.costPlanningEditor = { show: function (id, column, config, placeholder) { var min = config.min || 0 var html = "<div><input onkeyup='costPlanningChange(this)' type='text' min='" + min + "' name='" + column.name + "'></div>"; placeholder.innerHTML = html; }, hide: function () { }, set_value: function (value, id, column, node) { getInput(node).value = value; }, get_value: function (id, column, node) { return getInput(node).value || 0; }, is_changed: function (value, id, column, node) { var currentValue = this.get_value(id, column, node); return value !== currentValue; }, is_valid: function (value, id, column, node) { return true; }, focus: function (node) { var input = getInput(node); if (!input) { return; } if (input.focus) { input.focus(); } if (input.select) { input.select(); } } }; gantt.config.editor_types.progressCustom = { show: function (id, column, config, placeholder) { var min = config.min || 0, max = config.max || 100; var html = "<div><input type='number' min='" + min + "' max='" + max + "' name='" + column.name + "'></div>"; placeholder.innerHTML = html; }, hide: function () { }, set_value: function (value, id, column, node) { value = value*100 getInput(node).value = value; }, get_value: function (id, column, node) { return getInput(node).value || 0; }, is_changed: function (value, id, column, node) { var currentValue = this.get_value(id, column, node); return Number(value) !== Number(currentValue); }, is_valid: function (value, id, column, node) { return !isNaN(parseInt(value, 10)); }, focus: function (node) { var input = getInput(node); if (!input) { return; } if (input.focus) { input.focus(); } if (input.select) { input.select(); } } }; function initializationProject(){ let projectId = getUrlParameter("proyek_id"); if(projectId && projectId > 0){ $.ajax({ url: `${base_url}project/edit/${projectId}`, type:"GET", success: function (result) { let data = result.data; let projectName = data.nama; // $("#project-name-header").html(projectName); }, error: function (data) { actionHappen = false; } }); } } function getSatuan(){ $.ajax({ url: `${base_url}satuan/list`, type:"GET", success: function (result) { let satuanList = []; let resSatuan = result.data || [] resSatuan.map((val, index) => { let satuan = { key:val.id, label:val.name, text:val.name } satuanList.push(satuan) }); if(satuanList.length > 0){ gantt.updateCollection("satuan", satuanList); gantt.refreshData(); gantt.render(); } }, error: function (data) { } }); } function updateActivity(id) { $.ajax({ url: `${base_url}task/get-update/${id}`, type:"GET", success: function (result) { let data = result.data; gantt.getTask(id).assign_hr = data.assign_hr; gantt.getTask(id).assign_material = data.assign_material; gantt.getTask(id).assign_tools = data.assign_tools; gantt.getTask(id).bobot_planning = data.bobot_planning; gantt.getTask(id).rencana_biaya = data.rencana_biaya; gantt.getTask(id).biaya_actual = data.biaya_actual; gantt.getTask(id).progress = data.progress; gantt.getTask(id).jobs_done = data.jobs_done ? data.jobs_done : 0; gantt.updateTask(id); actionHappen = false; }, error: function (data) { actionHappen = false; } }); } /* Fungsi format ribuan label*/ function formatRupiah(n) { var parts=n.toString().split("."); return parts[0].replace(/\B(?=(\d{3})+(?!\d))/g, ".") + (parts[1] ? "," + parts[1] : ""); } /* Fungsi format ribuan inputan*/ function formatRibuanInput(angka, prefix) { var number_string = angka.replace(/[^,\d]/g, '').toString(), split = number_string.split(','), sisa = split[0].length % 3, rupiah = split[0].substr(0, sisa), ribuan = split[0].substr(sisa).match(/\d{3}/gi); if (ribuan) { separator = sisa ? '.' : ''; rupiah += separator + ribuan.join('.'); } rupiah = split[1] != undefined ? rupiah + ',' + split[1] : rupiah; return prefix == undefined ? rupiah : (rupiah ? 'Rp. ' + rupiah : ''); } /* Fungsi replace titik, untuk save ke DB*/ function formatReplaceTitikRibuan(param){ let myStr = param; let newStr = myStr.replace(/\./g, ''); return newStr; } function formatDate(params){ let today = new Date(params); let yyyy = today.getFullYear(); let mm = today.getMonth() + 1; // Months start at 0! let dd = today.getDate(); if (dd < 10) dd = '0' + dd; if (mm < 10) mm = '0' + mm; today = dd + '/' + mm + '/' + yyyy; return today; } function roundToTwo(num) { return +(Math.round(num + "e+2") + "e-2"); } function initialProperty() { $.ajax({ url: `${base_url}user-to-version-gantt/get-by-gantt/${ganttId}`, type:"GET", success: function (result) { let data = result.data; if(data.status && data.status=="not have"){ toggleCollapseTasks(); }else{ if(data.id){ userToVersionGanttId = data.id } if(data.critical_path){ gantt.config.highlight_critical_path = true; $("#critalPathBox").prop("checked", true); } if(data.auto_schedule){ gantt.config.auto_schedule = true; $("#autoSchedule").prop("checked", true); } if(data.zoom){ gantt.ext.zoom.setLevel(data.zoom); $('input[value="'+data.zoom+'"]').prop("checked", true); } if(data.task_open){ gantt.eachTask(function(task){ task.$open = true; }); toggleTasks = "Collapse"; $("#gantt_toggle_task_btn").prop('title', 'Collapse Activities'); $("#gantt_toggle_task_btn").children().removeClass('fa-expand-alt'); $("#gantt_toggle_task_btn").children().addClass('fa-compress-alt'); }else{ toggleCollapseTasks(); } gantt.render(); } }, error: function (data) { } }); } function initializationColumn() { $.ajax({ url: `${base_url}gantt-show-hide/get-by-gantt/${ganttId}`, type:"GET", success: function (result) { let data = result.data; if(data.status=="not yet have"){ addShowHideColumn(); }else if(data.status=="not have access"){ }else{ setUpForShowHideColumn(data); } }, error: function (data) { } }); } $(document).ready(function () { $("#critalPathBox").on("change", function (){ let checked = $(this).is(":checked"); if(checked){ gantt.config.highlight_critical_path = true; updateProperty({critical_path:true}) }else{ gantt.config.highlight_critical_path = false; updateProperty({critical_path:false}) } gantt.render(); }); $("#autoSchedule").on("change", function (){ let checked = $(this).is(":checked"); if(checked){ gantt.config.auto_schedule = true; updateProperty({auto_schedule:true}) }else{ gantt.config.auto_schedule = false; updateProperty({auto_schedule:false}) } gantt.render(); }); }); function linkLagEditor(){ function endPopup(){ modal = null; editLinkId = null; } function cancelEditLink(){ endPopup() } function deleteLink(){ gantt.deleteLink(editLinkId); endPopup() } function saveLink(){ var link = gantt.getLink(editLinkId); var lagValue = modal.querySelector(".lag-input").value; if(!isNaN(parseInt(lagValue, 10))){ link.lag = parseInt(lagValue, 10); } gantt.updateLink(link.id); if(gantt.autoSchedule){ gantt.autoSchedule(link.source); } endPopup(); } var modal; var editLinkId; gantt.attachEvent("onLinkDblClick", function(id,e){ editLinkId = id; var link = gantt.getLink(id); var linkTitle; switch(link.type){ case gantt.config.links.finish_to_start: linkTitle = "FS"; break; case gantt.config.links.finish_to_finish: linkTitle = "FF"; break; case gantt.config.links.start_to_start: linkTitle = "SS"; break; case gantt.config.links.start_to_finish: linkTitle = "SF"; break; } linkTitle += " " + gantt.getTask(link.source).text + " -> " + gantt.getTask(link.target).text; modal = gantt.modalbox({ title: linkTitle, text: "<div>" + "<label>Lag <input type='number' class='lag-input' /></label>" + "</div>", buttons: [ {label:"Save", css:"link-save-btn", value:"save"}, {label:"Cancel", css:"link-cancel-btn", value:"cancel"}, {label:"Delete", css:"link-delete-btn", value:"delete"} ], width: "500px", type: "popup-css-class-here", callback: function(result){ switch(result){ case "save": saveLink(); break; case "cancel": cancelEditLink(); break; case "delete": deleteLink(); break; } } }); modal.querySelector(".lag-input").value = link.lag || 0; //any custom logic here return false; }); } function addShowHideColumn() { let allColumn = []; allColumns.forEach(function(column){ allColumn.push(column.name); }); submitShowHideColumn(allColumn); } function submitShowHideColumn(allColumn) { let payload = { version_gantt_id:ganttId, columns:allColumn } $.ajax({ data: JSON.stringify(payload), url: `${base_url}gantt-show-hide/add`, type: "POST", processData: false, contentType: false, success: function (data) { }, error: function (data) { } }); } function setUpForShowHideColumn(data) { let columns = data || [] let configColumn = {} columns.map((val, index) => { configColumn[val.column_name] = val.show }); gantt.config.columns = createColumnsConfig(configColumn); gantt.render(); } function updateShowHideColumn(data) { let payload = { columns:data } $.ajax({ data: JSON.stringify(payload), url: `${base_url}gantt-show-hide/update/${ganttId}`, type: "POST", processData: false, contentType: false, success: function (data) { console.log(data); }, error: function (data) { console.log(data); } }); } function updateProperty(payload){ if(userToVersionGanttId > 0 && readOnly && parseInt(readOnly)==0){ $.ajax({ data: JSON.stringify(payload), url: `${base_url}user-to-version-gantt/update/${userToVersionGanttId}`, type: "PUT", processData: false, contentType: false, success: function (data) { }, error: function (data) { } }); } } function costPlanningChange(e){ let value = e.value; value = replaceAll(value, ".", "") value = replaceAll(value, ",", ".") let newValue = formatRupiah(value); $(e).val(newValue) } function escapeRegExp(string) { return string.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'); } function replaceAll(str, find, replace) { if(str){ return str.replace(new RegExp(escapeRegExp(find), 'g'), replace); } return str } // Function to get the earliest planned start date among all tasks function getEarliestTaskDate() { var earliestDate = null; gantt.eachTask(function (task) { var taskStartDate = task.planned_start || task.start_date; if (!earliestDate || task.planned_start < earliestDate) { earliestDate = taskStartDate; if (task.start_date < earliestDate) { earliestDate = task.start_date; } } }); return earliestDate; } // Function to get the latest planned end date among all tasks function getLatestTaskDate() { var latestDate = null; gantt.eachTask(function (task) { var taskEndDate = task.planned_end || task.end_date; if (!latestDate || task.planned_end > latestDate) { latestDate = taskEndDate; if (task.end_date > latestDate) { latestDate = task.end_date; } } }); return latestDate; }