Files
SIPAIIS_WMS_JSSW/WebRoot/jsp/process/routineWorkList.jsp

476 lines
21 KiB
Plaintext
Raw Normal View History

2026-01-16 14:13:44 +08:00
<%@page import="com.sipai.tools.CommString" %>
<%@ page language="java" pageEncoding="UTF-8" %>
<%@ taglib uri="http://java.sun.com/jstl/core_rt" prefix="c" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/functions" prefix="fn" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/fmt" prefix="fmt" %>
<%@ page import="com.sipai.entity.base.ServerObject" %>
<%@ taglib uri="http://www.springsecurity.org/jsp" prefix="security" %>
<%@page import="com.sipai.entity.process.LibraryRoutineWork" %>
<% request.setAttribute("Type_Run", LibraryRoutineWork.Type_Run); %>
<% request.setAttribute("Type_Manage", LibraryRoutineWork.Type_Manage); %>
<%@page import="com.sipai.entity.process.RoutineWork" %>
<% request.setAttribute("Status_NotStart", RoutineWork.Status_NotStart); %>
<% request.setAttribute("Status_Start", RoutineWork.Status_Start); %>
<% request.setAttribute("Status_Receive", RoutineWork.Status_Receive); %>
<% request.setAttribute("Status_Finish", RoutineWork.Status_Finish); %>
<!DOCTYPE html>
<head>
<title><%= ServerObject.atttable.get("TOPTITLE")%>
</title>
<!-- 引用页头及CSS页-->
<jsp:include page="/jsp/inc.jsp"></jsp:include>
<style type="text/css">
.select2-container .select2-selection--single {
height: 34px;
line-height: 34px;
}
.select2-selection__arrow {
margin-top: 3px;
}
.table-hover > tbody > tr:hover {
cursor: pointer;
}
</style>
<script type="text/javascript">
var addFun = function () {
// $.post(ext.contextPath + '/process/routineWork/doadd.do', {unitId:unitId} , function(data) {
// $("#subDiv").html(data);
// openModal('subModal');
// });
$.post(ext.contextPath + '/process/libraryRoutineWork/showlist4Choice.do', {}, function (data) {
$("#librarySelectDiv").html(data);
openModal("librarySelectModal");
});
};
var editFun = function (id) {
stopBubbleDefaultEvent();
$.post(ext.contextPath + '/process/routineWork/doedit.do', {id: id}, function (data) {
$("#subDiv").html(data);
openModal('subModal');
});
};
var viewFun = function (id) {
$.post(ext.contextPath + '/process/routineWork/doview.do', {id: id}, function (data) {
$("#subDiv").html(data);
openModal('subModal');
});
};
var processViewFun = function (id) {
stopBubbleDefaultEvent();
$.post(ext.contextPath + '/process/routineWork/showProcessView.do', {id: id}, function (data) {
$("#subDiv").html(data);
openModal('processViewModal');
});
}
var deleteFun = function (id) {
stopBubbleDefaultEvent();
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/routineWork/dodelete.do', {id: id}, function (data) {
var datajson = JSON.parse(data);
if (datajson.code == 1) {
$("#table").bootstrapTable('refresh');
} else {
showAlert('d', '删除失败', 'mainAlertdiv');
}
});
}
});
};
var deletesFun = function () {
var checkedItems = $("#table").bootstrapTable('getSelections');
var datas = "";
$.each(checkedItems, function (index, item) {
//进入流程的不能删除
if (item.status == '${Status_NotStart}') {
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/routineWork/dodeletes.do', {ids: datas}, function (data) {
if (data.code > 0) {
$("#table").bootstrapTable('refresh');
} else {
showAlert('d', '删除失败', 'mainAlertdiv');
}
}, 'json');
}
});
}
};
//表格查询参数
function queryParamsFun(params) { // 请求服务器数据时发送的参数可以在这里添加额外的查询参数返回false则终止请求
var typestr = $('#typestr').val();
return {
rows: params.limit, // 每页要显示的数据条数
page: params.offset / params.limit + 1, // 每页显示数据的开始页码
sort: params.sort, // 要排序的字段
order: params.order,
unitId: unitId,
typestr: typestr
}
};
//厂区选择后,初始化工艺段,加载表格
var initFun = function () {
// initoverhaulType();
$('#table').bootstrapTable('destroy');
$("#table").bootstrapTable({ // 对应table标签的id
url: ext.contextPath + '/process/routineWork/getList.do', // 获取表格数据的url
cache: false, // 设置为 false 禁用 AJAX 数据缓存, 默认为true
singleSelect: false,//单选多选
striped: true, //表格显示条纹默认为false
pagination: true, // 在表格底部显示分页组件默认false
pageList: [10, 20, 50], // 设置页面可以显示的数据条数
pageSize: 50, // 页面数据条数
pageNumber: 1, // 首页页码
sidePagination: 'server', // 设置为服务器端分页
queryParams: queryParamsFun,
sortName: 'morder', // 要排序的字段
sortOrder: 'asc', // 排序规则
onClickRow: function (row) {//单击行事件,执行查看功能
viewFun(row.id);
},
columns: [
{
checkbox: true,
width: '40px',
formatter: function (value, row, index) {
if (row.status == '' || row.status == '${Status_NotStart}') {
return {disabled: false,}
} else {
return {disabled: true,}
}
}
},
/*{
field: '', // 返回json数据中的name
title: '类型', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '5%',
formatter: function (value, row, index) {
if (row.libraryRoutineWork != null && row.libraryRoutineWork != '') {
if (row.libraryRoutineWork.type == '${Type_Run}') {
return '运行';
}
if (row.libraryRoutineWork.type == '${Type_Manage}') {
return '行政';
}
}
}
},*/
{
field: '', // 返回json数据中的name
title: '工单号', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '15%',
formatter: function (value, row, index) {
return "<span style='display: block;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;' title='" + row.jobNumber + "'>" + row.jobNumber + "</span>";
}
},
{
field: '', // 返回json数据中的name
title: '工作类型名称', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '10%',
formatter: function (value, row, index) {
if (row.libraryRoutineWork != null && row.libraryRoutineWork != '') {
return row.libraryRoutineWork.pworkTypeName;
}
}
},
{
field: '', // 返回json数据中的name
title: '计划开始时间', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '7%',
formatter: function (value, row, index) {
if (row.planStartDate != null && row.planStartDate != '') {
return row.planStartDate.substring(0, 10);
}
}
},
{
field: '', // 返回json数据中的name
title: '工作编号', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '8%',
formatter: function (value, row, index) {
if (row.libraryRoutineWork != null && row.libraryRoutineWork != '') {
return row.libraryRoutineWork.workCode;
}
}
},
{
field: '', // 返回json数据中的name
title: '工作名称', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '10%',
formatter: function (value, row, index) {
if (row.libraryRoutineWork != null && row.libraryRoutineWork != '') {
return "<span style='display: block;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;' title='" + row.libraryRoutineWork.workName + "'>" + row.libraryRoutineWork.workName + "</span>";
}
}
},
{
field: '', // 返回json数据中的name
title: '工作内容', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '21%',
formatter: function (value, row, index) {
if (row.libraryRoutineWork != null && row.libraryRoutineWork != '') {
return "<span style='display: block;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;' title='" + row.libraryRoutineWork.workContent + "'>" + row.libraryRoutineWork.workContent + "</span>";
}
}
},
// {
// field: '', // 返回json数据中的name
// title: '定额工时(小时)', // 表格表头显示文字
// align: 'center', // 左右居中
// valign: 'middle',
// width: '8%',
// formatter: function (value, row, index) {
// if (row.libraryRoutineWork != null && row.libraryRoutineWork != '') {
// return row.libraryRoutineWork.baseHours;
// }
// }
// },
// {
// field: '', // 返回json数据中的name
// title: '定额费用(元)', // 表格表头显示文字
// align: 'center', // 左右居中
// valign: 'middle',
// width: '8%',
// formatter: function (value, row, index) {
// if (row.libraryRoutineWork != null && row.libraryRoutineWork != '') {
// return row.libraryRoutineWork.baseCost;
// }
// }
// },
{
field: '', // 返回json数据中的name
title: '是否可抢单', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '7%',
formatter: function (value, row, index) {
if (row.libraryRoutineWork != null && row.libraryRoutineWork != '') {
return row.libraryRoutineWork.robWorkorder;
}
}
},
{
field: '', // 返回json数据中的name
title: '接单人', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '10%',
formatter: function (value, row, index) {
// if (row.receiveUser != null && row.receiveUser != '') {
// return row.receiveUser.caption;
// }
return row.receiveUsersName;
}
},
/*{
field: '', // 返回json数据中的name
title: '验收时间', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '7%',
formatter: function (value, row, index) {
return row.checkTime;
}
},*/
{
field: '', // 返回json数据中的name
title: '状态', // 表格表头显示文字
align: 'center', // 左右居中
valign: 'middle',
width: '7%',
formatter: function (value, row, index) {
if (row.status == '${Status_NotStart}') {
return '未下发';
}
if (row.status == '${Status_Start}') {
return '待接单';
}
if (row.status == '${Status_Receive}') {
return '已接单';
}
if (row.status == '${Status_Finish}') {
return '已完成';
}
}
},
{
title: "操作",
align: 'center',
valign: 'middle',
width: '5%', // 定义列的宽度单位为像素px
formatter: function (value, row, index) {
var buts = '';
if (row.status == '${Status_NotStart}') {
buts += '<button class="btn btn-default btn-sm" title="编辑" onclick="editFun(\'' + row.id + '\')"><i class="fa fa-edit"></i><span class="hidden-md hidden-lg"> 编辑</span></button>';
} else {
buts += '<button class="btn btn-default btn-sm" title="查看详情" onclick="processViewFun(\'' + row.id + '\')"><i class="fa fa-history"></i><span class="hidden-md hidden-lg">查看详情</span></button>';
}
buts = '<div class="btn-group" >' + buts + '</div>';
return buts;
}
}
],
onLoadSuccess: function () { //加载成功时执行
adjustBootstrapTableView("table");
},
onLoadError: function () { //加载失败时执行
console.info("加载数据失败");
}
});
}
function receiveFun() {
alert('已签收');
}
function doRelease() {
var checkedItems = $("#table").bootstrapTable('getSelections');
var datas = "";
$.each(checkedItems, function (index, item) {
if (datas != "") {
datas += ",";
}
datas += item.id;
});
// $.each(checkedItems, function (index, item) {
// datas += item.id + ",";
// });
if (datas == "") {
showAlert('d', '请先选择记录', 'mainAlertdiv');
} else {
$.post(ext.contextPath + '/process/routineWork/doRelease4slect.do', {ckids: datas}, function (data) {
$("#user4SelectDiv").html(data);
openModal('user4SelectModal');
});
}
}
</script>
</head>
<body onload="initFun()">
<div class="wrapper">
<div class="content-wrapper">
<input type="hidden" id="typestr" name="typestr" value="${param.typestr}">
<section class="content-header">
<h1 id="head_title"></h1>
<ol class="breadcrumb">
<li><a id='head_firstlevel' href="#"><i class="fa fa-dashboard"></i> </a></li>
</ol>
</section>
<section class="content container-fluid">
<div id="subDiv"></div>
<div id="fileInputDiv"></div>
<div id="librarySelectDiv"></div>
<div id="user4SelectDiv"></div>
<div id="alertDiv"></div>
<div id="mainAlertdiv"></div>
<form id="searchForm">
<div id="companySelectTree" style="display:none;"></div>
<div class="btn-group" style="width: 220px;padding-bottom:10px;">
<security:authorize buttonUrl="process/routineWork/add.do">
<button type="button" class="btn btn-default btn-sm" onclick="addFun();"><i
class="fa fa-plus"></i>
新增
</button>
<button type="button" class="btn btn-default btn-sm" onclick="deletesFun();"><i
class="fa fa-trash-o"></i>
删除
</button>
<button type="button" class="btn btn-default btn-sm" onclick="doRelease();"><i
class="fa fa-download"></i>
下发
</button>
</security:authorize>
</div>
</form>
<table id="table" style="table-layout:fixed;"></table>
</section>
<!-- /.content -->
</div>
</div>
</body>
</html>