Blame view

src/main/java/com/huaheng/api/tv/controller/TvController.java 14.3 KB
游杰 authored
1
2
package com.huaheng.api.tv.controller;
易文鹏 authored
3
import com.alibaba.fastjson.JSONObject;
游杰 authored
4
5
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
易文鹏 authored
6
import com.huaheng.api.tv.domain.*;
游杰 authored
7
8
import com.huaheng.api.wcs.domain.WcsTask;
import com.huaheng.common.constant.QuantityConstant;
9
import com.huaheng.framework.aspectj.lang.annotation.ApiLogger;
游杰 authored
10
11
import com.huaheng.framework.web.controller.BaseController;
import com.huaheng.framework.web.domain.AjaxResult;
易文鹏 authored
12
import com.huaheng.mobile.task.TaskDomain;
游杰 authored
13
14
15
16
17
18
19
20
21
22
23
24
25
import com.huaheng.pc.config.container.domain.Container;
import com.huaheng.pc.config.container.service.ContainerService;
import com.huaheng.pc.config.location.domain.Location;
import com.huaheng.pc.config.location.service.LocationService;
import com.huaheng.pc.config.material.domain.Material;
import com.huaheng.pc.config.material.service.MaterialService;
import com.huaheng.pc.config.zone.domain.Zone;
import com.huaheng.pc.config.zone.service.ZoneService;
import com.huaheng.pc.inventory.InventoryMaterialSummary.domain.InventoryMaterialSummary;
import com.huaheng.pc.inventory.InventoryMaterialSummary.service.InventoryMaterialSummaryService;
import com.huaheng.pc.inventory.inventoryDetail.domain.InventoryDetail;
import com.huaheng.pc.inventory.inventoryDetail.service.InventoryDetailService;
import com.huaheng.pc.inventory.inventoryTransaction.service.InventoryTransactionService;
易文鹏 authored
26
import com.huaheng.pc.report.excelReport.mapper.ExcelReportMapper;
27
28
import com.huaheng.pc.shipment.shipmentDetail.domain.ShipmentDetailTv;
import com.huaheng.pc.shipment.shipmentDetail.mapper.ShipmentDetailMapper;
易文鹏 authored
29
30
import com.huaheng.pc.system.dict.domain.DictData;
import com.huaheng.pc.system.dict.service.IDictDataService;
31
32
import com.huaheng.pc.task.taskDetail.domain.TaskDetail;
import com.huaheng.pc.task.taskDetail.service.TaskDetailService;
游杰 authored
33
34
import com.huaheng.pc.task.taskHeader.domain.TaskHeader;
import com.huaheng.pc.task.taskHeader.service.TaskHeaderService;
易文鹏 authored
35
import com.huaheng.pc.task.taskHeader.service.TaskHeaderTvService;
游杰 authored
36
37
38
39
import io.swagger.annotations.ApiOperation;
import org.springframework.web.bind.annotation.*;

import javax.annotation.Resource;
40
import java.util.*;
游杰 authored
41
42

@RestController
易文鹏 authored
43
@RequestMapping
游杰 authored
44
45
46
public class TvController extends BaseController {

    @Resource
易文鹏 authored
47
48
    ExcelReportMapper excelReportMapper;
    @Resource
游杰 authored
49
50
    private TaskHeaderService taskHeaderService;
    @Resource
51
52
    private TaskDetailService taskDetailService;
    @Resource
游杰 authored
53
54
55
56
57
58
59
60
61
62
63
64
65
    private ContainerService containerService;
    @Resource
    private LocationService locationService;
    @Resource
    private InventoryTransactionService inventoryTransactionService;
    @Resource
    private ZoneService zoneService;
    @Resource
    private InventoryDetailService inventoryDetailService;
    @Resource
    private InventoryMaterialSummaryService inventoryMaterialSummaryService;
    @Resource
    private MaterialService materialService;
66
67
    @Resource
    private ShipmentDetailMapper shipmentDetailMapper;
游杰 authored
68
易文鹏 authored
69
70
71
72
73
74
75
    @Resource
    private TaskHeaderTvService taskHeaderTvService;
    @Resource
    private IDictDataService dictDataService;


    @CrossOrigin
易文鹏 authored
76
77
78
    @GetMapping("/stackA")
    private AjaxResult mainA(@RequestParam String port) {
        return getTvView("A", port);
易文鹏 authored
79
80
81
    }

