Merge pull request 'E-BOM 확인/수정 파일업로드기능추가' (#18) from V20251023001 into main
Reviewed-on: #18
This commit was merged in pull request #18.
This commit is contained in:
@@ -138,7 +138,16 @@ function fileDelete(fileObjId){
|
|||||||
dataType:"json",
|
dataType:"json",
|
||||||
async:true,
|
async:true,
|
||||||
success:function(data){
|
success:function(data){
|
||||||
fn_fileCallback("sr","${docType}");
|
fn_fileCallback("sr","${docType}");
|
||||||
|
// 부모 창의 그리드 새로고침
|
||||||
|
if(opener && typeof opener.fn_search == "function"){
|
||||||
|
opener.fn_search();
|
||||||
|
}
|
||||||
|
// Tabulator 그리드가 있는 경우
|
||||||
|
if(opener && opener._tabulGrid){
|
||||||
|
opener._tabulGrid.replaceData();
|
||||||
|
}
|
||||||
|
// 기존 콜백 함수도 실행
|
||||||
if(fnc_checkNull(callbackFnc) != ""){
|
if(fnc_checkNull(callbackFnc) != ""){
|
||||||
opener.eval(callbackFnc+"();");
|
opener.eval(callbackFnc+"();");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -164,7 +164,16 @@ function fileDelete(fileObjId){
|
|||||||
dataType:"json",
|
dataType:"json",
|
||||||
async:false,
|
async:false,
|
||||||
success:function(data){
|
success:function(data){
|
||||||
fn_fileCallback("sr","${docType}");
|
fn_fileCallback("sr","${docType}");
|
||||||
|
// 부모 창의 그리드 새로고침
|
||||||
|
if(opener && typeof opener.fn_search == "function"){
|
||||||
|
opener.fn_search();
|
||||||
|
}
|
||||||
|
// Tabulator 그리드가 있는 경우
|
||||||
|
if(opener && opener._tabulGrid){
|
||||||
|
opener._tabulGrid.replaceData();
|
||||||
|
}
|
||||||
|
// 기존 콜백 함수도 실행
|
||||||
if(fnc_checkNull(callbackFnc) != ""){
|
if(fnc_checkNull(callbackFnc) != ""){
|
||||||
opener.eval(callbackFnc+"();");
|
opener.eval(callbackFnc+"();");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -39,27 +39,7 @@
|
|||||||
.tabulator-row.level-9 { background-color: #FFFFEB !important; }
|
.tabulator-row.level-9 { background-color: #FFFFEB !important; }
|
||||||
.tabulator-row.level-10 { background-color: #ffffff !important; }
|
.tabulator-row.level-10 { background-color: #ffffff !important; }
|
||||||
|
|
||||||
.file_icon, .file_empty_icon {
|
/* 파일 아이콘 스타일은 basic.css에서 관리 */
|
||||||
display: inline-block;
|
|
||||||
width: 20px;
|
|
||||||
height: 20px;
|
|
||||||
line-height: 20px;
|
|
||||||
text-align: center;
|
|
||||||
cursor: pointer;
|
|
||||||
font-size: 16px;
|
|
||||||
}
|
|
||||||
.file_icon {
|
|
||||||
color: #4CAF50;
|
|
||||||
}
|
|
||||||
.file_icon::before {
|
|
||||||
content: '📄';
|
|
||||||
}
|
|
||||||
.file_empty_icon {
|
|
||||||
color: #ccc;
|
|
||||||
}
|
|
||||||
.file_empty_icon::before {
|
|
||||||
content: '○';
|
|
||||||
}
|
|
||||||
</style>
|
</style>
|
||||||
<script>
|
<script>
|
||||||
var _tabulGrid;
|
var _tabulGrid;
|
||||||
@@ -74,6 +54,16 @@ $(function(){
|
|||||||
fn_excel();
|
fn_excel();
|
||||||
});
|
});
|
||||||
|
|
||||||
|
// 도면 업로드 버튼 클릭
|
||||||
|
$("#btnDrawingUpload").click(function() {
|
||||||
|
$("#drawingFiles").click();
|
||||||
|
});
|
||||||
|
|
||||||
|
// 파일 선택 이벤트
|
||||||
|
$("#drawingFiles").change(function() {
|
||||||
|
fn_uploadDrawingFiles(this.files);
|
||||||
|
});
|
||||||
|
|
||||||
// Tabulator 초기화
|
// Tabulator 초기화
|
||||||
fn_initGrid();
|
fn_initGrid();
|
||||||
});
|
});
|
||||||
@@ -425,6 +415,153 @@ function fn_resetFilter() {
|
|||||||
$("#filterPartName").val("");
|
$("#filterPartName").val("");
|
||||||
_tabulGrid.clearFilter();
|
_tabulGrid.clearFilter();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// 도면 업로드 처리 함수
|
||||||
|
function fn_uploadDrawingFiles(files) {
|
||||||
|
if(!files || files.length === 0) {
|
||||||
|
Swal.fire('파일을 선택해주세요.');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 품번 목록 조회 (현재 BOM의 모든 품번)
|
||||||
|
var bomObjId = "${info.OBJID}";
|
||||||
|
if(!bomObjId) {
|
||||||
|
Swal.fire('BOM 정보를 찾을 수 없습니다.');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 파일 분류 및 처리
|
||||||
|
var filesByType = {
|
||||||
|
'3D': [], // stp 파일
|
||||||
|
'2D': [], // dwg 파일
|
||||||
|
'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();
|
||||||
|
|
||||||
|
console.log('파일명: ' + fileName + ', 확장자: ' + ext); // 디버깅용
|
||||||
|
|
||||||
|
if(ext === 'stp' || ext === 'step') {
|
||||||
|
filesByType['3D'].push(file);
|
||||||
|
} else if(ext === 'dwg') {
|
||||||
|
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, pdf만 가능)');
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 확인 메시지
|
||||||
|
var msg = '총 ' + totalFiles + '개의 파일을 업로드하시겠습니까?\n';
|
||||||
|
msg += '- 3D (STP): ' + filesByType['3D'].length + '개\n';
|
||||||
|
msg += '- 2D (DWG): ' + 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(bomObjId, filesByType);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
// 실제 업로드 처리
|
||||||
|
function fn_processDrawingUpload(bomObjId, filesByType) {
|
||||||
|
// FormData 생성
|
||||||
|
var formData = new FormData();
|
||||||
|
formData.append('bomObjId', bomObjId);
|
||||||
|
|
||||||
|
// 모든 파일을 files 이름으로 추가 (MultipartRequest가 처리)
|
||||||
|
var allFiles = filesByType['3D'].concat(filesByType['2D']).concat(filesByType['PDF']);
|
||||||
|
for(var i = 0; i < allFiles.length; i++) {
|
||||||
|
formData.append('files', allFiles[i]);
|
||||||
|
}
|
||||||
|
|
||||||
|
// 로딩 표시 (구버전 SweetAlert2)
|
||||||
|
Swal.fire({
|
||||||
|
title: '업로드 중...',
|
||||||
|
text: '파일을 업로드하는 중입니다. 잠시만 기다려주세요.',
|
||||||
|
allowOutsideClick: false,
|
||||||
|
allowEscapeKey: false,
|
||||||
|
allowEnterKey: false,
|
||||||
|
showConfirmButton: false,
|
||||||
|
onOpen: function() {
|
||||||
|
Swal.showLoading();
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// AJAX 업로드
|
||||||
|
$.ajax({
|
||||||
|
url: '/partMng/uploadDrawingFiles.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() {
|
||||||
|
// 그리드 새로고침
|
||||||
|
_tabulGrid.replaceData();
|
||||||
|
// 파일 input 초기화
|
||||||
|
$("#drawingFiles").val('');
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
Swal.fire({
|
||||||
|
title: '업로드 실패',
|
||||||
|
text: response.message || '도면 업로드 중 오류가 발생했습니다.',
|
||||||
|
icon: 'error'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
},
|
||||||
|
error: function(xhr, status, error) {
|
||||||
|
Swal.close();
|
||||||
|
console.error('Upload error:', error);
|
||||||
|
console.error('Response:', xhr.responseText);
|
||||||
|
Swal.fire({
|
||||||
|
title: '업로드 실패',
|
||||||
|
text: '서버 오류가 발생했습니다: ' + error,
|
||||||
|
icon: 'error'
|
||||||
|
});
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
</script>
|
</script>
|
||||||
</head>
|
</head>
|
||||||
<body class="backcolor">
|
<body class="backcolor">
|
||||||
@@ -453,12 +590,10 @@ function fn_resetFilter() {
|
|||||||
</c:otherwise>
|
</c:otherwise>
|
||||||
</c:choose>
|
</c:choose>
|
||||||
</span>
|
</span>
|
||||||
<input type="button" value="Excel Download" class="plm_btns structure_btn" id="btnExcel" style="float:right;">
|
<input type="button" value="Excel Download" class="plm_btns structure_btn" id="btnExcel" style="float:right;">
|
||||||
|
<input type="button" value="도면 업로드" class="plm_btns structure_btn" id="btnDrawingUpload" style="float:right; margin-right:5px;">
|
||||||
|
<input type="file" id="drawingFiles" multiple style="display:none;" accept=".stp,.step,.dwg,.pdf">
|
||||||
</div>
|
</div>
|
||||||
<div id="structureName2">
|
|
||||||
<font size="2px">※수량 변경 후, 엔터치시면 저장됩니다.(신규 추가 파트만 가능)</font>
|
|
||||||
</div>
|
|
||||||
|
|
||||||
<div id="structureGrid"></div>
|
<div id="structureGrid"></div>
|
||||||
</div>
|
</div>
|
||||||
</form>
|
</form>
|
||||||
|
|||||||
@@ -35,6 +35,14 @@ $(document).ready(function(){
|
|||||||
|
|
||||||
function refeshAttachFileArea(){
|
function refeshAttachFileArea(){
|
||||||
srAreaDraw();
|
srAreaDraw();
|
||||||
|
// 부모 창의 그리드도 새로고침
|
||||||
|
if(opener && typeof opener.fn_search == "function"){
|
||||||
|
opener.fn_search();
|
||||||
|
}
|
||||||
|
// Tabulator 그리드가 있는 경우
|
||||||
|
if(opener && opener._tabulGrid){
|
||||||
|
opener._tabulGrid.replaceData();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//형상 영역을 display 한다.
|
//형상 영역을 display 한다.
|
||||||
@@ -112,7 +120,15 @@ function fileDelete(fileObjId){
|
|||||||
dataType:"json",
|
dataType:"json",
|
||||||
async:true,
|
async:true,
|
||||||
success:function(data){
|
success:function(data){
|
||||||
fn_fileCallback("sr","${docType}");
|
fn_fileCallback("sr","${docType}");
|
||||||
|
// 부모 창의 그리드 새로고침
|
||||||
|
if(opener && typeof opener.fn_search == "function"){
|
||||||
|
opener.fn_search();
|
||||||
|
}
|
||||||
|
// Tabulator 그리드가 있는 경우
|
||||||
|
if(opener && opener._tabulGrid){
|
||||||
|
opener._tabulGrid.replaceData();
|
||||||
|
}
|
||||||
},
|
},
|
||||||
error: function(jqxhr, status, error){
|
error: function(jqxhr, status, error){
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -21,6 +21,8 @@ import org.springframework.web.bind.annotation.RequestMethod;
|
|||||||
import org.springframework.web.bind.annotation.RequestParam;
|
import org.springframework.web.bind.annotation.RequestParam;
|
||||||
import org.springframework.web.bind.annotation.ResponseBody;
|
import org.springframework.web.bind.annotation.ResponseBody;
|
||||||
|
|
||||||
|
import com.oreilly.servlet.MultipartRequest;
|
||||||
|
import com.pms.common.FileRenameClass;
|
||||||
import com.pms.common.JsonUtil;
|
import com.pms.common.JsonUtil;
|
||||||
import com.pms.common.SqlMapConfig;
|
import com.pms.common.SqlMapConfig;
|
||||||
import com.pms.common.bean.PersonBean;
|
import com.pms.common.bean.PersonBean;
|
||||||
@@ -2136,4 +2138,188 @@ public class PartMngController {
|
|||||||
|
|
||||||
return "/ajax/ajaxResult";
|
return "/ajax/ajaxResult";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 도면 파일 일괄 업로드
|
||||||
|
* 파일명에 품번이 포함된 경우 자동 매칭하여 업로드
|
||||||
|
* - stp 파일 -> 3D CAD 컬럼
|
||||||
|
* - dwg 파일 -> 2D Drawing CAD 컬럼
|
||||||
|
* - pdf 파일 -> 2D PDF CAD 컬럼
|
||||||
|
*
|
||||||
|
* @param request
|
||||||
|
* @param session
|
||||||
|
* @param bomObjId BOM OBJID
|
||||||
|
* @return
|
||||||
|
*/
|
||||||
|
@RequestMapping(value="/partMng/uploadDrawingFiles.do", method=RequestMethod.POST)
|
||||||
|
@ResponseBody
|
||||||
|
public Map<String, Object> uploadDrawingFiles(
|
||||||
|
HttpServletRequest request,
|
||||||
|
HttpSession session) {
|
||||||
|
|
||||||
|
Map<String, Object> resultMap = new HashMap<>();
|
||||||
|
MultipartRequest multi = null;
|
||||||
|
FileRenameClass frc = null;
|
||||||
|
|
||||||
|
try {
|
||||||
|
PersonBean person = (PersonBean)session.getAttribute(Constants.PERSON_BEAN);
|
||||||
|
String userId = person != null ? person.getUserId() : "plmAdmin";
|
||||||
|
|
||||||
|
// MultipartRequest로 파일 업로드 처리
|
||||||
|
String storagePath = Constants.FILE_STORAGE;
|
||||||
|
int maxSize = 1024*1024*1024*9; // 9GB
|
||||||
|
|
||||||
|
File storage = new File(storagePath);
|
||||||
|
if(!storage.exists()) storage.mkdirs();
|
||||||
|
|
||||||
|
frc = new FileRenameClass();
|
||||||
|
multi = new MultipartRequest(request, storagePath, maxSize, "UTF-8", frc);
|
||||||
|
java.util.List fileList = frc.getFileList();
|
||||||
|
|
||||||
|
// MultipartRequest에서 bomObjId 파라미터 가져오기
|
||||||
|
String bomObjId = multi.getParameter("bomObjId");
|
||||||
|
|
||||||
|
if(bomObjId == null || bomObjId.isEmpty()) {
|
||||||
|
resultMap.put("result", "fail");
|
||||||
|
resultMap.put("message", "BOM ID가 전달되지 않았습니다.");
|
||||||
|
return resultMap;
|
||||||
|
}
|
||||||
|
|
||||||
|
// BOM 정보 조회
|
||||||
|
Map<String, Object> bomParam = new HashMap<>();
|
||||||
|
bomParam.put("objId", bomObjId);
|
||||||
|
Map bomInfo = partMngService.getBOMStructureStandardInfo(request, bomParam);
|
||||||
|
|
||||||
|
if(bomInfo == null) {
|
||||||
|
resultMap.put("result", "fail");
|
||||||
|
resultMap.put("message", "BOM 정보를 찾을 수 없습니다.");
|
||||||
|
return resultMap;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 해당 BOM의 모든 파트 정보 조회
|
||||||
|
bomParam.put("SEARCH_BOM_OBJID", bomObjId);
|
||||||
|
ArrayList<Map> partList = commonService.selectList("partMng.partMngListByBom", request, bomParam);
|
||||||
|
|
||||||
|
if(partList == null || partList.isEmpty()) {
|
||||||
|
resultMap.put("result", "fail");
|
||||||
|
resultMap.put("message", "BOM에 등록된 파트가 없습니다.");
|
||||||
|
return resultMap;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 품번 기준 파트 맵 생성
|
||||||
|
Map<String, Map> partNoMap = new HashMap<>();
|
||||||
|
for(Map part : partList) {
|
||||||
|
String partNo = CommonUtils.checkNull((String)part.get("PART_NO"));
|
||||||
|
if(!partNo.isEmpty()) {
|
||||||
|
partNoMap.put(partNo, part);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int successCount = 0;
|
||||||
|
int failCount = 0;
|
||||||
|
int notFoundCount = 0;
|
||||||
|
|
||||||
|
// 업로드된 파일 처리
|
||||||
|
if(fileList != null && !fileList.isEmpty()) {
|
||||||
|
for(Object fileObj : fileList) {
|
||||||
|
Map fileInfo = (Map)fileObj;
|
||||||
|
String originalFileName = CommonUtils.checkNull((String)fileInfo.get("realFileName"));
|
||||||
|
String savedFileName = CommonUtils.checkNull((String)fileInfo.get("savedFileName"));
|
||||||
|
String fileExt = CommonUtils.checkNull((String)fileInfo.get("fileExt"));
|
||||||
|
long fileSize = Long.parseLong(CommonUtils.checkNull(fileInfo.get("fileSize"), "0"));
|
||||||
|
|
||||||
|
// 확장자 대문자 변환 (이미 점 없이 저장됨)
|
||||||
|
fileExt = fileExt.toUpperCase();
|
||||||
|
|
||||||
|
System.out.println("========== 파일 업로드 처리 ==========");
|
||||||
|
System.out.println("원본 파일명: " + originalFileName);
|
||||||
|
System.out.println("저장 파일명: " + savedFileName);
|
||||||
|
System.out.println("확장자: " + fileExt);
|
||||||
|
System.out.println("===================================");
|
||||||
|
|
||||||
|
// 파일 확장자에 따른 문서 타입 결정
|
||||||
|
String docType = "";
|
||||||
|
String docTypeName = "";
|
||||||
|
|
||||||
|
if("STP".equals(fileExt) || "STEP".equals(fileExt)) {
|
||||||
|
docType = "3D_CAD";
|
||||||
|
docTypeName = "3D CAD 첨부파일";
|
||||||
|
} else if("DWG".equals(fileExt)) {
|
||||||
|
docType = "2D_DRAWING_CAD";
|
||||||
|
docTypeName = "2D(Drawing) CAD 첨부파일";
|
||||||
|
} else if("PDF".equals(fileExt)) {
|
||||||
|
docType = "2D_PDF_CAD";
|
||||||
|
docTypeName = "2D(PDF) CAD 첨부파일";
|
||||||
|
} else {
|
||||||
|
// 지원하지 않는 확장자는 스킵
|
||||||
|
System.out.println("지원하지 않는 확장자: " + fileExt + ", 파일명: " + originalFileName);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 파일명에서 품번 찾기 (파일명에 품번이 포함되어 있는 경우)
|
||||||
|
String matchedPartNo = null;
|
||||||
|
System.out.println("품번 매칭 시작 - 파일명: " + originalFileName);
|
||||||
|
for(String partNo : partNoMap.keySet()) {
|
||||||
|
System.out.println(" 품번 확인: " + partNo + " -> " + (originalFileName.contains(partNo) ? "매칭!" : "미매칭"));
|
||||||
|
if(originalFileName.contains(partNo)) {
|
||||||
|
matchedPartNo = partNo;
|
||||||
|
System.out.println(" ✓ 품번 매칭 성공: " + partNo);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if(matchedPartNo == null) {
|
||||||
|
System.out.println(" ✗ 품번 매칭 실패 - 파일명에서 품번을 찾을 수 없음");
|
||||||
|
}
|
||||||
|
|
||||||
|
if(matchedPartNo == null) {
|
||||||
|
notFoundCount++;
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
|
||||||
|
// 해당 파트에 파일 정보 저장
|
||||||
|
Map partInfo = partNoMap.get(matchedPartNo);
|
||||||
|
String partObjId = CommonUtils.checkNull((String)partInfo.get("OBJID"));
|
||||||
|
|
||||||
|
Map<String, Object> fileMap = new HashMap<>();
|
||||||
|
fileMap.put("OBJID", CommonUtils.createObjId());
|
||||||
|
fileMap.put("TARGET_OBJID", partObjId);
|
||||||
|
fileMap.put("SAVED_FILE_NAME", savedFileName);
|
||||||
|
fileMap.put("REAL_FILE_NAME", originalFileName);
|
||||||
|
fileMap.put("DOC_TYPE", docType);
|
||||||
|
fileMap.put("DOC_TYPE_NAME", docTypeName);
|
||||||
|
fileMap.put("FILE_SIZE", String.valueOf(fileSize));
|
||||||
|
fileMap.put("FILE_EXT", fileExt);
|
||||||
|
fileMap.put("FILE_PATH", storagePath);
|
||||||
|
fileMap.put("WRITER", userId);
|
||||||
|
|
||||||
|
try {
|
||||||
|
// 파일 정보 DB 저장
|
||||||
|
partMngService.insertDrawingFile(fileMap);
|
||||||
|
successCount++;
|
||||||
|
} catch(Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
failCount++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
resultMap.put("result", "success");
|
||||||
|
resultMap.put("successCount", successCount);
|
||||||
|
resultMap.put("failCount", failCount);
|
||||||
|
resultMap.put("notFoundCount", notFoundCount);
|
||||||
|
resultMap.put("message", "업로드가 완료되었습니다.");
|
||||||
|
|
||||||
|
} catch(Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
resultMap.put("result", "error");
|
||||||
|
resultMap.put("message", "업로드 중 오류가 발생했습니다: " + e.getMessage());
|
||||||
|
} finally {
|
||||||
|
if(frc != null) {
|
||||||
|
frc.clear();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return resultMap;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -162,10 +162,10 @@
|
|||||||
P.HEAT_TREATMENT_HARDNESS,
|
P.HEAT_TREATMENT_HARDNESS,
|
||||||
P.HEAT_TREATMENT_METHOD,
|
P.HEAT_TREATMENT_METHOD,
|
||||||
P.SURFACE_TREATMENT
|
P.SURFACE_TREATMENT
|
||||||
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID <!-- AND F.STATUS = 'Active'--> AND F.DOC_TYPE IN ('3D_CAD')) CU01_CNT
|
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID AND F.STATUS = 'Active' AND F.DOC_TYPE IN ('3D_CAD')) CU01_CNT
|
||||||
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID <!-- AND F.STATUS = 'Active'--> AND F.DOC_TYPE IN ('2D_DRAWING_CAD')) CU02_CNT
|
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID AND F.STATUS = 'Active' AND F.DOC_TYPE IN ('2D_DRAWING_CAD')) CU02_CNT
|
||||||
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID <!-- AND F.STATUS = 'Active'--> AND F.DOC_TYPE IN ('2D_PDF_CAD')) CU03_CNT
|
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID AND F.STATUS = 'Active' AND F.DOC_TYPE IN ('2D_PDF_CAD')) CU03_CNT
|
||||||
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID <!-- AND F.STATUS = 'Active'--> AND F.DOC_TYPE IN ('2D_PDF_CAD','2D_DRAWING_CAD')) CU_TOTAL_CNT
|
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID AND F.STATUS = 'Active' AND F.DOC_TYPE IN ('2D_PDF_CAD','2D_DRAWING_CAD')) CU_TOTAL_CNT
|
||||||
FROM PART_MNG P
|
FROM PART_MNG P
|
||||||
<!--
|
<!--
|
||||||
LEFT OUTER JOIN ATTACH_FILE_INFO F
|
LEFT OUTER JOIN ATTACH_FILE_INFO F
|
||||||
@@ -3327,9 +3327,9 @@ SELECT T1.LEV, T1.BOM_REPORT_OBJID, T1.ROOT_PART_NO, T1.PATH, T1.LEAF, T2.*
|
|||||||
,P.HEAT_TREATMENT_HARDNESS
|
,P.HEAT_TREATMENT_HARDNESS
|
||||||
,P.HEAT_TREATMENT_METHOD
|
,P.HEAT_TREATMENT_METHOD
|
||||||
,P.SURFACE_TREATMENT
|
,P.SURFACE_TREATMENT
|
||||||
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID <!--AND STATUS = 'Active'--> AND F.DOC_TYPE IN ('3D_CAD')) AS CU01_CNT
|
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID AND F.STATUS = 'Active' AND F.DOC_TYPE IN ('3D_CAD')) AS CU01_CNT
|
||||||
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID <!--AND STATUS = 'Active'--> AND F.DOC_TYPE IN ('2D_DRAWING_CAD')) AS CU02_CNT
|
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID AND F.STATUS = 'Active' AND F.DOC_TYPE IN ('2D_DRAWING_CAD')) AS CU02_CNT
|
||||||
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID <!--AND STATUS = 'Active'--> AND F.DOC_TYPE IN ('2D_PDF_CAD')) AS CU03_CNT
|
,(SELECT COUNT(1) FROM ATTACH_FILE_INFO F WHERE P.OBJID = F.TARGET_OBJID AND F.STATUS = 'Active' AND F.DOC_TYPE IN ('2D_PDF_CAD')) AS CU03_CNT
|
||||||
|
|
||||||
,V.LEV
|
,V.LEV
|
||||||
,(SELECT OBJID FROM VIEW_BOM VT WHERE V.BOM_REPORT_OBJID = VT.BOM_REPORT_OBJID AND VT.LEV = 1 ORDER BY SEQ LIMIT 1) AS ROOT_OBJID
|
,(SELECT OBJID FROM VIEW_BOM VT WHERE V.BOM_REPORT_OBJID = VT.BOM_REPORT_OBJID AND VT.LEV = 1 ORDER BY SEQ LIMIT 1) AS ROOT_OBJID
|
||||||
|
|||||||
@@ -4869,4 +4869,27 @@ public class PartMngService extends BaseService {
|
|||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 도면 파일 정보 DB 저장
|
||||||
|
* @param fileMap 파일 정보
|
||||||
|
*/
|
||||||
|
public void insertDrawingFile(Map<String, Object> fileMap) {
|
||||||
|
SqlSession sqlSession = null;
|
||||||
|
try {
|
||||||
|
sqlSession = SqlMapConfig.getInstance().getSqlSession(false);
|
||||||
|
sqlSession.insert("partMng.insertpartfileInfo", fileMap);
|
||||||
|
sqlSession.commit();
|
||||||
|
} catch(Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
if(sqlSession != null) {
|
||||||
|
sqlSession.rollback();
|
||||||
|
}
|
||||||
|
throw e;
|
||||||
|
} finally {
|
||||||
|
if(sqlSession != null) {
|
||||||
|
sqlSession.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user