E-BOM 확인/수정 파일업로드기능추가
This commit is contained in:
@@ -138,7 +138,16 @@ function fileDelete(fileObjId){
|
||||
dataType:"json",
|
||||
async:true,
|
||||
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) != ""){
|
||||
opener.eval(callbackFnc+"();");
|
||||
}
|
||||
|
||||
@@ -164,7 +164,16 @@ function fileDelete(fileObjId){
|
||||
dataType:"json",
|
||||
async:false,
|
||||
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) != ""){
|
||||
opener.eval(callbackFnc+"();");
|
||||
}
|
||||
|
||||
@@ -39,27 +39,7 @@
|
||||
.tabulator-row.level-9 { background-color: #FFFFEB !important; }
|
||||
.tabulator-row.level-10 { background-color: #ffffff !important; }
|
||||
|
||||
.file_icon, .file_empty_icon {
|
||||
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: '○';
|
||||
}
|
||||
/* 파일 아이콘 스타일은 basic.css에서 관리 */
|
||||
</style>
|
||||
<script>
|
||||
var _tabulGrid;
|
||||
@@ -74,6 +54,16 @@ $(function(){
|
||||
fn_excel();
|
||||
});
|
||||
|
||||
// 도면 업로드 버튼 클릭
|
||||
$("#btnDrawingUpload").click(function() {
|
||||
$("#drawingFiles").click();
|
||||
});
|
||||
|
||||
// 파일 선택 이벤트
|
||||
$("#drawingFiles").change(function() {
|
||||
fn_uploadDrawingFiles(this.files);
|
||||
});
|
||||
|
||||
// Tabulator 초기화
|
||||
fn_initGrid();
|
||||
});
|
||||
@@ -425,6 +415,153 @@ function fn_resetFilter() {
|
||||
$("#filterPartName").val("");
|
||||
_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>
|
||||
</head>
|
||||
<body class="backcolor">
|
||||
@@ -453,12 +590,10 @@ function fn_resetFilter() {
|
||||
</c:otherwise>
|
||||
</c:choose>
|
||||
</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 id="structureName2">
|
||||
<font size="2px">※수량 변경 후, 엔터치시면 저장됩니다.(신규 추가 파트만 가능)</font>
|
||||
</div>
|
||||
|
||||
<div id="structureGrid"></div>
|
||||
</div>
|
||||
</form>
|
||||
|
||||
@@ -35,6 +35,14 @@ $(document).ready(function(){
|
||||
|
||||
function refeshAttachFileArea(){
|
||||
srAreaDraw();
|
||||
// 부모 창의 그리드도 새로고침
|
||||
if(opener && typeof opener.fn_search == "function"){
|
||||
opener.fn_search();
|
||||
}
|
||||
// Tabulator 그리드가 있는 경우
|
||||
if(opener && opener._tabulGrid){
|
||||
opener._tabulGrid.replaceData();
|
||||
}
|
||||
}
|
||||
|
||||
//형상 영역을 display 한다.
|
||||
@@ -112,7 +120,15 @@ function fileDelete(fileObjId){
|
||||
dataType:"json",
|
||||
async:true,
|
||||
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){
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user