    @CrossOrigin
易文鹏 authored
82
83
84
    @GetMapping("/stackB")
    private AjaxResult mainB(@RequestParam String port) {
        return getTvView("B", port);
易文鹏 authored
85
86
87
    }

    @CrossOrigin
易文鹏 authored
88
89
90
    @GetMapping("/stackC")
    private AjaxResult mainC(@RequestParam String port) {
        return getTvView("C", port);
易文鹏 authored
91
92
    }
易文鹏 authored
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
    public AjaxResult<TvTask> getTvView(String zone, String port) {

        //库位利用率(矮库位有货、矮库位无货、高库位有货、高库位无货)
        String sql1 = "SELECT\n" +
                "SUM(CASE WHEN zoneCode='" + zone + "' AND warehouseCode = 'CS0001' AND containerCode !='' AND high = 0 THEN 1 ELSE 0 END) AS 'lowInStock',\n" +
                "SUM(CASE WHEN zoneCode='" + zone + "' AND warehouseCode = 'CS0001' AND containerCode ='' AND high = 0 THEN 1 ELSE 0 END) AS 'lowSoldOut',\n" +
                "SUM(CASE WHEN zoneCode='" + zone + "' AND warehouseCode = 'CS0001' AND containerCode !='' AND high = 1 THEN 1 ELSE 0 END) AS 'highInStock',\n" +
                "SUM(CASE WHEN zoneCode='" + zone + "' AND warehouseCode = 'CS0001' AND containerCode ='' AND high = 1 THEN 1 ELSE 0 END) AS 'highSoldOut'\n" +
                "FROM location;";
        List<LinkedHashMap<String, Object>> locationProportion = excelReportMapper.selectCommon(sql1);
        JSONObject location = new JSONObject();
        location.put("locationProportion", locationProportion);


        //空托盘
        String sql3 = "";
        if ("A".equals(zone)) {
            sql3 = "SELECT ct.name, COUNT(*) AS count FROM container c JOIN container_type ct ON c.containerType = ct.code \n" +
                    "WHERE c.status = 'empty' and c.locationCode!='' AND c.containerType in ('A') GROUP BY ct.name;";
        } else if ("B".equals(zone)) {
            sql3 = "SELECT ct.name, COUNT(*) AS count FROM container c JOIN container_type ct ON c.containerType = ct.code \n" +
                    "WHERE c.status = 'empty' and c.locationCode!='' AND c.containerType in ('B', 'C', 'D', 'E') GROUP BY ct.name;";
        } else {
            sql3 = "SELECT ct.name, COUNT(*) AS count FROM container c JOIN container_type ct ON c.containerType = ct.code \n" +
                    "WHERE c.status = 'empty' and c.locationCode!='' AND c.containerType in ('F', 'G') GROUP BY ct.name;";
        }
        List<LinkedHashMap<String, Object>> emptyPallet = excelReportMapper.selectCommon(sql3);
        JSONObject empty = new JSONObject();
        empty.put("emptyPallet", emptyPallet);


        //任务
易文鹏 authored
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
        List<TaskDomain> taskDomainList = new ArrayList<>();
        //port多个站台用,分隔,查出所有头表
        List<DictData> dictlist = dictDataService.selectDictDataByType("taskType");
        List<TaskHeader> taskList = new ArrayList<>();
        for (String p : port.split(",")) {
            List<TaskHeader> tmpTaskList = taskHeaderTvService.getTaskByTvPort(p);
            taskList.addAll(tmpTaskList);
        }

        lable1:
        for (TaskHeader task : taskList) {
            if (task.getInternalTaskType() == 100) {
                task.setFromLocation(task.getToLocation());
            }
            lable2:
            for (DictData dictData : dictlist) {
                if (task.getTaskType().toString().equals(dictData.getDictValue())) {
                    task.setUserDef1(dictData.getDictLabel());
                    break lable2;
                }
            }
            TaskDomain taskDomain = new TaskDomain();
            List<TaskDetail> taskDetails = taskDetailService.findByTaskId(task.getId());
            taskDomain.setTaskHeader(task);
            taskDomain.setTaskDetails(taskDetails);
            taskDomainList.add(taskDomain);
        }

        taskDomainList.sort((o1, o2) -> {
            TaskHeader task1 = o1.getTaskHeader();
            TaskHeader task2 = o2.getTaskHeader();
            int ret = task2.getStatus() - task1.getStatus();
            if (ret == 0) {
                ret = (int) (task2.getLastUpdated().getTime() - task1.getLastUpdated().getTime());
            }
            return ret;
        });
易文鹏 authored
162
163
164
165
166
167
168


        TvTask tvTask = new TvTask();
        tvTask.setTaskDomains(taskDomainList);
        tvTask.setEmptyPallet(empty);
        tvTask.setLocationProportion(location);
        return AjaxResult.success(tvTask);
易文鹏 authored
169
170
171
    }
游杰 authored
172
    @PostMapping("/getTvView")
173
174
175
    //@ApiOperation("获取电视信息")
    @CrossOrigin
    //@ApiLogger(apiName = "获取电视信息", from="TV")
游杰 authored
176
177
    @ResponseBody
    public AjaxResult getTvView(@RequestBody WcsTask wcsTask) {
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
        String area = wcsTask.getArea();
        LambdaQueryWrapper<TaskHeader> taskHeaderLambdaQueryWrapper = Wrappers.lambdaQuery();
        taskHeaderLambdaQueryWrapper.eq(TaskHeader::getArea, area)
                .lt(TaskHeader::getStatus, QuantityConstant.TASK_STATUS_COMPLETED)
                .orderByDesc(TaskHeader::getId);
        List<TaskHeader> taskHeaderList = taskHeaderService.list(taskHeaderLambdaQueryWrapper);
        if (taskHeaderList != null && taskHeaderList.size() > 0) {
            for (TaskHeader taskHeader : taskHeaderList) {
                String materialCode = taskHeader.getMaterialCode();
                String warehouseCode = taskHeader.getWarehouseCode();
                Material material = materialService.getMaterialByCode(materialCode, warehouseCode);
                if (material != null) {
                    taskHeader.setMaterialCode(material.getName());
                }
            }
        }
游杰 authored
194
195
        LambdaQueryWrapper<Container> containerEmptyLambdaQueryWrapper = Wrappers.lambdaQuery();
游杰 authored
196
        containerEmptyLambdaQueryWrapper.eq(Container::getArea, area)
197
198
199
                .eq(Container::getStatus, QuantityConstant.STATUS_CONTAINER_EMPTY)
                .ne(Container::getLocationCode, "");
        List<Container> containerEmptyList = containerService.list(containerEmptyLambdaQueryWrapper);
游杰 authored
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
        int containerEmptySize = containerEmptyList.size();

        LambdaQueryWrapper<Container> containerManyLambdaQueryWrapper = Wrappers.lambdaQuery();
        containerManyLambdaQueryWrapper.eq(Container::getArea, area)
                .eq(Container::getStatus, QuantityConstant.STATUS_CONTAINER_MANY)
                .ne(Container::getLocationCode, "");
        List<Container> manyEmptyList = containerService.list(containerManyLambdaQueryWrapper);
        int manyEmptyListSize = manyEmptyList.size();
        containerEmptySize = containerEmptySize + manyEmptyListSize * 6;
        LambdaQueryWrapper<Container> containerSomeLambdaQueryWrapper = Wrappers.lambdaQuery();
        containerSomeLambdaQueryWrapper.eq(Container::getArea, area)
                .eq(Container::getStatus, QuantityConstant.STATUS_CONTAINER_SOME)
                .ne(Container::getLocationCode, "");
        List<Container> containerSomeList = containerService.list(containerSomeLambdaQueryWrapper);
        int containerSomeSize = containerSomeList.size();

        LambdaQueryWrapper<Location> locationLambdaQueryWrapper = Wrappers.lambdaQuery();
        locationLambdaQueryWrapper.eq(Location::getArea, area);
        List<Location> locationList = locationService.list(locationLambdaQueryWrapper);
        int totalLocationSize = locationList.size();

        LambdaQueryWrapper<Zone> zoneLambdaQueryWrapper = Wrappers.lambdaQuery();
        zoneLambdaQueryWrapper.eq(Zone::getArea, area);
        Zone zone = zoneService.getOne(zoneLambdaQueryWrapper);
        LambdaQueryWrapper<InventoryDetail> inventoryDetailLambdaQueryWrapper = Wrappers.lambdaQuery();
        inventoryDetailLambdaQueryWrapper.eq(InventoryDetail::getZoneCode, zone.getCode());
        List<InventoryDetail> inventoryDetailList = inventoryDetailService.list(inventoryDetailLambdaQueryWrapper);
        int inventorySize = inventoryDetailList.size();


        LambdaQueryWrapper<InventoryMaterialSummary> lambdaQueryWrapper = Wrappers.lambdaQuery();
        lambdaQueryWrapper.eq(InventoryMaterialSummary::getZoneCode, zone.getCode());
        List<InventoryMaterialSummary> list = inventoryMaterialSummaryService.list(lambdaQueryWrapper);
        if (list == null) {
            list = Collections.emptyList();
        }
        //筛选库存汇总数据的专用方法
        List<InventoryMaterialSummary> details = inventoryMaterialSummaryService.duplicateRemoval(list);

        TvBean tvBean = new TvBean();
        tvBean.setDetails(details);
        tvBean.setContainerEmptySize(containerEmptySize);
        tvBean.setContainerSomeSize(containerSomeSize);
        tvBean.setTotalLocationSize(totalLocationSize);
        tvBean.setTaskHeaderList(taskHeaderList);
        tvBean.setInventorySize(inventorySize);
        return AjaxResult.success(tvBean);
    }
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305

