- 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
367 lines
16 KiB
Plaintext
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> |