From ade1b378ff2f0781be2fbc537b6c09237a50631a Mon Sep 17 00:00:00 2001
From: k94314517 <8417338+k94314517@user.noreply.gitee.com>
Date: 星期二, 20 八月 2024 18:18:59 +0800
Subject: [PATCH] 代码初始化

---
 server/system_service/src/main/java/com/doumee/core/utils/Constants.java                                   |    4 
 server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/Platform.java                    |    3 
 server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformWmsJob.java              |    4 
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java       |    2 
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java   |  496 +++++++++++++++++++++++++++++++++++++++--
 server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformJob.java                 |   34 ++
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/PlatformJobService.java            |   50 ++++
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformGroupServiceImpl.java |    3 
 server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/web/PdaPlatformController.java                  |   68 +++++
 server/visits/dmvisit_service/src/main/java/com/doumee/dao/web/reqeust/JobOperateDTO.java                  |   33 ++
 server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformLog.java                 |    6 
 11 files changed, 666 insertions(+), 37 deletions(-)

diff --git a/server/system_service/src/main/java/com/doumee/core/utils/Constants.java b/server/system_service/src/main/java/com/doumee/core/utils/Constants.java
index fde9d51..7d06378 100644
--- a/server/system_service/src/main/java/com/doumee/core/utils/Constants.java
+++ b/server/system_service/src/main/java/com/doumee/core/utils/Constants.java
@@ -5,6 +5,8 @@
 import com.fasterxml.jackson.core.JsonProcessingException;
 import com.fasterxml.jackson.databind.ObjectMapper;
 import com.fasterxml.jackson.databind.PropertyNamingStrategy;
+import io.swagger.models.auth.In;
+import org.apache.batik.util.Platform;
 import org.apache.commons.collections4.CollectionUtils;
 import org.apache.commons.lang3.StringUtils;
 
@@ -918,6 +920,8 @@
         T reqJson =  mapper.readValue(json, clazz);
         return reqJson;
     }
+
+
     /**
      * 鍛樺伐淇℃伅缁存姢鎿嶄綔鍘嗗彶绫诲瀷 0瑙e喕 1鍐荤粨 2鎷夐粦 3鎭㈠ 4璁句负鎷滆浜� 5鍙栨秷鎷滆浜� 6璁句负楂樼骇瀹℃壒浜� 7鍙栨秷楂樼骇瀹℃壒浜� 8鎵嬪姩绂诲満 9鍒犻櫎 10鏇存柊 11鎺堟潈闂ㄧ鏉冮檺 12绂昏亴 13鎭㈠鍦ㄨ亴
      */
diff --git a/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/web/PdaPlatformController.java b/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/web/PdaPlatformController.java
index b9c77b5..91a3cb7 100644
--- a/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/web/PdaPlatformController.java
+++ b/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/web/PdaPlatformController.java
@@ -21,6 +21,7 @@
 import io.swagger.annotations.ApiImplicitParams;
 import io.swagger.annotations.ApiOperation;
 import lombok.extern.slf4j.Slf4j;
+import org.apache.shiro.authz.annotation.RequiresPermissions;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
 
@@ -47,8 +48,6 @@
     @Autowired
     private PlatformJobService platformJobService;
 
-    @Autowired
-    private PlatformBooksService platformBooksService;
 
     @Autowired
     private PlatformGroupService platformGroupService;
@@ -58,9 +57,12 @@
 
 
 
+
+
+
     @ApiOperation("鑾峰彇鏈堝彴缁勪俊鎭�")
     @ApiImplicitParams({
-            @ApiImplicitParam(name = "queryType", dataType = "Integer", value = "0=鍏ㄩ儴鏈堝彴锛�1=鍚敤鏈堝彴 2=閰嶇疆鎴戠殑鏈堝彴", required = false)
+            @ApiImplicitParam(name = "queryType", dataType = "Integer", value = "0=鍏ㄩ儴鏈堝彴锛�1=鍚敤鏈堝彴 2=閰嶇疆鏄剧ず鏈堝彴", required = false)
     })
     @GetMapping("/getPlatformGroupList")
     public ApiResponse<List<PlatformGroup>>  getPlatformGroupList (@RequestParam Integer queryType, @RequestHeader(Constants.HEADER_USER_TOKEN) String token){
@@ -74,5 +76,65 @@
         return ApiResponse.success("鎿嶄綔鎴愬姛");
     }
 
+    @ApiOperation("杞﹁締鎺掗槦鎯呭喌")
+    @PostMapping("/platformLineUpPage")
+    public ApiResponse<PageData<PlatformJob>> platformLineUpPage (@RequestBody PageWrap<PlatformJob> pageWrap) {
+        return ApiResponse.success(platformJobService.findPage(pageWrap));
+    }
+
+
+    @ApiOperation("鏈堝彴鍙彿")
+    @PostMapping("/platformCallNumber")
+    public ApiResponse platformCallNumber (@RequestBody JobOperateDTO jobOperateDTO, @RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
+        jobOperateDTO.setLoginUserInfo(getLoginUser(token));
+        platformJobService.platformInPark(jobOperateDTO);
+        return ApiResponse.success("鎿嶄綔鎴愬姛");
+    }
+
+
+    @ApiOperation("杞Щ鏈堝彴")
+    @PostMapping("/platformMove")
+    public ApiResponse platformMove (@RequestBody JobOperateDTO jobOperateDTO, @RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
+        jobOperateDTO.setLoginUserInfo(getLoginUser(token));
+        platformJobService.platformInPark(jobOperateDTO);
+        return ApiResponse.success("鎿嶄綔鎴愬姛");
+    }
+
+    @ApiOperation("鏈堝彴杩囧彿")
+    @PostMapping("/platformOverNumber")
+    public ApiResponse platformOverNumber (@RequestBody JobOperateDTO jobOperateDTO, @RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
+        jobOperateDTO.setLoginUserInfo(getLoginUser(token));
+        platformJobService.platformInPark(jobOperateDTO);
+        return ApiResponse.success("鎿嶄綔鎴愬姛");
+    }
+
+    @ApiOperation("寮傚父鎸傝捣")
+    @PostMapping("/platformErr")
+    public ApiResponse platformErr (@RequestBody JobOperateDTO jobOperateDTO, @RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
+        jobOperateDTO.setLoginUserInfo(getLoginUser(token));
+        platformJobService.platformInPark(jobOperateDTO);
+        return ApiResponse.success("鎿嶄綔鎴愬姛");
+    }
+
+    @ApiOperation("鎵嬪姩寮�濮嬩綔涓�")
+    @PostMapping("/beginWork")
+    public ApiResponse beginWork (@RequestBody JobOperateDTO jobOperateDTO, @RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
+        jobOperateDTO.setLoginUserInfo(getLoginUser(token));
+        platformJobService.platformInPark(jobOperateDTO);
+        return ApiResponse.success("鎿嶄綔鎴愬姛");
+    }
+
+
+    @ApiOperation("瀹屾垚浣滀笟")
+    @PostMapping("/finishWork")
+    public ApiResponse finishWork (@RequestBody JobOperateDTO jobOperateDTO, @RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
+        jobOperateDTO.setLoginUserInfo(getLoginUser(token));
+        platformJobService.platformInPark(jobOperateDTO);
+        return ApiResponse.success("鎿嶄綔鎴愬姛");
+    }
+
+
+
+
 
 }
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/Platform.java b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/Platform.java
index 314f0df..7f6c4b6 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/Platform.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/Platform.java
@@ -180,4 +180,7 @@
     @TableField(exist = false)
     private Boolean showConfig = false;
 
