401 lines
13 KiB
Plaintext
401 lines
13 KiB
Plaintext
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
|
|
<%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core"%>
|
|
<%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt"%>
|
|
<%@ page import="com.pms.common.utils.*"%>
|
|
<%@ page import="java.util.*" %>
|
|
<%@include file= "/init.jsp" %>
|
|
<%
|
|
PersonBean person = (PersonBean) session.getAttribute(Constants.PERSON_BEAN);
|
|
String connector = person.getUserId();
|
|
%>
|
|
<c:set var="now" value="<%=new java.util.Date()%>" />
|
|
<c:set var="today"><fmt:formatDate value="${now}" pattern="yyyy-MM-dd" /></c:set>
|
|
<!DOCTYPE html>
|
|
<html>
|
|
<head>
|
|
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
|
|
<title><%=Constants.SYSTEM_NAME%></title>
|
|
</head>
|
|
|
|
<style>
|
|
.form-header {
|
|
display: flex;
|
|
align-items: center;
|
|
gap: 20px;
|
|
padding: 10px 15px;
|
|
background: #f8f9fa;
|
|
border-bottom: 1px solid #ddd;
|
|
}
|
|
.form-header label {
|
|
font-weight: bold;
|
|
margin-right: 5px;
|
|
}
|
|
.form-header .required {
|
|
color: red;
|
|
}
|
|
.form-header input, .form-header select {
|
|
padding: 5px 10px;
|
|
border: 1px solid #ccc;
|
|
border-radius: 3px;
|
|
}
|
|
</style>
|
|
|
|
<script type="text/javascript">
|
|
var _editable = true;
|
|
var grid;
|
|
var modifiedRows = [];
|
|
|
|
// 불량유형 목록 (0001820)
|
|
var _DEFECT_TYPE_LIST = [];
|
|
// 불량원인 목록 (불량유형의 하위코드)
|
|
var _DEFECT_REASON_LIST = [];
|
|
// 처리현황 목록
|
|
var _ACTION_STATUS_LIST = [
|
|
{"CODE": "", "NAME": "선택"},
|
|
{"CODE": "Rework", "NAME": "Rework"},
|
|
{"CODE": "Scrap", "NAME": "Scrap"}
|
|
];
|
|
// 검사자 목록
|
|
var _INSPECTOR_LIST = [];
|
|
|
|
$(document).ready(function(){
|
|
fnc_datepick();
|
|
$('.select2').select2();
|
|
|
|
// 불량유형 목록 조회
|
|
_DEFECT_TYPE_LIST = [{"CODE": "", "NAME": "선택"}].concat(
|
|
fnc_getJsonAllDataListBySqlId({"sqlId": "common.getCodeselect", "code": "0001820"})
|
|
);
|
|
|
|
// 검사자 목록 조회
|
|
_INSPECTOR_LIST = [{"CODE": "", "NAME": "선택"}].concat(
|
|
fnc_getJsonAllDataListBySqlId({"sqlId": "common.getUserselect"})
|
|
);
|
|
|
|
// 검사일 기본 설정 (저장된 값 없으면 오늘 날짜)
|
|
var savedInspectionDate = "${info.inspection_date}";
|
|
if(savedInspectionDate != '' && savedInspectionDate != 'null'){
|
|
$("#INSPECTION_DATE").val(savedInspectionDate);
|
|
} else if($("#INSPECTION_DATE").val() == ''){
|
|
$("#INSPECTION_DATE").val("${today}");
|
|
}
|
|
|
|
// 저장 버튼
|
|
$("#btnSave").click(function(){
|
|
fn_save();
|
|
});
|
|
|
|
// 닫기 버튼
|
|
$("#btnClose").click(function(){
|
|
self.close();
|
|
});
|
|
|
|
// 그리드 초기화 및 조회
|
|
fn_search();
|
|
|
|
// 셀 편집 이벤트
|
|
grid.on("cellEdited", function(cell) {
|
|
var row = cell.getRow();
|
|
var rowData = row.getData();
|
|
|
|
// 불량유형 변경 시 불량원인 목록 갱신
|
|
if (cell.getField() === 'DEFECT_TYPE') {
|
|
row.update({"DEFECT_REASON": ""}); // 불량원인 초기화
|
|
}
|
|
|
|
// 검사여부 변경 시 처리
|
|
if (cell.getField() === 'INSPECTION_YN') {
|
|
if (cell.getValue() === '스킵') {
|
|
// 스킵인 경우 불량 관련 필드 초기화
|
|
row.update({
|
|
"DEFECT_TYPE": "",
|
|
"DEFECT_REASON": "",
|
|
"ACTION_STATUS": "",
|
|
"INSPECTION_QTY": "",
|
|
"DEFECT_QTY": "",
|
|
"DEFECT_RATE": ""
|
|
});
|
|
}
|
|
}
|
|
|
|
// 검사수량, 불량수량 변경 시 불량율 자동 계산
|
|
if (cell.getField() === 'INSPECTION_QTY' || cell.getField() === 'DEFECT_QTY') {
|
|
fn_calcDefectRate(row);
|
|
}
|
|
|
|
// 검사결과 자동 설정 (불량수량 > 0이면 NG, 아니면 OK)
|
|
if (cell.getField() === 'DEFECT_QTY') {
|
|
var defectQty = parseInt(rowData.DEFECT_QTY) || 0;
|
|
if (defectQty > 0) {
|
|
row.update({"INSPECTION_RESULT": "NG"});
|
|
} else {
|
|
row.update({"INSPECTION_RESULT": "OK"});
|
|
}
|
|
}
|
|
|
|
rowData.GRID_STATUS = 'U';
|
|
});
|
|
});
|
|
|
|
// 불량율 계산
|
|
function fn_calcDefectRate(row) {
|
|
var data = row.getData();
|
|
var inspectionQty = parseInt(data.INSPECTION_QTY) || 0;
|
|
var defectQty = parseInt(data.DEFECT_QTY) || 0;
|
|
|
|
if (inspectionQty > 0) {
|
|
var rate = (defectQty / inspectionQty * 100).toFixed(2);
|
|
row.update({"DEFECT_RATE": rate});
|
|
} else {
|
|
row.update({"DEFECT_RATE": ""});
|
|
}
|
|
}
|
|
|
|
// 편집 가능 여부 체크
|
|
function editCheck(cell) {
|
|
return _editable;
|
|
}
|
|
|
|
// 검사여부가 '검사'인 경우만 편집 가능
|
|
function editCheckInspection(cell) {
|
|
var rowData = cell.getRow().getData();
|
|
return rowData.INSPECTION_YN === '검사';
|
|
}
|
|
|
|
// 품목상세 팝업
|
|
function fn_openPartDetailPopUp(partObjId) {
|
|
if (!partObjId) return;
|
|
var popup_width = 1200;
|
|
var popup_height = 900;
|
|
var url = "/partMng/partMngDetailPopUp.do?OBJID=" + partObjId;
|
|
window.open(url, "partMngDetailPopUp", "width=" + popup_width + ",height=" + popup_height + ",scrollbars=yes,resizable=yes");
|
|
}
|
|
|
|
function fn_search() {
|
|
var columns = [
|
|
//{formatter:"rowSelection", titleFormatter:"rowSelection", hozAlign:"center", headerSort:false, width:30},
|
|
{title:'품번', field:'PART_NO', headerHozAlign:'center', hozAlign:'left', width:180, editor:false,
|
|
formatter: fnc_createGridAnchorTag,
|
|
cellClick: function(e, cell) {
|
|
fn_openPartDetailPopUp(cell.getData().PART_OBJID);
|
|
}
|
|
},
|
|
{title:'품명', field:'PART_NAME', headerHozAlign:'center', hozAlign:'left', width:180, editor:false},
|
|
{title:'입고일', field:'DELIVERY_DATE', headerHozAlign:'center', hozAlign:'center', width:100, editor:false},
|
|
{title:'입고수량', field:'DELIVERY_QTY', headerHozAlign:'center', hozAlign:'right', width:80, editor:false,
|
|
formatter:"money", formatterParams:{thousand:",", precision:false}
|
|
},
|
|
{title:'검사성적서', field:'INSPECTION_FILE', headerHozAlign:'center', hozAlign:'center', width:90, editor:false},
|
|
{title:'검사구분', field:'INSPECTION_TYPE', headerHozAlign:'center', hozAlign:'center', width:80,
|
|
editor:"select",
|
|
editorParams:{values:{"원자재":"원자재", "외주가공":"외주가공"}}
|
|
},
|
|
{title:'검사여부', field:'INSPECTION_YN', headerHozAlign:'center', hozAlign:'center', width:80,
|
|
editor:"select",
|
|
editorParams:{values:{"검사":"검사", "스킵":"스킵"}},
|
|
cellEdited: function(cell) {
|
|
// 스킵 선택 시 검사결과 자동 OK
|
|
if (cell.getValue() === '스킵') {
|
|
cell.getRow().update({"INSPECTION_RESULT": "OK"});
|
|
}
|
|
}
|
|
},
|
|
{title:'불량유형', field:'DEFECT_TYPE', headerHozAlign:'center', hozAlign:'center', width:100,
|
|
editor: fnc_customSelectEditor,
|
|
formatter: function(cell) {
|
|
if (cell.getData().INSPECTION_YN === '스킵') return '-';
|
|
return fnc_customSelectFormatter(cell, {valueId:"CODE", labelId:"NAME", values:_DEFECT_TYPE_LIST});
|
|
},
|
|
editorParams: {valueId:"CODE", labelId:"NAME", values:_DEFECT_TYPE_LIST},
|
|
editable: editCheckInspection
|
|
},
|
|
{title:'불량원인', field:'DEFECT_REASON', headerHozAlign:'center', hozAlign:'center', width:100,
|
|
editor: fnc_customSelectEditor,
|
|
formatter: function(cell) {
|
|
if (cell.getData().INSPECTION_YN === '스킵') return '-';
|
|
var defectType = cell.getData().DEFECT_TYPE;
|
|
if (defectType) {
|
|
var reasonList = [{"CODE": "", "NAME": "선택"}].concat(
|
|
fnc_getJsonAllDataListBySqlId({"sqlId": "common.getCodeselect", "code": defectType})
|
|
);
|
|
return fnc_customSelectFormatter(cell, {valueId:"CODE", labelId:"NAME", values: reasonList});
|
|
}
|
|
return fnc_customSelectFormatter(cell, {valueId:"CODE", labelId:"NAME", values: [{"CODE": "", "NAME": "선택"}]});
|
|
},
|
|
editorParams: function(cell) {
|
|
var defectType = cell.getData().DEFECT_TYPE;
|
|
if (defectType) {
|
|
var reasonList = [{"CODE": "", "NAME": "선택"}].concat(
|
|
fnc_getJsonAllDataListBySqlId({"sqlId": "common.getCodeselect", "code": defectType})
|
|
);
|
|
return {valueId:"CODE", labelId:"NAME", values: reasonList};
|
|
}
|
|
return {valueId:"CODE", labelId:"NAME", values: [{"CODE": "", "NAME": "선택"}]};
|
|
},
|
|
editable: editCheckInspection
|
|
},
|
|
{title:'처리현황', field:'ACTION_STATUS', headerHozAlign:'center', hozAlign:'center', width:80,
|
|
editor: fnc_customSelectEditor,
|
|
formatter: function(cell) {
|
|
if (cell.getData().INSPECTION_YN === '스킵') return '-';
|
|
return fnc_customSelectFormatter(cell, {valueId:"CODE", labelId:"NAME", values:_ACTION_STATUS_LIST});
|
|
},
|
|
editorParams: {valueId:"CODE", labelId:"NAME", values:_ACTION_STATUS_LIST},
|
|
editable: editCheckInspection
|
|
},
|
|
{title:'검사수량', field:'INSPECTION_QTY', headerHozAlign:'center', hozAlign:'right', width:80,
|
|
editor:"input", editable: editCheckInspection,
|
|
formatter: function(cell) {
|
|
if (cell.getData().INSPECTION_YN === '스킵') return '-';
|
|
return cell.getValue();
|
|
}
|
|
},
|
|
{title:'불량수량', field:'DEFECT_QTY', headerHozAlign:'center', hozAlign:'right', width:80,
|
|
editor:"input", editable: editCheckInspection,
|
|
formatter: function(cell) {
|
|
if (cell.getData().INSPECTION_YN === '스킵') return '-';
|
|
return cell.getValue();
|
|
}
|
|
},
|
|
{title:'불량율', field:'DEFECT_RATE', headerHozAlign:'center', hozAlign:'right', width:70, editor:false,
|
|
formatter: function(cell) {
|
|
if (cell.getData().INSPECTION_YN === '스킵') return '-';
|
|
var val = cell.getValue();
|
|
if (val) return val + '%';
|
|
return '';
|
|
}
|
|
},
|
|
{title:'검사결과', field:'INSPECTION_RESULT', headerHozAlign:'center', hozAlign:'center', width:80,
|
|
editor:"select",
|
|
editorParams:{values:{"OK":"OK", "NG":"NG"}},
|
|
editable: editCheckInspection,
|
|
formatter: function(cell) {
|
|
if (cell.getData().INSPECTION_YN === '스킵') return '-';
|
|
var val = cell.getValue();
|
|
if (val === 'OK') return '<span style="color:#28a745;font-weight:bold;">OK</span>';
|
|
if (val === 'NG') return '<span style="color:#dc3545;font-weight:bold;">NG</span>';
|
|
return val;
|
|
}
|
|
},
|
|
{title:'첨부파일', field:'ATTACH_FILE_CNT', headerHozAlign:'center', hozAlign:'center', width:80,
|
|
formatter: fnc_subInfoValueFormatter,
|
|
cellClick: function(e, cell) {
|
|
var objid = fnc_checkNull(cell.getData().OBJID);
|
|
fn_openFilePopup(objid);
|
|
}
|
|
},
|
|
{title:'비고', field:'REMARK', headerHozAlign:'center', hozAlign:'left', width:150,
|
|
editor:"input", editable: editCheck
|
|
}
|
|
];
|
|
|
|
var param = {
|
|
PURCHASE_ORDER_MASTER_OBJID: "${param.OBJID}"
|
|
};
|
|
grid = fnc_tabul_search(_tabul_layout_fitDataStretch, grid, "/quality/incomingInspectionDetailGridList.do", columns, false, false, true, param);
|
|
}
|
|
|
|
// 파일 첨부 팝업
|
|
function fn_openFilePopup(objId) {
|
|
var url = "/projectConcept/FileRegistPopup.do?docType=INCOMING_INSPECTION&targetObjId=" + objId + "&docTypeName=수입검사첨부";
|
|
window.open(url, "filePopup", "width=700,height=500,scrollbars=yes,resizable=yes");
|
|
}
|
|
|
|
// 저장
|
|
function fn_save() {
|
|
// 유효성 검사
|
|
if($("#INSPECTION_DATE").val() == ''){
|
|
Swal.fire("검사일을 입력해주세요.");
|
|
$("#INSPECTION_DATE").focus();
|
|
return;
|
|
}
|
|
if($("#INSPECTOR_ID").val() == ''){
|
|
Swal.fire("검사자를 선택해주세요.");
|
|
$("#INSPECTOR_ID").focus();
|
|
return;
|
|
}
|
|
|
|
var gridData = grid.getData();
|
|
if(gridData.length == 0){
|
|
Swal.fire("검사할 항목이 없습니다.");
|
|
return;
|
|
}
|
|
|
|
Swal.fire({
|
|
title: '저장 확인',
|
|
text: '수입검사 내용을 저장하시겠습니까?',
|
|
icon: 'question',
|
|
showCancelButton: true,
|
|
confirmButtonColor: '#3085d6',
|
|
cancelButtonColor: '#d33',
|
|
confirmButtonText: '저장',
|
|
cancelButtonText: '취소'
|
|
}).then((result) => {
|
|
if (result.isConfirmed) {
|
|
var param = $("#form1").serializeObject();
|
|
param.dataListJson = JSON.stringify(gridData);
|
|
|
|
$.ajax({
|
|
url: "/quality/saveIncomingInspection.do",
|
|
type: "POST",
|
|
data: param,
|
|
dataType: "json",
|
|
success: function(data) {
|
|
Swal.fire({
|
|
title: data.result ? '저장 완료' : '저장 실패',
|
|
text: data.msg,
|
|
icon: data.result ? 'success' : 'error'
|
|
}).then(() => {
|
|
if(data.result){
|
|
opener.fn_search();
|
|
self.close();
|
|
}
|
|
});
|
|
},
|
|
error: function(xhr, status, error) {
|
|
Swal.fire('서버 오류가 발생했습니다.');
|
|
}
|
|
});
|
|
}
|
|
});
|
|
}
|
|
|
|
// 팝업 닫힐 때 부모 새로고침
|
|
window.addEventListener('unload', function() {
|
|
if(window.opener && window.opener.fn_search) {
|
|
window.opener.fn_search();
|
|
}
|
|
});
|
|
</script>
|
|
|
|
<body style="overflow-x: hidden;">
|
|
<form name="form1" id="form1" action="" method="post" onsubmit="return false">
|
|
<input type="hidden" name="PURCHASE_ORDER_MASTER_OBJID" id="PURCHASE_ORDER_MASTER_OBJID" value="${param.OBJID}">
|
|
|
|
<div class="plm_menu_name_gdnsi">
|
|
<h2><span>수입검사 등록</span></h2>
|
|
<div class="btnArea">
|
|
<input type="button" value="저장" class="plm_btns" id="btnSave">
|
|
<input type="button" value="닫기" class="plm_btns" id="btnClose">
|
|
</div>
|
|
</div>
|
|
|
|
<div class="form-header">
|
|
<div>
|
|
<label>검사일<span class="required">*</span></label>
|
|
<input type="text" name="INSPECTION_DATE" id="INSPECTION_DATE" class="date_icon" style="width:120px;" value="${info.INSPECTION_DATE}">
|
|
</div>
|
|
<div>
|
|
<label>검사자<span class="required">*</span></label>
|
|
<select name="INSPECTOR_ID" id="INSPECTOR_ID" class="select2" style="width:150px;">
|
|
<option value="">선택</option>
|
|
${code_map.inspector_id}
|
|
</select>
|
|
</div>
|
|
</div>
|
|
|
|
<%@include file= "/WEB-INF/view/common/common_gridArea.jsp" %>
|
|
</form>
|
|
</body>
|
|
</html>
|