Files
wace_plm/WebContent/WEB-INF/view/contractMgmt/contractDashboard.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

367 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 %>" />
<script>
$(document).ready(function(){
$('.select2').select2();
fnc_datepick();
$("#btnSearch").click(function(){
$("#page").val("1");
fn_search();
});
$("#btnAddReturnProduct").click(function(){
window.open("/ordermgmt/productReturnMngForm.do","productReturnMngForm","width=600, height=350, menubars=no, scrollbars=yes, resizable=yes");
});
//엔터 조회
$("input").keyup(function(e){
if(e.keyCode == 13){
$("#page").val("1");
fn_search();
}
});
fnc_getCodeListAppend("CUST_CD","CUSTOMER_CD","${param.CUSTOMER_CD}");
$("#Year").val("${sysYear}");
});
function fn_search(){
document.form1.action = "/contractMgmt/contractDashBoard.do";
document.form1.submit();
}
function fn_openTargetList(productCategory,product,targetType,dateType,searchYear,startDate,endDate){
var hiddenForm = document.hiddenForm;
var url = "";
if("contract" == targetType){
url = "/contractMgmt/contractList.do";
hiddenForm.Year.value = searchYear;
hiddenForm.contract_start_date.value = startDate;
hiddenForm.contract_end_date.value = endDate;
}else{
url = "/releaseMgmt/releaseMgmtList.do";
hiddenForm.Year.value = searchYear;
hiddenForm.contract_start_date.value = startDate;
hiddenForm.contract_end_date.value = endDate;
}
window.open(url,"openTargetList","width=1500, height=1000, menubars=no, scrollbars=yes, resizable=yes");
hiddenForm.target = "openTargetList";
hiddenForm.PRODUCT_CATEGORY.value = productCategory;
hiddenForm.PRODUCT.value = product;
hiddenForm.action = url;
hiddenForm.submit();
}
</script>
</head>
<body>
<form name="hiddenForm" id="hiddenForm" action="" method="post">
<input type="hidden" name="PRODUCT_CATEGORY" id="PRODUCT_CATEGORY">
<input type="hidden" name="PRODUCT" id="PRODUCT">
<input type="hidden" name="RESULT_TYPE" id="RESULT_TYPE">
<input type="hidden" name="SEARCH_YEAR" id="SEARCH_YEAR">
<input type="hidden" name="Year" id="Year">
<input type="hidden" name="SEARCH_START_DATE" id="SEARCH_START_DATE">
<input type="hidden" name="contract_start_date" id="contract_start_date">
<input type="hidden" name="SEARCH_END_DATE" id="SEARCH_END_DATE">
<input type="hidden" name="contract_end_date" id="contract_end_date">
</form>
<form name="form1" id="form1" action="" method="post">
<div class="content-box">
<div class="content-box-s">
<div class="plm_menu_name">
<h2>
<span>영업관리_계약현황</span>
</h2>
</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) or (sysYear eq req_year) ? 'selected':'' }>${req_year}</option>
</c:forEach>
</select>
</td>
<td><label for="type_cd">구분</label></td>
<td>
<select name="type_cd" id="type_cd" style="" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.type_cd}
</select>
</td>
<td><label for="customer_cd">고객명</label></td>
<td>
<select name="customer_cd" id="customer_cd" style="" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.customer_cd}
</select>
</td>
<%-- <td><label for="area_cd">지역</label></td>
<td>
<select name="area_cd" id="area_cd" style="" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.area_cd}
</select>
</td> --%>
<td><label for="product_cd">제품구분</label></td>
<td>
<select name="product_cd" id="product_cd" style="" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.product_cd}
</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}">~
<input type="text" name="contract_end_date" id="contract_end_date" style="width:90px;" autocomplete="off" value="${param.contract_end_date}">
</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.status_cd}
</select>
</td> --%>
</tr>
</table>
</div>
<div class="contents_page_basic_margin">
<div class="btn_wrap">
<div class="plm_btn_wrap">
<input type="button" value="조회" class="plm_btns" id="btnSearch" name="btnSearch">
</div>
</div>
<div class="plm_table_wrap">
<div style="overflow-y:scroll;">
<table class="plm_table">
<colgroup>
<col width="7%">
<col width="6%">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
</colgroup>
<thead>
<tr class="plm_thead">
<!-- <td colspan="2" rowspan="2" style="font-size:15px;">제품군</td> -->
<td rowspan="2" style="font-size:15px;">명칭</td>
<td rowspan="2" style="font-size:15px;">제품구분</td>
<c:if test="${!empty monthList}">
<c:forEach var="info" items="${monthList}" varStatus="status">
<td colspan="2" class="plm_thead" style="font-size:15px;">${info.MONTH_TITLE}</td>
</c:forEach>
</c:if>
<td colspan="2" style="font-size:15px;">계</td>
</tr>
<tr>
<c:if test="${!empty monthList}">
<c:forEach var="info" items="${monthList}" varStatus="status">
<td class="plm_thead" style="font-size:15px;">수주</td>
<td class="plm_thead" style="font-size:15px;">출고</td>
</c:forEach>
</c:if>
<td class="plm_thead" style="font-size:15px;">수주</td>
<td class="plm_thead" style="font-size:15px;">출고</td>
</tr>
</thead>
</table>
</div>
<div class="plm_scroll_table" style="height:500px;">
<table class="plm_table">
<colgroup>
<col width="7%">
<col width="6%">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
<col width="*">
</colgroup>
<tbody>
<c:choose>
<c:when test="${!empty LIST}">
<c:forEach var="item" items="${LIST}" varStatus="status">
<c:choose>
<c:when test="${empty item.CODE_NAME and empty item.PRODUCT_CODE}">
<tr>
<td class="plm_thead" style="font-size:15px;" colspan="2">소계(확정대수)</td>
<c:if test="${!empty monthList}">
<c:forEach var="month" items="${monthList}" varStatus="status">
<c:set var="contractColName" value="${month.CONTRACT_MONTH_COL_NAME}" />
<c:set var="releaseColName" value="${month.RELEASE_MONTH_COL_NAME}" />
<c:set var="monthFirstDayColName" value="${month.MONTH_FIRST_DAY_COL_NAME}" />
<c:set var="monthLastDayColName" value="${month.MONTH_LAST_DAY_COL_NAME}" />
<c:set var="monthVal" value="${month.MONTH}" />
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','contract','month','${item.TARGET_YEAR}','${item[monthFirstDayColName]}','${item[monthLastDayColName]}');"><fmt:formatNumber value="${item[contractColName]}"/></a>
</td>
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','release','month','${item.TARGET_YEAR}','${item[monthFirstDayColName]}','${item[monthLastDayColName]}');"><fmt:formatNumber value="${item[releaseColName]}"/></a>
</td>
</c:forEach>
</c:if>
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','contract','year','${item.TARGET_YEAR}','','');">${item.CONTRACT_CNT_YEAR}</a>
</td>
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','release','year','${item.TARGET_YEAR}','','');">${item.RELEASE_CNT_YEAR}</a>
</td>
</tr>
<tr>
<td class="plm_thead" style="font-size:15px;" colspan="2">수주확정 매출합계(원)</td>
<c:if test="${!empty monthList}">
<c:forEach var="month" items="${monthList}" varStatus="status">
<c:set var="contractColName" value="${month.CONTRACT_MONTH_COL_NAME}" />
<c:set var="contractCostColName" value="${month.CONTRACT_COST_MONTH_COL_NAME}" />
<c:set var="releaseColName" value="${month.RELEASE_MONTH_COL_NAME}" />
<c:set var="monthFirstDayColName" value="${month.MONTH_FIRST_DAY_COL_NAME}" />
<c:set var="monthLastDayColName" value="${month.MONTH_LAST_DAY_COL_NAME}" />
<c:set var="monthVal" value="${month.MONTH}" />
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;" colspan="2">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','fund','month','${item.TARGET_YEAR}','${item[monthFirstDayColName]}','${item[monthLastDayColName]}');"><fmt:formatNumber value="${item[contractCostColName]}"/></a>
</td>
</c:forEach>
</c:if>
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;" colspan="2">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','fund','year','${item.TARGET_YEAR}','','');">${item.CONTRACT_COST_YEAR}</a>
</td>
</tr>
</c:when>
<c:otherwise>
<tr>
<td class="plm_thead" style="font-size:15px;">${item.RNUM eq '1' ? item.CODE_NAME:''}</td>
<td class="plm_thead" style="font-size:15px;">${item.PRODUCT_CODE}</td>
<c:if test="${!empty monthList}">
<c:forEach var="month" items="${monthList}" varStatus="status">
<c:set var="contractColName" value="${month.CONTRACT_MONTH_COL_NAME}" />
<c:set var="releaseColName" value="${month.RELEASE_MONTH_COL_NAME}" />
<c:set var="monthFirstDayColName" value="${month.MONTH_FIRST_DAY_COL_NAME}" />
<c:set var="monthLastDayColName" value="${month.MONTH_LAST_DAY_COL_NAME}" />
<c:set var="monthVal" value="${month.MONTH}" />
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','contract','month','${item.TARGET_YEAR}','${item[monthFirstDayColName]}','${item[monthLastDayColName]}');"><fmt:formatNumber value="${item[contractColName]}"/></a>
</td>
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','release','month','${item.TARGET_YEAR}','${item[monthFirstDayColName]}','${item[monthLastDayColName]}');"><fmt:formatNumber value="${item[releaseColName]}"/></a>
</td>
</c:forEach>
</c:if>
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','contract','year','${item.TARGET_YEAR}','','');">${item.CONTRACT_CNT_YEAR}</a>
</td>
<td style="font-size:15px;text-align:center; padding:0px 8px 0px 0px;">
<a href="#" onclick="javascript:fn_openTargetList('${item.PRODUCT_GROUP}','${item.PRODUCT}','release','year','${item.TARGET_YEAR}','','');">${item.RELEASE_CNT_YEAR}</a>
</td>
</tr>
</c:otherwise>
</c:choose>
</c:forEach>
</c:when>
<c:otherwise>
<tr>
<!-- <td colspan="27" align="center">조회된 데이터가 없습니다.</td> -->
<td colspan="28" align="center">조회된 데이터가 없습니다.</td>
</tr>
</c:otherwise>
</c:choose>
</tbody>
</table>
</div>
</div>
</div>
</div>
</div>
</form>
</body>
</html>