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
package cn.flightfeather.supervision.business.report
 
import cn.flightfeather.supervision.common.utils.ExcelUtil
import kotlin.math.max
 
/**
 * 统计数据列基类
 */
abstract class BaseCols(){
 
    protected var heads = mutableListOf<MutableList<ExcelUtil.MyCell>>()
 
    //生成表头
    fun getHeads(dataSource: DataSource): MutableList<MutableList<ExcelUtil.MyCell>> {
        heads = onHeads(dataSource)
        return heads
    }
 
    abstract fun onHeads(dataSource: DataSource): MutableList<MutableList<ExcelUtil.MyCell>>
 
    //生成一行内容
    fun getOneRow(rowData: DataSource.RowData): List<Any> {
//        return if (rowData.noRecord()) {
//            val r = mutableListOf<String>()
//            repeat(heads.last().size) { r.add(("")) }
//            r
//        } else {
//            onOneRow(rowData)
//        }
        return onOneRow(rowData)
    }
 
    abstract fun onOneRow(rowData: DataSource.RowData): List<Any>
 
    fun emptyJudge() {
 
    }
 
    /**
     * 新老表头合并
     */
    fun combineHead(oldHeads: MutableList<MutableList<ExcelUtil.MyCell>>, dataSource: DataSource) {
        //合并表头,采取简化逻辑,只有第一行的表头会进行单元格的跨行合并
        val newHeads = getHeads(dataSource)
        if (oldHeads.isEmpty()) {
            newHeads.forEach { oldHeads.add(it) }
        } else {
            val maxRow = max(oldHeads.size, newHeads.size)
            for (i in 0 until maxRow) {
                val oH =
                    //取已有表头中的行
                    if (i < oldHeads.size) {
                        oldHeads[i]
                    }
                    //取新一行,同时第一行表头跨行数加一
                    else {
                        if (i > 0) {
                            oldHeads.first().forEach { it.rowSpan++ }
                        }
                        val h = mutableListOf<ExcelUtil.MyCell>()
 
                        var cols = 0
                        oldHeads.last().forEach {
                            cols += it.colSpan
                        }
                        repeat(cols) { h.add(ExcelUtil.MyCell("")) }
                        oldHeads.add(h)
                        h
                    }
 
                val nH =
                    if (i < newHeads.size) {
                        newHeads[i]
                    } else {
                        if (i > 0) {
                            newHeads.first().forEach { it.rowSpan++ }
                        }
                        val h = mutableListOf<ExcelUtil.MyCell>()
 
                        var cols = 0
                        newHeads.last().forEach {
                            cols += it.colSpan
                        }
                        repeat(cols) { h.add(ExcelUtil.MyCell("")) }
                        newHeads.add(h)
                        h
                    }
            }
 
            for (i in oldHeads.indices) {
                oldHeads[i].addAll(newHeads[i])
            }
        }
    }
}