write_xlsx 0.90.0 → 0.97.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (135) hide show
  1. checksums.yaml +4 -4
  2. data/Changes +37 -0
  3. data/README.md +1 -1
  4. data/examples/a_simple.rb +1 -6
  5. data/examples/conditional_format.rb +73 -46
  6. data/examples/demo.rb +1 -7
  7. data/examples/hyperlink1.rb +4 -11
  8. data/lib/write_xlsx/chart.rb +81 -205
  9. data/lib/write_xlsx/chart/axis.rb +2 -2
  10. data/lib/write_xlsx/chart/caption.rb +3 -1
  11. data/lib/write_xlsx/chart/pie.rb +2 -0
  12. data/lib/write_xlsx/chart/series.rb +11 -7
  13. data/lib/write_xlsx/format.rb +15 -11
  14. data/lib/write_xlsx/package/conditional_format.rb +351 -38
  15. data/lib/write_xlsx/package/content_types.rb +10 -0
  16. data/lib/write_xlsx/package/custom.rb +125 -0
  17. data/lib/write_xlsx/package/packager.rb +26 -0
  18. data/lib/write_xlsx/package/styles.rb +53 -21
  19. data/lib/write_xlsx/package/table.rb +11 -4
  20. data/lib/write_xlsx/utility.rb +234 -34
  21. data/lib/write_xlsx/version.rb +1 -1
  22. data/lib/write_xlsx/workbook.rb +88 -1
  23. data/lib/write_xlsx/worksheet.rb +247 -23
  24. data/test/helper.rb +6 -1
  25. data/test/regression/_test_hyperlink31.rb +26 -0
  26. data/test/regression/images/zero_dpi.jpg +0 -0
  27. data/test/regression/test_chart_bar08.rb +3 -0
  28. data/test/regression/test_chart_bar11.rb +3 -0
  29. data/test/regression/test_chart_bar14.rb +3 -0
  30. data/test/regression/test_chart_chartarea05.rb +16 -17
  31. data/test/regression/test_chart_chartarea06.rb +49 -0
  32. data/test/regression/test_chart_data_labels25.rb +61 -0
  33. data/test/regression/test_chart_format26.rb +48 -0
  34. data/test/regression/test_chart_format27.rb +58 -0
  35. data/test/regression/test_chart_format28.rb +52 -0
  36. data/test/regression/test_chart_format29.rb +59 -0
  37. data/test/regression/test_chart_format30.rb +53 -0
  38. data/test/regression/test_chart_format31.rb +60 -0
  39. data/test/regression/test_chart_table03.rb +56 -0
  40. data/test/regression/test_cond_format14.rb +42 -0
  41. data/test/regression/test_cond_format15.rb +53 -0
  42. data/test/regression/test_cond_format16.rb +53 -0
  43. data/test/regression/test_cond_format17.rb +37 -0
  44. data/test/regression/test_cond_format18.rb +136 -0
  45. data/test/regression/test_date_1904_01.rb +1 -1
  46. data/test/regression/test_escapes04.rb +3 -0
  47. data/test/regression/test_escapes05.rb +3 -0
  48. data/test/regression/test_escapes07.rb +3 -0
  49. data/test/regression/test_escapes08.rb +3 -0
  50. data/test/regression/test_hyperlink01.rb +3 -0
  51. data/test/regression/test_hyperlink02.rb +3 -0
  52. data/test/regression/test_hyperlink03.rb +4 -0
  53. data/test/regression/test_hyperlink04.rb +3 -0
  54. data/test/regression/test_hyperlink05.rb +3 -0
  55. data/test/regression/test_hyperlink06.rb +3 -0
  56. data/test/regression/test_hyperlink07.rb +3 -0
  57. data/test/regression/test_hyperlink08.rb +3 -0
  58. data/test/regression/test_hyperlink09.rb +3 -0
  59. data/test/regression/test_hyperlink10.rb +3 -0
  60. data/test/regression/test_hyperlink11.rb +3 -0
  61. data/test/regression/test_hyperlink12.rb +3 -0
  62. data/test/regression/test_hyperlink13.rb +3 -0
  63. data/test/regression/test_hyperlink14.rb +3 -0
  64. data/test/regression/test_hyperlink15.rb +3 -0
  65. data/test/regression/test_hyperlink16.rb +3 -0
  66. data/test/regression/test_hyperlink17.rb +3 -0
  67. data/test/regression/test_hyperlink18.rb +3 -0
  68. data/test/regression/test_hyperlink20.rb +3 -0
  69. data/test/regression/test_hyperlink21.rb +3 -0
  70. data/test/regression/test_hyperlink22.rb +3 -0
  71. data/test/regression/test_hyperlink23.rb +3 -0
  72. data/test/regression/test_hyperlink24.rb +3 -0
  73. data/test/regression/test_hyperlink25.rb +3 -0
  74. data/test/regression/test_hyperlink26.rb +3 -0
  75. data/test/regression/test_hyperlink27.rb +3 -0
  76. data/test/regression/test_hyperlink28.rb +50 -0
  77. data/test/regression/test_hyperlink29.rb +27 -0
  78. data/test/regression/test_hyperlink30.rb +36 -0
  79. data/test/regression/test_image35.rb +26 -0
  80. data/test/regression/test_properties01.rb +1 -4
  81. data/test/regression/test_properties02.rb +1 -4
  82. data/test/regression/test_properties03.rb +26 -0
  83. data/test/regression/test_properties04.rb +61 -0
  84. data/test/regression/test_properties05.rb +30 -0
  85. data/test/regression/test_table03.rb +3 -0
  86. data/test/regression/test_table04.rb +3 -0
  87. data/test/regression/test_table05.rb +3 -0
  88. data/test/regression/test_table06.rb +3 -0
  89. data/test/regression/test_table20.rb +34 -0
  90. data/test/regression/test_table21.rb +36 -0
  91. data/test/regression/test_table22.rb +32 -0
  92. data/test/regression/xlsx_files/chart_chartarea05.xlsx +0 -0
  93. data/test/regression/xlsx_files/chart_chartarea06.xlsx +0 -0
  94. data/test/regression/xlsx_files/chart_data_labels25.xlsx +0 -0
  95. data/test/regression/xlsx_files/chart_format26.xlsx +0 -0
  96. data/test/regression/xlsx_files/chart_format27.xlsx +0 -0
  97. data/test/regression/xlsx_files/chart_format28.xlsx +0 -0
  98. data/test/regression/xlsx_files/chart_format29.xlsx +0 -0
  99. data/test/regression/xlsx_files/chart_format30.xlsx +0 -0
  100. data/test/regression/xlsx_files/chart_format31.xlsx +0 -0
  101. data/test/regression/xlsx_files/chart_table03.xlsx +0 -0
  102. data/test/regression/xlsx_files/cond_format14.xlsx +0 -0
  103. data/test/regression/xlsx_files/cond_format15.xlsx +0 -0
  104. data/test/regression/xlsx_files/cond_format16.xlsx +0 -0
  105. data/test/regression/xlsx_files/cond_format17.xlsx +0 -0
  106. data/test/regression/xlsx_files/cond_format18.xlsx +0 -0
  107. data/test/regression/xlsx_files/date_1904_01.xlsx +0 -0
  108. data/test/regression/xlsx_files/hyperlink28.xlsx +0 -0
  109. data/test/regression/xlsx_files/hyperlink29.xlsx +0 -0
  110. data/test/regression/xlsx_files/hyperlink30.xlsx +0 -0
  111. data/test/regression/xlsx_files/hyperlink31.xlsx +0 -0
  112. data/test/regression/xlsx_files/image35.xlsx +0 -0
  113. data/test/regression/xlsx_files/properties03.xlsx +0 -0
  114. data/test/regression/xlsx_files/properties04.xlsx +0 -0
  115. data/test/regression/xlsx_files/properties05.xlsx +0 -0
  116. data/test/regression/xlsx_files/table21.xlsx +0 -0
  117. data/test/regression/xlsx_files/table22.xlsx +0 -0
  118. data/test/workbook/test_write_workbook_view.rb +81 -0
  119. data/test/worksheet/test_cond_format_22.rb +266 -0
  120. data/test/worksheet/test_cond_format_23.rb +242 -0
  121. data/test/worksheet/test_cond_format_24.rb +303 -0
  122. data/test/worksheet/test_data_bar_01.rb +53 -0
  123. data/test/worksheet/test_data_bar_02.rb +79 -0
  124. data/test/worksheet/test_data_bar_03.rb +147 -0
  125. data/test/worksheet/test_data_bar_04.rb +145 -0
  126. data/test/worksheet/test_data_bar_05.rb +147 -0
  127. data/test/worksheet/test_data_bar_06.rb +145 -0
  128. data/test/worksheet/test_data_bar_07.rb +146 -0
  129. data/test/worksheet/test_data_bar_08.rb +54 -0
  130. data/test/worksheet/test_data_bar_09.rb +80 -0
  131. data/test/worksheet/test_data_bar_10.rb +165 -0
  132. data/test/worksheet/test_data_bar_11.rb +167 -0
  133. data/test/worksheet/test_data_bar_12.rb +104 -0
  134. data/test/worksheet/test_write_data_validation_02.rb +27 -0
  135. metadata +135 -2
