ERP-node/WebContent/WEB-INF/view/costMgmt/costTotaltList.jsp

435 lines
18 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>
.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();
});
//엔터 조회
$("input").keyup(function(e){
if(e.keyCode == 13){
fn_search();
}
});
//등록
$("#btnReg").click(function(){
var targetObj = _tabulGrid.getSelectedData();
if(1 == targetObj.length){
var contractObjId = fnc_checkNull(targetObj[0].OBJID);
//var productGroup = fnc_checkNull(targetObj[0].PRODUCT_GROUP);
//var product = fnc_checkNull(targetObj[0].PRODUCT);
//var releaseObjId = fnc_checkNull(targetObj[0].RELEASE_OBJID);
fn_openGoalRegistPopUp(contractObjId);
}else if(0 == targetObj.length){
Swal.fire("선택된 내용이 없습니다.");
return false;
}else if(1 < targetObj.length){
Swal.fire("한번에 1개의 내용만 등록 가능합니다. ");
return false;
}
});
fn_search();
});
var columns = [
{headerHozAlign : 'center', hozAlign : 'left', width : '100', title : '프로젝트번호', field : 'PROJECT_NO' ,frozen:true,
formatter:fnc_createGridAnchorTag,
cellClick:function(e, cell){
var objid = fnc_checkNull(cell.getData().OBJID);
openProjectFormPopUp(objid);
}
},
{title:"프로젝트정보", headerHozAlign:'center', //고객정보
columns:[
{headerHozAlign : 'center', hozAlign : 'left', width : '120', title : '고객사', field : 'CUSTOMER_NAME' },
//{headerHozAlign : 'center', hozAlign : 'left', width : '90', title : '제품구분', field : 'PRODUCT_NAME' },
//{headerHozAlign : 'center', hozAlign : 'left', width : '90', title : '기계형식', field : 'MECHANICAL_TYPE' },
//{headerHozAlign : 'center', hozAlign : 'left', width : '200', title : '고객사프로젝트명', field : 'CUSTOMER_PROJECT_NAME' },
{headerHozAlign : 'center', hozAlign : 'left', width : '150', title : '당사프로젝트명', field : 'PROJECT_NAME' },
//{headerHozAlign : 'center', hozAlign : 'center', width : '100', title : '고객납기일', field : 'DUE_DATE' },
{headerHozAlign : 'center', hozAlign : 'center', width : '100', title : '요청납기일', field : 'REQ_DEL_DATE' },
{headerHozAlign : 'center', hozAlign : 'center', width : '130', title : '셋업지', field : 'SETUP' },
{headerHozAlign : 'center', hozAlign : 'center', width : '70', title : 'PM', field : 'PM_USER_NAME' }
]
},
{
title:'투입원가현황', headerHozAlign:'center',
columns:[
{title: '수주가', field: 'CONTRACT_PRICE',headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
},
{title: '목표가', field: 'TOTAL_COST_GOAL', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
},
{title: '실투입원가', field: 'TOTAL_COST_ACTUAL', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
}
,
{title: '투입율(%)', field: 'TOTAL_INPUT_RATE', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
}
,
{title: 'MC율(%)', field: 'MC_RATE', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
}
]
},
{
title:'재료비현황', headerHozAlign:'center',
columns:[
{title: '목표가', field: 'MATERIAL_COST_GOAL',headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
},
{title: '발생재료비', field: 'ACCRUAL_MATERIAL_COST', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
},
{title: '투입율(%)', field: 'MATERIAL_COST_GOAL_RATE', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
}
]
},
{
title:'노무비현황', headerHozAlign:'center',
columns:[
{title: '목표가', field: 'LABOR_COST_GOAL',headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
},
{title: '발생노무비', field: 'LABOR_COST_ACTUAL', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
},
{title: '투입율(%)', field: 'LABOR_INPUT_RATE', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
}
]
},
{
title:'경비현황', headerHozAlign:'center',
columns:[
{title: '목표가', field: 'EXPENSE_COST_GOAL',headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
},
{title: '발생경비', field: 'ACCRUAL_EXPENSE', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:fnc_createGridAnchorTagAndComma,
cellClick:function(e, cell){
var projectObjId = fnc_checkNull(cell.getData().OBJID);
fn_openTargetList(projectObjId);
}
},
{title: '투입율(%)', field: 'EXPENSE_RATE', headerHozAlign: 'center', hozAlign: 'right', width : '100',
formatter:"money", formatterParams:{thousand:",", symbolAfter:"p", precision:false,},
/* cellClick:function(e, cell){
var CONTRACT_OBJID = fnc_checkNull(cell.getData().CONTRACT_OBJID);
var CUSTOMER_OBJID = fnc_checkNull(cell.getData().CUSTOMER_OBJID);
var UNIT_CODE = fnc_checkNull(cell.getData().UNIT_CODE);
openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE);
} */
}
]
}
];
//var grid;
function fn_search(){
var selectedValues = $("#project_no").val();
$('<input>').attr({
type: 'hidden',
name: 'project_nos',
value: selectedValues
}).appendTo('#form1');
_tabulGrid = fnc_tabul_search(_tabul_layout_fitColumns, _tabulGrid, "/costMgmt/costTotaltGridList.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);
}
//프로젝트의 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);
}
//조립 등록 팝업
function openAssemblyWbsFormPopUp(CONTRACT_OBJID,CUSTOMER_OBJID,UNIT_CODE){
var popup_width = 1600;
var popup_height = 800;
var params = "?project_name="+CONTRACT_OBJID+"&customer_cd="+CUSTOMER_OBJID+"&unit_code="+UNIT_CODE;
var url = "/productionplanning/assemblyWbsFormPopUp.do"+params;
fn_centerPopup(popup_width, popup_height, url);
}
//목표가등록
function fn_openGoalRegistPopUp(contractObjId){
var popup_width = 450;
var popup_height = 200;
var hiddenForm = document.hiddenForm;
var url = "";
var target = "openPopup"+contractObjId;
url = "/costMgmt/costGoalRegistPopUp.do";
fn_centerPopup(popup_width, popup_height, "", target);
hiddenForm.action = url;
//hiddenForm.RELEASE_OBJID.value = releaseObjId;
hiddenForm.CONTRACT_OBJID.value = contractObjId;
hiddenForm.objId.value = contractObjId;
hiddenForm.target = target;
hiddenForm.submit();
}
function fn_openTargetList(contractObjid){
var hiddenForm = document.hiddenForm;
var url = "/costMgmt/expenseList.do";
window.open(url,"openTargetList","width=1800, height=700, menubars=no, scrollbars=yes, resizable=yes");
hiddenForm.contractObjid.value = contractObjid;
hiddenForm.target = "openTargetList";
hiddenForm.action = url;
hiddenForm.submit();
}
</script>
</head>
<body>
<form name="hiddenForm" id="hiddenForm" method="post">
<input type="hidden" name="CONTRACT_OBJID" id="CONTRACT_OBJID">
<input type="hidden" name="objId" id="objId">
<input type="hidden" name="contractObjid" id="contractObjid" >
</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>투입원가관리_현황</span>
</h2>
<div class="btnArea">
<input type="button" value="목표가 등록" class="plm_btns" id="btnReg" name="btnReg">
<input type="button" value="조회" class="plm_btns" 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="width:300px;" class="select2" autocomplete="off" multiple="multiple">
<option value="">선택</option>
${code_map.project_no}
</select>
</td>
<td><label for="customer_objid">고객사</label></td>
<td>
<select name="customer_objid" id="customer_objid" style="width:200px" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.customer_cd}
</select>
</td>
<td><label for="product">제품구분</label></td>
<td>
<select name="product" id="product" style="" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.product_cd}
</select>
</td>
<td><label for="pm_user_id">PM</label></td>
<td>
<select name="pm_user_id" id="pm_user_id" style="" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.pm_user_id}
</select>
</td>
</tr>
</table>
</div>
<%@include file= "/WEB-INF/view/common/common_gridArea.jsp" %>
</div>
</div>
</form>
</body>
</html>