+    @ApiModelProperty(value = "浣滀笟鐘舵�侊細0=绌洪棽锛�1=浣滀笟涓�")
+    @TableField(exist = false)
+    private Integer workStatus;
 }
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformJob.java b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformJob.java
index 7859656..57cfc6d 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformJob.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformJob.java
@@ -2,6 +2,7 @@
 
 import com.baomidou.mybatisplus.annotation.TableField;
 import com.doumee.core.annotation.excel.ExcelColumn;
+import com.doumee.core.utils.Constants;
 import io.swagger.annotations.ApiModel;
 import io.swagger.annotations.ApiModelProperty;
 import com.baomidou.mybatisplus.annotation.IdType;
@@ -11,6 +12,7 @@
 import com.fasterxml.jackson.annotation.JsonFormat;
 import java.util.Date;
 import java.math.BigDecimal;
+import java.util.Objects;
 
 /**
  * 鏈堝彴璋冨害浣滀笟淇℃伅琛�
@@ -91,7 +93,6 @@
 
     @ApiModelProperty(value = "绛惧埌鏃堕棿")
     @ExcelColumn(name="绛惧埌鏃堕棿")
-  
     private Date signDate;
 
     @ApiModelProperty(value = "绛惧埌鏂瑰紡 0app绛惧埌 1鎵爜绛惧埌", example = "1")
@@ -161,7 +162,6 @@
 
     @ApiModelProperty(value = "鏈堝彴杞氦鏃堕棿")
     @ExcelColumn(name="鏈堝彴杞氦鏃堕棿")
-  
     private Date transPlatformDate;
 
     @ApiModelProperty(value = "鏈堝彴杞氦澶勭悊浜�", example = "1")
@@ -278,4 +278,34 @@
     @TableField(exist = false)
     private BigDecimal getDistance;
 
+
+    @ApiModelProperty(value = "涓氬姟瑙﹀彂鏃堕棿  鏃堕棿")
+    @TableField(exist = false)
+    private Long optTime;
+
+    @ApiModelProperty(value = "宸蹭綔涓氭椂闂�")
+    @TableField(exist = false)
+    private Long workTime;
+
+    @ApiModelProperty(value = "WMS浠诲姟淇℃伅")
+    @TableField(exist = false)
+    private  PlatformWmsJob platformWmsJob;
+
+    public void dealTime(){
+        if(Constants.equalsInteger(this.getStatus(),Constants.PlatformJobStatus.WAIT_CONFIRM.getKey())
+                || Constants.equalsInteger(this.getStatus(),Constants.PlatformJobStatus.WART_SIGN_IN.getKey())
+         ){
+            return;
+        }
+        if(Constants.equalsInteger(this.getStatus(),Constants.PlatformJobStatus.WAIT_CALL.getKey())){
+            this.setOptTime(this.getSignDate().getTime());
+        }else if(Constants.equalsInteger(this.getStatus(),Constants.PlatformJobStatus.IN_WAIT.getKey())){
+            this.setOptTime(this.getInwaitDate().getTime());
+        }else if(Constants.equalsInteger(this.getStatus(),Constants.PlatformJobStatus.CALLED.getKey())){
+            this.setOptTime(this.getCallDate().getTime());
+        }else if(Constants.equalsInteger(this.getStatus(),Constants.PlatformJobStatus.WORKING.getKey())){
+            this.setOptTime(this.getStartDate().getTime());
+        }
+    }
+
 }
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformLog.java b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformLog.java
index 972c60c..dc52393 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformLog.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformLog.java
@@ -79,15 +79,15 @@
     @ExcelColumn(name="鎿嶄綔鍚庡唴瀹�")
     private String afterContent;
 
-    @ApiModelProperty(value = "鍙傛暟1")
+    @ApiModelProperty(value = "鍙傛暟1 寮�濮嬩綔涓氭椂闂�")
     @ExcelColumn(name="鍙傛暟1")
     private String param1;
 
-    @ApiModelProperty(value = "鍙傛暟2")
+    @ApiModelProperty(value = "鍙傛暟2 缁撴潫浣滀笟鏃堕棿")
     @ExcelColumn(name="鍙傛暟2")
     private String param2;
 
-    @ApiModelProperty(value = "鍙傛暟3")
+    @ApiModelProperty(value = "鍙傛暟3 鏈浣滀笟鑰楁椂 鍗曚綅锛� 绉�")
     @ExcelColumn(name="鍙傛暟3")
     private String param3;
 
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformWmsJob.java b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformWmsJob.java
index 5b9a619..f3b22db 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformWmsJob.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/PlatformWmsJob.java
@@ -10,6 +10,7 @@
 import lombok.Data;
 import com.fasterxml.jackson.annotation.JsonFormat;
 import java.util.Date;
+import java.util.List;
 
 /**
  * 鏈堝彴_WMS浣滀笟閫氱煡鍗曡鏁版嵁
@@ -112,4 +113,7 @@
     @TableField(exist = false)
     private int isNew;
 
+    @ApiModelProperty(value = "鏈堝彴_WMS浣滀笟閫氱煡鍗曟槑缁�")
+    @TableField(exist = false)
+    private List<PlatformWmsDetail> platformWmsDetailList;
 }
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/web/reqeust/JobOperateDTO.java b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/web/reqeust/JobOperateDTO.java
new file mode 100644
index 0000000..5af0cb3
--- /dev/null
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/web/reqeust/JobOperateDTO.java
@@ -0,0 +1,33 @@
+package com.doumee.dao.web.reqeust;
+
+import com.doumee.core.model.LoginUserInfo;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+/**
+ * Created by IntelliJ IDEA.
+ *
+ * @Author : Rk
+ * @create 2023/12/7 11:19
+ */
+@Data
+@Api(tags = "鏈堝彴杞Щ涓氬姟" )
+public class JobOperateDTO {
+
+    @ApiModelProperty(value = "浠诲姟涓婚敭")
+    private Integer jobId;
+
+    @ApiModelProperty(value = "杞Щ鏈堝彴涓婚敭 杞Щ涓氬姟浣跨敤")
+    private Integer platformId;
+
+    @ApiModelProperty(value = "鍚庤溅鐗屽彿 鑷姩寮�濮嬩换鍔′娇鐢�")
+    private String carCodeBack;
+
+    @ApiModelProperty(value = "鏈堝彴鐩告満涓婚敭 鑷姩寮�濮嬩换鍔′娇鐢�")
+    private Integer deviceId;
+
+    @ApiModelProperty(value = "鐢ㄦ埛", hidden = true)
+    private LoginUserInfo loginUserInfo;
+
+}
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/PlatformJobService.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/PlatformJobService.java
index e663954..ac8a7a8 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/PlatformJobService.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/PlatformJobService.java
@@ -4,6 +4,7 @@
 import com.doumee.core.model.PageWrap;
 import com.doumee.dao.business.model.PlatformJob;
 import com.doumee.dao.web.reqeust.JobDetailDTO;
