ERP-node/WebContent/WEB-INF/view/supplyChainMgmt/fundPaymentMgmtList.jsp

419 lines
16 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="connector" value="<%=connector %>" />
<style>
/* 헤더의 배경색을 빨간색으로 변경 */
.tabulator-header {
background-color: red !important;
color: blue !important;
/* headerBackgroundColor */
}
.select2-selection__choice {
font-size: 11px;
background-color: #fff !important;
border: none !important;
margin-right: 0px !important;
}
.select2-selection__choice__remove {
display: contents !important;
}
.select2-container .select2-selection--multiple {
min-height: 20px !important;
}
.select2-container--default .select2-selection--multiple .select2-selection__choice {
margin-top: 3.5px !important;
}
.select2-selection__rendered {
height: 18px !important;
}
.select2-container .select2-selection--multiple .select2-selection__rendered {
overflow: auto !important;
}
</style>
<script>
$(document).ready(function(){
$('.select2').select2();
$("#btnSearch").click(function(){
fn_search();
});
fnc_datepick();
//엔터 조회
$("input").keyup(function(e){
if(e.keyCode == 13){
fn_search();
}
});
$("#btnActReg").click(function(){
fn_dueDateReg();
});
$("#btnConfirm").click(function(){
fn_confirm();
});
$("#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',
formatter:fnc_createGridAnchorTag,
cellClick:function(e, cell){
var objId = fnc_checkNull(cell.getData().OBJID);
fn_formPopUp(objId);
}
},
/* {headerHozAlign : 'center', hozAlign : 'center', width : '130', title : '프로젝트번호', field : 'PROJECT_NO',
formatter:fnc_createGridAnchorTag,
cellClick:function(e, cell){
var objid = fnc_checkNull(cell.getData().CONTRACT_OBJID);
openProjectFormPopUp(objid);
}
}, */
{headerHozAlign : 'center', hozAlign : 'left', width : '110', title : '프로젝트번호', field : 'PROJECT_NO' },
{headerHozAlign : 'center', hozAlign : 'left', /* width : '200', */title : '유닛명', field : 'UNIT_NAME' },
{headerHozAlign : 'center', hozAlign : 'center', width : '100', title : '발주일', field : 'REGDATE' },
{headerHozAlign : 'center', hozAlign : 'center', width : '100', title : '총발주수량', field : 'ORDER_CNT' ,
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
},
/*
{headerHozAlign : 'center', hozAlign : 'right', width : '150', title : '발주금액(원)', field : 'TOTAL_SUPPLY_UNIT_PRICE',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
},
*/
{headerHozAlign : 'center', hozAlign : 'right' , /* width : '90', */ title : '공급가', field : "TOTAL_SUPPLY_PRICE", formatter:"money", formatterParams:{ thousand:",", symbolAfter:"p", precision:false, } },
{headerHozAlign : 'center', hozAlign : 'right' , /* width : '90', */ title : '세액', field : "VAT_PRICE", formatter:"money", formatterParams:{ thousand:",", symbolAfter:"p", precision:false, } },
{headerHozAlign : 'center', hozAlign : 'right' , width : '130', title : '부가세포함공급가', field : "TOTAL_SUPPLY_UNIT_PRICE", formatter:"money", formatterParams:{ thousand:",", symbolAfter:"p", precision:false, } },
{headerHozAlign : 'center', hozAlign : 'right', width : '100', title : '총입고수량', field : 'TOTAL_RECEIPT_QTY',
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_ERROR_QTY',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false }
},
{headerHozAlign : 'center', hozAlign : 'center', width : '80', title : '입고일', field : 'RECEIPT_DATE' },
{headerHozAlign : 'center', hozAlign : 'center', width : '100', 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);
}
},
{headerHozAlign : 'center', hozAlign : 'center', width : '80', title : '발행일', field : 'ISSUANCE_DATE' },
{headerHozAlign : 'center', hozAlign : 'center', width : '100', title : '발행담당자', field : 'ISSUANCE_NAME'},
{headerHozAlign : 'center', hozAlign : 'center', width : '80', title : '상태', field : 'INVOICE_STATUS_NAME' },
{headerHozAlign : 'center', hozAlign : 'center', width : '130', title : '자금지급예정일', field : 'PAY_DATE' },
];
function fn_openInvoiceFormPopup(objId,GROUPSEQ){
var OBJID = objId;
var GROUPSEQ = fnc_checkNull(GROUPSEQ);
var params = "?OBJID="+OBJID+"&GROUPSEQ="+GROUPSEQ+"&actionType=view";
var hiddenForm = document.hiddenForm;
var url = "/supplyChainMgmt/invoiceFormPopUp.do"+params;
var target = "partMngPopUp";
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();
}
//var grid;
function fn_search(){
var selectedValues = $("#project_no").val();
//alert(selectedValues);
/*
var projectNoParam = new Array();
projectNoParam.push(selectedValues);
var checkArr = projectNoParam.join();
*/
//alert("checkArr:"+checkArr)
//$("#checkArr").val(checkArr);
$('<input>').attr({
type: 'hidden',
name: 'project_nos',
value: selectedValues
}).appendTo('#form1');
_tabulGrid = fnc_tabul_search(_tabul_layout_fitColumns, _tabulGrid, "/supplyChainMgmt/fundPaymentMgmtGridList.do", columns, true);
var _sum=0;
var text ="&nbsp;&nbsp; <font size='2px' color='red'>자금지급예정 합계 금액(원) : ";
$.ajax({
url:"/supplyChainMgmt/fundPaymentMgmtListSum.do",
type:"POST",
data:$("#form1").serializeObject(),
dataType:"json",
async:false,
success:function(data){
_sum = numberWithCommas(data.REQUEST_AMOUNT_SUM);
},
error: function(jqxhr, status, error){
}
});
text +=_sum+"</font>";
$(".purchaseOrderSum").html(text);
}
//영업활동등록 상세
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);
}
//프로젝트의 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 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 fn_dueDateReg(){
var selected = _tabulGrid.getSelectedData();
if(selected.length==0){
Swal.fire("선택된 데이터가 없습니다.");
return;
}else{
if(selected.length > 1){
Swal.fire("한건씩 등록 가능합니다.");
return;
}else{
var paymentTerms = fnc_checkNull(selected[0].PAYMENT_TERMS);
//alert("paymentTerms:"+paymentTerms);
if(paymentTerms == '0001075'){
Swal.fire("결재조건이 계산서발행월+1M일 경우 등록이 불가능합니다.");
return;
}else{
var objId = fnc_checkNull(selected[0].INVOICE_OBJID);
var popup_width = 400;
var popup_height = 300;
var target = "dueDateReg";
var url = "/supplyChainMgmt/dueDateRegPopUp.do?objId="+objId;
fn_centerPopup(popup_width, popup_height, url, target);
}
}
}
}
//지급완료 상태값 변경
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].INVOICE_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/invoiceComplete.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 class="bodyNoScroll">
<form name="hiddenForm" id="hiddenForm" method="post">
<input type="hidden" name="PURCHASE_ORDER_MASTER_OBJID" id="PURCHASE_ORDER_MASTER_OBJID">
</form>
<form name="form1" id="form1" action="" method="post">
<input type="hidden" name="actionType" value="" />
<input type="hidden" name="nemu" value="${param.menu}">
<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" name="btnActReg">
<c:if test="${param.menu eq 'costMgmt'}">
<input type="button" value="지급완료" class="plm_btns" id="btnConfirm" name="btnConfirm">
</c:if>
<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" style="width:70px">
<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="contract_no">영업번호</label></td>
<td>
<select name="contract_no" id="contract_no" style="width:180px" class="select2" autocomplete="off" >
<option value="">선택</option>
${code_map.contract_no}
</select>
</td>
<td><label for="project_no">프로젝트번호</label></td>
<td>
<select name="project_no" id="project_no" style="width:300px;" class="select2" autocomplete="off" multiple="multiple">
<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:180px" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.partner_objid}
</select>
</td>
</tr>
<tr>
<td><label>입고일</label></td>
<td>
<input type="text" name="RECEIPT_START_DATE" id="RECEIPT_START_DATE" style="width:90px;" autocomplete="off" value="${param.RECEIPT_START_DATE}" class="date_icon">~
<input type="text" name="RECEIPT_END_DATE" id="RECEIPT_END_DATE" style="width:90px;" autocomplete="off" value="${param.RECEIPT_END_DATE }" class="date_icon">
</td>
<td><label>자금지급일</label></td>
<td>
<input type="text" name="payment_start_date" id="payment_start_date" style="width:90px;" autocomplete="off" value="${param.payment_start_date}" class="date_icon">~
<input type="text" name="payment_end_date" id="payment_end_date" style="width:90px;" autocomplete="off" value="${param.payment_end_date }" class="date_icon">
</td>
</tr>
</table>
</div>
<div style="width:50%;float:left; color: RED;" class="purchaseOrderSum">
</div>
<%@include file= "/WEB-INF/view/common/common_gridArea.jsp" %>
</div>
</div>
</form>
</body>
</html>