package com.zy.common.entity;
|
|
import com.alibaba.excel.context.AnalysisContext;
|
import com.alibaba.excel.event.AnalysisEventListener;
|
import com.core.common.Cools;
|
import com.core.common.SpringUtils;
|
import com.core.exception.CoolException;
|
import com.zy.asrs.entity.Node;
|
import com.zy.asrs.mapper.NodeMapper;
|
import com.zy.asrs.service.NodeService;
|
import com.zy.common.utils.NodeUtils;
|
|
import java.util.ArrayList;
|
import java.util.Date;
|
import java.util.List;
|
import java.util.Map;
|
|
public class NodeExcelListener extends AnalysisEventListener<NodeExcel> {
|
private int total = 0;
|
private Long userId;
|
private Long hostId;
|
|
public NodeExcelListener() {
|
}
|
|
public NodeExcelListener(Long userId, Long hostId) {
|
this.userId = userId;
|
this.hostId = hostId;
|
}
|
|
/**
|
* 每隔5条存储数据库,实际使用中可以3000条,然后清理list ,方便内存回收
|
*/
|
private static final int BATCH_COUNT = 50;
|
|
private final List<NodeExcel> list = new ArrayList<>();
|
|
/**
|
* 这里会一行行的返回头
|
*/
|
@Override
|
public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {
|
}
|
|
/**
|
* 这个每一条数据解析都会来调用
|
*/
|
@Override
|
public void invoke(NodeExcel excel, AnalysisContext ctx) {
|
NodeService nodeService = SpringUtils.getBean(NodeService.class);
|
NodeMapper nodeMapper = SpringUtils.getBean(NodeMapper.class);
|
Date now = new Date();
|
Node top = nodeService.getTop();
|
// 仓库
|
if (!Cools.isEmpty(excel.getWarehouse())) {
|
Node wareHouse = nodeService.selectByUuid(excel.getWarehouse(), hostId, 1, top.getId());
|
if (wareHouse == null) {
|
wareHouse = new Node();
|
wareHouse.setHostId(this.hostId);
|
wareHouse.setUuid(excel.getWarehouse());
|
wareHouse.setName(excel.getWarehouse());
|
wareHouse.setType(1);
|
wareHouse.setParentId(top.getId());
|
wareHouse.setParentName(top.getName());
|
wareHouse.setLevel(top.getLevel() + 1);
|
NodeUtils nodeUtils = new NodeUtils();
|
nodeUtils.executePath(wareHouse);
|
wareHouse.setPath(nodeUtils.path.toString());
|
wareHouse.setNamePath(nodeUtils.pathName.toString());
|
wareHouse.setStatus(1);
|
wareHouse.setCreateTime(now);
|
wareHouse.setUpdateTime(now);
|
if (nodeMapper.insert(wareHouse) == 0) {
|
throw new CoolException("保存仓库数据失败");
|
}
|
total ++;
|
}
|
|
// 库区
|
if (!Cools.isEmpty(excel.getArea())) {
|
Node area = nodeService.selectByUuid(excel.getArea(), hostId, 2, wareHouse.getId());
|
if (area == null) {
|
area = new Node();
|
area.setHostId(this.hostId);
|
area.setUuid(excel.getArea());
|
area.setName(excel.getArea());
|
area.setType(2);
|
area.setParentId(wareHouse.getId());
|
area.setParentName(wareHouse.getName());
|
area.setLevel(wareHouse.getLevel() + 1);
|
NodeUtils nodeUtils = new NodeUtils();
|
nodeUtils.executePath(area);
|
area.setPath(nodeUtils.path.toString());
|
area.setNamePath(nodeUtils.pathName.toString());
|
area.setStatus(1);
|
area.setCreateTime(now);
|
area.setUpdateTime(now);
|
if (nodeMapper.insert(area) == 0) {
|
throw new CoolException("保存库区数据失败");
|
}
|
total ++;
|
}
|
|
// 货位
|
if (!Cools.isEmpty(excel.getAllo())) {
|
Node allo = nodeService.selectByUuid(excel.getAllo(), hostId, 3);
|
if (allo == null) {
|
allo = new Node();
|
allo.setHostId(this.hostId);
|
allo.setUuid(excel.getAllo());
|
allo.setName(excel.getAllo());
|
allo.setType(3);
|
allo.setParentId(area.getId());
|
allo.setParentName(area.getName());
|
allo.setLevel(area.getLevel() + 1);
|
NodeUtils nodeUtils = new NodeUtils();
|
nodeUtils.executePath(allo);
|
allo.setPath(nodeUtils.path.toString());
|
allo.setNamePath(nodeUtils.pathName.toString());
|
allo.setStatus(1);
|
allo.setCreateTime(now);
|
allo.setUpdateTime(now);
|
if (nodeMapper.insert(allo) == 0) {
|
throw new CoolException("保存货位数据失败");
|
}
|
total ++;
|
}
|
}
|
|
}
|
}
|
}
|
|
/**
|
* 所有数据解析完成了调用
|
* 适合事务
|
*/
|
@Override
|
public void doAfterAllAnalysed(AnalysisContext ctx) {
|
//log.info("新增{}条物料信息!", total);
|
}
|
|
public int getTotal() {
|
return total;
|
}
|
}
|