- 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
391 lines
14 KiB
Plaintext
391 lines
14 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" %>
|
|
<!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>
|
|
|
|
<script type="text/javascript">
|
|
$(function() {
|
|
$(document).ready(function() {
|
|
fnc_datepick();
|
|
|
|
$("input[type=text]").keyup(function(e) {
|
|
if (e.keyCode == 13)
|
|
search();
|
|
});
|
|
|
|
$("#btnReg").click(function(){
|
|
fn_openEOMngPopUp("");
|
|
});
|
|
|
|
$("#btnDelete").click(function(){
|
|
fn_deleteEOMng();
|
|
});
|
|
|
|
$("#btnDeploy").click(function(){
|
|
fn_eoMngDeploy();
|
|
});
|
|
|
|
$("#btnSearch").click(function(){
|
|
fn_search();
|
|
});
|
|
|
|
$("#btnApproval").click(function(){
|
|
var eoMng = $("input[name=OBJID]:checked");
|
|
var title = "";
|
|
if(1 < eoMng.length){
|
|
Swal.fire("한번에 한개의 결재만 가능합니다.");
|
|
return false;
|
|
}else{
|
|
var targetStatus = eoMng.attr("data-STATUS");
|
|
var objId = eoMng.val();
|
|
|
|
if(targetStatus == "create" || targetStatus == "reject"){
|
|
if(confirm("결재상신 하시겠습니까?")){
|
|
window.open("/approval/registApproval.do?targetType=EO_MNG&targetObjId="+objId+"&approvalTitle="+title+"&callbackFnc=fn_search","registApproval","width=700,height=700");
|
|
}
|
|
}else{
|
|
Swal.fire("이미 결재완료 또는 결재중 상태입니다.");
|
|
return false;
|
|
}
|
|
}
|
|
});
|
|
|
|
$(".btnApprovalDetail").click(function(){
|
|
var approvalObjId = $(this).attr("data-APPROVAL_OBJID");
|
|
var routeObjId = $(this).attr("data-ROUTE_OBJID");
|
|
var params = "?approvalObjId="+approvalObjId;
|
|
params += "&routeObjId="+routeObjId;
|
|
//Swal.fire("params : "+params);
|
|
window.open("/approval/approvalDetail.do"+params,"approvalDetailPopup","width=650 height=400 menubar=no status=no");
|
|
});
|
|
|
|
$("#search_customer").change(function(){
|
|
$("#search_car_type").empty();
|
|
if("" != this.value){
|
|
fnc_getCarList("", this.value, "search_car_type","${param.search_car_type}");
|
|
}
|
|
});
|
|
|
|
if("" != "${param.search_customer}"){
|
|
fnc_getCarList("", "${param.search_customer}", "search_car_type","${param.search_car_type}");
|
|
}
|
|
|
|
fnc_getOEMList("search_customer", "${param.search_customer}");
|
|
|
|
fnc_getUserList("search_deploy_writer","${param.search_deploy_writer}");
|
|
|
|
$('.select2').select2();
|
|
|
|
});
|
|
});
|
|
|
|
function fn_openEOMngPopUp(objId){
|
|
var hiddenForm = document.hiddenForm;
|
|
|
|
var target = "eoMngTempListPopUp";
|
|
var url = "/eoMng/eoMngFormPopUp.do";
|
|
if("" != objId){
|
|
url = "/eoMng/eoMngDetailPopUp.do";
|
|
}
|
|
|
|
window.open("",target,"width=1200,height=650");
|
|
|
|
hiddenForm.OBJID.value = objId;
|
|
hiddenForm.action = url;
|
|
hiddenForm.target = target;
|
|
hiddenForm.submit();
|
|
}
|
|
|
|
function fn_deleteEOMng(){
|
|
var selectedEO = $("input[name=OBJID]:checked");
|
|
|
|
if(0 < selectedEO.length){
|
|
if(confirm("해당 EO를 삭제하시겠습니까?")){
|
|
$.ajax({
|
|
url:"/eoMng/deleteEOMng.do",
|
|
type:"POST",
|
|
data:$("#form1").serialize(),
|
|
dataType:"json",
|
|
success:function(data){
|
|
Swal.fire(data.msg);
|
|
fn_search();
|
|
},
|
|
error: function(jqxhr, status, error){
|
|
}
|
|
});
|
|
}
|
|
}
|
|
}
|
|
|
|
//EO 배포
|
|
function fn_eoMngDeploy() {
|
|
var selectedPart = $("input[name=OBJID]:checked");
|
|
|
|
if(0 < selectedPart.length){
|
|
if(confirm("선택된 EO를 배포하시겠습니까?")){
|
|
|
|
$.ajax({
|
|
url:"/eoMng/eoMngDeploy.do",
|
|
type:"POST",
|
|
data:$("#form1").serialize(),
|
|
dataType:"json",
|
|
success:function(data){
|
|
Swal.fire(data.msg);
|
|
fn_search();
|
|
},
|
|
error: function(jqxhr, status, error){
|
|
}
|
|
});
|
|
}
|
|
}else{
|
|
Swal.fire("선택된 Part가 없습니다.");
|
|
return false;
|
|
}
|
|
}
|
|
|
|
function search(){
|
|
var form = document.form1;
|
|
form.action = "/eoMng/eoMngTempList.do";
|
|
form.submit();
|
|
}
|
|
|
|
function fn_search(){
|
|
search();
|
|
}
|
|
|
|
</script>
|
|
|
|
</head>
|
|
<body class="backcolor">
|
|
<form name="hiddenForm" id="hiddenForm" method="post">
|
|
<input type="hidden" name="OBJID" id="OBJID">
|
|
</form>
|
|
<form name="form1" id="form1" method="post">
|
|
<div class="content-box">
|
|
<div class="content-box-s">
|
|
<div class="plm_menu_name">
|
|
<h2>
|
|
<span>설계통보(Engineering Order)</span>
|
|
</h2>
|
|
</div>
|
|
<div id="plmSearchZon">
|
|
<table>
|
|
<tbody>
|
|
<tr>
|
|
<!-- <td><label for="">고객사</label></td> -->
|
|
<!-- <td> -->
|
|
<!-- <select name="search_customer" id="search_customer" style="width:200px;" autocomplete="off" class="select2"></select> -->
|
|
<!-- </td> -->
|
|
<!-- <td><label for="">차종</label></td> -->
|
|
<!-- <td> -->
|
|
<!-- <select name="search_car_type" id="search_car_type" style="width:200px;" autocomplete="off" class="select2"></select> -->
|
|
<!-- </td> -->
|
|
<!-- <td><label for="">EO No.</label></td> -->
|
|
<!-- <td> -->
|
|
<%-- <input type="text" name="search_eo_no" id="search_eo_no" style="width:200px;" autocomplete="off" value="${param.search_eo_no}"> --%>
|
|
<!-- </td> -->
|
|
<!-- <td><label for="">EO Date</label></td> -->
|
|
<!-- <td> -->
|
|
<%-- <input type="text" name="search_eo_date_from" id="search_eo_date_from" style="width:90px;" autocomplete="off" value="${param.search_eo_date_from}">~ --%>
|
|
<%-- <input type="text" name="search_eo_date_to" id="search_eo_date_to" style="width:90px;" autocomplete="off" value="${param.search_eo_date_to}"> --%>
|
|
<!-- </td> -->
|
|
<!-- <td><label for="">배포자</label></td> -->
|
|
<!-- <td> -->
|
|
<!-- <select name="search_deploy_writer" id="search_deploy_writer" style="width:200px;" autocomplete="off" class="select2"></select> -->
|
|
<!-- </td> -->
|
|
|
|
<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 class="align_r"><label for="" class="">기종(모델)명</label></td>
|
|
<td>
|
|
<select name="product_code" id="product_code" style="width:150px;" class="select2" autocomplete="off">
|
|
<option value="">전체</option>
|
|
${code_map.product_code}
|
|
</select>
|
|
</td>
|
|
|
|
<td class="align_r"><label for="" class="">EO 종류</label></td>
|
|
<td>
|
|
<select name="eo_kind" id="eo_kind" style="width:150px;" class="select2" autocomplete="off">
|
|
<option value="">전체</option>
|
|
${code_map.eo_kind}
|
|
</select>
|
|
</td>
|
|
|
|
<td class="align_r"><label for="" class="">상태</label></td>
|
|
<td>
|
|
<select name="status_code" id="status_code" style="width:150px;" class="select2" autocomplete="off">
|
|
<option value="">전체</option>
|
|
${code_map.status_code}
|
|
</select>
|
|
</td>
|
|
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
<section class="contents_page_basic_margin">
|
|
<div class="btn_wrap">
|
|
<div class="plm_btn_wrap">
|
|
|
|
<input type="button" value="삭제" class="plm_btns" id="btnDelete">
|
|
<!-- <input type="button" value="배포" class="plm_btns" id="btnDeploy"> -->
|
|
<input type="button" value="결재상신" class="plm_btns" id="btnApproval">
|
|
<input type="button" value="등록" class="plm_btns" id="btnReg">
|
|
<input type="button" value="조회" class="plm_btns" id="btnSearch">
|
|
</div>
|
|
</div>
|
|
<div class="ascendig_text">
|
|
<font size="3px">총 ${fn:length(LIST)}건</font>
|
|
</div>
|
|
<div class="plm_table_wrap">
|
|
<div>
|
|
<table class="plm_table">
|
|
<colgroup>
|
|
<col width="2%" />
|
|
<col width="15%" /> <!-- no -->
|
|
<col width="8%" /> <!-- 기종 -->
|
|
<col width="6%" /> <!-- 종류 -->
|
|
<col width="5%" /> <!-- 구분 -->
|
|
<col width="8%" /> <!-- ECR NO -->
|
|
<col width="10%" /> <!-- 설변목적 -->
|
|
<col width="13%" /> <!-- 제목 -->
|
|
<col width="5%" /><!-- EO DATE -->
|
|
<col width="15%" /> <!-- EO 배포팀 -->
|
|
<col width="15%" /> <!-- 적용시기 -->
|
|
<col width="4%" /> <!-- 상태 -->
|
|
</colgroup>
|
|
<thead>
|
|
<tr class="plm_thead">
|
|
<td><input type="checkbox" name="allCheck"></td>
|
|
<td>EO No.</td>
|
|
<td>기종(모델)명</td>
|
|
<td>EO 종류</td>
|
|
<td>구분</td>
|
|
<td>ECR NO</td>
|
|
<td>설변 목적</td>
|
|
<td>제목</td>
|
|
<td>EO Date</td>
|
|
<td>EO 배포팀</td>
|
|
<td>적용시기</td>
|
|
<td>상태</td>
|
|
</tr>
|
|
</thead>
|
|
<c:choose>
|
|
<c:when test="${empty LIST}">
|
|
<tr style="text-align:center;">
|
|
<td align="center" colspan="12">조회된 데이터가 없습니다.</td>
|
|
</tr>
|
|
</c:when>
|
|
<c:otherwise>
|
|
<c:forEach var="item" items="${LIST}" varStatus="varStatus">
|
|
<tr>
|
|
<td><input type="checkbox" name="OBJID" value="${item.OBJID}" data-STATUS="${item.STATUS}" data-WRITER="${item.WRITER}"></td>
|
|
<td title="${item.EO_NO}" style="text-align: left; padding-left: 8px;"><a href="#" onclick="fn_openEOMngPopUp('${item.OBJID}');">${item.EO_NO}</a></td> <!-- No -->
|
|
<td title="${item.PRODUCT_TITLE}">${item.PRODUCT_TITLE}</td> <!-- 기종 모델명 -->
|
|
<td title="${item.EO_KIND_TITLE}">${item.EO_KIND_TITLE}</td> <!-- EO 종류 -->
|
|
<td title="${item.EO_GUBUN_TITLE}">${item.EO_GUBUN_TITLE}</td> <!-- 구분 -->
|
|
<%-- <td title="${item.EO_NO}"><a href="#" onclick="fn_openEOMngPopUp('${item.OBJID}');">${item.EO_NO}</a></td> <!-- EO No --> --%>
|
|
<td title="${item.ECR_NO_TITLE}">${item.ECR_NO_TITLE}</td> <!-- ecr no -->
|
|
<td title="${item.REQUEST_NAME}">${item.REQUEST_NAME}</td> <!-- 설변 목적 -->
|
|
<%-- <td title="${item.TITLE}">${item.TITLE}</td> <!-- 제목 --> --%>
|
|
<td title="${item.TITLE}" style="text-align: left; padding-left: 8px;">${item.TITLE}</td> <!-- 제목 -->
|
|
<td title="${item.REG_DATE_TIME}">${item.REG_DATE_TIME}</td> <!-- EO DATE -->
|
|
<td title="${item.DEPLOY_DEPT_NAME}" style="text-align: left; padding-left: 8px;">${item.DEPLOY_DEPT_NAME}</td> <!-- 배포팀 -->
|
|
<td title="${item.PERIOD_CODE_NAME}">${item.PERIOD_CODE_NAME_UNIT}
|
|
|
|
</td> <!-- 적용시기 -->
|
|
|
|
<td title="${item.STATUS_TITLE}">
|
|
<c:choose>
|
|
<c:when test="${item.STATUS ne 'create'}">
|
|
<a href="#" class="btnApprovalDetail" data-APPROVAL_OBJID="${item.APPROVAL_OBJID}" data-ROUTE_OBJID="${item.ROUTE_OBJID}">${item.STATUS_TITLE}</a>
|
|
</c:when>
|
|
<c:otherwise>
|
|
${item.STATUS_TITLE}
|
|
</c:otherwise>
|
|
</c:choose>
|
|
</td><!-- 상태 -->
|
|
</tr>
|
|
</c:forEach>
|
|
</c:otherwise>
|
|
</c:choose>
|
|
</table>
|
|
</div>
|
|
</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> </td>
|
|
</c:when>
|
|
<c:otherwise>
|
|
<td class="no_more_page">prev</td>
|
|
<td> </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> </td>
|
|
</c:when>
|
|
<c:otherwise>
|
|
<td><a href="javascript:fnc_goPage('${status.index}');">${status.index}</a></td>
|
|
<td> </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>
|
|
</form>
|
|
</body>
|
|
</html> |