+import com.doumee.dao.web.reqeust.JobOperateDTO;
 import com.doumee.dao.web.reqeust.LineUpDetailDTO;
 import com.doumee.dao.web.reqeust.SignInDTO;
 import com.doumee.dao.web.response.DriverHomeVO;
@@ -122,4 +123,53 @@
      * @return
      */
     LineUpVO lineUpDetail(LineUpDetailDTO lineUpDetailDTO);
+
+    /**
+     * 閫氱煡鍏ュ洯
+     * @param jobOperateDTO
+     */
+    void platformInPark(JobOperateDTO jobOperateDTO);
+
+    /**
+     * 鏈堝彴鍙彿
+     * @param jobOperateDTO
+     */
+    void platformCallNumber(JobOperateDTO jobOperateDTO);
+
+    /**
+     * 杞Щ鏈堝彴
+     * @param jobOperateDTO
+     */
+    void platformMove(JobOperateDTO jobOperateDTO);
+
+    /**
+     * 鏈堝彴杩囧彿
+     * @param jobOperateDTO
+     */
+    void platformOverNumber(JobOperateDTO jobOperateDTO);
+
+    /**
+     * 寮傚父鎸傝捣
+     * @param jobOperateDTO
+     */
+    void platformErr(JobOperateDTO jobOperateDTO);
+
+    /**
+     * 鎵嬪姩寮�濮嬩綔涓�
+     * @param jobOperateDTO
+     */
+    void beginWork(JobOperateDTO jobOperateDTO);
+
+    /**
+     * 鏈堝彴鐩告満 寮�濮嬩綔涓�
+     * @param jobOperateDTO
+     */
+    void cameraStartWork(JobOperateDTO jobOperateDTO);
+
+    /**
+     * 瀹屾垚浣滀笟
+     * @param jobOperateDTO
+     */
+    void finishWork(JobOperateDTO jobOperateDTO);
+
 }
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java
index 4742664..804ee30 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/ApproveServiceImpl.java
@@ -1365,7 +1365,7 @@
             platformLog.setCreateDate(new Date());
             platformLog.setJobId(platformJob.getId());
             platformLog.setIsdeleted(Constants.ZERO);
-            platformLog.setObjType(Constants.ZERO);
+            platformLog.setObjType(Constants.PlatformJobStatus.WART_SIGN_IN.getKey());
             platformLog.setObjId(platformJob.getId().toString());
             platformLog.setAfterContent(JSONObject.toJSONString(platformJob));
             platformLogMapper.insert(platformLog);
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformGroupServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformGroupServiceImpl.java
index 7700605..7dcc045 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformGroupServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformGroupServiceImpl.java
@@ -204,8 +204,9 @@
         List<Platform> allPlatformList = platformJoinMapper.selectJoinList(Platform.class,
                 new MPJLambdaWrapper<Platform>()
                         .selectAll(Platform.class)
+                        .select(" ( select count(1) from platform_job pj where t.id = pj.PLATFORM_ID and pj.STATUS = "+Constants.PlatformJobStatus.WORKING.getKey()+" ) as workStatus ")
                         .eq(Platform::getIsdeleted, Constants.ZERO)
-                        //TODO 寰呯‘璁ゆ湀鍙扮姸鎬佸瓧娈�
+                        .eq(Platform::getStatus, Constants.ZERO)
                         .eq(Objects.nonNull(queryType)&&!Constants.equalsInteger(queryType,Constants.ZERO),Platform::getStatus,Constants.ZERO)
         );
         //澶勭悊鎴戠殑鏈堝彴淇℃伅 鏄惁閰嶇疆闅愯棌
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java
index a5ec104..d8e0284 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/PlatformJobServiceImpl.java
@@ -1,24 +1,20 @@
 package com.doumee.service.business.impl;
 
-import cn.hutool.crypto.asymmetric.Sign;
+import com.alibaba.fastjson.JSONObject;
 import com.doumee.biz.system.SystemDictDataBiz;
 import com.doumee.core.constants.ResponseStatus;
 import com.doumee.core.exception.BusinessException;
-import com.doumee.core.model.LoginUserInfo;
 import com.doumee.core.model.PageData;
 import com.doumee.core.model.PageWrap;
 import com.doumee.core.utils.Constants;
 import com.doumee.core.utils.DateUtil;
 import com.doumee.core.utils.PositionUtil;
 import com.doumee.core.utils.Utils;
-import com.doumee.dao.business.PlatformJobMapper;
-import com.doumee.dao.business.PlatformMapper;
+import com.doumee.dao.business.*;
 import com.doumee.dao.business.join.PlatformJobJoinMapper;
