|
|
@@ -13,11 +13,12 @@
|
|
|
* See the License for the specific language governing permissions and
|
|
|
* limitations under the License.
|
|
|
*/
|
|
|
-package com.java110.job.adapt.hcIot.staff;
|
|
|
+package com.java110.job.adapt.hcIot.attendance;
|
|
|
|
|
|
import com.alibaba.fastjson.JSONArray;
|
|
|
import com.alibaba.fastjson.JSONObject;
|
|
|
import com.java110.dto.attendanceClasses.AttendanceClassesDto;
|
|
|
+import com.java110.dto.attendanceClassesStaff.AttendanceClassesStaffDto;
|
|
|
import com.java110.dto.file.FileDto;
|
|
|
import com.java110.dto.file.FileRelDto;
|
|
|
import com.java110.dto.machine.MachineDto;
|
|
|
@@ -27,11 +28,12 @@ import com.java110.intf.common.IAttendanceClassesInnerServiceSMO;
|
|
|
import com.java110.intf.common.IFileInnerServiceSMO;
|
|
|
import com.java110.intf.common.IFileRelInnerServiceSMO;
|
|
|
import com.java110.intf.common.IMachineV1InnerServiceSMO;
|
|
|
+import com.java110.intf.user.IAttendanceClassesStaffV1InnerServiceSMO;
|
|
|
import com.java110.intf.user.IOrgStaffRelInnerServiceSMO;
|
|
|
import com.java110.job.adapt.DatabusAdaptImpl;
|
|
|
import com.java110.job.adapt.hcIot.asyn.IIotSendAsyn;
|
|
|
+import com.java110.po.attendanceClassesStaff.AttendanceClassesStaffPo;
|
|
|
import com.java110.po.store.StoreUserPo;
|
|
|
-import com.java110.utils.util.Assert;
|
|
|
import com.java110.utils.util.BeanConvertUtil;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Component;
|
|
|
@@ -46,14 +48,14 @@ import java.util.List;
|
|
|
*
|
|
|
* @desc add by 吴学文 18:58
|
|
|
*/
|
|
|
-@Component(value = "addStaffToIotAdapt")
|
|
|
-public class AddStaffToIotAdapt extends DatabusAdaptImpl {
|
|
|
+@Component(value = "addAttendanceClassStaffToIotAdapt")
|
|
|
+public class AddAttendanceClassStaffToIotAdapt extends DatabusAdaptImpl {
|
|
|
|
|
|
@Autowired
|
|
|
private IIotSendAsyn hcStoreUserAsynImpl;
|
|
|
|
|
|
@Autowired
|
|
|
- private IOrgStaffRelInnerServiceSMO orgStaffRelInnerServiceSMOImpl;
|
|
|
+ private IAttendanceClassesStaffV1InnerServiceSMO attendanceClassesStaffV1InnerServiceSMOImpl;
|
|
|
|
|
|
@Autowired
|
|
|
private IAttendanceClassesInnerServiceSMO attendanceClassesInnerServiceSMOImpl;
|
|
|
@@ -85,8 +87,8 @@ public class AddStaffToIotAdapt extends DatabusAdaptImpl {
|
|
|
public void execute(Business business, List<Business> businesses) {
|
|
|
JSONObject data = business.getData();
|
|
|
JSONArray businessStoreUsers = new JSONArray();
|
|
|
- if (data.containsKey(StoreUserPo.class.getSimpleName())) {
|
|
|
- Object bObj = data.get(StoreUserPo.class.getSimpleName());
|
|
|
+ if (data.containsKey(AttendanceClassesStaffPo.class.getSimpleName())) {
|
|
|
+ Object bObj = data.get(AttendanceClassesStaffPo.class.getSimpleName());
|
|
|
if (bObj instanceof JSONObject) {
|
|
|
|
|
|
businessStoreUsers.add(bObj);
|
|
|
@@ -109,71 +111,66 @@ public class AddStaffToIotAdapt extends DatabusAdaptImpl {
|
|
|
|
|
|
private void doSendStoreUser(Business business, JSONObject businessStoreUser) {
|
|
|
|
|
|
- StoreUserPo storeUserPo = BeanConvertUtil.covertBean(businessStoreUser, StoreUserPo.class);
|
|
|
+ AttendanceClassesStaffPo attendanceClassesStaffPo = BeanConvertUtil.covertBean(businessStoreUser, AttendanceClassesStaffPo.class);
|
|
|
|
|
|
- //查询员工部门
|
|
|
- //查询员工部门
|
|
|
- OrgStaffRelDto orgStaffRelDto = new OrgStaffRelDto();
|
|
|
- orgStaffRelDto.setStaffId(storeUserPo.getUserId());
|
|
|
- orgStaffRelDto.setStoreId(storeUserPo.getStoreId());
|
|
|
- List<OrgStaffRelDto> orgStaffRelDtos = orgStaffRelInnerServiceSMOImpl.queryOrgStaffRels(orgStaffRelDto);
|
|
|
-
|
|
|
-
|
|
|
- if(orgStaffRelDtos == null || orgStaffRelDtos.size()<1){
|
|
|
- throw new IllegalArgumentException("员工未包含组织");
|
|
|
+ AttendanceClassesStaffDto attendanceClassesStaffDto = new AttendanceClassesStaffDto();
|
|
|
+ attendanceClassesStaffDto.setCsId(attendanceClassesStaffPo.getCsId());
|
|
|
+ attendanceClassesStaffDto.setStoreId(attendanceClassesStaffPo.getStoreId());
|
|
|
+ List<AttendanceClassesStaffDto> attendanceClassesStaffs = attendanceClassesStaffV1InnerServiceSMOImpl.queryAttendanceClassesStaffs(attendanceClassesStaffDto);
|
|
|
+ if (attendanceClassesStaffs == null || attendanceClassesStaffs.size() < 1) {
|
|
|
+ return;
|
|
|
}
|
|
|
|
|
|
- for (OrgStaffRelDto tmpOrgStaffRelDto : orgStaffRelDtos) {
|
|
|
|
|
|
- //查询员工部门是否参与考勤
|
|
|
- AttendanceClassesDto attendanceClassesDto = new AttendanceClassesDto();
|
|
|
- attendanceClassesDto.setClassesObjType(AttendanceClassesDto.CLASSES_OBJ_TYPE_PARTMENT);
|
|
|
- attendanceClassesDto.setClassesObjId(tmpOrgStaffRelDto.getOrgId());
|
|
|
- List<AttendanceClassesDto> attendanceClassesDtos = attendanceClassesInnerServiceSMOImpl.queryAttendanceClassess(attendanceClassesDto);
|
|
|
+ //查询员工部门是否参与考勤
|
|
|
+ AttendanceClassesDto attendanceClassesDto = new AttendanceClassesDto();
|
|
|
+ attendanceClassesDto.setClassesId(attendanceClassesStaffs.get(0).getClassesId());
|
|
|
+ attendanceClassesDto.setStoreId(attendanceClassesStaffs.get(0).getStoreId());
|
|
|
+ List<AttendanceClassesDto> attendanceClassesDtos = attendanceClassesInnerServiceSMOImpl.queryAttendanceClassess(attendanceClassesDto);
|
|
|
|
|
|
- //员工部门没有考勤,不用处理
|
|
|
- if (attendanceClassesDtos == null || attendanceClassesDtos.size() < 1) {
|
|
|
- continue;
|
|
|
- }
|
|
|
+ //员工部门没有考勤,不用处理
|
|
|
+ if (attendanceClassesDtos == null || attendanceClassesDtos.size() < 1) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
|
|
|
- MachineDto machineDto = new MachineDto();
|
|
|
- machineDto.setLocationObjId(tmpOrgStaffRelDto.getOrgId());
|
|
|
- machineDto.setMachineTypeCd(MachineDto.MACHINE_TYPE_ATTENDANCE);
|
|
|
- List<MachineDto> machineDtos = machineV1InnerServiceSMOImpl.queryMachines(machineDto);
|
|
|
-
|
|
|
- String img = getStaffPhoto(orgStaffRelDtos.get(0));
|
|
|
-
|
|
|
- JSONObject storeUserObj = null;
|
|
|
- List<JSONObject> storeUserObjs = new ArrayList<>();
|
|
|
- for (AttendanceClassesDto tmpAttendanceClassesDto : attendanceClassesDtos) {
|
|
|
-
|
|
|
- storeUserObj = new JSONObject();
|
|
|
- storeUserObj.put("extClassesId", tmpAttendanceClassesDto.getClassesId());
|
|
|
- storeUserObj.put("extStaffId", tmpOrgStaffRelDto.getStaffId());
|
|
|
- storeUserObj.put("staffName", tmpOrgStaffRelDto.getStaffName());
|
|
|
- storeUserObj.put("departmentId", tmpOrgStaffRelDto.getOrgId());
|
|
|
- storeUserObj.put("departmentName", tmpOrgStaffRelDto.getOrgName());
|
|
|
- if (machineDtos != null && machineDtos.size() > 0) {
|
|
|
- storeUserObj.put("machineCode", machineDtos.get(0).getMachineCode());
|
|
|
- storeUserObj.put("extMachineId", machineDtos.get(0).getMachineId());
|
|
|
- storeUserObj.put("extCommunityId", machineDtos.get(0).getCommunityId());
|
|
|
- }
|
|
|
- storeUserObj.put("faceBase64", img);
|
|
|
- storeUserObjs.add(storeUserObj);
|
|
|
- }
|
|
|
- JSONObject postParameters = new JSONObject();
|
|
|
- postParameters.put("classesName", attendanceClassesDtos.get(0).getClassesName());
|
|
|
- postParameters.put("extClassesId", attendanceClassesDtos.get(0).getClassesId());
|
|
|
- postParameters.put("extCommunityId", "-1");
|
|
|
- hcStoreUserAsynImpl.addAttendanceStaff(postParameters, storeUserObjs);
|
|
|
+ MachineDto machineDto = new MachineDto();
|
|
|
+ machineDto.setLocationObjId(attendanceClassesDtos.get(0).getClassesId());
|
|
|
+ machineDto.setMachineTypeCd(MachineDto.MACHINE_TYPE_ATTENDANCE);
|
|
|
+ List<MachineDto> machineDtos = machineV1InnerServiceSMOImpl.queryMachines(machineDto);
|
|
|
+ //员工部门没有考勤,不用处理
|
|
|
+ if (machineDtos == null || machineDtos.size() < 1) {
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ String img = getStaffPhoto(attendanceClassesStaffs.get(0));
|
|
|
+
|
|
|
+ JSONObject storeUserObj = null;
|
|
|
+ List<JSONObject> storeUserObjs = new ArrayList<>();
|
|
|
+ for (MachineDto tmpMachineDto : machineDtos) {
|
|
|
+
|
|
|
+ storeUserObj = new JSONObject();
|
|
|
+ storeUserObj.put("extClassesId", attendanceClassesDtos.get(0).getClassesId());
|
|
|
+ storeUserObj.put("extStaffId", attendanceClassesStaffs.get(0).getStaffId());
|
|
|
+ storeUserObj.put("staffName", attendanceClassesStaffs.get(0).getStaffName());
|
|
|
+ storeUserObj.put("departmentId", "-1");
|
|
|
+ storeUserObj.put("departmentName", "未知");
|
|
|
+ storeUserObj.put("machineCode", tmpMachineDto.getMachineCode());
|
|
|
+ storeUserObj.put("extMachineId", tmpMachineDto.getMachineId());
|
|
|
+ storeUserObj.put("extCommunityId", tmpMachineDto.getCommunityId());
|
|
|
+ storeUserObj.put("faceBase64", img);
|
|
|
+ storeUserObjs.add(storeUserObj);
|
|
|
}
|
|
|
+ JSONObject postParameters = new JSONObject();
|
|
|
+ postParameters.put("classesName", attendanceClassesDtos.get(0).getClassesName());
|
|
|
+ postParameters.put("extClassesId", attendanceClassesDtos.get(0).getClassesId());
|
|
|
+ postParameters.put("extCommunityId", "-1");
|
|
|
+ hcStoreUserAsynImpl.addAttendanceStaff(postParameters, storeUserObjs);
|
|
|
+
|
|
|
}
|
|
|
|
|
|
- private String getStaffPhoto(OrgStaffRelDto orgStaffRelDto) {
|
|
|
+ private String getStaffPhoto(AttendanceClassesStaffDto attendanceClassesStaffDto) {
|
|
|
|
|
|
FileRelDto fileRelDto = new FileRelDto();
|
|
|
- fileRelDto.setObjId(orgStaffRelDto.getStaffId());
|
|
|
- fileRelDto.setRelTypeCd("12000");
|
|
|
+ fileRelDto.setObjId(attendanceClassesStaffDto.getCsId());
|
|
|
List<FileRelDto> fileRelDtos = fileRelInnerServiceSMOImpl.queryFileRels(fileRelDto);
|
|
|
if (fileRelDtos == null || fileRelDtos.size() != 1) {
|
|
|
return "";
|