Bladeren bron

优化代码

java110 3 jaren geleden
bovenliggende
commit
01f5647aa5

+ 15 - 0
java110-bean/src/main/java/com/java110/dto/attendanceClasses/AttendanceClassesTaskDetailDto.java

@@ -15,6 +15,10 @@ import java.util.Date;
  **/
 public class AttendanceClassesTaskDetailDto extends PageDto implements Serializable {
 
+    //打卡状态 10000未考勤  30000正常考勤 40000 迟到 50000早退 60000 免考勤 70000 补考勤
+    public static final String STATE_REPLENISH = "70000";//补考勤
+    public static final String STATE_WAIT = "10000";//补考勤
+
     private String checkTime;
     private String detailId;
     private String specCd;
@@ -22,6 +26,9 @@ public class AttendanceClassesTaskDetailDto extends PageDto implements Serializa
     private String remark;
     private String facePath;
     private String state;
+
+    private String[] states;
+
     private String stateName;
     private String storeId;
     private String value;
@@ -147,4 +154,12 @@ public class AttendanceClassesTaskDetailDto extends PageDto implements Serializa
     public void setStateName(String stateName) {
         this.stateName = stateName;
     }
+
+    public String[] getStates() {
+        return states;
+    }
+
+    public void setStates(String[] states) {
+        this.states = states;
+    }
 }

+ 5 - 0
java110-bean/src/main/java/com/java110/dto/attendanceClasses/AttendanceClassesTaskDto.java

