张晓波
2023-09-19 164694c47c35d6654df69b533e8dbf8b5423efc5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
package com.thhy.materials.modules.biz.mixmateria.controller;
 
import com.alibaba.fastjson.JSON;
import com.alibaba.fastjson.JSONObject;
import com.alibaba.nacos.api.utils.StringUtils;
import com.github.pagehelper.PageInfo;
import com.thhy.general.common.BasicResult;
import com.thhy.general.common.BasicStatus;
import com.thhy.general.config.GlobalConfig;
import com.thhy.general.exception.BasicException;
import com.thhy.general.utils.ExcelUtils;
import com.thhy.general.utils.PagingUtils;
import com.thhy.general.utils.TitleField;
import com.thhy.materials.modules.biz.materialsplan.entity.RsbMaterialDict;
import com.thhy.materials.modules.biz.mixmateria.entity.MixDto;
import com.thhy.materials.modules.biz.mixmateria.entity.MixMaterial;
import com.thhy.materials.modules.biz.mixmateria.entity.MixMaterialInfo;
import com.thhy.materials.modules.biz.mixmateria.service.MixMaterialService;
import org.redisson.api.RBucket;
import org.redisson.api.RedissonClient;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
 
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.text.SimpleDateFormat;
import java.time.LocalDateTime;
import java.util.*;
 
/**
 * @author zhang_xiao_bo
 * @since 2023-05-16 15:18:52
 */
@RestController
@RequestMapping("mixMaterial")
public class MixMaterialController {
 
 
    @Autowired
    private MixMaterialService mixMaterialService;
 
    @Autowired
    private RedissonClient redissonClient;
 
    @Autowired
    private GlobalConfig globalConfig;
 
    @RequestMapping("findList")
    public BasicResult findList(@RequestBody(required = false) MixDto mixDto,HttpServletRequest req){
        Map<String,Object> map = new HashMap<>();
        List<HashMap<String, Object>> tableHeader = mixMaterialService.tableHeader();
        PagingUtils.setPageParam(req);
        List<HashMap<String, Object>> mixMaterialList = mixMaterialService.findList(mixDto);
        PageInfo<HashMap<String, Object>> pageInfo = new PageInfo<>(mixMaterialList);
        map.put("tableHeader",tableHeader);
        map.put("pageInfo",pageInfo);
        return BasicResult.success(map);
    }
 
    @RequestMapping("mixTotalCount")
    public BasicResult mixTotalCount(){
        List<MixMaterialInfo> infoList = mixMaterialService.mixTotalCount();
        return BasicResult.success(infoList);
    }
 
    @RequestMapping("addMixMaterial")
    public BasicResult addMixMaterial(@RequestBody MixMaterial mixMaterial){
        mixMaterialService.addMixMaterial(mixMaterial);
        return BasicResult.success();
    }
 
    @RequestMapping("info")
    public BasicResult info(@RequestBody MixDto mixDto){
        List<RsbMaterialDict> rsbMaterialPlanList = mixMaterialService.info(mixDto);
        return BasicResult.success(rsbMaterialPlanList);
    }
 
    /**
    @RequestMapping("update")
    public BasicResult update(@RequestBody MixMaterial mixMaterial){
        mixMaterialService.update(mixMaterial);
        return BasicResult.success();
    }**/
 
    @RequestMapping("delete")
    public BasicResult delete(@RequestBody MixMaterial mixMaterial){
        mixMaterialService.delete(mixMaterial.getId());
        return BasicResult.success();
    }
 
    @RequestMapping("export")
    public void export(String authcode, HttpServletResponse resp){
        List<TitleField> list = new ArrayList<>();
        list.add(new TitleField("序号","seq"));
        list.add(new TitleField("出砼时间","outTime"));
        list.add(new TitleField("盘方量","size"));
        List<HashMap<String,Object>> headers = mixMaterialService.tableHeader();
        for(int i=0;i<headers.size();i++){
            HashMap<String,Object> map = headers.get(i);
            map.put("fieldName","field"+i);
            list.add(new TitleField(map.get("title").toString(),"field"+i));
        }
 
        RBucket<String> rBucket = redissonClient.getBucket(globalConfig.getFilePreKey()+":authcode:"+authcode);
        String param = rBucket.getAndDelete();
        if(StringUtils.isEmpty(param)){
            throw new BasicException(BasicStatus.TOKEN_IS_NULL);
        }
        JSONObject jsonObject = JSON.parseObject(param);
        MixDto mixDto = JSON.toJavaObject(jsonObject,MixDto.class);
 
        List<HashMap<String,Object>> mapList = mixMaterialService.findListForExport(mixDto,jsonObject.getString("token"));
        for(HashMap<String,Object> map : mapList){
            String materialValue = mixMaterialService.queryGroup(map.get("id").toString());
            String[] valueArray = materialValue.split(",");
            for(int i=0;i<headers.size();i++){
                map.put("field"+i,valueArray[i]);
            }
        }
        ExcelUtils.downExcel(mapList,list,resp,"搅拌站原料管理");
    }
}