Files
SIPAIIS_WMS_JSSW/WebRoot/jsp/process/waterTestEdit.jsp
2026-01-16 14:13:44 +08:00

416 lines
18 KiB
Plaintext
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

<%@ page language="java" pageEncoding="UTF-8" %>
<%@page import="com.sipai.entity.process.WaterTest" %>
<% request.setAttribute("Job_Type_Huanbao", WaterTest.Job_Type_Huanbao); %>
<% request.setAttribute("Job_Type_Linshi", WaterTest.Job_Type_Linshi); %>
<% request.setAttribute("Job_Type_Richang", WaterTest.Job_Type_Richang); %>
<style type="text/css">
</style>
<script type="text/javascript">
function dosave() {
//先刷新接收人字段验证
$('#subForm').data('bootstrapValidator')
.updateStatus('receiveUsersName', 'NOT_VALIDATED', null)
.validateField('receiveUsersName');
$("#subForm").bootstrapValidator('validate');//提交验证
if ($("#subForm").data('bootstrapValidator').isValid()) {
//获取验证结果,如果成功,执行下面代码
$.post(ext.contextPath + "/process/waterTest/doupdate.do", $("#subForm").serialize(), function (data) {
if (data.res == 1) {
$("#table").bootstrapTable('refresh');
closeModal("subModal");
} else if (data.res == 0) {
showAlert('d', '保存失败');
} else {
showAlert('d', data.res);
}
}, 'json');
}
}
$("#subForm").bootstrapValidator({
live: 'disabled',//验证时机enabled是内容有变化就验证默认disabled和submitted是提交再验证
fields: {
jobNumber: {
validators: {
notEmpty: {
message: '工单号不能为空'
}
}
},
jobType: {
validators: {
notEmpty: {
message: '请选择工单类型'
}
}
},
receiveUsersName: {
validators: {
notEmpty: {
message: '接收人员不能为空'
}
}
}
}
});
$('#jobType').select2({minimumResultsForSearch: 10}).val('${waterTest.jobType}').trigger('change');
//附表内容
$("#table_detail").bootstrapTable({ // 对应table标签的id
url: ext.contextPath + '/process/waterTestDetail/getList.do', // 获取表格数据的url
cache: false, // 设置为 false 禁用 AJAX 数据缓存, 默认为true
striped: true, //表格显示条纹默认为false
pagination: true, // 在表格底部显示分页组件默认false
pageList: [10, 20, 50], // 设置页面可以显示的数据条数
pageSize: 50, // 页面数据条数
pageNumber: 1, // 首页页码
sidePagination: 'server', // 设置为服务器端分页
queryParams: function (params) { // 请求服务器数据时发送的参数可以在这里添加额外的查询参数返回false则终止请求
return {
rows: params.limit, // 每页要显示的数据条数
page: params.offset / params.limit + 1, // 每页显示数据的开始页码
sort: params.sort, // 要排序的字段
order: params.order,
pid: '${waterTest.id}'
}
},
sortName: 'id', // 要排序的字段
sortOrder: 'desc', // 排序规则
columns: [
{
checkbox: true, // 显示一个勾选框
width: '40px'
},
{
field: '', // 返回json数据中的name
title: '化验指标编号', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '22%',
formatter: function (value, row, index) {
if (row.libraryWaterTest != null && row.libraryWaterTest != '') {
return row.libraryWaterTest.measurePointId;
}
}
},
{
field: '', // 返回json数据中的name
title: '化验指标名称', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '22%',
formatter: function (value, row, index) {
if (row.libraryWaterTest != null && row.libraryWaterTest != '') {
return row.libraryWaterTest.name;
}
}
},
{
field: '', // 返回json数据中的name
title: '额定工时(小时)', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '14%',
formatter: function (value, row, index) {
if (row.libraryWaterTest != null && row.libraryWaterTest != '') {
return row.libraryWaterTest.baseHours;
}
}
},
{
field: '', // 返回json数据中的name
title: '额定费用(元)', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '12%',
formatter: function (value, row, index) {
if (row.libraryWaterTest != null && row.libraryWaterTest != '') {
return row.libraryWaterTest.baseCost;
}
}
},
{
field: '', // 返回json数据中的name
title: '化验方法', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '30%',
formatter: function (value, row, index) {
if (row.libraryWaterTest != null && row.libraryWaterTest != '') {
return row.libraryWaterTest.method;
}
}
}
],
onLoadSuccess: function () { //加载成功时执行
adjustBootstrapTableView("table_detail");
},
onLoadError: function () { //加载失败时执行
console.info("加载数据失败");
}
});
$("#table_contentFile").bootstrapTable({ // 对应table标签的id
url: ext.contextPath + '/process/waterTestDetail/getListForFile.do', // 获取表格数据的url
cache: false, // 设置为 false 禁用 AJAX 数据缓存, 默认为true
striped: true, //表格显示条纹默认为false
pagination: true, // 在表格底部显示分页组件默认false
pageList: [10, 20, 50], // 设置页面可以显示的数据条数
pageSize: 10, // 页面数据条数
pageNumber: 1, // 首页页码
sidePagination: 'client', // 设置为服务器端分页
queryParams: function (params) { // 请求服务器数据时发送的参数可以在这里添加额外的查询参数返回false则终止请求
return {
// rows: params.limit, // 每页要显示的数据条数
// page: params.offset / params.limit + 1, // 每页显示数据的开始页码
// sort: params.sort, // 要排序的字段
// order: params.order,
pid: '${waterTest.id}'
}
},
// sortName: 'id', // 要排序的字段
// sortOrder: 'desc', // 排序规则
columns: [
{
field: 'mpid', // 返回json数据中的name
title: '化验指标编号', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle'
},
{
field: 'name', // 返回json数据中的name
title: '化验指标名称', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle'
},
{
field: 'filename', // 返回json数据中的name
title: '档案名称', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle'
},
{
field: 'upuser', // 返回json数据中的name
title: '上传人', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle'
},
{
title: "操作",
align: 'center',
valign: 'middle',
width: '80',
formatter: function (value, row, index) {
var buts = '';
buts += '<button class="btn btn-default btn-sm" title="下载" onclick="fileDownload(\'' + row.docId + '\')"><i class="fa fa-download"></i><span class="hidden-md hidden-lg">下载</span></button>';
// buts += '<button class="btn btn-default btn-sm" title="删除" onclick="delRelation(\'' + row.id + '\')"><i class="fa fa fa-trash-o"></i><span class="hidden-md hidden-lg">删除</span></button>';
buts = '<div class = "btn-group">' + buts + '</div>';
return buts;
}
}
],
onLoadSuccess: function () { //加载成功时执行
adjustBootstrapTableView("table_contentFile");
},
onLoadError: function () { //加载失败时执行
console.info("加载数据失败");
}
});
//下载文件
var fileDownload = function (id) {
window.open(ext.contextPath + "/base/downloadFile.do?key=" + id + "&tbName=tb_doc_file");
};
//导入化验指标页面
var doaddDetail = function (jobId, unitId) {
var tableData = $("#table_detail").bootstrapTable('getData');
var libraryIds = "";
$.each(tableData, function (index, item) {
if (libraryIds != "") {
libraryIds += ",";
}
libraryIds += item.libraryId;//维保库id
})
$.post(ext.contextPath + '/process/libraryWaterTest/showList4Choice.do', {
jobId: jobId,
libraryIds: libraryIds,
// jonId: id,
unitId: unitId
}, function (data) {
$("#subDiv_library").html(data);
openModal('libraryModal');
});
}
var deletesFunDetail = function () {
var checkedItems = $("#table_detail").bootstrapTable('getSelections');
var datas = "";
$.each(checkedItems, function (index, item) {
datas += item.id + ",";
});
if (datas == "") {
showAlert('d', '请先选择记录', 'mainAlertdiv');
} else {
swal({
text: "您确定要删除此记录?",
dangerMode: true,
buttons: {
cancel: {
text: "取消",
value: null,
visible: true,
className: "btn btn-default btn-sm",
closeModal: true,
},
confirm: {
text: "确定",
value: true,
visible: true,
className: "btn btn-danger btn-sm",
closeModal: true
}
}
})
.then(function (willDelete) {
if (willDelete) {
$.post(ext.contextPath + '/process/waterTestDetail/dodeletes.do', {ids: datas}, function (data) {
if (data.code > 0) {
$("#table_detail").bootstrapTable('refresh');
} else {
showAlert('d', '删除失败', 'mainAlertdiv');
}
}, 'json');
}
});
}
};
var showUser4SelectsFun = function () {
var userIds = $("#receiveUserIds").val();
$.post(ext.contextPath + '/user/userForSelect.do', {
formId: "subForm",
hiddenId: "receiveUserIds",
textId: "receiveUsersName",
userIds: userIds
}, function (data) {
$("#user4SelectDiv").html(data);
openModal("user4SelectModal");
});
};
function submitFun() {
$('#subForm').data('bootstrapValidator')
.updateStatus('receiveUsersName', 'NOT_VALIDATED', null)
.validateField('receiveUsersName');
$("#subForm").bootstrapValidator('validate');//提交验证
if ($("#subForm").data('bootstrapValidator').isValid()) {
dosubmit();
}
}
function dosubmit() {
$("#status").val('${Status_Start}');
$.post(ext.contextPath + "/process/waterTest/startProcess.do", $("#subForm").serialize(), function (data) {
if (data.res == 1) {
$("#table").bootstrapTable('refresh');
closeModal('subModal');
} else if (data.res == 0) {
showAlert('d', '保存失败');
} else if (data.res == 2) {
showAlert('d', '未检测到化验工单流程,请先部署化验工单流程!');
} else {
showAlert('d', data.res);
}
}, 'json');
}
</script>
<div class="modal fade" id="subModal">
<div class="modal-dialog modal-lg">
<div class="modal-content">
<div class="modal-header">
<button type="button" class="close" data-dismiss="modal" aria-label="Close">
<span aria-hidden="true">&times;</span></button>
<h4 class="modal-title">修改</h4>
</div>
<div class="modal-body">
<!-- 新增界面formid强制为subForm -->
<form class="form-horizontal" id="subForm">
<!-- 界面提醒div强制id为alertDiv -->
<div id="alertDiv"></div>
<input type="hidden" name="id" id="id" value="${waterTest.id}"/>
<input type="hidden" name="unitId" id="unitId" value="${waterTest.unitId}"/>
<div class="form-group">
<label class="col-sm-2 control-label">*工单号</label>
<div class="col-sm-4">
<input type="text" class="form-control" id="jobNumber" name="jobNumber" placeholder="工单号"
value="${waterTest.jobNumber}">
</div>
<label class="col-sm-2 control-label">* 工单类型</label>
<div class="col-sm-4">
<select class="form-control select2" id="jobType" name="jobType" style="width: 170px;">
<option value="" selected="selected">请选择</option>
<option value="${Job_Type_Huanbao}">环保取样</option>
<option value="${Job_Type_Linshi}">临时取样</option>
<option value="${Job_Type_Richang}">日常取样</option>
</select>
</div>
</div>
<div class="form-group">
<label class="col-sm-2 control-label">*接收人员</label>
<div class="col-sm-4">
<input type="text" class="form-control" id="receiveUsersName" name="receiveUsersName"
placeholder="请选择接收人员" onclick="showUser4SelectsFun();"
value="${waterTest.receiveUsersName}">
<input id="receiveUserIds" name="receiveUserIds" type="hidden"
value="${waterTest.receiveUserIds}"/>
</div>
</div>
</form>
<div class="box box-primary">
<div class="box-header with-border">
<h3 class="box-title">化验指标配置</h3>
<div class="box-tools pull-right">
<a onclick="doaddDetail('${waterTest.id}','${waterTest.unitId}')" class="btn btn-box-tool"
data-toggle="tooltip" title="新增"><i class="glyphicon glyphicon-plus"></i></a>
<a onclick="deletesFunDetail()" class="btn btn-box-tool" data-toggle="tooltip" title="删除"><i
class="glyphicon glyphicon-minus"></i></a>
</div>
</div>
<div class="box-body ">
<table id="table_detail" style="table-layout:fixed;"></table>
</div>
</div>
<div class="box box-primary">
<div class="box-header with-border">
<h3 class="box-title">相关资料</h3>
</div>
<div class="box-body ">
<table id="table_contentFile" style="table-layout:fixed;"></table>
</div>
</div>
</div>
<div class="modal-footer">
<button type="button" class="btn btn-default" data-dismiss="modal">关闭</button>
<button type="button" class="btn btn-primary" onclick="dosave()" id="btn_save">保存</button>
<button type="button" class="btn btn-primary" onclick="submitFun()" id="btn_save">下发</button>
</div>
</div>
<!-- /.modal-content -->
</div>
<!-- /.modal-dialog -->
</div>