Files
wace_plm/WebContent/WEB-INF/view/supplyChainMgmt/invoiceMgmtList.jsp
chpark da06c4684c Initial commit: WACE PLM with database initialization features
- 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
2025-08-29 15:46:08 +09:00

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>