src/main/java/com/zy/asrs/controller/TaskWrkLogController.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/zy/asrs/entity/TaskWrkLog.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/zy/asrs/mapper/TaskWrkLogMapper.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/zy/asrs/service/TaskWrkLogService.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/java/com/zy/asrs/service/impl/TaskWrkLogServiceImpl.java | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/resources/mapper/TaskWrkLogMapper.xml | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 | |
src/main/webapp/views/taskWrkLog/taskWrkLog.html | ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史 |
src/main/java/com/zy/asrs/controller/TaskWrkLogController.java
New file @@ -0,0 +1,123 @@ package com.zy.asrs.controller; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.baomidou.mybatisplus.plugins.Page; import com.core.common.DateUtils; import com.zy.asrs.entity.TaskWrkLog; import com.zy.asrs.service.TaskWrkLogService; import com.core.annotations.ManagerAuth; import com.core.common.BaseRes; import com.core.common.Cools; import com.core.common.R; import com.zy.common.web.BaseController; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import java.util.*; @RestController public class TaskWrkLogController extends BaseController { @Autowired private TaskWrkLogService taskWrkLogService; @RequestMapping(value = "/taskWrkLog/{id}/auth") @ManagerAuth public R get(@PathVariable("id") String id) { return R.ok(taskWrkLogService.selectById(String.valueOf(id))); } @RequestMapping(value = "/taskWrkLog/list/auth") @ManagerAuth public R list(@RequestParam(defaultValue = "1")Integer curr, @RequestParam(defaultValue = "10")Integer limit, @RequestParam(required = false)String orderByField, @RequestParam(required = false)String orderByType, @RequestParam Map<String, Object> param){ EntityWrapper<TaskWrkLog> wrapper = new EntityWrapper<>(); excludeTrash(param); convert(param, wrapper); if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));} return R.ok(taskWrkLogService.selectPage(new Page<>(curr, limit), wrapper)); } private <T> void convert(Map<String, Object> map, EntityWrapper<T> wrapper){ for (Map.Entry<String, Object> entry : map.entrySet()){ String val = String.valueOf(entry.getValue()); if (val.contains(RANGE_TIME_LINK)){ String[] dates = val.split(RANGE_TIME_LINK); wrapper.ge(entry.getKey(), DateUtils.convert(dates[0])); wrapper.le(entry.getKey(), DateUtils.convert(dates[1])); } else { wrapper.like(entry.getKey(), val); } } } @RequestMapping(value = "/taskWrkLog/add/auth") @ManagerAuth public R add(TaskWrkLog taskWrkLog) { taskWrkLogService.insert(taskWrkLog); return R.ok(); } @RequestMapping(value = "/taskWrkLog/update/auth") @ManagerAuth public R update(TaskWrkLog taskWrkLog){ if (Cools.isEmpty(taskWrkLog) || null==taskWrkLog.getId()){ return R.error(); } taskWrkLogService.updateById(taskWrkLog); return R.ok(); } @RequestMapping(value = "/taskWrkLog/delete/auth") @ManagerAuth public R delete(@RequestParam(value="ids[]") Long[] ids){ for (Long id : ids){ taskWrkLogService.deleteById(id); } return R.ok(); } @RequestMapping(value = "/taskWrkLog/export/auth") @ManagerAuth public R export(@RequestBody JSONObject param){ EntityWrapper<TaskWrkLog> wrapper = new EntityWrapper<>(); List<String> fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class); Map<String, Object> map = excludeTrash(param.getJSONObject("taskWrkLog")); convert(map, wrapper); List<TaskWrkLog> list = taskWrkLogService.selectList(wrapper); return R.ok(exportSupport(list, fields)); } @RequestMapping(value = "/taskWrkLogQuery/auth") @ManagerAuth public R query(String condition) { EntityWrapper<TaskWrkLog> wrapper = new EntityWrapper<>(); wrapper.like("id", condition); Page<TaskWrkLog> page = taskWrkLogService.selectPage(new Page<>(0, 10), wrapper); List<Map<String, Object>> result = new ArrayList<>(); for (TaskWrkLog taskWrkLog : page.getRecords()){ Map<String, Object> map = new HashMap<>(); map.put("id", taskWrkLog.getId()); map.put("value", taskWrkLog.getId()); result.add(map); } return R.ok(result); } @RequestMapping(value = "/taskWrkLog/check/column/auth") @ManagerAuth public R query(@RequestBody JSONObject param) { Wrapper<TaskWrkLog> wrapper = new EntityWrapper<TaskWrkLog>().eq(humpToLine(String.valueOf(param.get("key"))), param.get("val")); if (null != taskWrkLogService.selectOne(wrapper)){ return R.parse(BaseRes.REPEAT).add(getComment(TaskWrkLog.class, String.valueOf(param.get("key")))); } return R.ok(); } } src/main/java/com/zy/asrs/entity/TaskWrkLog.java
New file @@ -0,0 +1,313 @@ package com.zy.asrs.entity; import com.core.common.Cools;import com.baomidou.mybatisplus.annotations.TableField; import java.text.SimpleDateFormat; import java.util.Date; import org.springframework.format.annotation.DateTimeFormat; import com.core.common.SpringUtils; import com.zy.asrs.service.BasWrkIotypeService; import com.zy.asrs.entity.BasWrkIotype; import com.core.common.SpringUtils; import com.zy.system.service.UserService; import com.zy.system.entity.User; import java.text.SimpleDateFormat; import java.util.Date; import java.text.SimpleDateFormat; import java.util.Date; import java.text.SimpleDateFormat; import java.util.Date; import java.text.SimpleDateFormat; import java.util.Date; import java.text.SimpleDateFormat; import java.util.Date; import com.core.common.SpringUtils; import com.zy.asrs.service.BasWrkStatusService; import com.zy.asrs.entity.BasWrkStatus; import com.baomidou.mybatisplus.annotations.TableId; import com.baomidou.mybatisplus.enums.IdType; import io.swagger.annotations.ApiModelProperty; import lombok.Data; import com.baomidou.mybatisplus.annotations.TableName; import java.io.Serializable; @Data @TableName("wcs_task_wrk_log") public class TaskWrkLog implements Serializable { private static final long serialVersionUID = 1L; /** * wms任务号 */ @ApiModelProperty(value= "wms任务号") @TableField("task_no") private String taskNo; /** * 任务状态 1: 接收 2: 派发 3: 完结 4: 取消 */ @ApiModelProperty(value= "任务状态 1: 接收 2: 派发 3: 完结 4: 取消 ") private Integer status; /** * 任务号 */ @ApiModelProperty(value= "任务号") @TableField("wrk_no") private Integer wrkNo; /** * 任务时间(接收时间) */ @ApiModelProperty(value= "任务时间(接收时间)") @TableField("create_time") @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date createTime; /** * 任务类型 */ @ApiModelProperty(value= "任务类型") @TableField("io_type") private Integer ioType; /** * 优先级 */ @ApiModelProperty(value= "优先级") @TableField("io_pri") private Double ioPri; /** * 起点 */ @ApiModelProperty(value= "起点") @TableField("start_point") private String startPoint; /** * 终点 */ @ApiModelProperty(value= "终点") @TableField("target_point") private String targetPoint; /** * 修改人员 */ @ApiModelProperty(value= "修改人员") @TableField("modi_user") private Long modiUser; /** * 修改时间 */ @ApiModelProperty(value= "修改时间") @TableField("modi_time") @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date modiTime; /** * 备注 */ @ApiModelProperty(value= "备注") private String memo; /** * 条码 */ @ApiModelProperty(value= "条码") private String barcode; /** * 派发时间 */ @ApiModelProperty(value= "派发时间") @TableField("assign_time") @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date assignTime; /** * 执行时间 */ @ApiModelProperty(value= "执行时间") @TableField("execute_time") @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date executeTime; /** * 完结时间 */ @ApiModelProperty(value= "完结时间") @TableField("complete_time") @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date completeTime; /** * 取消时间 */ @ApiModelProperty(value= "取消时间") @TableField("cancel_time") @DateTimeFormat(pattern="yyyy-MM-dd HH:mm:ss") private Date cancelTime; /** * 工作状态 */ @ApiModelProperty(value= "工作状态") @TableField("wrk_sts") private Integer wrkSts; /** * 堆垛机号 */ @ApiModelProperty(value= "堆垛机号") @TableField("crn_no") private Integer crnNo; /** * 指令执行步序 */ @ApiModelProperty(value= "指令执行步序") @TableField("command_step") private Integer commandStep; @ApiModelProperty(value= "") @TableId(value = "id", type = IdType.AUTO) private Long id; public TaskWrkLog() {} public TaskWrkLog(String taskNo,Integer status,Integer wrkNo,Date createTime,Integer ioType,Double ioPri,String startPoint,String targetPoint,Long modiUser,Date modiTime,String memo,String barcode,Date assignTime,Date executeTime,Date completeTime,Date cancelTime,Integer wrkSts,Integer crnNo,Integer commandStep) { this.taskNo = taskNo; this.status = status; this.wrkNo = wrkNo; this.createTime = createTime; this.ioType = ioType; this.ioPri = ioPri; this.startPoint = startPoint; this.targetPoint = targetPoint; this.modiUser = modiUser; this.modiTime = modiTime; this.memo = memo; this.barcode = barcode; this.assignTime = assignTime; this.executeTime = executeTime; this.completeTime = completeTime; this.cancelTime = cancelTime; this.wrkSts = wrkSts; this.crnNo = crnNo; this.commandStep = commandStep; } // TaskWrkLog taskWrkLog = new TaskWrkLog( // null, // wms任务号 // null, // 任务状态 // null, // 任务号 // null, // 任务时间(接收时间) // null, // 任务类型 // null, // 优先级 // null, // 起点 // null, // 终点 // null, // 修改人员 // null, // 修改时间 // null, // 备注 // null, // 条码 // null, // 派发时间 // null, // 执行时间 // null, // 完结时间 // null, // 取消时间 // null, // 工作状态 // null, // 堆垛机号 // null, // 指令执行步序 // ); public String getStatus$(){ if (null == this.status){ return null; } switch (this.status){ case 1: return "接收"; case 2: return "派发"; case 3: return "完结"; case 4: return "取消"; default: return String.valueOf(this.status); } } public String getCreateTime$(){ if (Cools.isEmpty(this.createTime)){ return ""; } return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(this.createTime); } public String getIoType$(){ BasWrkIotypeService service = SpringUtils.getBean(BasWrkIotypeService.class); BasWrkIotype basWrkIotype = service.selectById(this.ioType); if (!Cools.isEmpty(basWrkIotype)){ return String.valueOf(basWrkIotype.getIoDesc()); } return null; } public String getModiUser$(){ UserService service = SpringUtils.getBean(UserService.class); User user = service.selectById(this.modiUser); if (!Cools.isEmpty(user)){ return String.valueOf(user.getUsername()); } return null; } public String getModiTime$(){ if (Cools.isEmpty(this.modiTime)){ return ""; } return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(this.modiTime); } public String getAssignTime$(){ if (Cools.isEmpty(this.assignTime)){ return ""; } return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(this.assignTime); } public String getExecuteTime$(){ if (Cools.isEmpty(this.executeTime)){ return ""; } return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(this.executeTime); } public String getCompleteTime$(){ if (Cools.isEmpty(this.completeTime)){ return ""; } return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(this.completeTime); } public String getCancelTime$(){ if (Cools.isEmpty(this.cancelTime)){ return ""; } return new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(this.cancelTime); } public String getWrkSts$(){ BasWrkStatusService service = SpringUtils.getBean(BasWrkStatusService.class); BasWrkStatus basWrkStatus = service.selectById(this.wrkSts); if (!Cools.isEmpty(basWrkStatus)){ return String.valueOf(basWrkStatus.getWrkDesc()); } return null; } } src/main/java/com/zy/asrs/mapper/TaskWrkLogMapper.java
New file @@ -0,0 +1,12 @@ package com.zy.asrs.mapper; import com.zy.asrs.entity.TaskWrkLog; import com.baomidou.mybatisplus.mapper.BaseMapper; import org.apache.ibatis.annotations.Mapper; import org.springframework.stereotype.Repository; @Mapper @Repository public interface TaskWrkLogMapper extends BaseMapper<TaskWrkLog> { } src/main/java/com/zy/asrs/service/TaskWrkLogService.java
New file @@ -0,0 +1,8 @@ package com.zy.asrs.service; import com.zy.asrs.entity.TaskWrkLog; import com.baomidou.mybatisplus.service.IService; public interface TaskWrkLogService extends IService<TaskWrkLog> { } src/main/java/com/zy/asrs/service/impl/TaskWrkLogServiceImpl.java
New file @@ -0,0 +1,12 @@ package com.zy.asrs.service.impl; import com.zy.asrs.mapper.TaskWrkLogMapper; import com.zy.asrs.entity.TaskWrkLog; import com.zy.asrs.service.TaskWrkLogService; import com.baomidou.mybatisplus.service.impl.ServiceImpl; import org.springframework.stereotype.Service; @Service("taskWrkLogService") public class TaskWrkLogServiceImpl extends ServiceImpl<TaskWrkLogMapper, TaskWrkLog> implements TaskWrkLogService { } src/main/resources/mapper/TaskWrkLogMapper.xml
New file @@ -0,0 +1,30 @@ <?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.zy.asrs.mapper.TaskWrkLogMapper"> <!-- 通用查询映射结果 --> <resultMap id="BaseResultMap" type="com.zy.asrs.entity.TaskWrkLog"> <id column="id" property="id" /> <result column="task_no" property="taskNo" /> <result column="status" property="status" /> <result column="wrk_no" property="wrkNo" /> <result column="create_time" property="createTime" /> <result column="io_type" property="ioType" /> <result column="io_pri" property="ioPri" /> <result column="start_point" property="startPoint" /> <result column="target_point" property="targetPoint" /> <result column="modi_user" property="modiUser" /> <result column="modi_time" property="modiTime" /> <result column="memo" property="memo" /> <result column="barcode" property="barcode" /> <result column="assign_time" property="assignTime" /> <result column="execute_time" property="executeTime" /> <result column="complete_time" property="completeTime" /> <result column="cancel_time" property="cancelTime" /> <result column="wrk_sts" property="wrkSts" /> <result column="crn_no" property="crnNo" /> <result column="command_step" property="commandStep" /> </resultMap> </mapper> src/main/webapp/views/taskWrkLog/taskWrkLog.html
New file @@ -0,0 +1,181 @@ <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>任务管理</title> <link rel="stylesheet" href="../../static/wcs/css/element.css"> <script type="text/javascript" src="../../static/wcs/js/jquery/jquery-3.3.1.min.js"></script> <script type="text/javascript" src="../../static/wms/layui/layui.js"></script> <script type="text/javascript" src="../../static/wcs/js/common.js"></script> <script type="text/javascript" src="../../static/wcs/js/vue.min.js"></script> <script type="text/javascript" src="../../static/wcs/js/element.js"></script> </head> <body> <div id="app" style="display: flex;justify-content: center;flex-wrap: wrap;"> <div style="width: 100%;"> <el-card class="box-card"> <el-form :inline="true" :model="tableSearchParam" class="demo-form-inline"> <el-form-item label=""> <el-input v-model="tableSearchParam.task_no" placeholder="任务号"></el-input> </el-form-item> <el-form-item label=""> <el-input v-model="tableSearchParam.wrk_no" placeholder="工作号"></el-input> </el-form-item> <el-form-item> <el-button type="primary" @click="getTableData">查询</el-button> <el-button type="primary" @click="resetParam">重置</el-button> </el-form-item> </el-form> <el-table ref="singleTable" :data="tableData" style="width: 100%;"> <el-table-column label="操作" width="100"> <template slot-scope="scope"> <el-dropdown @command="(command)=>{handleCommand(command, scope.row)}"> <el-button icon="el-icon-more" size="mini" type="primary"></el-button> <el-dropdown-menu slot="dropdown"> <el-dropdown-item command="showCommand">查看指令</el-dropdown-item> </el-dropdown-menu> </el-dropdown> </template> </el-table-column> <el-table-column property="taskNo" label="任务号"> </el-table-column> <el-table-column property="status$" label="任务状态"> </el-table-column> <el-table-column property="wrkNo" label="工作号"> </el-table-column> <el-table-column property="createTime$" label="任务时间"> </el-table-column> <el-table-column property="durationTime" label="持续时长"> </el-table-column> <el-table-column property="ioType$" label="任务类型"> </el-table-column> <el-table-column property="startPoint" label="起点位置"> </el-table-column> <el-table-column property="targetPoint" label="终点位置"> </el-table-column> <el-table-column property="wrkSts$" label="工作状态"> </el-table-column> <el-table-column property="crnNo" label="堆垛机号"> </el-table-column> </el-table> <div style="margin-top: 10px;"> <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="currentPage" :page-sizes="pageSizes" :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper" :total="pageTotal"> </el-pagination> </div> </el-card> </div> </div> <script> var $layui = layui.config({ base: baseUrl + "/static/wms/layui/lay/modules/" }).use(['layer', 'form'], function() {}) var app = new Vue({ el: '#app', data: { tableData: [], currentPage: 1, pageSizes: [16, 30, 50, 100, 150, 200], pageSize: 16, pageTotal: 0, tableSearchParam: { task_no: null, status: null, wrk_no: null } }, created() { this.init() }, methods: { init() { let taskNo = getQueryVariable('taskNo') let wrkNo = getQueryVariable('wrkNo') if (taskNo != false) { this.tableSearchParam.task_no = taskNo } if (wrkNo != false) { this.tableSearchParam.wrk_no = wrkNo } this.getTableData() }, getTableData() { let that = this; let data = this.tableSearchParam data.curr = this.currentPage data.limit = this.pageSize $.ajax({ url: baseUrl + "/taskWrkLog/list/auth", headers: { 'token': localStorage.getItem('token') }, data: data, dataType: 'json', contentType: 'application/json;charset=UTF-8', method: 'GET', success: function(res) { if (res.code == 200) { that.tableData = res.data.records that.pageTotal = res.data.total } else if (res.code === 403) { top.location.href = baseUrl + "/"; } else { that.$message({ message: res.msg, type: 'error' }); } } }); }, handleSizeChange(val) { console.log(`每页 ${val} 条`); this.pageSize = val this.getTableData() }, handleCurrentChange(val) { console.log(`当前页: ${val}`); this.currentPage = val this.getTableData() }, resetParam() { this.tableSearchParam = { task_no: null, status: null, wrk_no: null } this.getTableData() }, handleCommand(command, row) { switch (command) { case "showCommand": //查看指令 this.showCommand(row) break; } }, showCommand(row) { let wrkNo = row.wrkNo == null ? "" : row.wrkNo //查看指令 $layui.layer.open({ type: 2, title: '指令管理', maxmin: true, area: [top.detailWidth, top.detailHeight], shadeClose: true, content: 'commandManage.html?taskNo=' + row.taskNo + "&wrkNo=" + wrkNo, success: function(layero, index) {} }); }, } }) </script> </body> </html>