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

481 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" %>
<!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_openECRMngPopUp("","");
});
$("#btnApproval").click(function(){
var ecrMng = $("input[name=OBJID]:checked");
if(1 < ecrMng.length){
Swal.fire("한번에 한개의 결재만 가능합니다.");
return false;
}else{
var targetStatus = ecrMng.attr("data-STATUS");
var title = ecrMng.attr("data-TITLE");
var objId = ecrMng.val();
if(targetStatus == "0000100" || targetStatus == "0000107" || targetStatus == "reject"){
if(confirm("결재상신 하시겠습니까?")){
window.open("/approval/registApproval.do?targetType=AS_MNG&targetObjId="+objId+"&approvalTitle="+title+"&callbackFnc=fn_search","registApproval","width=700,height=700");
}
}else{
Swal.fire("이미 결재완료 또는 결재중 상태입니다.");
return false;
}
}
});
//첨부파일 팝업
$(".File").click(function(){
var popup_width = 800;
var popup_height = 240;
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;
var target = "";
fn_centerPopup(popup_width, popup_height, url, target);
});
$("#btnDelete").click(function(){
fn_delete();
});
//체크박스 전체선택/전체해제
$("#allCheck").click(function(){
if($("#allCheck").prop("checked")) {
$("input[type=checkbox]").prop("checked",true);
} else {
$("input[type=checkbox]").prop("checked",false);
}
});
$(".btnApprovalDetail").click(function(){
var popup_width = 650;
var popup_height = 380;
var approvalObjId = $(this).attr("data-APPROVAL_OBJID");
var routeObjId = $(this).attr("data-ROUTE_OBJID");
var params = "?approvalObjId="+approvalObjId;
params += "&routeObjId="+routeObjId;
var url = "/approval/approvalDetail.do"+params;
var target = "approvalDetailPopup";
//Swal.fire("params : "+params);
fn_centerPopup(popup_width, popup_height, url, target);
});
});
$('.select2').select2();
});
function _fnc_datepick(){
var $dateinput = $("input");
for(var i=0; i<$dateinput.length; i++){
var id = $dateinput.eq(i).attr("id");
if(id != null){
if(id.indexOf("Date")>-1 || id.indexOf("date")>-1 || id.indexOf("DATE")>-1){
$dateinput.eq(i).attr("size","10");
$dateinput.eq(i).datepicker({
changeMonth:true,
changeYear:true
});
}else{
$dateinput.eq(i).attr("size","10");
}
}
}
}
function fn_openECRMngPopUp(objId,status){
var popup_width = 1400;
var popup_height = 530;
var hiddenForm = document.hiddenForm;
var actionType ="regist";
var target = "asMngFormPopUp";
var url = "/as/asMngFormPopUp.do";
if("" != status && "0000100" != status){
//url = "/as/asMngDetailPopUp.do";
actionType="viewOnly";
}
if("0000100" == status){
actionType="modify";
}
fn_centerPopup(popup_width, popup_height, "", target);
hiddenForm.objId.value = objId;
hiddenForm.actionType.value =actionType;
hiddenForm.action = url;
hiddenForm.target = target;
hiddenForm.submit();
}
function search(){
document.form1.action="/as/asMngList.do";
document.form1.submit();
}
function fn_search(){
search();
}
function fn_delete(){
var partLength = $("input[name=OBJID]:checked").length;
//초기화
$("#ecrobjid").val("");
if(0 < partLength){
var checkArr = new Array();
var statusFlag = false;
$("input[name=OBJID]:checked").each(function(){
var objId = fnc_checkNull($(this).attr("data-objId").replace(" ",""));
checkArr.push(objId);
statusFlag = true;
});
$("#ecrobjid").val(checkArr);
if(statusFlag){
var param = $("#hiddenForm").serialize();
$.ajax({
type : "POST",
url : "/as/asDelete.do",
data: param,
dataType:"json",
success:function(data){
if(data =="SUCCESS"){
Swal.fire("삭제되었습니다.");
fn_search();
};
}
,error: function(jqxhr, status, error){
}
});
}else{
Swal.fire("삭제 가능한 항목이 없습니다.");
}
}else{
Swal.fire("선택한 항목이 없습니다.");
}
}
</script>
</head>
<body class="backcolor">
<form name="hiddenForm" id="hiddenForm" method="post">
<input type="hidden" name="objId" id="objId">
<input type="hidden" name="actionType" id="actionType">
<input type="hidden" name="ecrobjid" id="ecrobjid">
</form>
<form name="form1" action="" method="post">
<div class="content-box">
<div class="content-box-s">
<div class="plm_menu_name">
<h2>
<span>AS 접수 및 처리</span>
</h2>
</div>
<div id="plmSearchZon">
<table>
<tbody>
<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 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="">기종모델명</label></td>
<td>
<select name="product_code1" id="product_code1" style="width:150px;" class="select2" autocomplete="off"> <option value="">전체</option>
${code_map.product_code}
</select>
</td> --%>
<td><label for="">출고일자</label></td>
<td>
<input type="text" id="search_release_date_from" name="search_release_date_from" style="width:70px;" autocomplete="off" value="${param.search_release_date_from}"/>~
<input type="text" id="search_release_date_to" name="search_release_date_to" style="width:70px;" autocomplete="off" value="${param.search_release_date_to}"/>
</td>
<td class="align_r"><label for="" class="">유/무상</label></td>
<td>
<select name="warranty_code" id="warranty_code" style="width:150px;" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.warranty_code}
</select>
</td>
<td class="align_r"><label for="" class="">접수유형</label></td>
<td>
<select name="rec_type" id="rec_type" style="width:150px;" class="select2" autocomplete="off">
<option value="">전체</option>
${code_map.rec_type}
</select>
</td>
<%-- <td><label for="">접수일</label></td>
<td>
<input type="text" id="search_req_date_from" name="search_req_date_from" style="width:70px;" autocomplete="off" value="${param.search_req_date_from}"/>~
<input type="text" id="search_req_date_to" name="search_req_date_to" style="width:70px;" autocomplete="off" value="${param.search_req_date_to }"/>
</td> --%>
</tr>
<tr>
<td class="align_r"><label for="" class="">등록자</label></td>
<td>
<select name="writer" id="writer" style="width: 150px;" class="select2" autocomplete="off">
<option value="">상태</option>
${code_map.writer}
</select>
</td>
<!-- <td class="align_r"><label for="" class="">정비업체명</label></td> -->
<!-- <td> -->
<!-- <select name="maintenance" id="maintenance" style="width:150px;" class="select2" autocomplete="off"> -->
<!-- <option value="">전체</option> -->
<%-- ${code_map.maintenance} --%>
<!-- </select> -->
<!-- </td> -->
<td><label for="">수리완료예정일</label></td>
<td>
<input type="text" id="search_plan_date_from" name="search_plan_date_from" style="width:70px;" autocomplete="off" value="${param.search_plan_date_from}"/>~
<input type="text" id="search_plan_date_to" name="search_plan_date_to" style="width:70px;" autocomplete="off" value="${param.search_plan_date_to }"/>
</td>
<%-- <td><label for="">고객인도일</label></td>
<td>
<input type="text" id="search_as_date_from" name="search_as_date_from" style="width:70px;" autocomplete="off" value="${param.search_as_date_from}"/>~
<input type="text" id="search_as_date_to" name="search_as_date_to" style="width:70px;" autocomplete="off" value="${param.search_as_date_to }"/>
</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="btnApproval">
<input type="button" value="등록" class="plm_btns" id="btnReg">
<input type="button" value="조회" class="plm_btns" onclick="search();">
</div>
</div>
<div class="new_eo_text"></div>
<div class="plm_table_wrap">
<table class="plm_table">
<colgroup>
<col width="2%" />
<col width="5%" />
<col width="3%" />
<col width="5%" />
<col width="3%" />
<col width="5%" />
<col width="5%" />
<col width="5%" />
<col width="5%" />
<!-- <col width="5%" /> -->
<col width="5%" />
<col width="5%" />
<!-- <col width="5%" /> -->
<col width="3%" />
<!-- <col width="5%" /> -->
<col width="3%" />
<col width="3%" />
<!-- <col width="5%" /> -->
</colgroup>
<thead>
<tr class="plm_thead">
<td><input type="checkbox" id="allCheck" class="checkBox" style="width:15px;height:15px"></td>
<td>접수_NO.</td>
<td>고객명</td>
<td>제품</td>
<td>년도</td>
<!-- <td>기종(모델)명</td> -->
<td>S/N</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>
<tbody>
<c:choose>
<c:when test="${empty ecrList}">
<tr style="text-align:center;">
<td align="center" colspan="14">조회된 데이터가 없습니다.</td>
</tr>
</c:when>
<c:otherwise>
<c:forEach var="item" items="${ecrList}" varStatus="varStatus">
<tr style="text-align:center;">
<td>
<c:if test="${item.STATUS_CD eq '0000100' || item.STATUS_CD eq '0000107'}">
<input type="checkbox" name="OBJID" data-objId="${item.OBJID}" value="${item.OBJID}" data-STATUS="${item.STATUS_CD}" data-TITLE="${item.TITLE}" data-WRITER="${item.WRITER}">
</c:if>
</td>
<td><a href="#" onclick="fn_openECRMngPopUp('${item.OBJID}','${item.STATUS_CD}')">${item.AS_NO}</a></td>
<td title="${item.CUST_NAME}">${item.CUST_NAME}</td>
<td title="${item.PRODUCT_NAME}">${item.PRODUCT_NAME}</td>
<td title="${item.YEAR}">${item.YEAR}</td>
<!-- <td title="-">-</td> -->
<%-- <td title="${item.CAR_NUMBER}">${item.CAR_NUMBER}</td> --%>
<td title="${item.SN_NO}">${item.SN_NO}</td>
<td title="${item.RELEASE_DATE}">${item.RELEASE_DATE}</td>
<td title="${item.PAID_FREE}">${item.PAID_FREE}</td>
<td title="${item.PHONE}">${item.PHONE}</td>
<%-- <td title="${item.MAINTENANCE}">${item.MAINTENANCE}</td> --%>
<td title="${item.PLAN_DATE}">${item.PLAN_DATE}</td>
<td title="${item.REC_TYPE_NAME}">${item.REC_TYPE_NAME}</td>
<%-- <td title="${item.REQ_DATE}">${item.REQ_DATE}</td> --%>
<td title="${item.WRITER_NAME}">${item.WRITER_NAME}</td>
<%-- <td title="${item.AS_DATE}">${item.AS_DATE}</td> --%>
<%-- <td><a href="#" class="File file_${item.CU01_CNT eq 0?'empty_':''}icon" data-OBJID="${item.OBJID}" data-docType="AS_DOC" data-docTypeName="AS첨부"></a></td> --%>
<td><a href="#" class="File file_${item.CU03_CNT eq 0?'empty_':''}icon" data-OBJID="${item.OBJID}" data-docType="ECR_ATTACH_02" data-docTypeName="AS첨부"></a></td>
<td title="${item.STATUS_NAME}">
<c:choose>
<c:when test="${item.STATUS_CD ne '0000100'}">
<a href="#" class="btnApprovalDetail" data-APPROVAL_OBJID="${item.APPROVAL_OBJID}" data-ROUTE_OBJID="${item.ROUTE_OBJID}">${item.STATUS_NAME}</a>
</c:when>
<c:otherwise>
${item.STATUS_NAME}
</c:otherwise>
</c:choose>
</td>
</tr>
</c:forEach>
</c:otherwise>
</c:choose>
</tbody>
</table>
</div>
<div class="pdm_page">
<input type="hidden" name="page" id="page" value="${nPage}">
<c:if test="${!empty ecrList}">
<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 ecrList}">
<p id="adminPageCount">총 ${totalCount}건</p>
</c:if>
</div>
</c:if>
</div>
</section>
</div>
</div>
</form>
</body>
</html>