-import com.doumee.dao.business.model.Platform;
-import com.doumee.dao.business.model.PlatformBooks;
-import com.doumee.dao.business.model.PlatformJob;
-import com.doumee.dao.business.model.PlatformReason;
+import com.doumee.dao.business.model.*;
 import com.doumee.dao.web.reqeust.JobDetailDTO;
+import com.doumee.dao.web.reqeust.JobOperateDTO;
 import com.doumee.dao.web.reqeust.LineUpDetailDTO;
 import com.doumee.dao.web.reqeust.SignInDTO;
 import com.doumee.dao.web.response.DriverHomeVO;
@@ -30,6 +26,7 @@
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.github.yulichang.wrapper.MPJLambdaWrapper;
 import org.apache.commons.lang3.StringUtils;
+import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
@@ -53,6 +50,9 @@
     private PlatformJobMapper platformJobMapper;
 
     @Autowired
+    private PlatformDeviceMapper platformDeviceMapper;
+
+    @Autowired
     private PlatformJobJoinMapper platformJobJoinMapper;
 
     @Autowired
@@ -60,6 +60,15 @@
 
     @Autowired
     private PlatformMapper platformMapper;
+
+    @Autowired
+    private PlatformLogMapper platformLogMapper;
+
+    @Autowired
+    private PlatformWmsJobMapper platformWmsJobMapper;
+
+    @Autowired
+    private PlatformWmsDetailMapper platformWmsDetailMapper;
 
 
     @Override
@@ -183,8 +192,8 @@
                 .ge(pageWrap.getModel().getInHkdate() != null, PlatformJob::getInHkdate, Utils.Date.getStart(pageWrap.getModel().getInHkdate()))
                 .le(pageWrap.getModel().getInHkdate() != null, PlatformJob::getInHkdate, Utils.Date.getEnd(pageWrap.getModel().getInHkdate()))
                 .eq(pageWrap.getModel().getType() != null, PlatformJob::getType, pageWrap.getModel().getType())
-                .eq(pageWrap.getModel().getCarCodeFront() != null, PlatformJob::getCarCodeFront, pageWrap.getModel().getCarCodeFront())
-                .eq(pageWrap.getModel().getCarCodeBack() != null, PlatformJob::getCarCodeBack, pageWrap.getModel().getCarCodeBack())
+                .like(pageWrap.getModel().getCarCodeFront() != null, PlatformJob::getCarCodeFront, pageWrap.getModel().getCarCodeFront())
+                .like(pageWrap.getModel().getCarCodeBack() != null, PlatformJob::getCarCodeBack, pageWrap.getModel().getCarCodeBack())
                 .eq(pageWrap.getModel().getCompanyId() != null, PlatformJob::getCompanyId, pageWrap.getModel().getCompanyId())
                 .eq(pageWrap.getModel().getCompanyNamePath() != null, PlatformJob::getCompanyNamePath, pageWrap.getModel().getCompanyNamePath())
                 .ge(pageWrap.getModel().getCancelDate() != null, PlatformJob::getCancelDate, Utils.Date.getStart(pageWrap.getModel().getCancelDate()))
@@ -197,7 +206,9 @@
                 .le(pageWrap.getModel().getArriveDate() != null, PlatformJob::getArriveDate, Utils.Date.getEnd(pageWrap.getModel().getArriveDate()))
                 .eq(pageWrap.getModel().getInType() != null, PlatformJob::getInType, pageWrap.getModel().getInType())
                 .eq(pageWrap.getModel().getTotalNum() != null, PlatformJob::getTotalNum, pageWrap.getModel().getTotalNum())
+                .eq(pageWrap.getModel().getPlatformGroupId() != null, PlatformJob::getPlatformGroupId, pageWrap.getModel().getPlatformGroupId())
         ;
+
         for(PageWrap.SortData sortData: pageWrap.getSorts()) {
             if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
                 queryWrapper.orderByDesc(sortData.getProperty());
@@ -205,8 +216,45 @@
                 queryWrapper.orderByAsc(sortData.getProperty());
             }
         }
-        return PageData.from(platformJobMapper.selectPage(page, queryWrapper));
+
+        PageData<PlatformJob> pageData = PageData.from(platformJobMapper.selectPage(page, queryWrapper));
+        pageData.getRecords().forEach(i->{
+            i.dealTime();
+            this.getWmsJobData(i);
+        });
+        return pageData;
     }
+
+
+    public void getWmsJobData(PlatformJob platformJob){
+        if(Constants.equalsInteger(platformJob.getType(),Constants.platformJobType.zycxh)
+        || Constants.equalsInteger(platformJob.getType(),Constants.platformJobType.zyczh)
+        || Constants.equalsInteger(platformJob.getType(),Constants.platformJobType.sgscxh)) {
+
+            PlatformWmsJob platformWmsJob = platformWmsJobMapper.selectOne(new QueryWrapper<PlatformWmsJob>().lambda()
+                    .eq(PlatformWmsJob::getIsdeleted,Constants.ZERO)
+                    .eq(PlatformWmsJob::getJobId,platformJob.getId())
+                    .orderByDesc(PlatformWmsJob::getId)
+                    .last(" limit 1")
+            );
+            if(Objects.isNull(platformWmsJob)){
+                return;
+            }
+            List<PlatformWmsDetail> platformWmsDetailList = platformWmsDetailMapper.selectList(new QueryWrapper<PlatformWmsDetail>().lambda()
+                    .eq(PlatformWmsDetail::getIsdeleted,Constants.ZERO)
+                    .eq(PlatformWmsDetail::getJobId,platformJob.getId()));
+            if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(platformWmsDetailList)){
+                platformJob.setTotalNum(
+                        platformWmsDetailList.stream().map(m->m.getIoQty()).reduce(BigDecimal.ZERO,BigDecimal::add)
+                );
+                platformWmsJob.setPlatformWmsDetailList(platformWmsDetailList);
+                platformJob.setPlatformWmsJob(platformWmsJob);
+            }
+        }
+
+
+    }
+
 
     @Override
     public long count(PlatformJob platformJob) {
@@ -251,6 +299,9 @@
         if(!Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WART_SIGN_IN.getKey())){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"涓氬姟鐘舵�佸凡娴佽浆锛岃鍒锋柊鏌ョ湅");
         }