    @PostMapping("/getTvReceiptView")
    //@ApiOperation("获取电视入库信息")
    @CrossOrigin
    @ResponseBody
    //@ApiLogger(apiName = "获取电视入库信息", from = "TV")
    public AjaxResult getTvReceiptView() {
        AllBean allBean = new AllBean();
        LambdaQueryWrapper<TaskDetail> queryWrapper = Wrappers.lambdaQuery();
        List<String> str = Arrays.asList("100", "200");
        queryWrapper.in(TaskDetail::getTaskType, str)
                .last(" and  date_format( created, '%Y-%m-%d' )= date_format( now(), '%Y-%m-%d' ) and `status`>=100");
        List<TaskDetail> list = taskDetailService.list(queryWrapper);
        List<TopBean> topList = new ArrayList<>();
        if (list.size() > 0) {
            topList = taskDetailService.getTvReceiptView("1");
        }
        allBean.setTopList(topList);
        List<UpBean> upList = taskDetailService.getTvNotReceiptList("1");
        allBean.setUpList(upList);
        return AjaxResult.success(allBean);
    }

    @PostMapping("/getTvShipmentView")
    //@ApiOperation("获取电视出库信息")
    @CrossOrigin
    @ResponseBody
    //@ApiLogger(apiName = "获取电视出库信息", from = "TV")
    public AjaxResult getTvShipmentView(@RequestBody Map<String, String> map) {
        AllBean allBean = new AllBean();
        LambdaQueryWrapper<TaskDetail> queryWrapper = Wrappers.lambdaQuery();
        List<String> str = Arrays.asList("300", "400");
        queryWrapper.in(TaskDetail::getTaskType, str)
                .last(" and  date_format( created, '%Y-%m-%d' )= date_format( now(), '%Y-%m-%d' ) and `status`>=100");
        List<TaskDetail> list = taskDetailService.list(queryWrapper);
        List<TopBean> topList = new ArrayList<>();
        if (list.size() > 0) {
            topList = taskDetailService.getTvReceiptView("2");
        }
        allBean.setTopList(topList);
        List<UpBean> upList = taskDetailService.getTvNotReceiptList("2");
        allBean.setUpList(upList);
        String par = map.get("par");
        List<ShipmentDetailTv> portList = shipmentDetailMapper.getTvOutList(par);
        allBean.setPortList(portList);
        return AjaxResult.success(allBean);
    }

    @PostMapping("/getTvPortShipmentView")
    @ApiOperation("获取出站口出库信息")
    @CrossOrigin
    @ResponseBody
    @ApiLogger(apiName = "获取出站口出库信息", from = "TV")
    public AjaxResult getTvPortShipmentView(@RequestBody Map<String, String> map) {
        String par = map.get("par");
        List<ShipmentDetailTv> upList = shipmentDetailMapper.getTvOutList(par);
        return AjaxResult.success(upList);
    }
游杰 authored
306
}