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,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