package com.zy.asrs.controller; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.mapper.EntityWrapper; import com.baomidou.mybatisplus.mapper.Wrapper; import com.baomidou.mybatisplus.plugins.Page; import com.zy.asrs.entity.BasDevp; import com.zy.asrs.entity.param.BasDevpInitParam; import com.zy.asrs.service.BasCrnpService; import com.zy.asrs.service.BasDevpService; import com.zy.asrs.utils.Utils; import com.zy.common.web.BaseController; import com.core.annotations.ManagerAuth; import com.core.common.BaseRes; import com.core.common.Cools; import com.core.common.DateUtils; import com.core.common.R; import com.core.exception.CoolException; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.*; import java.util.*; @RestController public class BasDevpController extends BaseController { @Autowired private BasDevpService basDevpService; @Autowired private BasCrnpService basCrnpService; @RequestMapping(value = "/basDevp/init/auth") @ManagerAuth(memo = "初始化站点") public R init(BasDevpInitParam param) { List list = new ArrayList<>(); for (int devNo = param.getStartDev() ; devNo<=param.getEndDev() ; devNo++){ BasDevp basDevp = basDevpService.selectById(devNo); if (Cools.isEmpty(basDevp)){ BasDevp basDevp1 = new BasDevp(); basDevp1.setDevNo(devNo); basDevp1.setInEnable("Y"); basDevp1.setOutEnable("Y"); basDevp1.setAutoing("Y"); basDevp1.setLoading("Y"); basDevp1.setCanining("Y"); basDevp1.setCanouting("Y"); basDevp1.setModiUser(getUserId()); basDevp1.setModiTime(new Date()); list.add(basDevp1); } } basDevpService.insertBatch(list); return R.ok("初始化成功"); } @RequestMapping(value = "/basDevp/{id}/auth") @ManagerAuth public R get(@PathVariable("id") Long id) { return R.ok(basDevpService.selectById(String.valueOf(id))); } @RequestMapping(value = "/basDevp/list/auth") @ManagerAuth public R list(@RequestParam(defaultValue = "1")Integer curr, @RequestParam(defaultValue = "10")Integer limit, @RequestParam(required = false)String orderByField, @RequestParam(required = false)String orderByType, @RequestParam Map param){ excludeTrash(param); EntityWrapper wrapper = new EntityWrapper<>(); convert(param, wrapper); if (!Cools.isEmpty(orderByField)){wrapper.orderBy(humpToLine(orderByField), "asc".equals(orderByType));} return R.ok(basDevpService.selectPage(new Page<>(curr, limit), wrapper)); } private void convert(Map map, EntityWrapper wrapper){ for (Map.Entry entry : map.entrySet()){ String val = String.valueOf(entry.getValue()); if (val.contains(RANGE_TIME_LINK)){ String[] dates = val.split(RANGE_TIME_LINK); wrapper.ge(entry.getKey(), DateUtils.convert(dates[0])); wrapper.le(entry.getKey(), DateUtils.convert(dates[1])); } else { wrapper.like(entry.getKey(), val); } } } @RequestMapping(value = "/basDevp/add/auth") @ManagerAuth(memo = "站点添加") public R add(BasDevp basDevp) { normalizeInboundPriority(basDevp, null); basDevp.setModiUser(getUserId()); basDevp.setModiTime(new Date()); basDevp.setAppeUser(getUserId()); basDevp.setAppeTime(new Date()); basDevpService.insert(basDevp); return R.ok(); } @RequestMapping(value = "/basDevp/update/auth") @ManagerAuth(memo = "站点修改") public R update(BasDevp basDevp){ if (Cools.isEmpty(basDevp) || null==basDevp.getDevNo()){ return R.error(); } BasDevp existing = basDevpService.selectById(basDevp.getDevNo()); if (existing == null) { return R.error("站点不存在"); } normalizeInboundPriority(basDevp, existing); basDevp.setModiUser(getUserId()); basDevp.setModiTime(new Date()); basDevpService.updateById(basDevp); return R.ok("修改完成"); } @RequestMapping(value = "/basDevp/delete/auth") @ManagerAuth(memo = "站点删除") public R delete(@RequestParam String param){ List list = JSONArray.parseArray(param, BasDevp.class); if (Cools.isEmpty(list)){ return R.error(); } for (BasDevp entity : list){ basDevpService.delete(new EntityWrapper<>(entity)); } return R.ok(); } @RequestMapping(value = "/basDevp/export/auth") @ManagerAuth(memo = "站点导出") public R export(@RequestBody JSONObject param){ List fields = JSONObject.parseArray(param.getJSONArray("fields").toJSONString(), String.class); EntityWrapper wrapper = new EntityWrapper<>(); Map map = excludeTrash(param.getJSONObject("basDevp")); convert(map, wrapper); List list = basDevpService.selectList(wrapper); return R.ok(exportSupport(list, fields)); } @RequestMapping(value = "/basDevpQuery/auth") @ManagerAuth public R query(String condition) { EntityWrapper wrapper = new EntityWrapper<>(); wrapper.like("dev_no", condition); Page page = basDevpService.selectPage(new Page<>(0, 10), wrapper); List> result = new ArrayList<>(); for (BasDevp basDevp : page.getRecords()){ Map map = new HashMap<>(); map.put("id", basDevp.getDevNo()); map.put("value", basDevp.getDevNo()); result.add(map); } return R.ok(result); } @RequestMapping(value = "/basDevp/check/column/auth") @ManagerAuth public R query(@RequestBody JSONObject param) { Wrapper wrapper = new EntityWrapper().eq(humpToLine(String.valueOf(param.get("key"))), param.get("val")); if (null != basDevpService.selectOne(wrapper)){ return R.parse(BaseRes.REPEAT).add(getComment(BasDevp.class, String.valueOf(param.get("key")))); } return R.ok(); } private void normalizeInboundPriority(BasDevp basDevp, BasDevp existing) { if (basDevp == null) { return; } String firstCsv = resolveCsvValue(basDevp.getInFirstCrnCsv(), existing == null ? null : existing.getInFirstCrnCsv()); String secondCsv = resolveCsvValue(basDevp.getInSecondCrnCsv(), existing == null ? null : existing.getInSecondCrnCsv()); List firstCrnNos = parseCrnPool("第一优先池", firstCsv); List secondCrnNos = parseCrnPool("第二优先池", secondCsv); Set duplicateCrnNos = new LinkedHashSet<>(firstCrnNos); duplicateCrnNos.retainAll(secondCrnNos); if (!duplicateCrnNos.isEmpty()) { throw new CoolException("第一优先池和第二优先池不能重复配置同一台堆垛机:" + duplicateCrnNos); } basDevp.setInFirstCrnCsv(Utils.normalizeCrnCsv(firstCrnNos)); basDevp.setInSecondCrnCsv(Utils.normalizeCrnCsv(secondCrnNos)); if (existing == null) { basDevp.setInFirstCrnCurrentNo(null); basDevp.setInSecondCrnCurrentNo(null); return; } basDevp.setInFirstCrnCurrentNo(resolveCurrentNo(existing.getInFirstCrnCurrentNo(), firstCrnNos)); basDevp.setInSecondCrnCurrentNo(resolveCurrentNo(existing.getInSecondCrnCurrentNo(), secondCrnNos)); } private String resolveCsvValue(String incoming, String existing) { if (incoming == null) { return existing; } return incoming; } private List parseCrnPool(String label, String csv) { List crnNos; try { crnNos = Utils.parseCrnNos(csv); } catch (CoolException e) { throw new CoolException(label + e.getMessage()); } List distinctCrnNos = Utils.distinctCrnNos(crnNos); if (crnNos.size() != distinctCrnNos.size()) { throw new CoolException(label + "存在重复堆垛机号"); } for (Integer crnNo : distinctCrnNos) { if (basCrnpService.selectById(crnNo) == null) { throw new CoolException(label + "包含不存在的堆垛机号:" + crnNo); } } return distinctCrnNos; } private Integer resolveCurrentNo(Integer currentNo, List crnNos) { if (currentNo == null || Cools.isEmpty(crnNos) || !crnNos.contains(currentNo)) { return null; } return currentNo; } }