@@ -16,6 +16,11 @@ import java.util.List;
  **/
 public class AttendanceClassesTaskDto extends PageDto implements Serializable {
 
+    //考勤状态,10000未考勤 20000 考勤中 30000考勤完成
+    public static final String STATE_WAIT = "10000";
+    public static final String STATE_DOING = "20000";
+    public static final String STATE_FINISH = "30000";
+
     private String classId;
     private String taskMonth;
     private String taskDay;

+ 113 - 0
service-common/src/main/java/com/java110/common/cmd/attendanceClasses/AttendanceReplenishCheckInCmd.java

@@ -0,0 +1,113 @@
+/*
+ * Copyright 2017-2020 吴学文 and java110 team.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package com.java110.common.cmd.attendanceClasses;
+
+import com.alibaba.fastjson.JSONObject;
+import com.java110.core.annotation.Java110Cmd;
+import com.java110.core.annotation.Java110Transactional;
+import com.java110.core.context.ICmdDataFlowContext;
+import com.java110.core.event.cmd.Cmd;
+import com.java110.core.event.cmd.CmdEvent;
+import com.java110.dto.attendanceClasses.AttendanceClassesTaskDetailDto;
+import com.java110.dto.attendanceClasses.AttendanceClassesTaskDto;
+import com.java110.intf.common.IAttendanceClassesAttrV1InnerServiceSMO;
+import com.java110.intf.common.IAttendanceClassesTaskDetailInnerServiceSMO;
+import com.java110.intf.common.IAttendanceClassesTaskInnerServiceSMO;
+import com.java110.po.attendanceClassesTask.AttendanceClassesTaskPo;
+import com.java110.po.attendanceClassesTaskDetail.AttendanceClassesTaskDetailPo;
+import com.java110.utils.exception.CmdException;
+import com.java110.utils.util.Assert;
+import com.java110.vo.ResultVo;
+import org.slf4j.Logger;
+import org.slf4j.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
+
+import java.util.List;
+
+
+/**
+ * 类表述:补考勤
+ * 员工 出差 等原因 无法通过考勤设备正常考勤时 通过此功能 补考勤
+ * <p>
+ * 服务编码:attendanceClasses.updateAttendanceClasses
+ * 请求路劲:/app/attendanceClasses.UpdateAttendanceClasses
+ * add by 吴学文 at 2022-07-16 17:50:14 mail: 928255095@qq.com
+ * open source address: https://gitee.com/wuxw7/MicroCommunity
+ * 官网:http://www.homecommunity.cn
+ * 温馨提示:如果您对此文件进行修改 请不要删除原有作者及注释信息,请补充您的 修改的原因以及联系邮箱如下
+ * // modify by 张三 at 2021-09-12 第10行在某种场景下存在某种bug 需要修复,注释10至20行 加入 20行至30行
+ */
+@Java110Cmd(serviceCode = "attendanceClasses.attendanceReplenishCheckIn")
+public class AttendanceReplenishCheckInCmd extends Cmd {
+
+    private static Logger logger = LoggerFactory.getLogger(AttendanceReplenishCheckInCmd.class);
+
+
+    @Autowired
+    private IAttendanceClassesTaskDetailInnerServiceSMO attendanceClassesTaskDetailInnerServiceSMOImpl;
+
+
+    @Autowired
+    private IAttendanceClassesTaskInnerServiceSMO attendanceClassesTaskInnerServiceSMOImpl;
+
+    @Override
+    public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
+        Assert.hasKeyAndValue(reqJson, "detailId", "detailId不能为空");
+        Assert.hasKeyAndValue(reqJson, "remark", "remark不能为空");
+
+    }
+
+    @Override
+    @Java110Transactional
+    public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
+
+
+        AttendanceClassesTaskDetailDto attendanceClassesTaskDetailDto = new AttendanceClassesTaskDetailDto();
+        attendanceClassesTaskDetailDto.setDetailId(reqJson.getString("detailId"));
+
+        List<AttendanceClassesTaskDetailDto> attendanceClassesTaskDetailDtos = attendanceClassesTaskDetailInnerServiceSMOImpl.queryAttendanceClassesTaskDetails(attendanceClassesTaskDetailDto);
+
+        Assert.listOnlyOne(attendanceClassesTaskDetailDtos, "未包含考勤任务");
+
+        AttendanceClassesTaskDetailPo attendanceClassesTaskDetailPo = new AttendanceClassesTaskDetailPo();
+        attendanceClassesTaskDetailPo.setDetailId(attendanceClassesTaskDetailDtos.get(0).getDetailId());
+        attendanceClassesTaskDetailPo.setState(AttendanceClassesTaskDetailDto.STATE_REPLENISH);
+        attendanceClassesTaskDetailPo.setRemark(reqJson.getString("remark"));
+        int flag = attendanceClassesTaskDetailInnerServiceSMOImpl.updateAttendanceClassesTaskDetail(attendanceClassesTaskDetailPo);
+
+        if (flag < 1) {
+            throw new CmdException("补考勤失败");
+        }
+
+        attendanceClassesTaskDetailDto = new AttendanceClassesTaskDetailDto();
+        attendanceClassesTaskDetailDto.setTaskId(attendanceClassesTaskDetailDtos.get(0).getTaskId());
+        attendanceClassesTaskDetailDto.setState(AttendanceClassesTaskDetailDto.STATE_WAIT);
+
+
+        int count = attendanceClassesTaskDetailInnerServiceSMOImpl.queryAttendanceClassesTaskDetailsCount(attendanceClassesTaskDetailDto);
+        AttendanceClassesTaskPo attendanceClassesTaskPo = new AttendanceClassesTaskPo();
+        attendanceClassesTaskPo.setTaskId(attendanceClassesTaskDetailDtos.get(0).getTaskId());
+        if(count >0){
+            attendanceClassesTaskPo.setState(AttendanceClassesTaskDto.STATE_DOING);
+        }else{
+            attendanceClassesTaskPo.setState(AttendanceClassesTaskDto.STATE_FINISH);
+        }
+
+        attendanceClassesTaskInnerServiceSMOImpl.updateAttendanceClassesTask(attendanceClassesTaskPo);
+
+        cmdDataFlowContext.setResponseEntity(ResultVo.success());
+    }
+}