package com.example.erp.service.pp; import com.alibaba.fastjson.JSONArray; import com.alibaba.fastjson.JSONObject; import com.baomidou.dynamic.datasource.annotation.DS; import com.example.erp.entity.pp.FlowCard; import com.example.erp.mapper.pp.ReportMapper; import com.example.erp.mapper.sd.OrderProcessDetailMapper; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.sql.Date; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; @Service @DS("pp") public class ReportService { private final ReportMapper reportMapper; private final OrderProcessDetailMapper orderProcessDetailMapper; public ReportService(ReportMapper reportMapper, OrderProcessDetailMapper orderProcessDetailMapper) { this.reportMapper = reportMapper; this.orderProcessDetailMapper = orderProcessDetailMapper; } public Map processCardProgressSv(String orderId, List columns) { Map map = new HashMap<>(); map.put("data", reportMapper.processCardProgressMp(orderId)); map.put("title", orderProcessDetailMapper.filterOrderProcess(orderId)); List> getRowCount = orderProcessDetailMapper.getGlassLRow(orderId); List> rowCount = new ArrayList<>(); columns.forEach(col ->{ getRowCount.forEach(row ->{ Map getRow = new HashMap<>(); // { row: 0, col: 1, rowspan: 3, colspan: 0}, getRow.put("row",row.get("RowNum")); getRow.put("col",col); getRow.put("rowspan",row.get("rowCount")); getRow.put("colspan",0); rowCount.add(getRow); }); }); map.put("mergeCells",rowCount); return map; } }