+        PlatformJob oldPlatformJob = new PlatformJob();
+        BeanUtils.copyProperties(platformJob,oldPlatformJob);
+
         if(Constants.equalsInteger(signInDTO.getSignType(),Constants.ZERO)){
             this.distanceSignIn(signInDTO,platformJob);
         }else if(Constants.equalsInteger(signInDTO.getSignType(),Constants.ONE)){
@@ -260,6 +311,8 @@
         platformJob.setSingType(Constants.ZERO);
         platformJob.setStatus(Constants.PlatformJobStatus.WAIT_CALL.getKey());
         platformJobMapper.updateById(platformJob);
+        //瀛樺偍鎿嶄綔鏃ュ織
+        savePlatformLog(Constants.PlatformJobStatus.WAIT_CALL.getKey(),oldPlatformJob,platformJob);
     }
 
 
@@ -331,7 +384,11 @@
             if(Objects.nonNull(platform)){
                 platformJob.setPlatformName(platform.getName());
             }
+
         }
+        platformJob.dealTime();
+        this.getWorkTime(platformJob);
+        this.getWmsJobData(platformJob);
         return platformJob;
     }
 
@@ -348,9 +405,6 @@
         List<PlatformJob> platformJobList = platformJobJoinMapper.selectJoinList(PlatformJob.class,
                 new MPJLambdaWrapper<PlatformJob>()
                         .selectAll(PlatformJob.class)
-                        .selectAs(PlatformReason::getGroupId,PlatformJob::getGroupId)
-                        .leftJoin(PlatformBooks.class,PlatformBooks::getJobId,PlatformJob::getId)
-                        .leftJoin(PlatformReason.class,PlatformReason::getId,PlatformBooks::getReasonId)
                         .eq(PlatformJob::getIsdeleted,Constants.ZERO)
                         .eq(Constants.equalsInteger(lineUpDetailDTO.getQueryType(),Constants.ZERO)
                                 ,PlatformJob::getDrivierPhone,lineUpDetailDTO.getMobile())
@@ -361,40 +415,35 @@
                                 Constants.PlatformJobStatus.CALLED.getKey())
                         .orderByAsc(PlatformJob::getSignDate)
         );
-        //鑾峰彇鎵�鏈夋湀鍙�
-        List<Integer> platformIdList = platformJobList.stream().map(m->m.getGroupId()).collect(Collectors.toList());
+        //鑾峰彇鎵�鏈夋湀鍙扮粍
+        List<Integer> platformIdList = platformJobList.stream().map(m->m.getPlatformGroupId()).collect(Collectors.toList());
         List<Platform> platformList = platformMapper.selectList(new QueryWrapper<Platform>().lambda()
                 .eq(Platform::getIsdeleted,Constants.ZERO)
                 .in(Platform::getId,platformIdList));
 
         for (Platform platform:platformList) {
-            //鏌ヨ鏈湀鍙颁笅 鑷繁鐨勬暟鎹� 鏈�鏃╃鍒扮殑
-            PlatformJob platformJob = platformJobList.stream().filter(i->Constants.equalsInteger(i.getGroupId(),platform.getId())).findFirst().orElse(null);
-            //鏌ヨ鍦ㄥ綋鍓嶆湀鍙颁笅 绛惧埌鎺掗槦杞﹁締鏁版嵁
+            //鏌ヨ鏈湀鍙扮粍涓� 鑷繁鐨勬暟鎹� 鏈�鏃╃鍒扮殑
+            PlatformJob platformJob = platformJobList.stream().filter(i->Constants.equalsInteger(i.getPlatformId(),platform.getId())).findFirst().orElse(null);
+            //鏌ヨ鍦ㄥ綋鍓嶆湀鍙扮粍涓� 绛惧埌鎺掗槦杞﹁締鏁版嵁
             List<PlatformJob> platformJobSignInList = platformJobJoinMapper.selectJoinList(PlatformJob.class,
                     new MPJLambdaWrapper<PlatformJob>()
                             .selectAll(PlatformJob.class)
-                            .selectAs(PlatformReason::getGroupId,PlatformJob::getGroupId)
-                            .leftJoin(PlatformBooks.class,PlatformBooks::getJobId,PlatformJob::getId)
-                            .leftJoin(PlatformReason.class,PlatformReason::getId,PlatformBooks::getReasonId)
                             .eq(PlatformJob::getIsdeleted,Constants.ZERO)
+                            .eq(PlatformJob::getPlatformGroupId,platform.getGroupId())
                             .ge(Objects.nonNull(platformJob),PlatformJob::getSignDate,DateUtil.getDate(platformJob.getSignDate(),"yyyy-MM-dd HH:mm:ss"))
                             .in(PlatformJob::getStatus,Constants.PlatformJobStatus.WAIT_CALL.getKey(),
                                     Constants.PlatformJobStatus.IN_WAIT.getKey(),
                                     Constants.PlatformJobStatus.CALLED.getKey())
                             .orderByDesc(PlatformJob::getSignDate));
             platform.setSignJobList(platformJobSignInList);
-            //鏌ヨ褰撳墠鏈堝彴涓�
+            //鏌ヨ褰撳墠鏈堝彴缁勪笅
             List<PlatformJob> platformJobWorkList = platformJobJoinMapper.selectJoinList(PlatformJob.class,
                     new MPJLambdaWrapper<PlatformJob>()
                             .selectAll(PlatformJob.class)
-                            .selectAs(PlatformReason::getGroupId,PlatformJob::getGroupId)
-                            .leftJoin(PlatformBooks.class,PlatformBooks::getJobId,PlatformJob::getId)
-                            .leftJoin(PlatformReason.class,PlatformReason::getId,PlatformBooks::getReasonId)
                             .eq(PlatformJob::getIsdeleted,Constants.ZERO)
+                            .eq(PlatformJob::getPlatformGroupId,platform.getGroupId())
                             .eq(PlatformJob::getStatus,Constants.PlatformJobStatus.WORKING.getKey())
                             .orderByDesc(PlatformJob::getSignDate));
-            platform.setSignJobList(platformJobSignInList);
             platform.setWorkJobList(platformJobWorkList);
         }
         lineUpVO.setPlatformList(platformList);
@@ -402,5 +451,398 @@
     }
 
 