@@ -0,0 +1,303 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+ require 'write_xlsx'
4
+ require 'stringio'
5
+
6
+ class TestCondFormat22 < Minitest::Test
7
+ def setup
8
+ @workbook = WriteXLSX.new(StringIO.new)
9
+ @worksheet = @workbook.add_worksheet('')
10
+ end
11
+
12
+ ###############################################################################
13
+ #
14
+ # Tests for Excel::Writer::XLSX::Worksheet methods.
15
+ #
16
+
17
+ ###############################################################################
18
+ #
19
+ # Test the _assemble_xml_file() method.
20
+ #
21
+ # Test conditional formats.
22
+ #
23
+ def test_conditional_formats
24
+ @worksheet.select
25
+
26
+ # Start test code.
27
+ @worksheet.write('A1', 1)
28
+ @worksheet.write('A2', 2)
29
+ @worksheet.write('A3', 3)
30
+ @worksheet.write('A4', 4)
31
+ @worksheet.write('A5', 5)
32
+ @worksheet.write('A6', 6)
33
+ @worksheet.write('A7', 7)
34
+ @worksheet.write('A8', 8)
35
+ @worksheet.write('A9', 9)
36
+
37
+ @worksheet.write('A12', 75)
38
+
39
+ @worksheet.conditional_formatting(
40
+ 'A1',
41
+ {
42
+ :type => 'icon_set',
43
+ :icon_style => '3_arrows',
44
+ :reverse_icons => 1
45
+ }
46
+ )
47
+
48
+ @worksheet.conditional_formatting(
49
+ 'A2',
50
+ {
51
+ :type => 'icon_set',
52
+ :icon_style => '3_flags',
53
+ :icons_only => 1
54
+ }
55
+ )
56
+
57
+ @worksheet.conditional_formatting(
58
+ 'A3',
59
+ {
60
+ :type => 'icon_set',
61
+ :icon_style => '3_traffic_lights_rimmed',
62
+ :icons_only => 1,
63
+ :reverse_icons => 1
64
+ }
65
+ )
66
+
67
+ @worksheet.conditional_formatting(
68
+ 'A4',
69
+ {
70
+ :type => 'icon_set',
71
+ :icon_style => '3_symbols_circled',
72
+ :icons => [
73
+ {:value => 80},
74
+ {:value => 20}
75
+ ]
76
+ }
77
+ )
78
+
79
+ @worksheet.conditional_formatting(
80
+ 'A5',
81
+ {
82
+ :type => 'icon_set',
83
+ :icon_style => '4_arrows',
84
+ :icons => [
85
+ {:criteria => '>'},
86
+ {:criteria => '>'},
87
+ {:criteria => '>'}
88
+ ]
89
+ }
90
+ )
91
+
92
+ @worksheet.conditional_formatting(
93
+ 'A6',
94
+ {
95
+ :type => 'icon_set',
96
+ :icon_style => '4_red_to_black',
97
+ :icons => [
98
+ {:criteria => '>=', :type => 'number', :value => 90},
99
+ {:criteria => '<', :type => 'percentile', :value => 50},
100
+ {:criteria => '<=', :type => 'percent', :value => 25}
101
+ ]
102
+ }
103
+ )
104
+
105
+ @worksheet.conditional_formatting(
106
+ 'A7',
107
+ {
108
+ :type => 'icon_set',
109
+ :icon_style => '4_traffic_lights',
110
+ :icons => [ {:value => '=$A$12'} ]
111
+ }
112
+ )
113
+
114
+ @worksheet.conditional_formatting(
115
+ 'A8',
116
+ {
117
+ :type => 'icon_set',
118
+ :icon_style => '5_arrows_gray',
119
+ :icons => [
120
+ {:type => 'formula', :value => '=$A$12'}
121
+ ]
122
+ }
123
+ )
124
+
125
+ @worksheet.conditional_formatting(
126
+ 'A9',
127
+ {
128
+ :type => 'icon_set',
129
+ :icon_style => '5_quarters',
130
+ :icons => [
131
+ {:type => 'percentile', :value => 70},
132
+ {:type => 'percentile', :value => 50},
133
+ {:type => 'percentile', :value => 30},
134
+ {:type => 'percentile', :value => 10},
135
+ {:type => 'percentile', :value => -1}
136
+ ],
137
+ :reverse_icons => 1
138
+ }
139
+ )
140
+
141
+ # End test code.
142
+
143
+ @worksheet.assemble_xml_file
144
+ result = got_to_array(@worksheet.instance_variable_get(:@writer).string)
145
+
146
+ expected = expected_to_array(expected_xml)
147
+ assert_equal(expected, result)
148
+ end
149
+
150
+ def expected_xml
151
+ <<EOS
152
+ <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
153
+ <worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships">
154
+ <dimension ref="A1:A12"/>
155
+ <sheetViews>
156
+ <sheetView tabSelected="1" workbookViewId="0"/>
157
+ </sheetViews>
158
+ <sheetFormatPr defaultRowHeight="15"/>
159
+ <sheetData>
160
+ <row r="1" spans="1:1">
161
+ <c r="A1">
162
+ <v>1</v>
163
+ </c>
164
+ </row>
165
+ <row r="2" spans="1:1">
166
+ <c r="A2">
167
+ <v>2</v>
168
+ </c>
169
+ </row>
170
+ <row r="3" spans="1:1">
171
+ <c r="A3">
172
+ <v>3</v>
173
+ </c>
174
+ </row>
175
+ <row r="4" spans="1:1">
176
+ <c r="A4">
177
+ <v>4</v>
178
+ </c>
179
+ </row>
180
+ <row r="5" spans="1:1">
181
+ <c r="A5">
182
+ <v>5</v>
183
+ </c>
184
+ </row>
185
+ <row r="6" spans="1:1">
186
+ <c r="A6">
187
+ <v>6</v>
188
+ </c>
189
+ </row>
190
+ <row r="7" spans="1:1">
191
+ <c r="A7">
192
+ <v>7</v>
193
+ </c>
194
+ </row>
195
+ <row r="8" spans="1:1">
196
+ <c r="A8">
197
+ <v>8</v>
198
+ </c>
199
+ </row>
200
+ <row r="9" spans="1:1">
201
+ <c r="A9">
202
+ <v>9</v>
203
+ </c>
204
+ </row>
205
+ <row r="12" spans="1:1">
206
+ <c r="A12">
207
+ <v>75</v>
208
+ </c>
209
+ </row>
210
+ </sheetData>
211
+ <conditionalFormatting sqref="A1">
212
+ <cfRule type="iconSet" priority="1">
213
+ <iconSet iconSet="3Arrows" reverse="1">
214
+ <cfvo type="percent" val="0"/>
215
+ <cfvo type="percent" val="33"/>
216
+ <cfvo type="percent" val="67"/>
217
+ </iconSet>
218
+ </cfRule>
219
+ </conditionalFormatting>
220
+ <conditionalFormatting sqref="A2">
221
+ <cfRule type="iconSet" priority="2">
222
+ <iconSet iconSet="3Flags" showValue="0">
223
+ <cfvo type="percent" val="0"/>
224
+ <cfvo type="percent" val="33"/>
225
+ <cfvo type="percent" val="67"/>
226
+ </iconSet>
227
+ </cfRule>
228
+ </conditionalFormatting>
229
+ <conditionalFormatting sqref="A3">
230
+ <cfRule type="iconSet" priority="3">
231
+ <iconSet iconSet="3TrafficLights2" showValue="0" reverse="1">
232
+ <cfvo type="percent" val="0"/>
233
+ <cfvo type="percent" val="33"/>
234
+ <cfvo type="percent" val="67"/>
235
+ </iconSet>
236
+ </cfRule>
237
+ </conditionalFormatting>
238
+ <conditionalFormatting sqref="A4">
239
+ <cfRule type="iconSet" priority="4">
240
+ <iconSet iconSet="3Symbols">
241
+ <cfvo type="percent" val="0"/>
242
+ <cfvo type="percent" val="20"/>
243
+ <cfvo type="percent" val="80"/>
244
+ </iconSet>
245
+ </cfRule>
246
+ </conditionalFormatting>
247
+ <conditionalFormatting sqref="A5">
248
+ <cfRule type="iconSet" priority="5">
249
+ <iconSet iconSet="4Arrows">
250
+ <cfvo type="percent" val="0"/>
251
+ <cfvo type="percent" val="25" gte="0"/>
252
+ <cfvo type="percent" val="50" gte="0"/>
253
+ <cfvo type="percent" val="75" gte="0"/>
254
+ </iconSet>
255
+ </cfRule>
256
+ </conditionalFormatting>
257
+ <conditionalFormatting sqref="A6">
258
+ <cfRule type="iconSet" priority="6">
259
+ <iconSet iconSet="4RedToBlack">
260
+ <cfvo type="percent" val="0"/>
261
+ <cfvo type="percent" val="25"/>
262
+ <cfvo type="percentile" val="50"/>
263
+ <cfvo type="num" val="90"/>
264
+ </iconSet>
265
+ </cfRule>
266
+ </conditionalFormatting>
267
+ <conditionalFormatting sqref="A7">
268
+ <cfRule type="iconSet" priority="7">
269
+ <iconSet iconSet="4TrafficLights">
270
+ <cfvo type="percent" val="0"/>
271
+ <cfvo type="percent" val="25"/>
272
+ <cfvo type="percent" val="50"/>
273
+ <cfvo type="percent" val="$A$12"/>
274
+ </iconSet>
275
+ </cfRule>
276
+ </conditionalFormatting>
277
+ <conditionalFormatting sqref="A8">
278
+ <cfRule type="iconSet" priority="8">
279
+ <iconSet iconSet="5ArrowsGray">
280
+ <cfvo type="percent" val="0"/>
281
+ <cfvo type="percent" val="20"/>
282
+ <cfvo type="percent" val="40"/>
283
+ <cfvo type="percent" val="60"/>
284
+ <cfvo type="formula" val="$A$12"/>
285
+ </iconSet>
286
+ </cfRule>
287
+ </conditionalFormatting>
288
+ <conditionalFormatting sqref="A9">
289
+ <cfRule type="iconSet" priority="9">
290
+ <iconSet iconSet="5Quarters" reverse="1">
291
+ <cfvo type="percent" val="0"/>
292
+ <cfvo type="percentile" val="10"/>
293
+ <cfvo type="percentile" val="30"/>
294
+ <cfvo type="percentile" val="50"/>
295
+ <cfvo type="percentile" val="70"/>
296
+ </iconSet>
297
+ </cfRule>
298
+ </conditionalFormatting>
299
+ <pageMargins left="0.7" right="0.7" top="0.75" bottom="0.75" header="0.3" footer="0.3"/>
300
+ </worksheet>
301
+ EOS
302
+ end
303
+ end
@@ -0,0 +1,53 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+
4
+ class TestWorksheetDataBar01 < Minitest::Test
5
+ def setup
6
+ @workbook = WriteXLSX.new(StringIO.new)
7
+ @worksheet = @workbook.add_worksheet('')
8
+ end
9
+
10
+ ###############################################################################
11
+ #
12
+ # Tests for WriteXLSX::Worksheet methods.
13
+ #
14
+ #
15
+ def test_data_bar_01
16
+ @worksheet.select
17
+
18
+ @worksheet.conditional_formatting(
19
+ 'A1',
20
+ :type => 'data_bar'
21
+ )
22
+
23
+ @worksheet.assemble_xml_file
24
+ result = got_to_array(@worksheet.instance_variable_get(:@writer).string)
25
+
26
+ expected = expected_to_array(expected_xml)
27
+ assert_equal(expected, result)
28
+ end
29
+
30
+ def expected_xml
31
+ <<EOS
32
+ <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
33
+ <worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships">
34
+ <dimension ref="A1"/>
35
+ <sheetViews>
36
+ <sheetView tabSelected="1" workbookViewId="0"/>
37
+ </sheetViews>
38
+ <sheetFormatPr defaultRowHeight="15"/>
39
+ <sheetData/>
40
+ <conditionalFormatting sqref="A1">
41
+ <cfRule type="dataBar" priority="1">
42
+ <dataBar>
43
+ <cfvo type="min" val="0"/>
44
+ <cfvo type="max" val="0"/>
45
+ <color rgb="FF638EC6"/>
46
+ </dataBar>
47
+ </cfRule>
48
+ </conditionalFormatting>
49
+ <pageMargins left="0.7" right="0.7" top="0.75" bottom="0.75" header="0.3" footer="0.3"/>
50
+ </worksheet>
51
+ EOS
52
+ end
53
+ end
@@ -0,0 +1,79 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+
4
+ class TestWorksheetDataBar02 < Minitest::Test
5
+ def setup
6
+ @workbook = WriteXLSX.new(StringIO.new)
7
+ @worksheet = @workbook.add_worksheet('')
8
+ end
9
+
10
+ ###############################################################################
11
+ #
12
+ # Tests for WriteXLSX::Worksheet methods.
13
+ #
14
+ #
15
+ def test_data_bar_02
16
+ @worksheet.select
17
+ @worksheet.instance_variable_set(:@index, 0)
18
+
19
+ @worksheet.conditional_formatting(
20
+ 'A1',
21
+ :type => 'data_bar',
22
+ :data_bar_2010 => 1
23
+ )
24
+
25
+ @worksheet.assemble_xml_file
26
+ result = got_to_array(@worksheet.instance_variable_get(:@writer).string)
27
+
28
+ expected = expected_to_array(expected_xml)
29
+ assert_equal(expected, result)
30
+ end
31
+
32
+ def expected_xml
33
+ <<EOS
34
+ <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
35
+ <worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:x14ac="http://schemas.microsoft.com/office/spreadsheetml/2009/9/ac" mc:Ignorable="x14ac">
36
+ <dimension ref="A1"/>
37
+ <sheetViews>
38
+ <sheetView tabSelected="1" workbookViewId="0"/>
39
+ </sheetViews>
40
+ <sheetFormatPr defaultRowHeight="15" x14ac:dyDescent="0.25"/>
41
+ <sheetData/>
42
+ <conditionalFormatting sqref="A1">
43
+ <cfRule type="dataBar" priority="1">
44
+ <dataBar>
45
+ <cfvo type="min"/>
46
+ <cfvo type="max"/>
47
+ <color rgb="FF638EC6"/>
48
+ </dataBar>
49
+ <extLst>
50
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
51
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000001}</x14:id>
52
+ </ext>
53
+ </extLst>
54
+ </cfRule>
55
+ </conditionalFormatting>
56
+ <pageMargins left="0.7" right="0.7" top="0.75" bottom="0.75" header="0.3" footer="0.3"/>
57
+ <extLst>
58
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{78C0D931-6437-407d-A8EE-F0AAD7539E65}">
59
+ <x14:conditionalFormattings>
60
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
61
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000001}">
62
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
63
+ <x14:cfvo type="autoMin"/>
64
+ <x14:cfvo type="autoMax"/>
65
+ <x14:borderColor rgb="FF638EC6"/>
66
+ <x14:negativeFillColor rgb="FFFF0000"/>
67
+ <x14:negativeBorderColor rgb="FFFF0000"/>
68
+ <x14:axisColor rgb="FF000000"/>
69
+ </x14:dataBar>
70
+ </x14:cfRule>
71
+ <xm:sqref>A1</xm:sqref>
72
+ </x14:conditionalFormatting>
73
+ </x14:conditionalFormattings>
74
+ </ext>
75
+ </extLst>
76
+ </worksheet>
77
+ EOS
78
+ end
79
+ end
@@ -0,0 +1,147 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+
4
+ class TestWorksheetDataBar03 < Minitest::Test
5
+ def setup
6
+ @workbook = WriteXLSX.new(StringIO.new)
7
+ @worksheet = @workbook.add_worksheet('')
8
+ end
9
+
10
+ ###############################################################################
11
+ #
12
+ # Tests for WriteXLSX::Worksheet methods.
13
+ #
14
+ #
15
+ def test_data_bar_03
16
+ @worksheet.select
17
+ @worksheet.instance_variable_set(:@index, 0)
18
+
19
+ @worksheet.conditional_formatting(
20
+ 'A1',
21
+ :type => 'data_bar',
22
+ :data_bar_2010 => 1
23
+ )
24
+
25
+ @worksheet.conditional_formatting(
26
+ 'A2:B2',
27
+ :type => 'data_bar',
28
+ :bar_color => '#63C384',
29
+ :data_bar_2010 => 1
30
+ )
31
+
32
+ @worksheet.conditional_formatting(
33
+ 'A3:C3',
34
+ :type => 'data_bar',
35
+ :bar_color => '#FF555A',
36
+ :data_bar_2010 => 1
37
+ )
38
+
39
+ @worksheet.assemble_xml_file
40
+ result = got_to_array(@worksheet.instance_variable_get(:@writer).string)
41
+
42
+ expected = expected_to_array(expected_xml)
43
+ assert_equal(expected, result)
44
+ end
45
+
46
+ def expected_xml
47
+ <<EOS
48
+ <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
49
+ <worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:x14ac="http://schemas.microsoft.com/office/spreadsheetml/2009/9/ac" mc:Ignorable="x14ac">
50
+ <dimension ref="A1"/>
51
+ <sheetViews>
52
+ <sheetView tabSelected="1" workbookViewId="0"/>
53
+ </sheetViews>
54
+ <sheetFormatPr defaultRowHeight="15" x14ac:dyDescent="0.25"/>
55
+ <sheetData/>
56
+ <conditionalFormatting sqref="A1">
57
+ <cfRule type="dataBar" priority="1">
58
+ <dataBar>
59
+ <cfvo type="min"/>
60
+ <cfvo type="max"/>
61
+ <color rgb="FF638EC6"/>
62
+ </dataBar>
63
+ <extLst>
64
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
65
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000001}</x14:id>
66
+ </ext>
67
+ </extLst>
68
+ </cfRule>
69
+ </conditionalFormatting>
70
+ <conditionalFormatting sqref="A2:B2">
71
+ <cfRule type="dataBar" priority="2">
72
+ <dataBar>
73
+ <cfvo type="min"/>
74
+ <cfvo type="max"/>
75
+ <color rgb="FF63C384"/>
76
+ </dataBar>
77
+ <extLst>
78
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
79
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000002}</x14:id>
80
+ </ext>
81
+ </extLst>
82
+ </cfRule>
83
+ </conditionalFormatting>
84
+ <conditionalFormatting sqref="A3:C3">
85
+ <cfRule type="dataBar" priority="3">
86
+ <dataBar>
87
+ <cfvo type="min"/>
88
+ <cfvo type="max"/>
89
+ <color rgb="FFFF555A"/>
90
+ </dataBar>
91
+ <extLst>
92
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
93
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000003}</x14:id>
94
+ </ext>
95
+ </extLst>
96
+ </cfRule>
97
+ </conditionalFormatting>
98
+ <pageMargins left="0.7" right="0.7" top="0.75" bottom="0.75" header="0.3" footer="0.3"/>
99
+ <extLst>
100
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{78C0D931-6437-407d-A8EE-F0AAD7539E65}">
101
+ <x14:conditionalFormattings>
102
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
103
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000001}">
104
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
105
+ <x14:cfvo type="autoMin"/>
106
+ <x14:cfvo type="autoMax"/>
107
+ <x14:borderColor rgb="FF638EC6"/>
108
+ <x14:negativeFillColor rgb="FFFF0000"/>
109
+ <x14:negativeBorderColor rgb="FFFF0000"/>
110
+ <x14:axisColor rgb="FF000000"/>
111
+ </x14:dataBar>
112
+ </x14:cfRule>
113
+ <xm:sqref>A1</xm:sqref>
114
+ </x14:conditionalFormatting>
115
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
116
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000002}">
117
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
118
+ <x14:cfvo type="autoMin"/>
119
+ <x14:cfvo type="autoMax"/>
120
+ <x14:borderColor rgb="FF63C384"/>
121
+ <x14:negativeFillColor rgb="FFFF0000"/>
122
+ <x14:negativeBorderColor rgb="FFFF0000"/>
123
+ <x14:axisColor rgb="FF000000"/>
124
+ </x14:dataBar>
125
+ </x14:cfRule>
126
+ <xm:sqref>A2:B2</xm:sqref>
127
+ </x14:conditionalFormatting>
128
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
129
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000003}">
130
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
131
+ <x14:cfvo type="autoMin"/>
132
+ <x14:cfvo type="autoMax"/>
133
+ <x14:borderColor rgb="FFFF555A"/>
134
+ <x14:negativeFillColor rgb="FFFF0000"/>
135
+ <x14:negativeBorderColor rgb="FFFF0000"/>
136
+ <x14:axisColor rgb="FF000000"/>
137
+ </x14:dataBar>
138
+ </x14:cfRule>
139
+ <xm:sqref>A3:C3</xm:sqref>
140
+ </x14:conditionalFormatting>
141
+ </x14:conditionalFormattings>
142
+ </ext>
143
+ </extLst>
144
+ </worksheet>
145
+ EOS
146
+ end
147
+ end