write_xlsx 0.90.0 → 0.97.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
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,54 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+
4
+ class TestWorksheetDataBar08 < 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_08
16
+ @worksheet.select
17
+
18
+ @worksheet.conditional_formatting(
19
+ 'A1',
20
+ :type => 'data_bar',
21
+ :bar_only => 1
22
+ )
23
+
24
+ @worksheet.assemble_xml_file
25
+ result = got_to_array(@worksheet.instance_variable_get(:@writer).string)
26
+
27
+ expected = expected_to_array(expected_xml)
28
+ assert_equal(expected, result)
29
+ end
30
+
31
+ def expected_xml
32
+ <<EOS
33
+ <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
34
+ <worksheet xmlns="http://schemas.openxmlformats.org/spreadsheetml/2006/main" xmlns:r="http://schemas.openxmlformats.org/officeDocument/2006/relationships">
35
+ <dimension ref="A1"/>
36
+ <sheetViews>
37
+ <sheetView tabSelected="1" workbookViewId="0"/>
38
+ </sheetViews>
39
+ <sheetFormatPr defaultRowHeight="15"/>
40
+ <sheetData/>
41
+ <conditionalFormatting sqref="A1">
42
+ <cfRule type="dataBar" priority="1">
43
+ <dataBar showValue="0">
44
+ <cfvo type="min" val="0"/>
45
+ <cfvo type="max" val="0"/>
46
+ <color rgb="FF638EC6"/>
47
+ </dataBar>
48
+ </cfRule>
49
+ </conditionalFormatting>
50
+ <pageMargins left="0.7" right="0.7" top="0.75" bottom="0.75" header="0.3" footer="0.3"/>
51
+ </worksheet>
52
+ EOS
53
+ end
54
+ end
@@ -0,0 +1,80 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+
4
+ class TestWorksheetDataBar09 < 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_09
16
+ @worksheet.select
17
+ @worksheet.instance_variable_set(:@index, 0)
18
+
19
+ @worksheet.conditional_formatting(
20
+ 'A1',
21
+ :type => 'data_bar',
22
+ :bar_only => 1,
23
+ :data_bar_2010 => 1
24
+ )
25
+
26
+ @worksheet.assemble_xml_file
27
+ result = got_to_array(@worksheet.instance_variable_get(:@writer).string)
28
+
29
+ expected = expected_to_array(expected_xml)
30
+ assert_equal(expected, result)
31
+ end
32
+
33
+ def expected_xml
34
+ <<EOS
35
+ <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
36
+ <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">
37
+ <dimension ref="A1"/>
38
+ <sheetViews>
39
+ <sheetView tabSelected="1" workbookViewId="0"/>
40
+ </sheetViews>
41
+ <sheetFormatPr defaultRowHeight="15" x14ac:dyDescent="0.25"/>
42
+ <sheetData/>
43
+ <conditionalFormatting sqref="A1">
44
+ <cfRule type="dataBar" priority="1">
45
+ <dataBar showValue="0">
46
+ <cfvo type="min"/>
47
+ <cfvo type="max"/>
48
+ <color rgb="FF638EC6"/>
49
+ </dataBar>
50
+ <extLst>
51
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
52
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000001}</x14:id>
53
+ </ext>
54
+ </extLst>
55
+ </cfRule>
56
+ </conditionalFormatting>
57
+ <pageMargins left="0.7" right="0.7" top="0.75" bottom="0.75" header="0.3" footer="0.3"/>
58
+ <extLst>
59
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{78C0D931-6437-407d-A8EE-F0AAD7539E65}">
60
+ <x14:conditionalFormattings>
61
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
62
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000001}">
63
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
64
+ <x14:cfvo type="autoMin"/>
65
+ <x14:cfvo type="autoMax"/>
66
+ <x14:borderColor rgb="FF638EC6"/>
67
+ <x14:negativeFillColor rgb="FFFF0000"/>
68
+ <x14:negativeBorderColor rgb="FFFF0000"/>
69
+ <x14:axisColor rgb="FF000000"/>
70
+ </x14:dataBar>
71
+ </x14:cfRule>
72
+ <xm:sqref>A1</xm:sqref>
73
+ </x14:conditionalFormatting>
74
+ </x14:conditionalFormattings>
75
+ </ext>
76
+ </extLst>
77
+ </worksheet>
78
+ EOS
79
+ end
80
+ end
@@ -0,0 +1,165 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+
4
+ class TestWorksheetDataBar10 < 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_10
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
+ :min_type => 'min',
24
+ :max_type => 'max'
25
+ )
26
+
27
+ @worksheet.conditional_formatting(
28
+ 'A2:B2',
29
+ :type => 'data_bar',
30
+ :bar_color => '#63C384',
31
+ :data_bar_2010 => 1,
32
+ :min_type => 'num',
33
+ :max_type => 'num',
34
+ :min_value => 0,
35
+ :max_value => 0
36
+ )
37
+
38
+ @worksheet.conditional_formatting(
39
+ 'A3:C3',
40
+ :type => 'data_bar',
41
+ :bar_color => '#FF555A',
42
+ :data_bar_2010 => 1,
43
+ :min_type => 'percent',
44
+ :max_type => 'percent',
45
+ :min_value => 0,
46
+ :max_value => 100
47
+ )
48
+
49
+ @worksheet.assemble_xml_file
50
+ result = got_to_array(@worksheet.instance_variable_get(:@writer).string)
51
+
52
+ expected = expected_to_array(expected_xml)
53
+ assert_equal(expected, result)
54
+ end
55
+
56
+ def expected_xml
57
+ <<EOS
58
+ <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
59
+ <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">
60
+ <dimension ref="A1"/>
61
+ <sheetViews>
62
+ <sheetView tabSelected="1" workbookViewId="0"/>
63
+ </sheetViews>
64
+ <sheetFormatPr defaultRowHeight="15" x14ac:dyDescent="0.25"/>
65
+ <sheetData/>
66
+ <conditionalFormatting sqref="A1">
67
+ <cfRule type="dataBar" priority="1">
68
+ <dataBar>
69
+ <cfvo type="min"/>
70
+ <cfvo type="max"/>
71
+ <color rgb="FF638EC6"/>
72
+ </dataBar>
73
+ <extLst>
74
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
75
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000001}</x14:id>
76
+ </ext>
77
+ </extLst>
78
+ </cfRule>
79
+ </conditionalFormatting>
80
+ <conditionalFormatting sqref="A2:B2">
81
+ <cfRule type="dataBar" priority="2">
82
+ <dataBar>
83
+ <cfvo type="num" val="0"/>
84
+ <cfvo type="num" val="0"/>
85
+ <color rgb="FF63C384"/>
86
+ </dataBar>
87
+ <extLst>
88
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
89
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000002}</x14:id>
90
+ </ext>
91
+ </extLst>
92
+ </cfRule>
93
+ </conditionalFormatting>
94
+ <conditionalFormatting sqref="A3:C3">
95
+ <cfRule type="dataBar" priority="3">
96
+ <dataBar>
97
+ <cfvo type="percent" val="0"/>
98
+ <cfvo type="percent" val="100"/>
99
+ <color rgb="FFFF555A"/>
100
+ </dataBar>
101
+ <extLst>
102
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
103
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000003}</x14:id>
104
+ </ext>
105
+ </extLst>
106
+ </cfRule>
107
+ </conditionalFormatting>
108
+ <pageMargins left="0.7" right="0.7" top="0.75" bottom="0.75" header="0.3" footer="0.3"/>
109
+ <extLst>
110
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{78C0D931-6437-407d-A8EE-F0AAD7539E65}">
111
+ <x14:conditionalFormattings>
112
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
113
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000001}">
114
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
115
+ <x14:cfvo type="min"/>
116
+ <x14:cfvo type="max"/>
117
+ <x14:borderColor rgb="FF638EC6"/>
118
+ <x14:negativeFillColor rgb="FFFF0000"/>
119
+ <x14:negativeBorderColor rgb="FFFF0000"/>
120
+ <x14:axisColor rgb="FF000000"/>
121
+ </x14:dataBar>
122
+ </x14:cfRule>
123
+ <xm:sqref>A1</xm:sqref>
124
+ </x14:conditionalFormatting>
125
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
126
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000002}">
127
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
128
+ <x14:cfvo type="num">
129
+ <xm:f>0</xm:f>
130
+ </x14:cfvo>
131
+ <x14:cfvo type="num">
132
+ <xm:f>0</xm:f>
133
+ </x14:cfvo>
134
+ <x14:borderColor rgb="FF63C384"/>
135
+ <x14:negativeFillColor rgb="FFFF0000"/>
136
+ <x14:negativeBorderColor rgb="FFFF0000"/>
137
+ <x14:axisColor rgb="FF000000"/>
138
+ </x14:dataBar>
139
+ </x14:cfRule>
140
+ <xm:sqref>A2:B2</xm:sqref>
141
+ </x14:conditionalFormatting>
142
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
143
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000003}">
144
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
145
+ <x14:cfvo type="percent">
146
+ <xm:f>0</xm:f>
147
+ </x14:cfvo>
148
+ <x14:cfvo type="percent">
149
+ <xm:f>100</xm:f>
150
+ </x14:cfvo>
151
+ <x14:borderColor rgb="FFFF555A"/>
152
+ <x14:negativeFillColor rgb="FFFF0000"/>
153
+ <x14:negativeBorderColor rgb="FFFF0000"/>
154
+ <x14:axisColor rgb="FF000000"/>
155
+ </x14:dataBar>
156
+ </x14:cfRule>
157
+ <xm:sqref>A3:C3</xm:sqref>
158
+ </x14:conditionalFormatting>
159
+ </x14:conditionalFormattings>
160
+ </ext>
161
+ </extLst>
162
+ </worksheet>
163
+ EOS
164
+ end
165
+ end
@@ -0,0 +1,167 @@
1
+ # -*- coding: utf-8 -*-
2
+ require 'helper'
3
+
4
+ class TestWorksheetDataBar11 < 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_11
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
+ :min_type => 'formula',
24
+ :min_value => '=$B$1'
25
+ )
26
+
27
+ @worksheet.conditional_formatting(
28
+ 'A2:B2',
29
+ :type => 'data_bar',
30
+ :bar_color => '#63C384',
31
+ :data_bar_2010 => 1,
32
+ :min_type => 'formula',
33
+ :max_type => 'formula',
34
+ :min_value => '$B$1',
35
+ :max_value => '$C$1'
36
+ )
37
+
38
+ @worksheet.conditional_formatting(
39
+ 'A3:C3',
40
+ :type => 'data_bar',
41
+ :bar_color => '#FF555A',
42
+ :data_bar_2010 => 1,
43
+ :min_type => 'percentile',
44
+ :max_type => 'percentile',
45
+ :min_value => 10,
46
+ :max_value => 90
47
+ )
48
+
49
+ @worksheet.assemble_xml_file
50
+ result = got_to_array(@worksheet.instance_variable_get(:@writer).string)
51
+
52
+ expected = expected_to_array(expected_xml)
53
+ assert_equal(expected, result)
54
+ end
55
+
56
+ def expected_xml
57
+ <<EOS
58
+ <?xml version="1.0" encoding="UTF-8" standalone="yes"?>
59
+ <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">
60
+ <dimension ref="A1"/>
61
+ <sheetViews>
62
+ <sheetView tabSelected="1" workbookViewId="0"/>
63
+ </sheetViews>
64
+ <sheetFormatPr defaultRowHeight="15" x14ac:dyDescent="0.25"/>
65
+ <sheetData/>
66
+ <conditionalFormatting sqref="A1">
67
+ <cfRule type="dataBar" priority="1">
68
+ <dataBar>
69
+ <cfvo type="formula" val="$B$1"/>
70
+ <cfvo type="max"/>
71
+ <color rgb="FF638EC6"/>
72
+ </dataBar>
73
+ <extLst>
74
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
75
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000001}</x14:id>
76
+ </ext>
77
+ </extLst>
78
+ </cfRule>
79
+ </conditionalFormatting>
80
+ <conditionalFormatting sqref="A2:B2">
81
+ <cfRule type="dataBar" priority="2">
82
+ <dataBar>
83
+ <cfvo type="formula" val="$B$1"/>
84
+ <cfvo type="formula" val="$C$1"/>
85
+ <color rgb="FF63C384"/>
86
+ </dataBar>
87
+ <extLst>
88
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
89
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000002}</x14:id>
90
+ </ext>
91
+ </extLst>
92
+ </cfRule>
93
+ </conditionalFormatting>
94
+ <conditionalFormatting sqref="A3:C3">
95
+ <cfRule type="dataBar" priority="3">
96
+ <dataBar>
97
+ <cfvo type="percentile" val="10"/>
98
+ <cfvo type="percentile" val="90"/>
99
+ <color rgb="FFFF555A"/>
100
+ </dataBar>
101
+ <extLst>
102
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{B025F937-C7B1-47D3-B67F-A62EFF666E3E}">
103
+ <x14:id>{DA7ABA51-AAAA-BBBB-0001-000000000003}</x14:id>
104
+ </ext>
105
+ </extLst>
106
+ </cfRule>
107
+ </conditionalFormatting>
108
+ <pageMargins left="0.7" right="0.7" top="0.75" bottom="0.75" header="0.3" footer="0.3"/>
109
+ <extLst>
110
+ <ext xmlns:x14="http://schemas.microsoft.com/office/spreadsheetml/2009/9/main" uri="{78C0D931-6437-407d-A8EE-F0AAD7539E65}">
111
+ <x14:conditionalFormattings>
112
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
113
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000001}">
114
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
115
+ <x14:cfvo type="formula">
116
+ <xm:f>$B$1</xm:f>
117
+ </x14:cfvo>
118
+ <x14:cfvo type="autoMax"/>
119
+ <x14:borderColor rgb="FF638EC6"/>
120
+ <x14:negativeFillColor rgb="FFFF0000"/>
121
+ <x14:negativeBorderColor rgb="FFFF0000"/>
122
+ <x14:axisColor rgb="FF000000"/>
123
+ </x14:dataBar>
124
+ </x14:cfRule>
125
+ <xm:sqref>A1</xm:sqref>
126
+ </x14:conditionalFormatting>
127
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
128
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000002}">
129
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
130
+ <x14:cfvo type="formula">
131
+ <xm:f>$B$1</xm:f>
132
+ </x14:cfvo>
133
+ <x14:cfvo type="formula">
134
+ <xm:f>$C$1</xm:f>
135
+ </x14:cfvo>
136
+ <x14:borderColor rgb="FF63C384"/>
137
+ <x14:negativeFillColor rgb="FFFF0000"/>
138
+ <x14:negativeBorderColor rgb="FFFF0000"/>
139
+ <x14:axisColor rgb="FF000000"/>
140
+ </x14:dataBar>
141
+ </x14:cfRule>
142
+ <xm:sqref>A2:B2</xm:sqref>
143
+ </x14:conditionalFormatting>
144
+ <x14:conditionalFormatting xmlns:xm="http://schemas.microsoft.com/office/excel/2006/main">
145
+ <x14:cfRule type="dataBar" id="{DA7ABA51-AAAA-BBBB-0001-000000000003}">
146
+ <x14:dataBar minLength="0" maxLength="100" border="1" negativeBarBorderColorSameAsPositive="0">
147
+ <x14:cfvo type="percentile">
148
+ <xm:f>10</xm:f>
149
+ </x14:cfvo>
150
+ <x14:cfvo type="percentile">
151
+ <xm:f>90</xm:f>
152
+ </x14:cfvo>
153
+ <x14:borderColor rgb="FFFF555A"/>
154
+ <x14:negativeFillColor rgb="FFFF0000"/>
155
+ <x14:negativeBorderColor rgb="FFFF0000"/>
156
+ <x14:axisColor rgb="FF000000"/>
157
+ </x14:dataBar>
158
+ </x14:cfRule>
159
+ <xm:sqref>A3:C3</xm:sqref>
160
+ </x14:conditionalFormatting>
161
+ </x14:conditionalFormattings>
162
+ </ext>
163
+ </extLst>
164
+ </worksheet>
165
+ EOS
166
+ end
167
+ end