Files
wace_plm/WebContent/WEB-INF/view/partMng/partMngTempList.jsp

646 lines
22 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="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>
<c:set var="connector" value="<%=connector%>" />
<style>
th.ui-th-column div {
white-space:normal !important;
/*height:50px !important;*/
}
ui-jqgrid tr.jqgrow td {
/*max-height : 100px;*/
height:50px !important;
}
</style>
<script type="text/javascript">
$(function() {
$(document).ready(function() {
fnc_datepick();
$("input[type=text]").keyup(function(e) {
if (e.keyCode == 13)
fn_search();
});
$("#btnReg").click(function(){
openPartMngPopup("");
});
$("#btnDelete").click(function(){
fn_deletePartMng();
});
$("#btnCopy").click(function(){
fn_CopyPartMng();
});
$("#btnDeploy").click(function(){
fn_partMngDeploy();
});
//image src encoding
$("img").each(function(i) {
var imgSrc = $(this).attr("data-SRC");
$(this).attr("src", encodeURI(imgSrc));
});
$("#btnSearch").click(function() {
$("#page").val("1");
fn_search();
});
// $("#search_product_group").change(function(){
// $("#search_product").empty();
// if("" != this.value){
// fnc_getCodeListAppend(this.value,"search_product","${param.search_product}");
// }
// });
// fnc_getCarList("", "", "search_car_type","${param.search_car_type}");
// fnc_getCodeListAppend("<%=Constants.PRODUCT_GROUP_CODE%>","search_product_group","${param.search_product_group}");
// if("" != "${param.search_product_group}"){
// fnc_getCodeListAppend("${param.search_product_group}","search_product","${param.search_product}");
// }
//fnc_getUserList("SEARCH_WRITER","${param.search_writer}");
$('.select2').select2();
// 품번/품명 Select2 AJAX 초기화
initPartSelect2Ajax("#SEARCH_PART_NO", "#SEARCH_PART_NAME", "#SEARCH_PART_OBJID");
fn_search();
//_tabulGrid.on("cellEdited", function(cell){
_tabulGrid.on("rowSelected", function(row){
//alert('rowSelected');
var rowData = row.getData();
var PART_NO = rowData.PART_NO;
var sameRows = _tabulGrid.searchRows("PART_NO", "=", PART_NO);
sameRows.forEach(function (sameRow) {
sameRow.select();
});
});
_tabulGrid.on("rowDeselected", function(row){
//alert('rowDeselected');
var rowData = row.getData();
var PART_NO = rowData.PART_NO;
var sameRows = _tabulGrid.searchRows("PART_NO", "=", PART_NO);
sameRows.forEach(function (sameRow) {
sameRow.deselect();
});
});
});
// 도면 다중 업로드 버튼 클릭
$("#btnDrawingUpload").click(function() {
$("#drawingFiles").click();
});
// 파일 선택 이벤트
$("#drawingFiles").change(function() {
fn_uploadDrawingFiles(this.files);
});
});
//var grid;
var columns = [
{title:'OBJID', field:'OBJID' ,visible:false ,frozen:true},
{title:'CODE1', field:'CODE1' ,visible:false ,frozen:true},
{title:'CODE2', field:'CODE2' ,visible:false ,frozen:true},
{title:'CODE3', field:'CODE3' ,visible:false ,frozen:true},
{title:'CODE4', field:'CODE4' ,visible:false ,frozen:true},
{title:'CODE5', field:'CODE5' ,visible:false ,frozen:true},
// {headerHozAlign : 'center', hozAlign : 'center', width : '60', title : '순', field : 'RNUM' ,frozen:true},
// {headerHozAlign : 'center', hozAlign : 'left', width : '125', title : '모품번', field : 'PARENT_PART_INFO' ,frozen:true},
{headerHozAlign : 'center', hozAlign : 'left', width : '250', title : '품번', field : 'PART_NO',frozen:true,
formatter:fnc_createGridAnchorTag,
cellClick:function(e, cell){
var objid = fnc_checkNull(cell.getData().OBJID);
openPartMngPopup(objid);
}
},
{headerHozAlign : 'center', hozAlign : 'left', /*width : '200',*/ title : '품명', field : 'PART_NAME' ,frozen:true},
// {headerHozAlign : 'center', hozAlign : 'center', width : '70', title : '수량', field : 'Q_QTY' },
{headerHozAlign : 'center', hozAlign : 'center', width : '60', title : '3D', field : 'CU01_CNT',
formatter:fnc_subInfoValueFormatter,
cellClick:function(e, cell){
var objid = fnc_checkNull(cell.getData().OBJID);
var docType = '3D_CAD';
var docTypeName = '3D CAD 첨부파일';
fn_FileRegist(objid, docType, docTypeName);
}
},
{headerHozAlign : 'center', hozAlign : 'center', width : '60', title : '2D', field : 'CU02_CNT',
formatter:fnc_subInfoValueFormatter,
cellClick:function(e, cell){
var objid = fnc_checkNull(cell.getData().OBJID);
var docType = '2D_DRAWING_CAD';
var docTypeName = '2D(Drawing) CAD 첨부파일';
fn_FileRegist(objid, docType, docTypeName);
}
},
{headerHozAlign : 'center', hozAlign : 'center', width : '60', title : 'PDF', field : 'CU03_CNT',
formatter:fnc_subInfoValueFormatter,
cellClick:function(e, cell){
var objid = fnc_checkNull(cell.getData().OBJID);
var docType = '2D_PDF_CAD';
var docTypeName = '2D(PDF) CAD 첨부파일';
fn_FileRegist(objid, docType, docTypeName);
}
},
{headerHozAlign : 'center', hozAlign : 'center', width : '120', title : '재료', field : 'MATERIAL' },
{headerHozAlign : 'center', hozAlign : 'center', width : '120', title : '열처리경도', field : 'HEAT_TREATMENT_HARDNESS' },
{headerHozAlign : 'center', hozAlign : 'center', width : '120', title : '열처리방법', field : 'HEAT_TREATMENT_METHOD' },
{headerHozAlign : 'center', hozAlign : 'center', width : '120', title : '표면처리', field : 'SURFACE_TREATMENT' },
{headerHozAlign : 'center', hozAlign : 'center', width : '150', title : '메이커', field : 'MAKER' },
{headerHozAlign : 'center', hozAlign : 'center', width : '100', title : '범주 이름', field : 'PART_TYPE_TITLE' },
// {headerHozAlign : 'center', hozAlign : 'left', width : '190', title : '사양(규격)', field : 'SPEC' },
// {headerHozAlign : 'center', hozAlign : 'center', width : '90', title : '후처리', field : 'POST_PROCESSING' },
// {headerHozAlign : 'center', hozAlign : 'center', width : '90', title : 'MAKER', field : 'MAKER' },
// {headerHozAlign : 'center', hozAlign : 'center', width : '120', title : '대분류', field : 'MAJOR_CATEGORY' },
// {headerHozAlign : 'center', hozAlign : 'center', width : '120', title : '중분류', field : 'SUB_CATEGORY' },
// {headerHozAlign : 'center', hozAlign : 'center', width : '90', title : 'Revision', field : 'REVISION' },
// {headerHozAlign : 'center', hozAlign : 'center', width : '90', title : 'EO No', field : 'EO_NO' },
// {headerHozAlign : 'center', hozAlign : 'center', width : '90', title : 'EO Date', field : 'EO_DATE' },
// {headerHozAlign : 'center', hozAlign : 'center', width : '90', title : 'PART 구분', field : 'PART_TYPE_TITLE' },
{headerHozAlign : 'center', hozAlign : 'center', width : '120', title : '비고', field : 'REMARK' }
];
function fn_search(){
_tabulGrid = fnc_tabul_search(_tabul_layout_fitColumns, _tabulGrid, "/partMng/partMngTempGridList.do", columns, true);
}
function openPartMngPopup(objId){
var hiddenForm = document.hiddenForm;
var url = "/partMng/partMngFormPopUp.do";
if("" != objId){
url = "/partMng/partMngDetailPopUp.do";
}
var target = "partMngPopUp";
window.open(url,target,"width=600, height=900, menubars=no, scrollbars=yes, resizable=yes");
hiddenForm.action = url;
hiddenForm.OBJID.value = objId;
hiddenForm.target = target;
hiddenForm.submit();
}
//파트 배포
function fn_partMngDeploy() {
var selectedPart = _tabulGrid.getSelectedData();
if(0 < selectedPart.length){
var checkedPartArr = [];
var overlapArr = [];
var OBJID = fnc_checkNull(selectedPart[0].OBJID);
//$("input[name=OBJID]:checked").each(function(){
for(var i=0; i<selectedPart.length; i++){
var targetPartNo = fnc_checkNull(selectedPart[i].PART_NO);
checkedPartArr.push(targetPartNo);
}
/* }); */
for(var i=0;i<checkedPartArr.length;i++){
var basePartNo = checkedPartArr[i];
var overlapCnt = 0;
for(var j=0;j<checkedPartArr.length;j++){
var comparePartNo = checkedPartArr[j];
if(basePartNo == comparePartNo){
overlapCnt++;
}
}
if(1 < overlapCnt){
//overlapArr.push(basePartNo); //231218 막음
}
}
if(0 < overlapArr.length){
var finalOverlapArr = [];
$.each(overlapArr,function(i,value){
if(finalOverlapArr.indexOf(value) == -1 ) finalOverlapArr.push(value);
});
Swal.fire("중복되는 파트가 존재합니다.\n("+finalOverlapArr.join(",")+")");
return false;
}else{
var OBJID = fnc_checkNull(selectedPart[0].OBJID);
//if(confirm("선택된 Part를 확정하시겠습니까?")){
Swal.fire({
title: '같은 Part는 동시 확정됩니다. 선택된 Part를 확정하시겠습니까?',
text: '',
icon: 'warning',
showCancelButton: true, // cancel버튼 보이기. 기본은 원래 없음
confirmButtonColor: '#3085d6', // confrim 버튼 색깔 지정
cancelButtonColor: '#d33', // cancel 버튼 색깔 지정
confirmButtonText: '확인', // confirm 버튼 텍스트 지정
cancelButtonText: '취소', // cancel 버튼 텍스트 지정
reverseButtons: false, // 버튼 순서 거꾸로
}).then(result => {
// 만약 Promise리턴을 받으면,
if (result.isConfirmed) { // 만약 모달창에서 confirm 버튼을 눌렀다면
var param = $("#form1").serializeObject();
param.dataListJson = JSON.stringify(_tabulGrid.getSelectedData());
$.ajax({
url:"/partMng/partMngDeploy.do",
type:"POST",
data: param,
//data:{"OBJID":OBJID},
dataType:"json",
success:function(data){
Swal.fire(data.msg);
fn_search();
},
error: function(jqxhr, status, error){
}
});
}
});
}
}else{
Swal.fire("선택된 Part가 없습니다.");
return false;
}
}
function fn_deletePartMng() {
var selectedPart = _tabulGrid.getSelectedData();
if(0 < selectedPart.length){
var checkArr = new Array();
for(var i=0;i<selectedPart.length;i++){
var objId = fnc_checkNull(selectedPart[i].OBJID);
checkArr.push(objId);
}
//if(confirm("선택된 Part를 삭제하시겠습니까?")){
Swal.fire({
title: '선택된 Part를 삭제하시겠습니까?',
text: '',
icon: 'warning',
showCancelButton: true, // cancel버튼 보이기. 기본은 원래 없음
confirmButtonColor: '#3085d6', // confrim 버튼 색깔 지정
cancelButtonColor: '#d33', // cancel 버튼 색깔 지정
confirmButtonText: '확인', // confirm 버튼 텍스트 지정
cancelButtonText: '취소', // cancel 버튼 텍스트 지정
reverseButtons: false, // 버튼 순서 거꾸로
}).then(result => {
// 만약 Promise리턴을 받으면,
if (result.isConfirmed) { // 만약 모달창에서 confirm 버튼을 눌렀다면
var param = $("#form1").serializeObject();
param.dataListJson = JSON.stringify(_tabulGrid.getSelectedData());
param.checkArr = checkArr.join();
$.ajax({
url:"/partMng/partMngDelete.do",
type:"POST",
data: param,
//data: {"checkArr":checkArr.join()},
dataType:"json",
success:function(data){
Swal.fire(data.msg);
fn_search();
},
error: function(jqxhr, status, error){
}
});
}
});
}else{
Swal.fire("선택된 Part가 없습니다.");
return false;
}
}
function fn_CopyPartMng() {
var selectedPart = $("input[name=OBJID]:checked");
if(1 < selectedPart.length){
Swal.fire("복사는 하나의 파트만 복사할수있습니다.");
return false;
}
if(0 < selectedPart.length){
if(confirm("선택된 Part를 복사하시겠습니까?")){
$.ajax({
url:"/partMng/partMngCopy.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 fn_FileRegist(objId, docType, docTypeName){
var popup_width = 800;
var popup_height = 300;
var objId = objId;
var docType = docType;
var docTypeName = docTypeName;
var params = "?targetObjId="+objId+"&docType="+docType+"&docTypeName="+docTypeName;
var url = "/projectConcept/FileRegistPopup.do"+params;
fn_centerPopup(popup_width, popup_height, url);
}
// 도면 다중 업로드 처리 함수
function fn_uploadDrawingFiles(files) {
if(!files || files.length === 0) {
Swal.fire('파일을 선택해주세요.');
return;
}
// 파일 분류 및 처리
var filesByType = {
'3D': [], // stp 파일
'2D': [], // dwg, dxf 파일
'PDF': [] // pdf 파일
};
// 파일 확장자 확인 및 분류
for(var i = 0; i < files.length; i++) {
var file = files[i];
var fileName = file.name;
var lastDotIndex = fileName.lastIndexOf('.');
if(lastDotIndex === -1) {
continue; // 확장자가 없는 파일은 스킵
}
var ext = fileName.substring(lastDotIndex + 1).toLowerCase();
if(ext === 'stp' || ext === 'step') {
filesByType['3D'].push(file);
} else if(ext === 'dwg' || ext === 'dxf') {
filesByType['2D'].push(file);
} else if(ext === 'pdf') {
filesByType['PDF'].push(file);
}
}
// 업로드할 파일이 있는지 확인
var totalFiles = filesByType['3D'].length + filesByType['2D'].length + filesByType['PDF'].length;
if(totalFiles === 0) {
Swal.fire('업로드 가능한 파일 형식이 없습니다. (stp, dwg, dxf, pdf만 가능)');
return;
}
// 확인 메시지
var msg = '총 ' + totalFiles + '개의 파일을 업로드하시겠습니까?\n';
msg += '- 3D (STP): ' + filesByType['3D'].length + '개\n';
msg += '- 2D (DWG/DXF): ' + filesByType['2D'].length + '개\n';
msg += '- PDF: ' + filesByType['PDF'].length + '개';
Swal.fire({
title: '도면 다중 업로드',
text: msg,
icon: 'question',
showCancelButton: true,
confirmButtonText: '업로드',
cancelButtonText: '취소'
}).then(function(result) {
if(result.isConfirmed) {
fn_processDrawingUpload(filesByType);
}
});
}
// 실제 업로드 처리
function fn_processDrawingUpload(filesByType) {
// 현재 그리드에 표시된 파트 데이터 가져오기
var gridData = _tabulGrid.getData();
if(!gridData || gridData.length === 0) {
Swal.fire('페이지에 표시된 파트가 없습니다.');
return;
}
// 품번 목록 생성 (현재 화면에 보이는 파트만)
var partNoList = [];
for(var i = 0; i < gridData.length; i++) {
var partNo = gridData[i].PART_NO;
if(partNo) {
partNoList.push(partNo);
}
}
// FormData 생성
var formData = new FormData();
// 현재 화면의 품번 목록 전송
formData.append('partNoList', JSON.stringify(partNoList));
// 모든 파일을 files 이름으로 추가
var allFiles = filesByType['3D'].concat(filesByType['2D']).concat(filesByType['PDF']);
for(var i = 0; i < allFiles.length; i++) {
formData.append('files', allFiles[i]);
}
// 로딩 표시
Swal.fire({
title: '업로드 중...',
text: '파일을 업로드하는 중입니다. 잠시만 기다려주세요.',
allowOutsideClick: false,
allowEscapeKey: false,
allowEnterKey: false,
showConfirmButton: false,
onOpen: function() {
Swal.showLoading();
}
});
// AJAX 업로드
$.ajax({
url: '/partMng/uploadDrawingFilesForPartList.do',
type: 'POST',
data: formData,
processData: false,
contentType: false,
success: function(response) {
Swal.close();
if(response.result === 'success') {
var successMsg = '도면 업로드가 완료되었습니다.\n\n';
successMsg += '- 성공: ' + response.successCount + '개\n';
if(response.failCount > 0) {
successMsg += '- 실패: ' + response.failCount + '개\n';
}
if(response.notFoundCount > 0) {
successMsg += '- 품번 미존재: ' + response.notFoundCount + '개\n';
}
Swal.fire({
title: '업로드 완료',
text: successMsg,
icon: response.failCount > 0 ? 'warning' : 'success'
}).then(function() {
// 그리드 새로고침
fn_search();
// 파일 input 초기화
$("#drawingFiles").val('');
});
} else {
Swal.fire({
title: '업로드 실패',
text: response.message || '도면 업로드 중 오류가 발생했습니다.',
icon: 'error'
});
}
},
error: function(xhr, status, error) {
Swal.close();
console.error('Upload error:', error);
Swal.fire({
title: '업로드 실패',
text: '서버 오류가 발생했습니다: ' + error,
icon: 'error'
});
}
});
}
function openExcelPopup() {
/*
if($("#customer_cd").val()==""){
Swal.fire('고객사를 선택해 주세요');
return;
}
if($("#project_name").val()==""){
Swal.fire('프로젝트를 선택해 주세요');
return;
}
if($("#unit_code").val()==""){
Swal.fire('유닛명을 선택해 주세요');
return;
}
*/
var url = "/partMng/openPartExcelImportPopUp.do"; //?customer_cd="+$("#customer_cd").val()+"&project_name="+$("#project_name").val()+"&unit_code="+$("#unit_code").val();
var target = "openPartExcelImportPopUp";
window.open(url, target,"width=1520, height=860, menubars=no, scrollbars=yes, resizable=yes");
}
</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_gdnsi">
<h2>
<span>개발관리_PART 등록</span>
</h2>
<div class="btnArea">
<input type="button" value="확정" class="plm_btns" id="btnDeploy">
<input type="button" value="삭제" class="plm_btns" id="btnDelete">
<input type="button" value="등록" class="plm_btns" id="btnReg">
<input type="button" value="등록(Excel Upload)" class="plm_btns" onclick="openExcelPopup();">
<input type="button" value="도면 다중 업로드" class="plm_btns" id="btnDrawingUpload">
<input type="button" value="조회" class="plm_btns" id="btnSearch">
<input type="file" id="drawingFiles" multiple style="display:none;" accept=".stp,.step,.dwg,.dxf,.pdf">
</div>
</div>
<div id="plmSearchZon">
<table>
<tr>
<!-- <td><label for="Year">년도</label></td>
<td>
<select name="SEARCH_YEAR" id="SEARCH_YEAR" style="width:200px;" autocomplete="off">
<option value="">선택</option>
<c:forEach begin="${sysYear-4}" end="${sysYear}" var="req_year">
<option value="${req_year}"${param.SEARCH_YEAR eq req_year ? 'selected':'' }>${req_year}</option>
</c:forEach>
</select>
</td> -->
<td><label for="">품번</label></td>
<td>
<select name="SEARCH_PART_NO" id="SEARCH_PART_NO" class="select2-part" style="width:194px;">
<option value="">품번 선택</option>
</select>
<input type="hidden" name="SEARCH_PART_OBJID" id="SEARCH_PART_OBJID" value="">
</td>
<td><label for="">품명</label></td>
<td>
<select name="SEARCH_PART_NAME" id="SEARCH_PART_NAME" class="select2-part" style="width:150px;">
<option value="">품명 선택</option>
</select>
</td>
<!-- <td><label for="">등록자</label></td>
<td>
<select name="WRITER" id="WRITER" required reqTitle="작성자" type="select" class="select2" autocomplete="off">
<option value="">선택</option>
${code_map.WRITER}
</select>
</td> -->
</td>
</tr>
</table>
</div>
<%@include file= "/WEB-INF/view/common/common_gridArea.jsp" %>
</div>
</div>
</form>
</body>
</html>