419 lines
16 KiB
Plaintext
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 =" <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> |