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.
- checksums.yaml +4 -4
- data/Changes +37 -0
- data/README.md +1 -1
- data/examples/a_simple.rb +1 -6
- data/examples/conditional_format.rb +73 -46
- data/examples/demo.rb +1 -7
- data/examples/hyperlink1.rb +4 -11
- data/lib/write_xlsx/chart.rb +81 -205
- data/lib/write_xlsx/chart/axis.rb +2 -2
- data/lib/write_xlsx/chart/caption.rb +3 -1
- data/lib/write_xlsx/chart/pie.rb +2 -0
- data/lib/write_xlsx/chart/series.rb +11 -7
- data/lib/write_xlsx/format.rb +15 -11
- data/lib/write_xlsx/package/conditional_format.rb +351 -38
- data/lib/write_xlsx/package/content_types.rb +10 -0
- data/lib/write_xlsx/package/custom.rb +125 -0
- data/lib/write_xlsx/package/packager.rb +26 -0
- data/lib/write_xlsx/package/styles.rb +53 -21
- data/lib/write_xlsx/package/table.rb +11 -4
- data/lib/write_xlsx/utility.rb +234 -34
- data/lib/write_xlsx/version.rb +1 -1
- data/lib/write_xlsx/workbook.rb +88 -1
- data/lib/write_xlsx/worksheet.rb +247 -23
- data/test/helper.rb +6 -1
- data/test/regression/_test_hyperlink31.rb +26 -0
- data/test/regression/images/zero_dpi.jpg +0 -0
- data/test/regression/test_chart_bar08.rb +3 -0
- data/test/regression/test_chart_bar11.rb +3 -0
- data/test/regression/test_chart_bar14.rb +3 -0
- data/test/regression/test_chart_chartarea05.rb +16 -17
- data/test/regression/test_chart_chartarea06.rb +49 -0
- data/test/regression/test_chart_data_labels25.rb +61 -0
- data/test/regression/test_chart_format26.rb +48 -0
- data/test/regression/test_chart_format27.rb +58 -0
- data/test/regression/test_chart_format28.rb +52 -0
- data/test/regression/test_chart_format29.rb +59 -0
- data/test/regression/test_chart_format30.rb +53 -0
- data/test/regression/test_chart_format31.rb +60 -0
- data/test/regression/test_chart_table03.rb +56 -0
- data/test/regression/test_cond_format14.rb +42 -0
- data/test/regression/test_cond_format15.rb +53 -0
- data/test/regression/test_cond_format16.rb +53 -0
- data/test/regression/test_cond_format17.rb +37 -0
- data/test/regression/test_cond_format18.rb +136 -0
- data/test/regression/test_date_1904_01.rb +1 -1
- data/test/regression/test_escapes04.rb +3 -0
- data/test/regression/test_escapes05.rb +3 -0
- data/test/regression/test_escapes07.rb +3 -0
- data/test/regression/test_escapes08.rb +3 -0
- data/test/regression/test_hyperlink01.rb +3 -0
- data/test/regression/test_hyperlink02.rb +3 -0
- data/test/regression/test_hyperlink03.rb +4 -0
- data/test/regression/test_hyperlink04.rb +3 -0
- data/test/regression/test_hyperlink05.rb +3 -0
- data/test/regression/test_hyperlink06.rb +3 -0
- data/test/regression/test_hyperlink07.rb +3 -0
- data/test/regression/test_hyperlink08.rb +3 -0
- data/test/regression/test_hyperlink09.rb +3 -0
- data/test/regression/test_hyperlink10.rb +3 -0
- data/test/regression/test_hyperlink11.rb +3 -0
- data/test/regression/test_hyperlink12.rb +3 -0
- data/test/regression/test_hyperlink13.rb +3 -0
- data/test/regression/test_hyperlink14.rb +3 -0
- data/test/regression/test_hyperlink15.rb +3 -0
- data/test/regression/test_hyperlink16.rb +3 -0
- data/test/regression/test_hyperlink17.rb +3 -0
- data/test/regression/test_hyperlink18.rb +3 -0
- data/test/regression/test_hyperlink20.rb +3 -0
- data/test/regression/test_hyperlink21.rb +3 -0
- data/test/regression/test_hyperlink22.rb +3 -0
- data/test/regression/test_hyperlink23.rb +3 -0
- data/test/regression/test_hyperlink24.rb +3 -0
- data/test/regression/test_hyperlink25.rb +3 -0
- data/test/regression/test_hyperlink26.rb +3 -0
- data/test/regression/test_hyperlink27.rb +3 -0
- data/test/regression/test_hyperlink28.rb +50 -0
- data/test/regression/test_hyperlink29.rb +27 -0
- data/test/regression/test_hyperlink30.rb +36 -0
- data/test/regression/test_image35.rb +26 -0
- data/test/regression/test_properties01.rb +1 -4
- data/test/regression/test_properties02.rb +1 -4
- data/test/regression/test_properties03.rb +26 -0
- data/test/regression/test_properties04.rb +61 -0
- data/test/regression/test_properties05.rb +30 -0
- data/test/regression/test_table03.rb +3 -0
- data/test/regression/test_table04.rb +3 -0
- data/test/regression/test_table05.rb +3 -0
- data/test/regression/test_table06.rb +3 -0
- data/test/regression/test_table20.rb +34 -0
- data/test/regression/test_table21.rb +36 -0
- data/test/regression/test_table22.rb +32 -0
- data/test/regression/xlsx_files/chart_chartarea05.xlsx +0 -0
- data/test/regression/xlsx_files/chart_chartarea06.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels25.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format26.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format27.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format28.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format29.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format30.xlsx +0 -0
- data/test/regression/xlsx_files/chart_format31.xlsx +0 -0
- data/test/regression/xlsx_files/chart_table03.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format14.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format15.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format16.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format17.xlsx +0 -0
- data/test/regression/xlsx_files/cond_format18.xlsx +0 -0
- data/test/regression/xlsx_files/date_1904_01.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink28.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink29.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink30.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink31.xlsx +0 -0
- data/test/regression/xlsx_files/image35.xlsx +0 -0
- data/test/regression/xlsx_files/properties03.xlsx +0 -0
- data/test/regression/xlsx_files/properties04.xlsx +0 -0
- data/test/regression/xlsx_files/properties05.xlsx +0 -0
- data/test/regression/xlsx_files/table21.xlsx +0 -0
- data/test/regression/xlsx_files/table22.xlsx +0 -0
- data/test/workbook/test_write_workbook_view.rb +81 -0
- data/test/worksheet/test_cond_format_22.rb +266 -0
- data/test/worksheet/test_cond_format_23.rb +242 -0
- data/test/worksheet/test_cond_format_24.rb +303 -0
- data/test/worksheet/test_data_bar_01.rb +53 -0
- data/test/worksheet/test_data_bar_02.rb +79 -0
- data/test/worksheet/test_data_bar_03.rb +147 -0
- data/test/worksheet/test_data_bar_04.rb +145 -0
- data/test/worksheet/test_data_bar_05.rb +147 -0
- data/test/worksheet/test_data_bar_06.rb +145 -0
- data/test/worksheet/test_data_bar_07.rb +146 -0
- data/test/worksheet/test_data_bar_08.rb +54 -0
- data/test/worksheet/test_data_bar_09.rb +80 -0
- data/test/worksheet/test_data_bar_10.rb +165 -0
- data/test/worksheet/test_data_bar_11.rb +167 -0
- data/test/worksheet/test_data_bar_12.rb +104 -0
- data/test/worksheet/test_write_data_validation_02.rb +27 -0
- 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
|