Files
vexplor/WebContent/WEB-INF/view/project/projectMgmtList_back.jsp
2025-08-21 09:41:46 +09:00

696 lines
27 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="totalCount" value="${empty TOTAL_COUNT?0:TOTAL_COUNT}" />
<c:set var="maxPage" value="${empty MAX_PAGE_SIZE?1:MAX_PAGE_SIZE}" />
<c:set var="nPage" value="${empty param.page?1:param.page}" />
<c:set var="pageIndex" value="${(nPage-1)/10}" />
<c:set var="nextPage" value="${empty NEXT_PAGE?1:NEXT_PAGE}" />
<c:set var="prevPage" value="${empty PREV_PAGE?1:PREV_PAGE}" />
<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 %>" />
<script>
$(document).ready(function(){
$("._table1").scroll(function () {
$("._table2").scrollLeft($("._table1").scrollLeft());
});
$("._table2").scroll(function () {
$("._table1").scrollLeft($("._table2").scrollLeft());
});
//날짜
_fnc_datepick();
$('.select2').select2();
$("#btnSearch").click(function(){
$("#page").val("1");
fn_search();
});
//SR자료등록 팝업
$(".File").click(function(){
var popup_width = 800;
var popup_height = 250;
var objId = $(this).attr("data-OBJID");
var docType =$(this).attr("data-docType");
var docTypeName = $(this).attr("data-docTypeName");
var params = "?targetObjId="+objId+"&docType="+docType+"&docTypeName="+docTypeName;
var url = "/projectConcept/FileRegistPopup.do"+params;
fn_centerPopup(popup_width, popup_height, url);
});
//영업활동 등록 팝업
$("#btnCreate").click(function(){
var popup_width = 1830;
var popup_height = 730;
var url = "/project/projectMgmtCreateList.do";
//window.open("/ordermgmt/ordermgmtUpdateFormPopup.do"+params, "", "width=650, height=750","menubars=no, scrollbars=yes, resizable=yes");
fn_centerPopup(popup_width, popup_height, url);
});
//wbs 등록
$(".wbs").click(function(){
var popup_width = 1800;
var popup_height = 800;
var objId = $(this).attr("data-OBJID");
var params = "?OBJID="+objId;
var url = "/project/wbsTaskProductFormPopUp.do"+params;
fn_centerPopup(popup_width, popup_height, url);
});
//wbs 등록
$(".modify").click(function(){
var popup_width = 420;
var popup_height = 350;
var objId = $(this).attr("data-OBJID");
var params = "?OBJID="+objId;
var url = "/project/projectmodifyPopUp.do"+params;
fn_centerPopup(popup_width, popup_height, url);
});
//고객 등록 팝업
$(".supplyMng").click(function(){
//window.open("/ordermgmt/ordermgmtUpdateFormPopup.do"+params, "", "width=650, height=750","menubars=no, scrollbars=yes, resizable=yes");
window.open("/contractMgmt/supplyMngPagingList.do", "", "width=1150, height=676","menubars=no, scrollbars=no, resizable=yes");
});
//엔터 조회
$("input").keyup(function(e){
if(e.keyCode == 13){
$("#page").val("1");
fn_search();
}
});
//체크박스 전체선택/전체해제
$("#allCheck").click(function(){
if($("#allCheck").prop("checked")) {
$("input[type=checkbox]").prop("checked",true);
} else {
$("input[type=checkbox]").prop("checked",false);
}
});
// 부분체크해제
$("input[name=chk_objId]").click(function(){
if($("#allCheck").is(":checked")){
$("#allCheck").prop("checked",false);
}
});
//삭제
$("#btnDelete").click(function(){
fn_delete();
});
$("#btnExcel").click(function(){
document.form1.actionType.value = "excel";
document.form1.action = "/contractMgmt/contractList.do";
document.form1.submit();
});
});
function _fnc_datepick(){
var $dateinput = $("input.date_icon");
for(var i=0; i<$dateinput.length; i++){
$dateinput.eq(i).attr("size","10");
$dateinput.eq(i).datepicker({
changeMonth:true,
changeYear:true
});
}
}
function fn_delete(){
if(0 < $("input[name=chk_objId]:checked").length){
var checkArr = new Array();
var ngCnt = 0;
$("input[name=chk_objId]:checked").each(function(){
var objId = fnc_checkNull($(this).val().replace(" ",""));
// var currentStatus = $(this).attr("data-STATUS");
// if("결재중" == currentStatus || "결재완료" == currentStatus){
// ngCnt++;
// }
checkArr.push(objId);
});
if(confirm("선택한 정보를 삭제하시겠습니까?")){
var param = $("#form1").serialize();
$.ajax({
type : "POST",
url : "/project/deleteProjectMngInfo.do",
data: {"checkArr":checkArr.join()},
dataType:"json",
success:function(data){
Swal.fire(data.msg);
if(data.result){
fn_search();
};
}
,error: function(jqxhr, status, error){
}
});
}
}else{
Swal.fire("선택한 항목이 없습니다.");
}
}
//영업활동등록 상세
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_search(){
document.form1.action = "/project/projectMgmtList.do";
document.form1.submit();
}
//코드값을 받아와서 동적으로 selectbox 생성
function optionJobGroup(code){
var val=code;
var params = "";
var option="";
var combobox = $("#writer");
combobox.empty();
if(val!=""){
params += "codeId="+val;
$.ajax({
type : "POST",
url : "/projectConcept/makewrite.do",
data : params,
dataType:"json",
async: false,
success: function(data){
if(data.RESULT !=""){
option += "<option value=''>전체</option>";
option += data.RESULT;
combobox.append(option);
}
}
});
// Swal.fire(Number(lev-1));
//$("#code"+Number(lev-1)).val(code).prop("selected", true);
}else{
option += "<option value=''>전체</option>";
combobox.append(option);
}
}
//코드값을 받아와서 동적으로 selectbox 생성
function makeSelect(code){
var val=code;
var params = "";
var option="";
var combobox = $("#outc_cd6_td");
combobox.empty();
/* <select name="outc_cd6" id="outc_cd6" type="select">
<option value="">선택</option>
</select> */
if(val!="" && val!="PLA03000"){
params += "codeId="+val;
$.ajax({
type : "POST",
url : "/ordermgmt/makeCodeselect.do",
data : params,
dataType:"json",
async: false,
success: function(data){
if(data.RESULT !=""){
option += "<select name='outc_cd6' id='outc_cd6' type='select'>"
option += "<option value=''>선택</option>";
option += data.RESULT;
option += "</select>";
combobox.append(option);
$("#outc_cd6").val("${param.outc_cd6}");
//$("#outc_cd6").select2();
}
}
});
}else{
if(val=="PLA03000"){
option += "<input type='text' name='outc_cd6' id='outc_cd6' value='${param.outc_cd6}'>"
combobox.append(option);
}else{
option += "<select name='outc_cd6' id='outc_cd6' type='select'>"
option += "<option value=''>선택</option>";
option += "</select>";
combobox.append(option);
//$("#outc_cd6").select2();
}
}
}
function saveexcelpop() {
var partLength = $("input[name=partCheckBox]:checked").length;
if(partLength == 0){
Swal.fire('선택된 영업정보가 없습니다.');
return;
}
if(partLength > 1){
Swal.fire('단건씩 선택해 주세요');
return;
}
var orderobjId ="";
$("input[name=partCheckBox]:checked").each(function(){
orderobjId = fnc_checkNull($(this).attr("data-objId").replace(" ",""));
});
var url = "/ordermgmt/openOrderExcelImportPopUp.do?orderobjId="+orderobjId;
var target = "openOrderExcelImportPopUp";
window.open(url, target,"width=1245, height=700, menubars=no, scrollbars=yes, resizable=yes");
}
//프로젝트의 form,detail 팝업을 보여준다.
function openProjectFormPopUp(objId){
window.open("","projectFormPopUp","width=1150, height=676");
var params = "?actionType=regist"
var url = "/project/projectFormPopUp.do"+params;
if("" != objId){
url = "/project/projectDetailPopUp.do";
}
var form = document.form1;
form.objId.value = objId;
form.action = url;
form.target = "projectFormPopUp";
form.submit();
}
</script>
</head>
<body>
<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="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="category_cd">계약구분</label></td>
<td>
<select name="category_cd" id="category_cd" style="" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.category_cd}
</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="status_cd">진행사항</label></td>
<td>
<select name="status_cd" id="status_cd" style="" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.product_code}
</select>
</td> --%>
<td class="align_r">
<label>예상납기일</label>
</td>
<td>
<input type="text" name="contract_start_date" id="contract_start_date" style="width:90px;" autocomplete="off" value="${param.contract_start_date}" class="date_icon">~
<input type="text" name="contract_end_date" id="contract_end_date" style="width:90px;" autocomplete="off" value="${param.contract_end_date}" class="date_icon">
</td>
</tr>
<tr>
<td class="align_r">
<label>입고지</label>
</td>
<td>
<input type="text" name="location" id="location" style="width:150px;" autocomplete="off" value="${param.location}">
</td>
<td class="align_r">
<label>셋업지</label>
</td>
<td>
<input type="text" name="setup" id="setup" style="width:150px;" autocomplete="off" value="${param.setup}">
</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>
<td><label for="">출고여부</label></td>
<td>
<select name="pm_user_id" id="pm_user_id" style="width:200px" class="select2" autocomplete="off">
<option value="">선택</option>
<%-- ${code_map.pm_user_id} --%>
</select>
</td>
</tr>
<%-- <td><label for="result_cd">수주결과</label></td>
<td>
<select name="result_cd" id="result_cd" style="" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.result_cd}
</select>
</td> --%>
</table>
</div>
<section class="contents_page_basic_margin">
<!-- <div class="btn_wrap">
<div class="plm_btn_wrap">
231122 막음(고도화에서 자동생성으로 변경)
<input type="button" value="프로젝트등록" class="plm_btns" id="btnCreate" name="btnSearch">
<input type="button" value="삭제" class="plm_btns" id="btnDelete" name="btnDelete">
<input type="button" value="조회" class="plm_btns" id="btnSearch" name="btnSearch">
</div>
</div> -->
<div class="in_table_scroll_wrap _table1" style="height:80px;width:100%;">
<table class="plm_table">
<colgroup>
<!-- <col width="25px"> -->
<col width="70px"><!-- 프로젝트번호 -->
<col width="100px"><!-- 고객사 -->
<col width="100px"><!-- 제품구분 -->
<col width="150px"><!-- 고객사프로젝트명-->
<col width="130px"><!-- 당사사프로젝트명-->
<col width="80px"><!-- 고객납기일-->
<col width="60px"><!-- 셋업지-->
<col width="60px"><!-- 설비방향 -->
<col width="60px"><!-- 설비타입 -->
<col width="60px"><!-- 설비길이 -->
<col width="70px"><!-- PM -->
<col width="60px"><!-- 제작공장 -->
<col width="80px"><!-- 예상납기일 -->
<!-- <col width="60px">통화
<col width="100px">수주가 -->
<col width="50px"><!-- 발생 -->
<col width="50px"><!-- 조치 -->
<col width="50px"><!-- 미결 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<!-- <col width="50px">최종검수
<col width="50px">출하
<col width="50px">셋업
<col width="50px">셋업 -->
</colgroup>
<thead>
<tr class="plm_thead">
<!-- <td rowspan="2"><input type="checkbox" id="allCheck" class="checkBox"></td> -->
<td rowspan="3">프로젝트</br>번호</td>
<td colspan="12">프로젝트정보</td>
<td colspan="11">현황</td>
</tr>
<tr class="plm_sub_thead">
<!-- <td>당사프로젝트번호</td>
<td>계약구분</td>
<td>국내/해외</td> -->
<td rowspan="2">고객사</td>
<td rowspan="2">제품구분</br>(기계형식)</td>
<td rowspan="2">고객사프로젝트명</td>
<td rowspan="2">당사프로젝트명</td>
<td rowspan="2">고객납기일</td>
<!-- <td>입고지</td> -->
<td rowspan="2">셋업지</td>
<td rowspan="2">설비방향</td>
<!-- <td>설비대수</td> -->
<td rowspan="2">설비타입</td>
<td rowspan="2">설비길이</td>
<td rowspan="2">PM</td>
<td rowspan="2">제작공장</td>
<td rowspan="2">예상납기일</td>
<td colspan="4">이슈(건수)</td>
<td colspan="3">투입원가(억원)</td>
<td colspan="2">진척율</td>
<td colspan="2">출고</td>
</tr>
<tr class="plm_sub_thead">
<td>발생</td>
<td>조치</td>
<td>미결</td>
<td>조치율</td>
<td>목표가</td>
<td>투입금액</td>
<td>투입율</td>
<td>제작</td>
<td>셋업</td>
<td>출고여부</td>
<td>출고일</td>
</tr>
</thead>
</table>
</div>
<div class="in_table_scroll_wrap _table2" style="height:540px;width:100%;overflow-y:auto;">
<table class="plm_table">
<colgroup>
<!-- <col width="25px"> -->
<col width="70px"><!-- 프로젝트번호 -->
<col width="100px"><!-- 고객사 -->
<col width="100px"><!-- 제품구분 -->
<col width="150px"><!-- 고객사프로젝트명-->
<col width="130px"><!-- 당사사프로젝트명-->
<col width="80px"><!-- 고객납기일-->
<col width="60px"><!-- 셋업지-->
<col width="60px"><!-- 설비방향 -->
<col width="60px"><!-- 설비타입 -->
<col width="60px"><!-- 설비길이 -->
<col width="70px"><!-- PM -->
<col width="60px"><!-- 제작공장 -->
<col width="80px"><!-- 예상납기일 -->
<!-- <col width="60px">통화
<col width="100px">수주가 -->
<col width="50px"><!-- 발생 -->
<col width="50px"><!-- 조치 -->
<col width="50px"><!-- 미결 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<col width="50px"><!-- 조치율 -->
<!-- <col width="50px">최종검수
<col width="50px">출하
<col width="50px">셋업
<col width="50px">셋업 -->
</colgroup>
<c:choose>
<c:when test="${!empty LIST}">
<c:forEach var="info" items="${LIST}" varStatus="status">
<tr>
<%-- <td style="text-align:left; padding-left: 5px;">
<input type="checkbox" name="chk_objId" value="${info.OBJID}">
</td> --%><!-- 계약번호 -->
<td title="${info.PROJECT_NO}" style="text-align:left; padding-left: 5px;"><a href="#" class="modify" data-OBJID="${info.OBJID}">${info.PROJECT_NO}</a></td><!-- 계약번호 -->
<%-- <td title="${info.CATEGORY_NAME}" >${info.CATEGORY_NAME}</td><!-- 지역 -->
<td title="${info.AREA_NAME}">${info.AREA_NAME}</td><!-- 지역 --> --%>
<td title="${info.CUSTOMER_NAME}" style="text-align:left; padding-left: 5px;">${info.CUSTOMER_NAME}</td><!-- 고객명 -->
<td title="${info.PRODUCT_NAME}" >${info.PRODUCT_NAME}(${info.MECHANICAL_TYPE})</td><!-- 사업자등록번호 -->
<td title="${info.CUSTOMER_PROJECT_NAME}" style="text-align:left; padding-left: 5px;">${info.CUSTOMER_PROJECT_NAME}</td><!-- 사업자등록번호 -->
<td title="${info.PROJECT_NAME}" style="text-align:left; padding-left: 5px;">${info.PROJECT_NAME}</td><!-- 사업자등록번호 -->
<td title="${info.REQ_DEL_DATE}">${info.REQ_DEL_DATE}</td><!-- 사업자등록번호 -->
<%-- <td title="${info.LOCATION}">${info.LOCATION}</td><!-- 사업자등록번호 --> --%>
<td title="${info.SETUP}">${info.SETUP}</td><!-- 사업자등록번호 -->
<td title="${info.FACILITY_NAME}">${info.FACILITY_NAME}</td><!-- 사업자등록번호 -->
<%-- <td title="${info.FACILITY_QTY}"><fmt:formatNumber value="${info.FACILITY_QTY}" pattern="#,###" /></td><!-- 계약체결금액 --> --%>
<td title="${info.FACILITY_TYPE}">${info.FACILITY_TYPE}</td><!-- 사업자등록번호 -->
<td title="${info.FACILITY_DEPTH}">${info.FACILITY_DEPTH}</td><!-- 사업자등록번호 -->
<td title="${info.PM_USER_NAME}">${info.PM_USER_NAME}</td><!-- 사업자등록번호 -->
<td title="${info.PM_USER_NAME}">${info.MANUFACTURE_PLANT_NAME}</td><!-- 사업자등록번호 -->
<td title="${info.CONTRACT_DEL_DATE}">${info.CONTRACT_DEL_DATE}</td><!-- 예상납기일 -->
<%-- <td title="${info.CONTRACT_CURRENCY_NAME}">${info.CONTRACT_CURRENCY_NAME}</td><!-- 통화 -->
<td title="${info.CONTRACT_PRICE_CURRENCY}" style="text-align:right;padding-right: 10px;"><fmt:formatNumber value="${info.CONTRACT_PRICE_CURRENCY}" pattern="#,###" /></td><!-- 계약체결금액 --> --%>
<td title=""></td><!-- 발생 -->
<td title=""></td><!-- 조치 -->
<td title=""></td><!-- 미결 -->
<td title=""></td><!-- 조치율 -->
<td title=""></td><!-- 조치율 -->
<td title=""></td><!-- 조치율 -->
<td title=""></td><!-- 조치율 -->
<td title=""></td><!-- 조치율 -->
<td title=""></td><!-- 조치율 -->
<td title=""></td><!-- 조치율 -->
<td title=""></td><!-- 조치율 -->
<%-- <td><a href="#" class="wbs" data-OBJID="${info.OBJID}">${info.TOTAL_RATE}%</a></td><!-- 전체-->
<td><a href="#" class="wbs" data-OBJID="${info.OBJID}">${info.DESIGN_RATE}%</a></td><!-- 설계-->
<td><a href="#" class="wbs" data-OBJID="${info.OBJID}">${info.PURCHASE_RATE}%</a></td><!-- 구매-->
<td><a href="#" class="wbs" data-OBJID="${info.OBJID}">${info.PRODUCE_RATE}%</a></td><!-- 제작-->
<td><a href="#" class="wbs" data-OBJID="${info.OBJID}">${info.SELFINS_RATE}%</a></td><!-- 자체검수-->
<td><a href="#" class="wbs" data-OBJID="${info.OBJID}">${info.FINALINS_RATE}%</a></td><!-- 최종검수-->
<td><a href="#" class="wbs" data-OBJID="${info.OBJID}">${info.SHIP_RATE}%</a></td><!-- 출하-->
<td><a href="#" class="wbs" data-OBJID="${info.OBJID}">${info.SETUP_RATE}%</a></td><!-- 셋업--> --%>
<!--
<td>0</td>발생
<td>0</td>조치
<td>0</td>미결
<td>15000000</td>미결
<td>49.9%</td>미결 -->
</tr>
</c:forEach>
</c:when>
<c:otherwise>
<tr>
<td colspan="30" align="center">조회된 데이터가 없습니다.</td>
</tr>
</c:otherwise>
</c:choose>
</table>
</div>
<div class="pdm_page">
<input type="hidden" name="page" id="page" value="${nPage}">
<c:if test="${!empty LIST}">
<div class="page_pro">
<table align="center">
<tr>
<c:choose>
<c:when test="${nPage > 1}">
<td><a href="javascript:fnc_goPrev('${prevPage}');">prev</a></td>
<td>&nbsp;&nbsp;&nbsp;</td>
</c:when>
<c:otherwise>
<td class="no_more_page">prev</td>
<td>&nbsp;&nbsp;&nbsp;</td>
</c:otherwise>
</c:choose>
<c:forEach var="v" begin="${nPage>5?nPage-5:1}" end="${nPage>5?nPage+4:10}" step="1" varStatus="status">
<c:if test="${status.index -1 < maxPage}">
<c:choose>
<c:when test="${status.index eq nPage}">
<td><a href="#" class="now_page">${nPage}</a></td>
<td>&nbsp;&nbsp;&nbsp;</td>
</c:when>
<c:otherwise>
<td><a href="javascript:fnc_goPage('${status.index}');">${status.index}</a></td>
<td>&nbsp;&nbsp;&nbsp;</td>
</c:otherwise>
</c:choose>
</c:if>
</c:forEach>
<c:choose>
<c:when test="${nPage < maxPage}">
<td><a href="javascript:fnc_goNext('${nextPage}');">next</a></td>
</c:when>
<c:otherwise>
<td class="no_more_page">next</td>
</c:otherwise>
</c:choose>
</tr>
</table>
<c:if test="${!empty LIST}">
<p id="adminPageCount">총 ${totalCount}건</p>
</c:if>
</div>
</c:if>
</div>
</section>
</div>
</div>
</div>
</form>
</body>
</html>