| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249 |
- package com.malk.huagao.service.impl;
- import cn.hutool.core.date.DateUtil;
- import cn.hutool.core.util.NumberUtil;
- import com.alibaba.fastjson.JSON;
- import com.alibaba.fastjson.JSONObject;
- import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
- import com.malk.huagao.entity.YdNonProdPrice;
- import com.malk.huagao.entity.YdProdWorkHoursPrice;
- import com.malk.huagao.entity.YdUserInput;
- import com.malk.huagao.mapper.YdNonProdPriceMapper;
- import com.malk.huagao.mapper.YdProdWorkHoursPriceMapper;
- import com.malk.huagao.mapper.YdUserInputMapper;
- import com.malk.huagao.service.HuaGaoService;
- import com.malk.server.aliwork.YDConf;
- import com.malk.server.aliwork.YDParam;
- import com.malk.server.common.McException;
- import com.malk.server.dingtalk.DDR;
- import com.malk.server.dingtalk.DDR_New;
- import com.malk.service.aliwork.YDClient;
- import com.malk.service.aliwork.YDService;
- import com.malk.service.dingtalk.DDClient;
- import com.malk.service.dingtalk.DDClient_Attendance;
- import com.malk.service.dingtalk.DDClient_Contacts;
- import com.malk.service.fxiaoke.FXKClient;
- import com.malk.utils.UtilDateTime;
- import com.malk.utils.UtilMap;
- import lombok.extern.slf4j.Slf4j;
- import org.springframework.beans.factory.annotation.Autowired;
- import org.springframework.beans.factory.annotation.Value;
- import org.springframework.stereotype.Service;
- import java.text.ParseException;
- import java.text.SimpleDateFormat;
- import java.time.LocalDateTime;
- import java.util.*;
- @Slf4j
- @Service
- public class HuaGaoServiceImpl implements HuaGaoService {
- @Autowired
- private YDService ydService;
- @Autowired
- private YDClient ydClient;
- @Autowired
- private DDClient_Contacts ddClient_contacts;
- @Autowired
- private DDClient_Attendance ddClientAttendance;
- @Autowired
- private DDClient ddClient;
- @Autowired
- private YdUserInputMapper ydUserInputMapper;
- @Autowired
- private YdNonProdPriceMapper ydNonProdPriceMapper;
- @Autowired
- private YdProdWorkHoursPriceMapper ydProdWorkHoursPriceMapper;
- @Override
- public void syncKqData(LocalDateTime startTime, LocalDateTime endTime) {
- String stTime=UtilDateTime.formatLocal(startTime,UtilDateTime.DATE_TIME_PATTERN);
- String edTime=UtilDateTime.formatLocal(endTime,UtilDateTime.DATE_TIME_PATTERN);
- List<Map> list=ydService.queryAllFormData(YDParam.builder().formUuid("FORM-5061F7AE543B429C8241EC730A6F31653NNK").build());
- for(Map map:list){
- Map formData= UtilMap.getMap(map,"formData");
- String deptId=String.valueOf(UtilMap.getList(formData,"departmentSelectField_m8e4zaju_id").get(0));
- String price=UtilMap.getString(formData,"numberField_m8e4zajw_value");
- List<String> users=ddClient_contacts.listDepartmentUserId(ddClient.getAccessToken(),Long.parseLong(deptId));
- for (String user : users) {
- List<Map> valList=ddClientAttendance.getAttColumnVal(ddClient.getAccessToken(),user, Arrays.asList("82772106","89349019","82772125"),stTime,edTime);
- if(valList!=null&&valList.size()==3){
- Map<String,Map<String,String>> dateMap=toDateMap(valList);
- for (String date:dateMap.keySet()) {
- Map<String,String> dataMap=dateMap.get(date);
- String workTime="休息".equals(dataMap.get("82772125"))?
- dataMap.get("89349019"): NumberUtil.add(dataMap.get("89349019"),dataMap.get("82772106")).toString();
- saveData(user,date,workTime,price);
- //同步到数据库
- LambdaQueryWrapper<YdUserInput> ydUserInputLambdaQueryWrapper = new LambdaQueryWrapper<>();
- ydUserInputLambdaQueryWrapper.eq(YdUserInput::getUserId,user)
- .eq(YdUserInput::getDate, date);
- YdUserInput ydUserInput = ydUserInputMapper.selectOne(ydUserInputLambdaQueryWrapper);
- if (Objects.nonNull(ydUserInput)){
- ydUserInput.setWorkHours(workTime);
- ydUserInput.setPrice(price);
- ydUserInput.setTotalPrice(NumberUtil.mul(workTime,price));
- ydUserInputMapper.update(ydUserInput,ydUserInputLambdaQueryWrapper);
- }else {
- try {
- ydUserInput = new YdUserInput();
- ydUserInput.setUserId(user);
- SimpleDateFormat formatter = new SimpleDateFormat(UtilDateTime.DATE_TIME_PATTERN);
- ydUserInput.setDate(formatter.parse(date));
- ydUserInput.setWorkHours(workTime);
- ydUserInput.setPrice(price);
- ydUserInput.setTotalPrice(NumberUtil.mul(workTime,price));
- ydUserInputMapper.insert(ydUserInput);
- }catch (ParseException e){
- log.info("无法解析日期字符串: {}",e.getMessage());
- }
- }
- }
- }
- }
- }
- }
- @Override
- public void upsertNonProdPrice(Map map) {
- String formInstId = UtilMap.getString(map, "formInstId");
- Map formData = ydClient.queryData(YDParam.builder()
- .formInstId(formInstId)
- .build(), YDConf.FORM_QUERY.retrieve_id).getFormData();
- String type = UtilMap.getString(formData, "textField_m8fljzks");
- String form = UtilMap.getString(formData, "textField_m8fljzkt");
- String position = UtilMap.getString(formData, "textField_m8fljzku");
- String materialCodeLeft = UtilMap.getString(formData, "textField_m8fljzkv");
- String price = UtilMap.getString(formData, "numberField_m8fljzkw");
- LambdaQueryWrapper<YdNonProdPrice> ydNonProdPriceLambdaQueryWrapper = new LambdaQueryWrapper<>();
- ydNonProdPriceLambdaQueryWrapper.eq(YdNonProdPrice::getType,type)
- .eq(YdNonProdPrice::getForm,form)
- .eq(YdNonProdPrice::getPosition,position)
- .eq(YdNonProdPrice::getMaterialCodeLeft,materialCodeLeft);
- YdNonProdPrice ydNonProdPrice = ydNonProdPriceMapper.selectOne(ydNonProdPriceLambdaQueryWrapper);
- if (Objects.nonNull(ydNonProdPrice)){
- ydNonProdPrice.setPrice(price);
- ydNonProdPriceMapper.update(ydNonProdPrice,ydNonProdPriceLambdaQueryWrapper);
- }else {
- ydNonProdPrice = new YdNonProdPrice();
- ydNonProdPrice.setType(type);
- ydNonProdPrice.setForm(form);
- ydNonProdPrice.setPosition(position);
- ydNonProdPrice.setMaterialCodeLeft(materialCodeLeft);
- ydNonProdPrice.setPrice(price);
- ydNonProdPriceMapper.insert(ydNonProdPrice);
- }
- }
- @Override
- public void upsertWorkHoursPrice(Map map) {
- String formInstId = UtilMap.getString(map, "formInstId");
- Map formData = ydClient.queryData(YDParam.builder()
- .formInstId(formInstId)
- .build(), YDConf.FORM_QUERY.retrieve_id).getFormData();
- String type = UtilMap.getString(formData, "selectField_m8zib4co");
- String price = UtilMap.getString(formData, "numberField_m8zib4cp");
- LambdaQueryWrapper<YdProdWorkHoursPrice> ydProdWorkHoursPriceLambdaQueryWrapper = new LambdaQueryWrapper<>();
- ydProdWorkHoursPriceLambdaQueryWrapper.eq(YdProdWorkHoursPrice::getType,type);
- YdProdWorkHoursPrice ydProdWorkHoursPrice = ydProdWorkHoursPriceMapper.selectOne(ydProdWorkHoursPriceLambdaQueryWrapper);
- if (Objects.nonNull(ydProdWorkHoursPrice)){
- ydProdWorkHoursPrice.setPrice(price);
- ydProdWorkHoursPriceMapper.update(ydProdWorkHoursPrice,ydProdWorkHoursPriceLambdaQueryWrapper);
- }else {
- ydProdWorkHoursPrice = new YdProdWorkHoursPrice();
- ydProdWorkHoursPrice.setType(type);
- ydProdWorkHoursPrice.setPrice(price);
- ydProdWorkHoursPriceMapper.insert(ydProdWorkHoursPrice);
- }
- }
- /*@Override
- public void syncUserInput(LocalDateTime startTime, LocalDateTime endTime) {
- List<Map> dataList = getYdFormDataList("FORM-78BF5DE20E244369BD475C11A5CA48A0ZAQJ", "", YDConf.FORM_QUERY.retrieve_list_all);
- for (Map data : dataList) {
- Map formData = UtilMap.getMap(data, "formData");
- YdUserInput ydUserInput = new YdUserInput();
- ydUserInput.setUser(UtilMap.getList(formData, "employeeField_m8cu0g58").get(0).toString());
- ydUserInput.setUserId(UtilMap.getList(formData, "employeeField_m8cu0g58_id").get(0).toString());
- ydUserInput.setDate(new Date(UtilMap.getLong(formData,"dateField_m8e53oef")));
- ydUserInput.setWorkHours(UtilMap.getString(formData,"numberField_m8ctvm2e"));
- ydUserInput.setPrice(UtilMap.getString(formData,"numberField_m8e53oeg"));
- ydUserInput.setTotalPrice(UtilMap.getString(formData,"numberField_m8e53oeh"));
- ydUserInputMapper.insert(ydUserInput);
- }
- }*/
- /*private List<Map> getYdFormDataList(String formUuid, String searchCondition, YDConf.FORM_QUERY formQuery) {
- List<Map> list = new ArrayList<>();
- DDR_New ddrNew = new DDR_New();
- int pageNumber = 1;
- int pageSize = 100;
- do {
- ddrNew = ydClient.queryData(YDParam.builder().formUuid(formUuid)
- .searchCondition(searchCondition)
- .pageNumber(pageNumber)
- .pageSize(pageSize).build(), formQuery);
- list.addAll((List<Map>) ddrNew.getData());
- pageNumber++;
- }while (ddrNew.getTotalCount() > ddrNew.getPageNumber() * pageSize);
- return list;
- }*/
- private Map<String,Map<String,String>> toDateMap(List<Map> valList){
- Map<String,Map<String,String>> result = new HashMap<>();
- for(Map map:valList){
- String columnId=UtilMap.getString(UtilMap.getMap(map,"column_vo"),"id");
- List<Map> list=UtilMap.getList(map,"column_vals");
- for(Map map1:list){
- String date=UtilMap.getString(map1,"date");
- String value=UtilMap.getString(map1,"value");
- value=columnId.equals("82772106")?NumberUtil.round(NumberUtil.div(value,"60"),2).toString():value; // 工作时长 分钟转小时
- if(result.containsKey(date)){
- result.get(date).put(columnId,value);
- }else{
- result.put(date,UtilMap.map(columnId,value));
- }
- }
- }
- return result;
- }
- private void saveData(String userId,String date,String gs,String price){
- Long dateTime= UtilDateTime.getLocalDateTimeTimeStamp(UtilDateTime.parseLocalDateTime(date));
- Map saveMap=UtilMap.map("employeeField_m8cu0g58, dateField_m8e53oef, numberField_m8ctvm2e, numberField_m8e53oeg, numberField_m8e53oeh",
- Arrays.asList(userId),dateTime,gs,price,NumberUtil.mul(gs,price));
- ydClient.operateData(YDParam.builder().formUuid("FORM-78BF5DE20E244369BD475C11A5CA48A0ZAQJ")
- .searchCondition(JSONObject.toJSONString(UtilMap.map("employeeField_m8cu0g58, dateField_m8e53oef", userId,Arrays.asList(dateTime,dateTime))))
- .formDataJson(JSONObject.toJSONString(saveMap)).build(), YDConf.FORM_OPERATION.upsert);
- }
- }
|