Commit d24a60ff by liyijie

fix: 解决each_method的逻辑错误

parent 6b0916d9
...@@ -65,7 +65,7 @@ module TalltyImportExport ...@@ -65,7 +65,7 @@ module TalltyImportExport
end end
end end
def export_workbook workbook, records def export_workbook workbook, association_records
# excel导出样式 # excel导出样式
alignment = { vertical: :center, horizontal: :center } alignment = { vertical: :center, horizontal: :center }
border = { color: '969696', style: :thin } border = { color: '969696', style: :thin }
...@@ -89,25 +89,29 @@ module TalltyImportExport ...@@ -89,25 +89,29 @@ module TalltyImportExport
merge_column_hash = {} merge_column_hash = {}
first_content_row_index = respond_to?(:first_header) ? 2 : 1 first_content_row_index = respond_to?(:first_header) ? 2 : 1
each_method = @each_method || :each index = 0
records.try_method(each_method).with_index do |record, index| association_records.each do |association_record|
row = [] row = []
headers.each_with_index do |header, col_index| headers.each_with_index do |header, col_index|
_data = handle_data(record, header, index) records = @each_method.present? ? association_record.try_method(@each_method) : [association_record]
if header[:merge].present? && last_row.present? && _data == last_row[col_index] records.each do |record|
# 这里使用二维数组,每个数组里都是列内容相同的各行 index += 1
merge_column_hash[col_index] ||= [] _data = handle_data(record, header, index)
if merge_column_hash[col_index].last&.last == index + first_content_row_index - 1 if header[:merge].present? && last_row.present? && _data == last_row[col_index]
# 说明内容和上面的是延续的,继续加入之前的数组 # 这里使用二维数组,每个数组里都是列内容相同的各行
merge_column_hash[col_index].last << index + first_content_row_index merge_column_hash[col_index] ||= []
else if merge_column_hash[col_index].last&.last == index + first_content_row_index - 1
merge_column_hash[col_index] << [index + first_content_row_index - 1, index + first_content_row_index] # 说明内容和上面的是延续的,继续加入之前的数组
merge_column_hash[col_index].last << index + first_content_row_index
else
merge_column_hash[col_index] << [index + first_content_row_index - 1, index + first_content_row_index]
end
end end
row.push(_data)
end end
row.push(_data) sheet.add_row row, style: title3, height: @row_height, types: headers.map{|header| header[:format]&.to_sym}
last_row = row
end end
sheet.add_row row, style: title3, height: @row_height, types: headers.map{|header| header[:format]&.to_sym}
last_row = row
end end
# 需要根据column进行多行的内容合并 # 需要根据column进行多行的内容合并
if merge_column_hash.present? if merge_column_hash.present?
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment