- Add Docker Compose configurations for dev, prod, and standalone environments - Add database initialization scripts (init-db.sh, init-db-docker.sh) - Add enhanced start-docker-linux.sh with DB init support - Add comprehensive database initialization guide - Support for automatic dbexport.pgsql import on first run - Include safety checks for production environment
426 lines
17 KiB
Plaintext
426 lines
17 KiB
Plaintext
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
|
|
<%@ page import="com.pms.common.utils.*"%>
|
|
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>
|
|
<%@ page import="java.util.*" %>
|
|
<%@include file= "/init.jsp" %>
|
|
<%
|
|
PersonBean person = (PersonBean)session.getAttribute(Constants.PERSON_BEAN);
|
|
String connector = person.getUserId();
|
|
|
|
%>
|
|
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
|
|
<title><%=Constants.SYSTEM_NAME%></title>
|
|
<!-- //JSTL 페이징 변수선언 -->
|
|
<c:set var="now" value="<%=new java.util.Date() %>"/>
|
|
<c:set var="sysYear"><fmt:formatDate value="${now}" pattern="yyyy" /></c:set>
|
|
<c:set var="sysDate"><fmt:formatDate value="${now}" pattern="yyyy-MM-dd" /></c:set>
|
|
|
|
<c:set var="connector" value="<%=connector %>" />
|
|
<script>
|
|
$(document).ready(function(){
|
|
$('.select2').select2();
|
|
$("#btnSearch").click(function(){
|
|
fn_search();
|
|
});
|
|
fnc_datepick();
|
|
//엔터 조회
|
|
$("input").keyup(function(e){
|
|
if(e.keyCode == 13){
|
|
fn_search();
|
|
}
|
|
});
|
|
|
|
$("#btnConfirm").click(function(){
|
|
fn_confirm();
|
|
});
|
|
|
|
$("#btnActReg").click(function(){
|
|
openbtnActRegPopup();
|
|
//fn_openInvoiceFormPopup();
|
|
});
|
|
|
|
$("#project_no").change(function(){
|
|
fn_UnitCodeList(this.value, "unit_code", "");
|
|
});
|
|
|
|
fn_search();
|
|
});
|
|
|
|
var columns = [
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '110', title : '발주번호', field : 'PURCHASE_ORDER_NO', frozen:true,
|
|
formatter:fnc_createGridAnchorTag,
|
|
cellClick:function(e, cell){
|
|
var objId = fnc_checkNull(cell.getData().OBJID);
|
|
fn_formPopUp(objId);
|
|
}
|
|
},
|
|
/* {headerHozAlign : 'center', hozAlign : 'left', width : '130', title : '프로젝트번호', field : 'PROJECT_NO',
|
|
formatter:fnc_createGridAnchorTag,
|
|
cellClick:function(e, cell){
|
|
var objid = fnc_checkNull(cell.getData().CONTRACT_MGMT_OBJID);
|
|
openProjectFormPopUp(objid);
|
|
}
|
|
}, */
|
|
{headerHozAlign : 'center', hozAlign : 'left' , width : '95', title : '고객사', field : "CUSTOMER_NAME" , frozen:true},
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '100', title : '프로젝트번호', field : 'PROJECT_NO' , frozen:true},
|
|
{headerHozAlign : 'center', hozAlign : 'left', width : '200', title : '유닛명', field : 'UNIT_NAME' },
|
|
{headerHozAlign : 'center', hozAlign : 'left ', width : '200', title : '발주서제목', field : "TITLE" },
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '80', title : '발주일', field : 'REGDATE' },
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '90', title : '총발주수량', field : 'ORDER_CNT' ,
|
|
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
|
|
},
|
|
{headerHozAlign : 'center', hozAlign : 'right', width : '120', title : '총발주금액(원)', field : 'TOTAL_REAL_SUPPLY_PRICE',
|
|
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
|
|
},
|
|
{headerHozAlign : 'center', hozAlign : 'right', width : '150', title : '할인적용발주금액(원)', field : 'TOTAL_PRICE_ALL',
|
|
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
|
|
},
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '60', title : '차수', field : 'GROUP_SEQ',
|
|
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
|
|
},
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '100', title : '입고예정수량', field : 'TOTAL_ARRIVAL_QTY',
|
|
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
|
|
},
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '80', title : '입고수량', field : 'TOTAL_RECEIPT_QTY',
|
|
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
|
|
},
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '90', title : '부적합수량', field : 'TOTAL_ERROR_QTY',
|
|
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
|
|
},
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '90', title : '미입고수량', field : 'UNRECEIVED_QTY',
|
|
formatter:fnc_createGridAnchorTagAndComma,
|
|
cellClick:function(e, cell){
|
|
var objid = fnc_checkNull(cell.getData().OBJID);
|
|
arrivalplanFormPopup(objid);
|
|
}
|
|
},
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '80', title : '입고결과', field : 'DELIVERY_STATUS' },
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '80', title : '입고일', field : 'RECEIPT_DATE' },
|
|
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '90', title : '거래명세서', field : 'INVOICE_OBJID',
|
|
formatter:fnc_subInfoValueFormatter,
|
|
cellClick:function(e, cell){
|
|
var objid = fnc_checkNull(cell.getData().OBJID);
|
|
var groupseq = fnc_checkNull(cell.getData().GROUP_SEQ);
|
|
var apprstatus = fnc_checkNull(cell.getData().APPR_STATUS);
|
|
fn_openInvoiceFormPopup(objid,groupseq,apprstatus);
|
|
}
|
|
},
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '80', title : '발행일', field : 'ISSUANCE_DATE' },
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '90', title : '발행담당자', field : 'ISSUANCE_NAME' },
|
|
{headerHozAlign : 'center', hozAlign : 'center', width : '80', title : '상태', field : 'APPR_STATUS_NAME',
|
|
formatter: fnc_createGridApprovalAnchorTag,
|
|
cellClick:function(e, cell){
|
|
|
|
var targetStatus = fnc_checkNull(cell.getData().APPR_STATUS).toUpperCase();
|
|
//alert("targetStatus:"+targetStatus);
|
|
if("INPROCESS" == targetStatus || "COMPLETE" == targetStatus){
|
|
fn_approvalDetail(cell.getData().APPROVAL_OBJID, cell.getData().ROUTE_OBJID);
|
|
}
|
|
}
|
|
}
|
|
];
|
|
|
|
//var grid;
|
|
function fn_search(){
|
|
_tabulGrid = fnc_tabul_search(_tabul_layout_fitColumns, _tabulGrid, "/supplyChainMgmt/invoiceMgmtGridList.do", columns, true);
|
|
}
|
|
|
|
//영업활동등록 상세
|
|
function fn_projectConceptDetail(objId){
|
|
var popup_width = 1200;
|
|
var popup_height = 760;
|
|
var url = "/contractMgmt/contracMgmtFormPopup.do?objId="+objId;
|
|
|
|
fn_centerPopup(popup_width, popup_height, url);
|
|
}
|
|
|
|
function fn_approvalDetail(approvalObjId,routeObjId){
|
|
var params = "?approvalObjId="+approvalObjId;
|
|
params += "&routeObjId="+routeObjId;
|
|
window.open("/approval/approvalDetail.do"+params,"approvalDetailPopup","width=650 height=400 menubar=no status=no");
|
|
}
|
|
|
|
//프로젝트의 form,detail 팝업을 보여준다.
|
|
function openProjectFormPopUp(objId){
|
|
var popup_width = 420;
|
|
var popup_height = 350;
|
|
var objId = objId;
|
|
var params = "?OBJID="+objId;
|
|
var url = "/project/projectmodifyPopUp.do"+params;
|
|
fn_centerPopup(popup_width, popup_height, url);
|
|
}
|
|
|
|
//프로젝트의 form,detail 팝업을 보여준다.
|
|
function openIssueFormPopUp(status,projectobjid){
|
|
var popup_width = 1720;
|
|
var popup_height = 900;
|
|
var objId = objId;
|
|
var params = "?status="+status+"&project_no="+projectobjid;
|
|
var url = "/productionplanning/issuemgmtList.do"+params;
|
|
fn_centerPopup(popup_width, popup_height, url);
|
|
}
|
|
|
|
function wbs_popup(objId){
|
|
|
|
var popup_width = 900;
|
|
var popup_height = 800;
|
|
var objId = objId;
|
|
var params = "?OBJID="+objId;
|
|
//var url = "/project/wbsTaskProductGanttFormPopUp.do"+params;
|
|
var url = "/project/wbsTaskProductProduceFormPopUp.do"+params;
|
|
fn_centerPopup(popup_width, popup_height, url);
|
|
}
|
|
|
|
function setup_wbs_popup(objId){
|
|
|
|
var popup_width = 1100;
|
|
var popup_height = 750;
|
|
var objId = objId;
|
|
var params = "?OBJID="+objId;
|
|
//var url = "/project/wbsTaskProductGanttFormPopUp.do"+params;
|
|
var url = "/project/wbsTaskProductSetupFormPopUp.do"+params;
|
|
fn_centerPopup(popup_width, popup_height, url);
|
|
}
|
|
|
|
function openbtnActRegPopup(){
|
|
var selected = _tabulGrid.getSelectedData();
|
|
if(selected.length==0){
|
|
Swal.fire("선택된 데이터가 없습니다.");
|
|
return;
|
|
}else{
|
|
if(selected.length > 1){
|
|
Swal.fire("한건씩 등록 가능합니다.");
|
|
return;
|
|
}else{
|
|
var partnerObjid = fnc_checkNull(selected[0].PARTNER_OBJID);
|
|
var deliveryStatus = fnc_checkNull(selected[0].DELIVERY_STATUS);
|
|
var arrivalPlanDate = fnc_checkNull(selected[0].ARRIVAL_PLAN_DATE);
|
|
var sysDate = "${sysDate}";
|
|
//alert("arrivalPlanDate:"+arrivalPlanDate);
|
|
//alert("sysDate:"+sysDate);
|
|
var arrivalDate = new Date(arrivalPlanDate);
|
|
var systemDate = new Date(sysDate);
|
|
|
|
if(partnerObjid == "${partnerCd}"){
|
|
if((arrivalDate < systemDate) || (deliveryStatus =='입고완료')){
|
|
var OBJID = fnc_checkNull(selected[0].OBJID);
|
|
var GROUPSEQ = fnc_checkNull(selected[0].GROUP_SEQ);
|
|
var APPRSTATUS = fnc_checkNull(selected[0].APPR_STATUS);
|
|
var TOTAL_RECEIPT_QTY = fnc_checkNullDefaultValue(selected[0].TOTAL_RECEIPT_QTY,0);
|
|
var TOTAL_ERROR_QTY = fnc_checkNullDefaultValue(selected[0].TOTAL_ERROR_QTY,0);
|
|
var TOTAL_ARRIVAL_QTY = fnc_checkNullDefaultValue(selected[0].TOTAL_ARRIVAL_QTY,0);
|
|
var popup_width = 1000;
|
|
var popup_height = 880;
|
|
|
|
/* if(parseInt(TOTAL_ARRIVAL_QTY) <= (parseInt(TOTAL_RECEIPT_QTY)+parseInt(TOTAL_ERROR_QTY))){ */
|
|
var params = "?PURCHASE_ORDER_MASTER_OBJID="+OBJID+"&GROUPSEQ="+GROUPSEQ+"&APPRSTATUS="+APPRSTATUS;
|
|
//alert(params);
|
|
//var hiddenForm = document.hiddenForm;
|
|
var url = "/supplyChainMgmt/invoiceFormPopUp.do"+params;
|
|
var target = "InvoicePopup";
|
|
|
|
fn_centerPopup(popup_width, popup_height, url, target);
|
|
|
|
//window.open(url,target,"width=1000, height=880, menubars=no, scrollbars=yes, resizable=yes");
|
|
//hiddenForm.action = url;
|
|
//hiddenForm.PURCHASE_ORDER_MASTER_OBJID.value = OBJID;
|
|
//hiddenForm.target = target;
|
|
//hiddenForm.submit();
|
|
/* }else{
|
|
Swal.fire("총입고수량 및 부적합수량의 합이 총입고예정 수량과 같아야 합니다.");
|
|
return;
|
|
} */
|
|
}else{
|
|
Swal.fire("거래명세서 발급은 입고예정일 이후 가능합니다.");
|
|
return;
|
|
}
|
|
}else{
|
|
Swal.fire("공급업체 담당자만 작성할 수 있습니다.");
|
|
return;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function fn_openInvoiceFormPopup(OBJID,GROUPSEQ,APPRSTATUS){
|
|
var popup_width = 1000;
|
|
var popup_height = 980;
|
|
var OBJID = OBJID;
|
|
var GROUPSEQ = GROUPSEQ;
|
|
var params = "?PURCHASE_ORDER_MASTER_OBJID="+OBJID+"&GROUPSEQ="+GROUPSEQ+"&APPRSTATUS="+APPRSTATUS+"&actionType=view";
|
|
//var hiddenForm = document.hiddenForm;
|
|
var url = "/supplyChainMgmt/invoiceFormPopUp.do"+params;
|
|
var target = "InvoicePopup";
|
|
fn_centerPopup(popup_width, popup_height, url, target);
|
|
|
|
/* window.open(url,target,"width=1000, height=880, menubars=no, scrollbars=yes, resizable=yes");
|
|
hiddenForm.action = url;
|
|
hiddenForm.PURCHASE_ORDER_MASTER_OBJID.value = OBJID;
|
|
hiddenForm.target = target;
|
|
hiddenForm.submit(); */
|
|
}
|
|
|
|
//등록,수정,뷰
|
|
function fn_formPopUp(objId){
|
|
var popup_width = 1260;
|
|
var popup_height = 1050;
|
|
var target = "purchaseOrderFormPopup_new";
|
|
var url = "/purchaseOrder/purchaseOrderFormPopup_new.do?PURCHASE_ORDER_MASTER_OBJID="+objId+"&action=view";
|
|
fn_centerPopup(popup_width, popup_height, url, target);
|
|
}
|
|
|
|
function arrivalplanFormPopup(OBJID){
|
|
var hiddenForm = document.hiddenForm;
|
|
var url = "/supplyChainMgmt/arrivalplanFormPopup.do";
|
|
var target = "partMngPopUp";
|
|
|
|
window.open(url,target,"width=1600, height=700, menubars=no, scrollbars=yes, resizable=yes");
|
|
hiddenForm.action = url;
|
|
hiddenForm.PURCHASE_ORDER_MASTER_OBJID.value = OBJID;
|
|
hiddenForm.ACTION_TYPE.value = "view";
|
|
hiddenForm.target = target;
|
|
hiddenForm.submit();
|
|
}
|
|
|
|
function fn_confirm() {
|
|
var checkedObj = _tabulGrid.getSelectedData();
|
|
if(0 < checkedObj.length){
|
|
var checkArr = new Array();
|
|
|
|
for(var i=0;i<checkedObj.length;i++){
|
|
var objId = fnc_checkNull(checkedObj[i].INVOICE_OBJID);
|
|
var status = fnc_checkNull(checkedObj[i].APPR_STATUS_NAME);
|
|
if(status=='승인완료'){
|
|
checkArr.push(objId);
|
|
}
|
|
}
|
|
|
|
if(checkArr.length > 0){
|
|
//if(confirm("선택된 Part를 삭제하시겠습니까?")){
|
|
Swal.fire({
|
|
title: '선택된 데이터를 마감 하시겠습니까?',
|
|
text: '',
|
|
icon: 'warning',
|
|
|
|
showCancelButton: true, // cancel버튼 보이기. 기본은 원래 없음
|
|
confirmButtonColor: '#3085d6', // confrim 버튼 색깔 지정
|
|
cancelButtonColor: '#d33', // cancel 버튼 색깔 지정
|
|
confirmButtonText: '확인', // confirm 버튼 텍스트 지정
|
|
cancelButtonText: '취소', // cancel 버튼 텍스트 지정
|
|
reverseButtons: false, // 버튼 순서 거꾸로
|
|
|
|
}).then(result => {
|
|
// 만약 Promise리턴을 받으면,
|
|
if (result.isConfirmed) { // 만약 모달창에서 confirm 버튼을 눌렀다면
|
|
$.ajax({
|
|
url:"/supplyChainMgmt/invoiceConfirm.do",
|
|
type:"POST",
|
|
data: {"checkArr":checkArr.join()},
|
|
dataType:"json",
|
|
success:function(data){
|
|
Swal.fire(data.msg);
|
|
fn_search();
|
|
},
|
|
error: function(jqxhr, status, error){
|
|
}
|
|
});
|
|
}
|
|
});
|
|
}else{
|
|
Swal.fire("승인완료된 데이터만 월별마감이 가능합니다.");
|
|
return false;
|
|
}
|
|
}else{
|
|
Swal.fire("선택된 데이터가 없습니다.");
|
|
}
|
|
}
|
|
|
|
</script>
|
|
</head>
|
|
<body>
|
|
<form name="hiddenForm" id="hiddenForm" method="post">
|
|
<input type="hidden" name="PURCHASE_ORDER_MASTER_OBJID" id="PURCHASE_ORDER_MASTER_OBJID">
|
|
<input type="hidden" name="ACTION_TYPE" id="ACTION_TYPE">
|
|
</form>
|
|
<form name="form1" id="form1" action="" method="post">
|
|
<input type="hidden" name="actionType" value="" />
|
|
<div class="min_part_enroll">
|
|
<div class="content-box">
|
|
<div class="content-box-s">
|
|
<div class="plm_menu_name_gdnsi">
|
|
<h2>
|
|
<span>SCM관리_거래명세서관리</span>
|
|
</h2>
|
|
<div class="btnArea">
|
|
<input type="button" class="plm_btns" value="거래명세서발행" id="btnActReg">
|
|
<input type="button" class="plm_btns" value="월별마감" id="btnConfirm">
|
|
<input type="button" class="plm_btns" value="조회" id="btnSearch" name="btnSearch">
|
|
</div>
|
|
</div>
|
|
<div id="plmSearchZon">
|
|
<table>
|
|
<tr>
|
|
<td><label for="Year">년도</label></td>
|
|
<td>
|
|
<select name="Year" id="Year" class="select2" autocomplete="off">
|
|
<option value="">선택</option>
|
|
<c:forEach begin="${sysYear-4}" end="${sysYear}" var="req_year">
|
|
<option value="${req_year}"${param.Year eq req_year ? 'selected':'' }>${req_year}</option>
|
|
</c:forEach>
|
|
</select>
|
|
</td>
|
|
|
|
<td><label for="project_no">프로젝트번호</label></td>
|
|
<td>
|
|
<select name="project_no" id="project_no" style="" class="select2" autocomplete="off">
|
|
<option value="">선택</option>
|
|
${code_map.project_no}
|
|
</select>
|
|
</td>
|
|
|
|
<td><label for="unit_code">유닛명</label></td>
|
|
<td>
|
|
<select name="unit_code" id="unit_code" class="select2" type="select" autocomplete="off">
|
|
</td>
|
|
|
|
<td><label for="">공급업체</label></td>
|
|
<td>
|
|
<select name="partner_objid" id="partner_objid" style="width:200px" class="select2" autocomplete="off">
|
|
<option value="">선택</option>
|
|
${code_map.partner_objid}
|
|
</select>
|
|
</td>
|
|
|
|
<td><label for="">발주No.</label></td>
|
|
<td><input type="text" name="purchase_order_no" id="purchase_order_no" autocomplete="off" value="${param.purchase_order_no}" style=""/></td>
|
|
|
|
<td><label for="">상태</label></td>
|
|
<td>
|
|
<select name="status" id="status" style="" class="select2" autocomplete="off">
|
|
<option value="">선택</option>
|
|
<option value="작성중" ${param.APPR_STATUS_NAME eq '작성중'?'selected':''}>작성중</option>
|
|
<option value="승인요청중" ${param.APPR_STATUS_NAME eq '승인요청중'?'selected':''}>승인요청중</option>
|
|
<option value="승인완료" ${param.APPR_STATUS_NAME eq '승인완료'?'selected':''}>승인완료</option>
|
|
<option value="반려" ${param.APPR_STATUS_NAME eq '반려'?'selected':''}>반려</option>
|
|
</select>
|
|
</td>
|
|
|
|
<td><label>발행일</label></td>
|
|
<td>
|
|
<input type="text" name="issuance_start_date" id="issuance_start_date" style="width:90px;" autocomplete="off" value="${param.issuance_start_date}" class="date_icon">~
|
|
<input type="text" name="issuance_end_date" id="issuance_end_date" style="width:90px;" autocomplete="off" value="${param.issuance_end_date }" class="date_icon">
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
</div>
|
|
|
|
<%@include file= "/WEB-INF/view/common/common_gridArea.jsp" %>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
</body>
|
|
</html> |