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
96
97
98
99
100
101
102
103
104
105
106
|
# File 'lib/htot_conv/generator/xlsx_type4.rb', line 18
def output_to_worksheet(ws)
max_level = @data.max_level
max_value_length = @data.max_value_length
row_index = 0
((1..max_level).map {|l| @data.[l - 1] || nil }).concat(
HTOTConv::Util.pad_array(@data., max_value_length)
).each_with_index do |v, col_index|
ws.add_cell(row_index, col_index, v)
[:top, :bottom, :left, :right].each do |edge|
ws[row_index][col_index].change_border(edge, "thin")
end
end
row_index = row_index.succ
rowspan_cells = Array.new(max_level) { [] }
@data.to_tree.descendants.each do |node|
if node.leaf?
item = node.item
key_cell = Array.new(max_level, nil)
[node].concat(node.ancestors.to_a).each do |c_node|
key_cell[c_node.item.level - 1] = c_node.item.key if c_node.item
break if c_node.prev
end
value_cell = HTOTConv::Util.pad_array(item.value, max_value_length)
key_cell.concat(value_cell).each_with_index do |v, col_index|
ws.add_cell(row_index, col_index, v)
[:top, :bottom, :left, :right].each do |edge|
ws[row_index][col_index].change_border(edge, "thin")
end
end
node.ancestors.each_with_object([node]) do |c_node, descendants|
if (c_node.item && c_node.item.level)
edges = []
edges << :top if (descendants.any? { |v| v.prev })
edges << :bottom if (descendants.any? { |v| v.next })
edges.each do |edge|
ws[row_index][c_node.item.level - 1].change_border(edge, nil)
end
end
descendants.unshift(c_node)
end
(item.level..max_level).each do |level|
edges = []
edges << :left unless (level == item.level)
edges << :right unless (level == max_level)
edges.each do |edge|
ws[row_index][level - 1].change_border(edge, nil)
end
end
if [:colspan, :both].include?(@option[:integrate_cells])
if item.level < max_level
ws.merge_cells(row_index, item.level - 1, row_index, max_level - 1)
end
end
node.ancestors.each_with_object([node]) do |c_node, descendants|
rowspan_cells[c_node.item.level - 1] << [row_index, c_node.item.level - 1]
unless (descendants.any? { |v| v.next })
if [:rowspan, :both].include?(@option[:integrate_cells])
if rowspan_cells[c_node.item.level - 1].length > 1
ws.merge_cells(
rowspan_cells[c_node.item.level - 1].map(&:first).min,
rowspan_cells[c_node.item.level - 1].map(&:last).min,
rowspan_cells[c_node.item.level - 1].map(&:first).max,
rowspan_cells[c_node.item.level - 1].map(&:last).max,
)
end
end
rowspan_cells[c_node.item.level - 1].clear
end
descendants.unshift(c_node)
end
(max_level..(max_level + max_value_length - 1)).each do |col_index|
[:top, :bottom, :left, :right].each do |edge|
ws[row_index][col_index].change_border(edge, "thin")
end
end
row_index = row_index.succ
end
end
end
|