+    /**
+     * 鑾峰彇宸蹭綔涓氭椂闂�
+     * @param platformJob
+     */
+    public void getWorkTime(PlatformJob platformJob){
+        List<PlatformLog> platformLogList = platformLogMapper.selectList(new QueryWrapper<PlatformLog>()
+                .lambda().eq(PlatformLog::getIsdeleted,Constants.ZERO)
+                .eq(PlatformLog::getJobId,platformJob.getId())
+                .ne(PlatformLog::getParam3,"0")
+        );
+        Long optTime = 0L;
+        if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(platformLogList)){
+            List<Long> param3List = platformLogList.stream().map(m->Long.valueOf(m.getParam3())).collect(Collectors.toList());
+            for (Long val:param3List) {
+                optTime = optTime + val;
+            }
+        }
+        if(Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WORKING.getKey())){
+            //鏌ヨ鏈�鍚庝竴娆″紑濮嬬殑鏃ュ織鏁版嵁
+            PlatformLog lastBeginPlatform = platformLogMapper.selectOne(new QueryWrapper<PlatformLog>().lambda()
+                    .eq(PlatformLog::getIsdeleted,Constants.ZERO)
+                    .eq(PlatformLog::getObjType,Constants.PlatformJobStatus.WORKING.getKey())
+                    .eq(PlatformLog::getJobId,platformJob.getId())
+                    .orderByDesc(PlatformLog::getCreateDate)
+                    .last(" limit 1 ")
+            );
+            if(Objects.nonNull(lastBeginPlatform)){
+                String v = Long.toString(System.currentTimeMillis() - lastBeginPlatform.getCreateDate().getTime() / 1000) ;
+                optTime = optTime + Long.valueOf(v);
+            }
+        }
+        platformJob.setWorkTime(optTime);
+    }
+
+    /**
+     * 閫氱煡鍏ュ洯
+     */
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void platformInPark(JobOperateDTO jobOperateDTO){
+        if(Objects.isNull(jobOperateDTO)
+                || Objects.isNull(jobOperateDTO.getJobId())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
+        PlatformJob platformJob = platformJobMapper.selectById(jobOperateDTO.getJobId());
+        if(Objects.isNull(platformJob)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        if(!Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WAIT_CALL.getKey())){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧�,涓氬姟鐘舵�佸凡娴佽浆锛�");
+        }
+        PlatformJob oldPlatformJob = new PlatformJob();
+        BeanUtils.copyProperties(platformJob,oldPlatformJob);
+
+        platformJob.setInwaitDate(new Date());
+        platformJob.setInwaitUserId(jobOperateDTO.getLoginUserInfo().getId());
+        platformJob.setStatus(Constants.PlatformJobStatus.IN_WAIT.getKey());
+        platformJob.setEditDate(new Date());
+        platformJobMapper.updateById(platformJob);
+
+        if(Constants.equalsInteger(platformJob.getType(),Constants.TWO)
+        || Constants.equalsInteger(platformJob.getType(),Constants.THREE)
+        || Constants.equalsInteger(platformJob.getType(),Constants.FOUR)){
+            //TODO 涓嬪彂鍏ュ洯鏉冮檺
+
+        }
+
+        //瀛樺偍鎿嶄綔鏃ュ織
+        savePlatformLog(Constants.PlatformJobStatus.WAIT_CALL.getKey(),oldPlatformJob,platformJob);
+
+    }
+
+    /**
+     * 鏈堝彴鍙彿
+     */
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void platformCallNumber(JobOperateDTO jobOperateDTO){
+        if(Objects.isNull(jobOperateDTO)
+                || Objects.isNull(jobOperateDTO.getJobId())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
+        PlatformJob platformJob = platformJobMapper.selectById(jobOperateDTO.getJobId());
+        if(Objects.isNull(platformJob)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        if(!(Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WAIT_CALL.getKey())
+                || Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.IN_WAIT.getKey())
+                || Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.TRANSFERING.getKey())
+        ) ){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧�,涓氬姟鐘舵�佸凡娴佽浆锛�");
+        }
+
+        PlatformJob oldPlatformJob = new PlatformJob();
+        BeanUtils.copyProperties(platformJob,oldPlatformJob);
+
+        platformJob.setCallDate(new Date());
+        platformJob.setCallUserId(jobOperateDTO.getLoginUserInfo().getId());
+        platformJob.setStatus(Constants.PlatformJobStatus.CALLED.getKey());
+        platformJob.setEditDate(new Date());
+        platformJobMapper.updateById(platformJob);
+        //瀛樺偍鎿嶄綔鏃ュ織
+        savePlatformLog(Constants.PlatformJobStatus.CALLED.getKey(),oldPlatformJob,platformJob);
+    }
+
+
+    /**
+     * 杞Щ鏈堝彴
+     * @param jobOperateDTO
+     */
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void platformMove(JobOperateDTO jobOperateDTO){
+        if(Objects.isNull(jobOperateDTO)
+        || Objects.isNull(jobOperateDTO.getJobId())
+                || Objects.isNull(jobOperateDTO.getPlatformId())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
+        PlatformJob platformJob = platformJobMapper.selectById(jobOperateDTO.getJobId());
+        if(Objects.isNull(platformJob)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        if( !( Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WORKING.getKey())
+            || Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.EXCEPTION.getKey())
+        )){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧�,涓氬姟鐘舵�佸凡娴佽浆锛�");
+        }
+        if(Constants.equalsInteger(platformJob.getPlatformId(),jobOperateDTO.getPlatformId())){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鏃犳硶杞Щ鏈湀鍙�");
+        }
+
+        PlatformJob oldPlatformJob = new PlatformJob();
+        BeanUtils.copyProperties(platformJob,oldPlatformJob);
+
+        platformJob.setTransPlatformDate(new Date());
+        platformJob.setTransPlatformUserId(jobOperateDTO.getLoginUserInfo().getId());
+        platformJob.setPlatformId(jobOperateDTO.getPlatformId());
+        platformJob.setStatus(Constants.PlatformJobStatus.TRANSFERING.getKey());
+        platformJob.setEditDate(new Date());
+        platformJobMapper.updateById(platformJob);
+
+        //TODO 璋冭捣WMS 閫氱煡鏈堝彴杞Щ
+        //瀛樺偍鎿嶄綔鏃ュ織
+        savePlatformLog(Constants.PlatformJobStatus.TRANSFERING.getKey(),oldPlatformJob,platformJob);
+    }
+
+
+    /**
+     * 鏈堝彴杩囧彿
+     */
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void platformOverNumber(JobOperateDTO jobOperateDTO){
+        if(Objects.isNull(jobOperateDTO)
+                || Objects.isNull(jobOperateDTO.getJobId())
+                || Objects.isNull(jobOperateDTO.getPlatformId())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
+        PlatformJob platformJob = platformJobMapper.selectById(jobOperateDTO.getJobId());
+        if(Objects.isNull(platformJob)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        if(!Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WORKING.getKey())){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧�,涓氬姟鐘舵�佸凡娴佽浆锛�");
+        }
+
+        PlatformJob oldPlatformJob = new PlatformJob();
+        BeanUtils.copyProperties(platformJob,oldPlatformJob);
+
+        platformJob.setStatus(Constants.PlatformJobStatus.WART_SIGN_IN.getKey());
+        platformJob.setEditDate(new Date());
+        platformJobMapper.updateById(platformJob);
+        //瀛樺偍鎿嶄綔鏃ュ織
+        savePlatformLog(Constants.PlatformJobStatus.WART_SIGN_IN.getKey(),oldPlatformJob,platformJob);
+
+
+    }
+
+
+    /**
+     * 寮傚父鎸傝捣
+     */
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void platformErr(JobOperateDTO jobOperateDTO){
+        if(Objects.isNull(jobOperateDTO)
+                || Objects.isNull(jobOperateDTO.getJobId())
+                || Objects.isNull(jobOperateDTO.getPlatformId())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
+        PlatformJob platformJob = platformJobMapper.selectById(jobOperateDTO.getJobId());
+        if(Objects.isNull(platformJob)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        if(!Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WORKING.getKey())){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧�,涓氬姟鐘舵�佸凡娴佽浆锛�");
+        }
+
+        PlatformJob oldPlatformJob = new PlatformJob();
+        BeanUtils.copyProperties(platformJob,oldPlatformJob);
+
+        platformJob.setErrorDate(new Date());
+        platformJob.setErrorUserId(jobOperateDTO.getLoginUserInfo().getId());
+        platformJob.setStatus(Constants.PlatformJobStatus.EXCEPTION.getKey());
+        platformJob.setEditDate(new Date());
+        platformJobMapper.updateById(platformJob);
+        //瀛樺偍鎿嶄綔鏃ュ織
+        savePlatformLog(Constants.PlatformJobStatus.EXCEPTION.getKey(),oldPlatformJob,platformJob);
+    }
+
+
+    /**
+     * 寮�濮嬩綔涓�
+     */
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void beginWork(JobOperateDTO jobOperateDTO){
+        if(Objects.isNull(jobOperateDTO)
+                || Objects.isNull(jobOperateDTO.getJobId())
+                || Objects.isNull(jobOperateDTO.getPlatformId())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
+        PlatformJob platformJob = platformJobMapper.selectById(jobOperateDTO.getJobId());
+        if(Objects.isNull(platformJob)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        if(!Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.CALLED.getKey())){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧�,涓氬姟鐘舵�佸凡娴佽浆锛�");
+        }
+        platformJobMapper.update(null,new UpdateWrapper<PlatformJob>()
+                .lambda()
+                .set(Objects.isNull(platformJob.getStartDate()),PlatformJob::getStartDate,new Date())
+                .set(PlatformJob::getEditDate,new Date())
+                .set(PlatformJob::getStatus,Constants.PlatformJobStatus.WORKING.getKey())
+                .eq(PlatformJob::getId,jobOperateDTO.getJobId())
+        );
+
+        PlatformJob oldPlatformJob = new PlatformJob();
+        BeanUtils.copyProperties(platformJob,oldPlatformJob);
+        if(Objects.isNull(platformJob.getStartDate())){
+            platformJob.setStartDate(new Date());
+        }
+        platformJob.setStatus(Constants.PlatformJobStatus.WORKING.getKey());
+        platformJob.setEditDate(new Date());
+        platformJobMapper.updateById(platformJob);
+        //瀛樺偍鎿嶄綔鏃ュ織
+        savePlatformLog(Constants.PlatformJobStatus.WORKING.getKey(),oldPlatformJob,platformJob);
+    }
+
+
+    /**
+     * 瀹屾垚浣滀笟
+     */
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void finishWork(JobOperateDTO jobOperateDTO){
+        if(Objects.isNull(jobOperateDTO)
+                || Objects.isNull(jobOperateDTO.getJobId())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
+        PlatformJob platformJob = platformJobMapper.selectById(jobOperateDTO.getJobId());
+        if(Objects.isNull(platformJob)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        if(!Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.WORKING.getKey())){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧�,涓氬姟鐘舵�佸凡娴佽浆锛�");
+        }
+        PlatformJob oldPlatformJob = new PlatformJob();
+        BeanUtils.copyProperties(platformJob,oldPlatformJob);
+
+        platformJob.setDoneDate(new Date());
+        platformJob.setStatus(Constants.PlatformJobStatus.EXCEPTION.getKey());
+        platformJob.setEditDate(new Date());
+        platformJobMapper.updateById(platformJob);
+        //瀛樺偍鎿嶄綔鏃ュ織
+        savePlatformLog(Constants.PlatformJobStatus.EXCEPTION.getKey(),oldPlatformJob,platformJob);
+
+        if(Constants.equalsInteger(platformJob.getType(),Constants.TWO)){
+            //TODO 澶栧崗杞﹁璐� 鏌ヨTMS 鐢靛瓙閿佹儏鍐�
+
+        }else if(Constants.equalsInteger(platformJob.getType(),Constants.ONE) || Constants.equalsInteger(platformJob.getType(),Constants.FOUR)){
+            //TODO 澶栧崗杞﹀嵏璐� 鎴栬�� 甯傚叕鍙歌溅鍗歌揣 鍒欐牴鎹换鍔℃儏鍐佃繘琛屼笅鍙戠鍥潈闄�
+
+        }
+    }
+
+
+    /**
+     * 鏈堝彴鐩告満鎺ㄩ�� 寮�濮嬩綔涓�
+     * @param jobOperateDTO
+     */
+    @Override
+    @Transactional(rollbackFor = {Exception.class,BusinessException.class})
+    public void cameraStartWork(JobOperateDTO jobOperateDTO){
+        if(Objects.isNull(jobOperateDTO)
+                || Objects.isNull(jobOperateDTO.getDeviceId())
+                || StringUtils.isBlank(jobOperateDTO.getCarCodeBack())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
+        PlatformDevice platformDevice = platformDeviceMapper.selectOne(new QueryWrapper<PlatformDevice>().lambda()
+                        .eq(PlatformDevice::getIsdeleted,Constants.ZERO)
+                .eq(PlatformDevice::getDeviceId,jobOperateDTO.getDeviceId())
+                .last(" limit 1")
+        );
+        if(Objects.isNull(platformDevice)){
+            return;
+        }
+        PlatformJob platformJob =  platformJobMapper.selectOne(new QueryWrapper<PlatformJob>().lambda()
+                .eq(PlatformJob::getPlatformId,platformDevice.getPlatformId())
+                .eq(PlatformJob::getCarCodeBack,jobOperateDTO.getCarCodeBack())
+                .eq(PlatformJob::getStatus,Constants.PlatformJobStatus.CALLED.getKey())
+                .last(" limit 1 ")
+        );
+        if(Objects.isNull(platformJob)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        if(!Constants.equalsInteger(platformJob.getStatus(),Constants.PlatformJobStatus.CALLED.getKey())){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"瀵逛笉璧�,涓氬姟鐘舵�佸凡娴佽浆锛�");
+        }
+
+        PlatformJob oldPlatformJob = new PlatformJob();
+        BeanUtils.copyProperties(platformJob,oldPlatformJob);
+        if(Objects.isNull(platformJob.getStartDate())){
+            platformJob.setStartDate(new Date());
+        }
+        platformJob.setStatus(Constants.PlatformJobStatus.WORKING.getKey());
+        platformJob.setEditDate(new Date());
+        platformJobMapper.updateById(platformJob);
+        //瀛樺偍鎿嶄綔鏃ュ織
+        savePlatformLog(Constants.PlatformJobStatus.WORKING.getKey(),oldPlatformJob,platformJob);
+    }
+
+
+    /**
+     * 瀛樺偍鎿嶄綔鏃ュ織
+     * @param objType
+     * @param platformJobBefor
+     * @param platformJobAfter
+     */
+    public void savePlatformLog(Integer objType,PlatformJob platformJobBefor,PlatformJob platformJobAfter){
+        PlatformLog platformLog = new PlatformLog();
+        platformLog.setIsdeleted(Constants.ZERO);
+        platformLog.setCreateDate(new Date());
+        platformLog.setJobId(platformJobAfter.getId());
+        platformLog.setObjType(objType);
+        platformLog.setBeforeContent(JSONObject.toJSONString(platformJobBefor));
+        platformLog.setAfterContent(JSONObject.toJSONString(platformJobAfter));
+        platformLog.setObjId(platformJobAfter.getId().toString());
+        //鏌ヨ鏈�鍚庝竴娆″紑濮嬩綔涓氱殑鏃ュ織
+        PlatformLog lastBeginPlatform = platformLogMapper.selectOne(new QueryWrapper<PlatformLog>().lambda()
+                .eq(PlatformLog::getIsdeleted,Constants.ZERO)
+                .eq(PlatformLog::getObjType,Constants.PlatformJobStatus.WORKING.getKey())
+                .eq(PlatformLog::getJobId,platformLog.getJobId())
+                .orderByDesc(PlatformLog::getCreateDate)
+                .last(" limit 1 ")
+        );
+        if(Objects.isNull(lastBeginPlatform)){
+            return;
+        }
+        if(Constants.equalsInteger(objType,Constants.PlatformJobStatus.EXCEPTION.getKey())
+            || Constants.equalsInteger(objType,Constants.PlatformJobStatus.TRANSFERING.getKey())){
+            //寮傚父鎸傝捣 涓庤浆绉讳腑 璁板綍鏈 浣滀笟鏃堕棿
+            platformLog.setParam1(DateUtil.getDate(lastBeginPlatform.getCreateDate(),"yyyy-MM-dd HH:mm:ss"));
+            platformLog.setParam2(DateUtil.getDate(platformLog.getCreateDate(),"yyyy-MM-dd HH:mm:ss"));
+            String v = Long.toString(platformJobAfter.getDoneDate().getTime() - platformJobBefor.getStartDate().getTime() / 1000) ;
+            platformLog.setParam3(v);
+        }else  if(Constants.equalsInteger(objType,Constants.PlatformJobStatus.DONE.getKey())){
+            //鏌ヨ鏈�鍚庝竴娆℃棩蹇楁槸鍚︿负寮傚父鎸傝捣锛屽紓甯告寕璧峰悗鍙繘琛岃浆绉� 濡傛灉杩涜杞Щ閭d箞涓氬姟灏遍渶瑕侀噸鏂拌繘琛屽紑濮嬪氨涓嶉渶瑕佺壒娈婂鐞�  锛屽鏋滀笉鏄紓甯告寕璧疯繘琛屾暟鎹粨鏉� 鍒欑洿鎺ユ煡璇㈡渶鍚庝竴娆″紑濮嬬殑鏃堕棿
+            PlatformLog lastPlatformLog = platformLogMapper.selectOne(new QueryWrapper<PlatformLog>().lambda()
+                    .eq(PlatformLog::getIsdeleted,Constants.ZERO)
+                    .eq(PlatformLog::getJobId,platformLog.getJobId())
+                    .orderByDesc(PlatformLog::getCreateDate)
+                    .last(" limit 1 ")
+            );
+            if(Objects.nonNull(lastPlatformLog) && Constants.equalsInteger(lastPlatformLog.getObjType(),Constants.PlatformJobStatus.EXCEPTION.getKey())){
+                platformLog.setParam3("0");
+            }else{
+                //闈炲紓甯告寕璧� 鍒欑洿鎺ヨ繃鍘绘渶鍚庝竴娆″紑濮嬩綔涓氱殑鏃ュ織鐨勫紑濮嬫椂闂�
+                platformLog.setParam1(DateUtil.getDate(lastBeginPlatform.getCreateDate(),"yyyy-MM-dd HH:mm:ss"));
+                platformLog.setParam2(DateUtil.getDate(platformLog.getCreateDate(),"yyyy-MM-dd HH:mm:ss"));
+                String v = Long.toString(platformJobAfter.getDoneDate().getTime() - platformJobBefor.getStartDate().getTime() / 1000) ;
+                platformLog.setParam3(v);
+            }
+        }else{
+            platformLog.setParam3("0");
+        }
+        platformLogMapper.insert(platformLog);
+    }
+
+
+
+
+
 
 }

--
Gitblit v1.9.3