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

460 lines
15 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">
/* 등록중 WPS00700
배포 WPS00800
조치중 WPS00900
결재중 WPS01000
결재완료 WPS01100
미조치대상 WPS01200 */
$(function(){
$(document).ready(function(){
$('.select2').select2();
$(".btnApproval").click(function(){
var objId = fnc_checkNull($("input[type=radio]:checked").val());
var approvalReleaseStatus = fnc_checkNull($("input[type=radio]:checked").attr("data-APPROVAL_STATUS"));
var approvalReleaseFlag = fnc_checkNull($("input[type=radio]:checked").attr("data-APPROVAL_FLAG"));
var content = fnc_checkNull($("input[type=radio]:checked").attr("data-CONTENT"));
var result = fnc_checkNull($("input[type=radio]:checked").attr("data-RESULT"));
var wpstNo = fnc_checkNull($("input[type=radio]:checked").attr("data-WPST_CD"));
var solUserid = fnc_checkNull($("input[type=radio]:checked").attr("data-SOL_USERID"));
var title = fnc_checkNull($("input[type=radio]:checked").attr("data-TITLE"));
//결재 상태값 변경을 위한 값
$("#objId").val(objId);
if("${writer}" == solUserid || "${writer}" == "plm_admin"){
if(approvalReleaseStatus != "complete"){
if(wpstNo == 'WPS00900'){
//결재 상태값 변경을 위한 값
$("#status").val("WPS01000");
if(result != ""){
if(objId == ""){
Swal.fire("선택된 대상이 없습니다.");
}else{
window.open("/approval/registApproval.do?targetType=ISSUE_RELEASE&targetObjId="+objId+"&approvalTitle="+title+"&callbackFnc=opener.fn_wpstUpdate","registApproval","width=700,height=700");
}
}else{
Swal.fire("결재 상신 가능한 상태가 아닙니다.\n문제점 현상 작성 완료 후 상신 가능합니다.");
}
}else{
Swal.fire("결재 대상이 아닙니다.");
}
} else {
Swal.fire("이미 결재처리 되어습니다.");
}
} else {
Swal.fire("결재상신은 담당자만 가능합니다.");
}
});
$(".btnRegister").click(function(){
var objId = fnc_checkNull($("input[type=radio]:checked").val());
var approvalReleaseStatus = fnc_checkNull($("input[type=radio]:checked").attr("data-APPROVAL_STATUS"));
var content = fnc_checkNull($("input[type=radio]:checked").attr("data-CONTENT"));
var wpstNo = fnc_checkNull($("input[type=radio]:checked").attr("data-WPST_CD"));
var writer = fnc_checkNull($("input[type=radio]:checked").attr("data-WRITER"));
//결재 상태값 변경을 위한 값
$("#objId").val(objId);
if("${writer}" == writer || "${writer}" == "plm_admin"){
if(wpstNo == "WPS00700"){
$("#objId").val(objId);
$("#status").val("WPS00800");
}else{
Swal.fire("이미 배포되었거나 배포대상이 아닙니다.");
return;
}
fn_wpstUpdate();
Swal.fire("배포 되었습니다.");
} else {
Swal.fire("배포권한이 없습니다.");
}
});
//등록 팝업
$(".btnRegist").click(function(){
var params = "?actionType=regist"
window.open("/project/issueFormPopup.do"+params, "", "width=1350, height=630");
});
//상세 팝업
$(".btnDetail").click(function(){
var objId = $(this).attr("data-OBJID");
var params = "?objId="+objId;
window.open("/project/issueDetailPopup.do"+params, "", "width=1350, height=630");
});
// 첨부파일 팝업
$(".btnFile").click(function(){
var objId = $(this).attr("data-OBJID");
var params = "?targetObjId="+objId;
window.open("/project/gate/issueFileRegistPopup.do"+params, "", "width=800, height=330");
});
//조회
$(".btnSearch").click(function(){
fn_search();
});
//엔터키로 조회
$("input").keyup(function(e){
if(e.keyCode == 13){
$("#page").val("1");
fn_search();
}
});
fnc_datepick();
});
if(""!="${param.occu_cd}"){
optionJobGroup("${param.occu_cd}");
}
$(".btnApprovalDetail").click(function(){
var approvalObjId = $(this).attr("data-APPROVAL_OBJID");
var routeObjId = $(this).attr("data-ROUTE_OBJID");
//Swal.fire("approvalObjId : "+approvalObjId+", routeObjId : "+routeObjId);
var params = "?approvalObjId="+approvalObjId;
params += "&routeObjId="+routeObjId;
//Swal.fire("params : "+params);
window.open("/approval/approvalDetail.do"+params,"approvalDetailPopup","width=650 height=810 menubar=no status=no");
});
});
</script>
<script>
function fn_issuedetail(objId){
var params = "?objId="+objId;
window.open("/project/issueDetailPopup.do"+params, "", "width=1350, height=630");
}
function fn_search(){
document.form1.action="/project/issueList.do";
document.form1.target="_self";
document.form1.submit();
}
//코드값을 받아와서 동적으로 selectbox 생성
function optionJobGroup(value){
var val=value;
var params = "";
var option="";
var combobox = $("#customer_cd");
combobox.empty();
option += "<option value=''>전체</option>";
if(val=="OCC00200"){
option += "${code_map.customer_cd}";
/* params += "code="+val;
$.ajax({
type : "POST",
url : "/project/makeproject.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);
}
combobox.append(option);
}
//결재상태 변경
function fn_wpstUpdate(){
var objId = $("#objId").val();
var status = $("#status").val();
$.ajax({
url:"/project/issueWpstStatusUpdate.do",
type:"POST",
data:{"objId": objId , "status" : status},
dataType:"json",
success:function(data){
fn_search();
},
error: function(jqxhr, status, error){
}
});
}
//영업활동등록 상세
function fn_projectConceptDetail(objId){
window.open("/ordermgmt/ordermgmtUpdateFormPopup.do?objId="+objId, "", "width=650, height=930");
}
</script>
</head>
<body class="backcolor">
<form name="form1" action="" method="post">
<div style="min-width:1600px;">
<input type="hidden" name="objId" id="objId">
<input type="hidden" name="status" id="status">
<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 ? 'selected':'' }>${req_year}</option>
</c:forEach>
</select>
</td>
<td><label for="issue_cd">구분</label></td>
<td>
<select name="issue_cd" id="issue_cd" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.issue_cd}
</select>
</td>
<td><label for="project_code">Project No.</label></td>
<td>
<select name="project_code" id="project_code" style="width:200px;" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.projectno}
</select>
</td>
<td><label for="occu_cd">발생처</label></td>
<td>
<select name="occu_cd" id="occu_cd" onchange='optionJobGroup($(this).val())' class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.occu_cd}
</select>
</td>
<td><label for="customer_cd">업체명</label></td>
<td>
<select name="customer_cd" id="customer_cd" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.customer_cd}
</select>
</td>
<td><label for="writer">등록자</label></td>
<td>
<select name="writer" id="writer" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.user_id}
</select>
</td>
<td><label for="sol_userid">조치 담당자</label></td>
<td>
<select name="sol_userid" id="sol_userid" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.sol_userid}
</select>
</td>
</tr>
<tr>
<td><label for="wpst_cd">상태</label></td>
<td>
<select name="wpst_cd" id="wpst_cd" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.wpst_cd}
</select>
</td>
<td><label for="step_cd">단계</label></td>
<td>
<select name="step_cd" id="step_cd" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.step_cd}
</select>
</td>
<td><label for="case_cd">유형</label></td>
<td>
<select name="case_cd" id="case_cd" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.case_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 btnSearch">
<input type="button" value="등록" class="plm_btns btnRegist">
<input type="button" value="배포" class="plm_btns btnRegister">
<input type="button" value="결재상신" class="plm_btns btnApproval">
</div>
</div>
<div class="plm_table_wrap">
<table class="plm_table">
<colgroup>
<col width="2%">
<col width="4%">
<col width="4%">
<col width="10%">
<col width="20%">
<col width="4%">
<col width="7%">
<col width="5%">
<col width="7%">
<col width="5%">
<col width="5%">
<col width="7%">
<col width="5%">
<col width="6%">
<col width="5%">
<col width="5%">
</colgroup>
<thead>
<tr class="plm_thead">
<td><!-- <input type="checkbox"> --></td>
<td>Issue No.</td>
<td>구분</td>
<td>Project No</td>
<td>제목</td>
<td>발생처</td>
<td>업체명</td>
<td>단계</td>
<td>유형</td>
<td>작성자</td>
<td>등록일</td>
<td>조치예정일</td>
<td>조치담당자</td>
<td>조치일</td>
<td>발생비용(원)</td>
<td>상태</td>
</tr>
</thead>
<c:choose>
<c:when test="${empty LIST}">
<tr style="text-align:center;">
<td align="center" colspan="16">조회된 데이터가 없습니다.</td>
</tr>
</c:when>
<c:otherwise>
<c:forEach var="info" items="${LIST}" varStatus="varStatus">
<tr>
<%-- <td><input type="checkbox" name="chk" id="chk" data-objId="${info.OBJID}"></td> --%>
<td><input type="radio" value="${info.OBJID}" name="targetRadio" data-WPST_CD="${info.WPST_CD}" data-WRITER="${info.WRITER}" data-SOL_USERID="${info.SOL_USERID}" data-CONTENT="${info.CONTENT}" data-RESULT="${info.RESULT}" data-TITLE="${info.TITLE}" data-APPROVAL_STATUS="${info.APPROVAL_STATUS}" data-APPROVAL_FLAG="${info.APPROVAL_FLAG}"></td>
<td title="${info.ISSUE_NO}"><a href="#" data-OBJID="${info.OBJID}" class="btnDetail">${info.ISSUE_NO}</a></td>
<td title="${info.ISU_NAME}">${info.ISU_NAME}</td>
<td title="${info.PROJECT_NAME}"><a href="#" onclick="javascript:fn_projectConceptDetail('${info.PARENT_OBJID}')">${info.PROJECT_NAME}</td>
<td title="${info.TITLE}" style="text-align:left; padding:0px 0px 0px 15px;"><a href="#" onclick="javascript:fn_issuedetail('${info.OBJID}')">${info.TITLE}</a></td>
<td title="${info.OCCU_NAME}">${info.OCCU_NAME}</td>
<td title="${info.STEP_NAME}">${info.CUSTOMER_NAME}</td>
<td title="${info.STEP_NAME}">${info.STEP_NAME}</td>
<td title="${info.CASE_NAME}">${info.CASE_NAME}</td>
<td title="${info.WRITER_NAME}">${info.WRITER_NAME}</td>
<td title="${info.REG_DATE}">${info.REG_DATE}</td>
<td title="${info.REQ_DATE}">${info.REQ_DATE}</td>
<td title="${info.SOL_USERID}">${info.SOL_USER_NAME}</td>
<td title="${info.RET_DATE}">${info.RET_DATE}</td>
<td title="${info.CUR_COST}" align="right"><fmt:formatNumber value="${info.CUR_COST}" pattern="#,###"/>&nbsp;&nbsp;</td>
<td title="${info.WPST_CD}">
<a href="#" class="btnApprovalDetail" data-APPROVAL_OBJID="${info.APPROVAL_OBJID}" data-ROUTE_OBJID="${info.ROUTE_OBJID}">
${info.APPROVAL_STATUS eq 'complete' ? '조치완료' : (info.APPROVAL_STATUS eq 'reject' ? '반려' : info.WPST_NAME)}</a>
</td>
</tr>
</c:forEach>
</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>
</div>
</div>
</div>
</div>
<input type="hidden" id="hdcustomer_cd" value="${code_map.customer_cd}"/>
</form>
</body>
</html>