fix: the problem of unable to page across columns in the same row #41

pr675
lemon 2 years ago
parent 4eab45fa3d
commit 7aca3a0553

@ -1357,12 +1357,12 @@ export class Draw {
let deleteStart = 0 //拆分开始行
let deleteCount = 0 //拆分行数
let preTrHeight = 0 //前面tr的高度
const colInfoCache = new Map()
const colInfoCache = new Map() //缓存需要加临时td的信息
// 大于一行时再拆分避免循环
if (trList.length > 1) {
// 拆分后剩余高度
// 思路改变tr的结构 得到第几行开始删除删除的第一行添加rowspan: rowspan - 前面的tr的row,
// 何时加临时td开始分页的head的上一级判断最大的colspan记录最大colspan在td的index
// 加临时td开始分页的head的上一级判断最大的colspan记录最大colspan在td的index
// 在分页的第一行的index位置添加临时td
for (let r = 0; r < trList.length; r++) {
const tr = trList[r]
@ -1371,50 +1371,108 @@ export class Draw {
curPagePreHeight + rowMarginHeight + preTrHeight + trHeight >
height
) {
// 当前行存在跨行中断-暂时忽略分页
// 开始计算添加临时td
colInfoCache.forEach((item, key) => {
const mdRowIndex = parseInt(key.split('-')[1], 10) // 3
const mdColIndex = parseInt(key.split('-')[0], 10) // 0
const mdRowIndex = parseInt(key.split('-')[1], 10)
const mdColIndex = parseInt(key.split('-')[0], 10)
// 确保 mdRowIndex 和 mdColIndex 是有效的索引
if (!trList[mdRowIndex] || !trList[mdRowIndex].tdList[mdColIndex]) {
console.error(`Invalid index: mdRowIndex=${mdRowIndex}, mdColIndex=${mdColIndex}`)
if (
!trList[mdRowIndex] ||
!trList[mdRowIndex].tdList[mdColIndex]
) {
console.error(
`Invalid index: mdRowIndex=${mdRowIndex}, mdColIndex=${mdColIndex}`
)
return
}
// 更新 rowspan
// 计算要被分割的rowspan
const cell = trList[mdRowIndex].tdList[mdColIndex]
const newRowspan = cell.rowspan - (item.row - item.count)
if (!isNaN(newRowspan)) {
cell.rowspan = newRowspan
} else {
console.error(`Invalid rowspan calculation: ${cell.rowspan} - (${item.row} - ${item.count})`)
cell.rowspan = newRowspan
let initHeight = 0
let initRealHeight = 0
let initRealMinHeight = 0
for (let i = mdRowIndex; i < newRowspan; i++) {
if (trList[i]?.tdList[mdColIndex]?.height) {
const td = trList[i]?.tdList[mdColIndex]
if (td && td.height) {
initHeight += td.height
} else if (td && td.realHeight) {
initRealHeight += td.realHeight
} else if (td && td.realMinHeight) {
initRealMinHeight += td.realMinHeight
} else {
console.error('td.height is undefined')
}
}
}
// temp之后的数组元素向后移一个位置
for (let i = tr.tdList.length - 1; i >= item.col; i--) {
tr.tdList[i + 1] = tr.tdList[i]
}
const tempRow = item.row - item.count
tr.tdList[mdColIndex] = {
...cell,
id: getUUID(),
rowspan: item.row - item.count
rowspan: tempRow,
height: height - initHeight,
realHeight: height - initRealHeight,
realMinHeight: height - initRealMinHeight,
tempFlag: true,
parentTr: `${mdColIndex}-${mdRowIndex}`,
value: cell.value.map(item => ({ ...item, value: '' }))
}
cell.height = initHeight
cell.realHeight = initRealHeight
cell.realMinHeight = initRealMinHeight
this.tableParticle.computeRowColInfo(element)
})
// const rowColCount = tr.tdList.reduce(
// (pre, cur) => pre + cur.colspan,
// 0
// )
// if (element.colgroup?.length !== rowColCount) {
// deleteCount = 0
// }
break
} else {
deleteStart = r + 1
deleteCount = trList.length - deleteStart
preTrHeight += trHeight
// debugger
for (let i = 0; i < trList.length; i++) {
for (let j = trList[i]?.tdList.length - 1; j >= 0; j--) {
if (trList[i]?.tdList[j]?.tempFlag) {
const tempTd = trList[i].tdList[j]
if (tempTd.parentTr) {
const mdRowIndex = parseInt(
tempTd?.parentTr.split('-')[1],
10
)
const mdColIndex = parseInt(
tempTd?.parentTr.split('-')[0],
10
)
const cell = trList[mdRowIndex].tdList[mdColIndex]
cell.rowspan += trList[i]?.tdList[j].rowspan
let initHeight = 0
let initRealHeight = 0
let initRealMinHeight = 0
for (let i = mdRowIndex; i < tempTd.rowspan; i++) {
if (trList[i]?.tdList[mdColIndex]?.height) {
const td = trList[i]?.tdList[mdColIndex]
if (td && td.height) {
initHeight += td.height
} else if (td && td.realHeight) {
initRealHeight += td.realHeight
} else if (td && td.realMinHeight) {
initRealMinHeight += td.realMinHeight
} else {
console.error('td.height is undefined')
}
}
}
cell.height = initHeight
cell.realHeight = initRealHeight
cell.realMinHeight = initRealMinHeight
trList[i]?.tdList.splice(j, 1)
}
}
}
}
// 找到要分页的位置存入Map
tr.tdList.forEach((td, index) => {
if (td.rowspan > 1) {
colInfoCache.set(`${index}-${r}`, {
@ -1424,6 +1482,7 @@ export class Draw {
})
}
})
// 计算分页是否需要添加临时td
colInfoCache.forEach((item, index) => {
++item.count
if (item.count >= item.row) {

@ -29,4 +29,6 @@ export interface ITd {
mainHeight?: number // 内容 + 内边距高度
realHeight?: number // 真实高度(包含跨列)
realMinHeight?: number // 真实最小高度(包含跨列)
tempFlag?: boolean,
parentTr?: string
}

Loading…
Cancel
Save