fix: get and set control property in table #323

pr675
Hufe921 2 years ago
parent 9ab9cb80f0
commit 17cd6ccd09

@ -419,16 +419,23 @@ export class Control {
payload: IGetControlValueOption payload: IGetControlValueOption
): IGetControlValueResult { ): IGetControlValueResult {
const { conceptId } = payload const { conceptId } = payload
const elementList = [
...this.draw.getHeaderElementList(),
...this.draw.getOriginalMainElementList(),
...this.draw.getFooterElementList()
]
const result: IGetControlValueResult = [] const result: IGetControlValueResult = []
const getValue = (elementList: IElement[]) => {
let i = 0 let i = 0
while (i < elementList.length) { while (i < elementList.length) {
const element = elementList[i] const element = elementList[i]
i++ i++
// 表格下钻处理
if (element.type === ElementType.TABLE) {
const trList = element.trList!
for (let r = 0; r < trList.length; r++) {
const tr = trList[r]
for (let d = 0; d < tr.tdList.length; d++) {
const td = tr.tdList[d]
getValue(td.value)
}
}
}
if (element?.control?.conceptId !== conceptId) continue if (element?.control?.conceptId !== conceptId) continue
const { type, code, valueSets } = element.control! const { type, code, valueSets } = element.control!
let j = i let j = i
@ -450,7 +457,10 @@ export class Control {
value: textControlValue || null, value: textControlValue || null,
innerText: textControlValue || null innerText: textControlValue || null
}) })
} else if (type === ControlType.SELECT || type === ControlType.CHECKBOX) { } else if (
type === ControlType.SELECT ||
type === ControlType.CHECKBOX
) {
const innerText = code const innerText = code
?.split(',') ?.split(',')
.map( .map(
@ -467,6 +477,13 @@ export class Control {
} }
i = j i = j
} }
}
const elementList = [
...this.draw.getHeaderElementList(),
...this.draw.getOriginalMainElementList(),
...this.draw.getFooterElementList()
]
getValue(elementList)
return result return result
} }
@ -575,16 +592,22 @@ export class Control {
const isReadonly = this.draw.isReadonly() const isReadonly = this.draw.isReadonly()
if (isReadonly) return if (isReadonly) return
const { conceptId, extension } = payload const { conceptId, extension } = payload
const data = [ const setExtension = (elementList: IElement[]) => {
this.draw.getHeaderElementList(),
this.draw.getOriginalMainElementList(),
this.draw.getFooterElementList()
]
for (const elementList of data) {
let i = 0 let i = 0
while (i < elementList.length) { while (i < elementList.length) {
const element = elementList[i] const element = elementList[i]
i++ i++
// 表格下钻处理
if (element.type === ElementType.TABLE) {
const trList = element.trList!
for (let r = 0; r < trList.length; r++) {
const tr = trList[r]
for (let d = 0; d < tr.tdList.length; d++) {
const td = tr.tdList[d]
setExtension(td.value)
}
}
}
if (element?.control?.conceptId !== conceptId) continue if (element?.control?.conceptId !== conceptId) continue
element.control.extension = extension element.control.extension = extension
// 修改后控件结束索引 // 修改后控件结束索引
@ -597,5 +620,13 @@ export class Control {
i = newEndIndex i = newEndIndex
} }
} }
const data = [
this.draw.getHeaderElementList(),
this.draw.getOriginalMainElementList(),
this.draw.getFooterElementList()
]
for (const elementList of data) {
setExtension(elementList)
}
} }
} }

Loading…
Cancel
Save