write_xlsx 0.99.0 → 1.07.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/.travis.yml +0 -1
- data/Changes +70 -0
- data/README.md +1 -1
- data/examples/a_simple.rb +1 -1
- data/examples/add_vba_project.rb +1 -1
- data/examples/array_formula.rb +1 -1
- data/examples/chart_area.rb +5 -2
- data/examples/chart_bar.rb +5 -2
- data/examples/chart_clustered.rb +1 -1
- data/examples/chart_column.rb +5 -2
- data/examples/chart_combined.rb +1 -1
- data/examples/chart_data_labels.rb +320 -0
- data/examples/chart_data_table.rb +9 -3
- data/examples/chart_data_tools.rb +25 -7
- data/examples/chart_doughnut.rb +17 -5
- data/examples/chart_gauge.rb +73 -0
- data/examples/chart_line.rb +90 -12
- data/examples/chart_pareto.rb +1 -1
- data/examples/chart_pie.rb +9 -3
- data/examples/chart_radar.rb +13 -4
- data/examples/chart_scatter.rb +5 -2
- data/examples/chart_secondary_axis.rb +5 -2
- data/examples/chart_stock.rb +1 -1
- data/examples/chart_styles.rb +1 -1
- data/examples/colors.rb +1 -1
- data/examples/data_validate.rb +1 -1
- data/examples/date_time.rb +1 -1
- data/examples/demo.rb +4 -1
- data/examples/formats.rb +1 -1
- data/examples/headers.rb +1 -1
- data/examples/hide_row_col.rb +1 -1
- data/examples/hide_sheet.rb +1 -1
- data/examples/hyperlink1.rb +1 -1
- data/examples/indent.rb +1 -1
- data/examples/macros.rb +1 -1
- data/examples/merge1.rb +1 -1
- data/examples/merge2.rb +1 -1
- data/examples/merge3.rb +1 -1
- data/examples/merge4.rb +1 -1
- data/examples/merge5.rb +1 -1
- data/examples/merge6.rb +1 -1
- data/examples/outline.rb +1 -1
- data/examples/outline_collapsed.rb +1 -1
- data/examples/panes.rb +1 -1
- data/examples/properties.rb +1 -1
- data/examples/regions.rb +1 -1
- data/examples/rich_strings.rb +1 -1
- data/examples/right_to_left.rb +1 -1
- data/examples/shape1.rb +1 -1
- data/examples/shape2.rb +1 -1
- data/examples/shape3.rb +1 -1
- data/examples/shape4.rb +1 -1
- data/examples/shape5.rb +1 -1
- data/examples/shape6.rb +1 -1
- data/examples/shape7.rb +1 -1
- data/examples/shape8.rb +1 -1
- data/examples/shape_all.rb +1 -1
- data/examples/sparklines1.rb +1 -1
- data/examples/sparklines2.rb +1 -1
- data/examples/stats.rb +1 -1
- data/examples/stats_ext.rb +1 -1
- data/examples/stocks.rb +1 -1
- data/examples/tab_colors.rb +1 -1
- data/examples/tables.rb +78 -43
- data/lib/write_xlsx/chart.rb +163 -34
- data/lib/write_xlsx/chart/area.rb +1 -1
- data/lib/write_xlsx/chart/bar.rb +1 -1
- data/lib/write_xlsx/chart/column.rb +1 -1
- data/lib/write_xlsx/chart/doughnut.rb +1 -1
- data/lib/write_xlsx/chart/line.rb +16 -2
- data/lib/write_xlsx/chart/pie.rb +21 -8
- data/lib/write_xlsx/chart/radar.rb +1 -1
- data/lib/write_xlsx/chart/scatter.rb +1 -1
- data/lib/write_xlsx/chart/series.rb +100 -0
- data/lib/write_xlsx/chart/stock.rb +1 -1
- data/lib/write_xlsx/chartsheet.rb +5 -5
- data/lib/write_xlsx/drawing.rb +86 -30
- data/lib/write_xlsx/format.rb +5 -5
- data/lib/write_xlsx/package/comments.rb +11 -11
- data/lib/write_xlsx/package/relationships.rb +4 -4
- data/lib/write_xlsx/package/styles.rb +26 -8
- data/lib/write_xlsx/package/table.rb +8 -7
- data/lib/write_xlsx/package/vml.rb +20 -19
- data/lib/write_xlsx/shape.rb +4 -3
- data/lib/write_xlsx/sheets.rb +18 -16
- data/lib/write_xlsx/sparkline.rb +1 -1
- data/lib/write_xlsx/utility.rb +40 -7
- data/lib/write_xlsx/version.rb +1 -1
- data/lib/write_xlsx/workbook.rb +69 -44
- data/lib/write_xlsx/worksheet.rb +206 -138
- data/lib/write_xlsx/worksheet/hyperlink.rb +16 -37
- data/test/drawing/test_drawing_chart_01.rb +6 -2
- data/test/drawing/test_drawing_image_01.rb +12 -3
- data/test/drawing/test_drawing_shape_01.rb +8 -5
- data/test/drawing/test_drawing_shape_02.rb +12 -5
- data/test/drawing/test_drawing_shape_03.rb +8 -5
- data/test/drawing/test_drawing_shape_04.rb +8 -24
- data/test/drawing/test_drawing_shape_05.rb +8 -5
- data/test/drawing/test_drawing_shape_06.rb +11 -6
- data/test/drawing/test_drawing_shape_07.rb +11 -6
- data/test/drawing/test_write_a_graphic_frame_locks.rb +1 -1
- data/test/drawing/test_write_c_chart.rb +1 -1
- data/test/drawing/test_write_c_nv_graphic_frame_pr.rb +1 -1
- data/test/drawing/test_write_c_nv_pr.rb +1 -1
- data/test/drawing/test_write_col.rb +1 -1
- data/test/drawing/test_write_col_off.rb +1 -1
- data/test/drawing/test_write_ext.rb +1 -1
- data/test/drawing/test_write_pos.rb +1 -1
- data/test/drawing/test_write_row.rb +1 -1
- data/test/drawing/test_write_row_off.rb +1 -1
- data/test/drawing/test_write_xfrm_extension.rb +1 -1
- data/test/drawing/test_write_xfrm_offset.rb +1 -1
- data/test/perl_output/chart_data_labels.xlsx +0 -0
- data/test/perl_output/chart_gauge.xlsx +0 -0
- data/test/perl_output/chart_line.xlsx +0 -0
- data/test/perl_output/comments2.xlsx +0 -0
- data/test/perl_output/tables.xlsx +0 -0
- data/test/regression/images/red2.png +0 -0
- data/test/regression/test_array_formula04.rb +31 -0
- data/test/regression/test_chart_axis26.rb +10 -8
- data/test/regression/test_chart_axis27.rb +1 -1
- data/test/regression/test_chart_axis28.rb +1 -1
- data/test/regression/test_chart_axis29.rb +1 -1
- data/test/regression/test_chart_axis33.rb +1 -1
- data/test/regression/test_chart_axis44.rb +54 -0
- data/test/regression/test_chart_axis45.rb +54 -0
- data/test/regression/test_chart_axis46.rb +54 -0
- data/test/regression/test_chart_combined10.rb +43 -0
- data/test/regression/test_chart_combined11.rb +63 -0
- data/test/regression/test_chart_data_labels25.rb +1 -1
- data/test/regression/test_chart_data_labels26.rb +44 -0
- data/test/regression/test_chart_data_labels27.rb +44 -0
- data/test/regression/test_chart_data_labels28.rb +52 -0
- data/test/regression/test_chart_data_labels29.rb +43 -0
- data/test/regression/test_chart_data_labels30.rb +46 -0
- data/test/regression/test_chart_data_labels31.rb +49 -0
- data/test/regression/test_chart_data_labels32.rb +54 -0
- data/test/regression/test_chart_data_labels33.rb +52 -0
- data/test/regression/test_chart_data_labels34.rb +54 -0
- data/test/regression/test_chart_data_labels35.rb +46 -0
- data/test/regression/test_chart_data_labels36.rb +54 -0
- data/test/regression/test_chart_data_labels37.rb +51 -0
- data/test/regression/test_chart_data_labels38.rb +54 -0
- data/test/regression/test_chart_data_labels39.rb +53 -0
- data/test/regression/test_chart_data_labels40.rb +53 -0
- data/test/regression/test_chart_data_labels41.rb +54 -0
- data/test/regression/test_chart_data_labels42.rb +58 -0
- data/test/regression/test_chart_data_labels43.rb +58 -0
- data/test/regression/test_chart_data_labels44.rb +56 -0
- data/test/regression/test_chart_data_labels45.rb +57 -0
- data/test/regression/test_chart_data_labels46.rb +61 -0
- data/test/regression/test_chart_data_labels47.rb +61 -0
- data/test/regression/test_chart_doughnut07.rb +37 -0
- data/test/regression/test_chart_font09.rb +1 -1
- data/test/regression/test_chart_line05.rb +43 -0
- data/test/regression/test_chart_line06.rb +43 -0
- data/test/regression/test_chart_size03.rb +4 -1
- data/test/regression/test_comment14.rb +29 -0
- data/test/regression/test_comment15.rb +28 -0
- data/test/regression/test_comment16.rb +34 -0
- data/test/regression/test_header_image15.rb +36 -0
- data/test/regression/test_header_image16.rb +42 -0
- data/test/regression/test_header_image17.rb +46 -0
- data/test/regression/test_header_image18.rb +48 -0
- data/test/regression/test_header_image19.rb +36 -0
- data/test/regression/test_hyperlink32.rb +27 -0
- data/test/regression/test_hyperlink33.rb +28 -0
- data/test/regression/test_hyperlink34.rb +33 -0
- data/test/regression/test_hyperlink35.rb +39 -0
- data/test/regression/test_hyperlink36.rb +34 -0
- data/test/regression/test_hyperlink37.rb +33 -0
- data/test/regression/test_hyperlink38.rb +27 -0
- data/test/regression/test_hyperlink39.rb +27 -0
- data/test/regression/test_hyperlink40.rb +27 -0
- data/test/regression/test_hyperlink41.rb +27 -0
- data/test/regression/test_hyperlink42.rb +27 -0
- data/test/regression/test_hyperlink43.rb +27 -0
- data/test/regression/test_hyperlink44.rb +27 -0
- data/test/regression/test_hyperlink45.rb +27 -0
- data/test/regression/test_hyperlink47.rb +27 -0
- data/test/regression/test_hyperlink48.rb +31 -0
- data/test/regression/test_hyperlink49.rb +29 -0
- data/test/regression/test_image06.rb +5 -5
- data/test/regression/test_image08.rb +5 -4
- data/test/regression/test_image15.rb +4 -2
- data/test/regression/test_image28.rb +1 -1
- data/test/regression/test_image44.rb +28 -0
- data/test/regression/test_image45.rb +29 -0
- data/test/regression/test_image46.rb +29 -0
- data/test/regression/test_image47.rb +28 -0
- data/test/regression/test_image48.rb +32 -0
- data/test/regression/test_image49.rb +38 -0
- data/test/regression/test_image50.rb +24 -0
- data/test/regression/test_image51.rb +30 -0
- data/test/regression/test_object_position01.rb +26 -0
- data/test/regression/test_object_position02.rb +26 -0
- data/test/regression/test_object_position03.rb +26 -0
- data/test/regression/test_object_position04.rb +44 -0
- data/test/regression/test_object_position06.rb +28 -0
- data/test/regression/test_object_position07.rb +28 -0
- data/test/regression/test_object_position08.rb +47 -0
- data/test/regression/test_object_position09.rb +50 -0
- data/test/regression/test_object_position10.rb +28 -0
- data/test/regression/test_object_position12.rb +25 -0
- data/test/regression/test_object_position13.rb +25 -0
- data/test/regression/test_object_position14.rb +25 -0
- data/test/regression/test_object_position15.rb +29 -0
- data/test/regression/test_object_position16.rb +29 -0
- data/test/regression/test_object_position17.rb +29 -0
- data/test/regression/test_object_position18.rb +29 -0
- data/test/regression/test_object_position19.rb +29 -0
- data/test/regression/test_object_position20.rb +29 -0
- data/test/regression/test_shape_connect01.rb +4 -2
- data/test/regression/test_table24.rb +27 -0
- data/test/regression/test_table25.rb +27 -0
- data/test/regression/xlsx_files/array_formula04.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis26.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis27.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis28.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis29.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis33.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis44.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis45.xlsx +0 -0
- data/test/regression/xlsx_files/chart_axis46.xlsx +0 -0
- data/test/regression/xlsx_files/chart_combined10.xlsx +0 -0
- data/test/regression/xlsx_files/chart_combined11.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels25.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels26.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels27.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels28.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels29.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels30.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels31.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels32.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels33.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels34.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels35.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels36.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels37.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels38.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels39.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels40.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels41.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels42.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels43.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels44.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels45.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels46.xlsx +0 -0
- data/test/regression/xlsx_files/chart_data_labels47.xlsx +0 -0
- data/test/regression/xlsx_files/chart_doughnut07.xlsx +0 -0
- data/test/regression/xlsx_files/chart_font09.xlsx +0 -0
- data/test/regression/xlsx_files/chart_line05.xlsx +0 -0
- data/test/regression/xlsx_files/chart_line06.xlsx +0 -0
- data/test/regression/xlsx_files/comment14.xlsx +0 -0
- data/test/regression/xlsx_files/comment15.xlsx +0 -0
- data/test/regression/xlsx_files/comment16.xlsx +0 -0
- data/test/regression/xlsx_files/header_image15.xlsx +0 -0
- data/test/regression/xlsx_files/header_image16.xlsx +0 -0
- data/test/regression/xlsx_files/header_image17.xlsx +0 -0
- data/test/regression/xlsx_files/header_image18.xlsx +0 -0
- data/test/regression/xlsx_files/header_image19.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink32.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink33.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink34.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink35.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink36.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink37.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink38.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink39.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink40.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink41.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink42.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink43.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink44.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink45.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink46.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink47.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink48.xlsx +0 -0
- data/test/regression/xlsx_files/hyperlink49.xlsx +0 -0
- data/test/regression/xlsx_files/image06.xlsx +0 -0
- data/test/regression/xlsx_files/image44.xlsx +0 -0
- data/test/regression/xlsx_files/image45.xlsx +0 -0
- data/test/regression/xlsx_files/image46.xlsx +0 -0
- data/test/regression/xlsx_files/image47.xlsx +0 -0
- data/test/regression/xlsx_files/image48.xlsx +0 -0
- data/test/regression/xlsx_files/image49.xlsx +0 -0
- data/test/regression/xlsx_files/image50.xlsx +0 -0
- data/test/regression/xlsx_files/image51.xlsx +0 -0
- data/test/regression/xlsx_files/object_position01.xlsx +0 -0
- data/test/regression/xlsx_files/object_position02.xlsx +0 -0
- data/test/regression/xlsx_files/object_position03.xlsx +0 -0
- data/test/regression/xlsx_files/object_position04.xlsx +0 -0
- data/test/regression/xlsx_files/object_position06.xlsx +0 -0
- data/test/regression/xlsx_files/object_position07.xlsx +0 -0
- data/test/regression/xlsx_files/object_position08.xlsx +0 -0
- data/test/regression/xlsx_files/object_position09.xlsx +0 -0
- data/test/regression/xlsx_files/object_position10.xlsx +0 -0
- data/test/regression/xlsx_files/object_position12.xlsx +0 -0
- data/test/regression/xlsx_files/object_position13.xlsx +0 -0
- data/test/regression/xlsx_files/object_position14.xlsx +0 -0
- data/test/regression/xlsx_files/object_position15.xlsx +0 -0
- data/test/regression/xlsx_files/object_position16.xlsx +0 -0
- data/test/regression/xlsx_files/object_position17.xlsx +0 -0
- data/test/regression/xlsx_files/object_position18.xlsx +0 -0
- data/test/regression/xlsx_files/object_position19.xlsx +0 -0
- data/test/regression/xlsx_files/object_position20.xlsx +0 -0
- data/test/regression/xlsx_files/table24.xlsx +0 -0
- data/test/regression/xlsx_files/table25.xlsx +0 -0
- data/test/test_example_match.rb +1268 -780
- data/test/workbook/test_check_sheetname.rb +51 -0
- data/write_xlsx.gemspec +1 -0
- metadata +367 -5
@@ -8,7 +8,7 @@
|
|
8
8
|
# See formatting note in Chart.
|
9
9
|
#
|
10
10
|
# Copyright 2000-2011, John McNamara, jmcnamara@cpan.org
|
11
|
-
# Convert to ruby by Hideo NAKAMURA,
|
11
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
12
12
|
#
|
13
13
|
|
14
14
|
require 'write_xlsx/package/xml_writer_simple'
|
data/lib/write_xlsx/chart/bar.rb
CHANGED
@@ -8,7 +8,7 @@
|
|
8
8
|
# See formatting note in Chart.
|
9
9
|
#
|
10
10
|
# Copyright 2000-2011, John McNamara, jmcnamara@cpan.org
|
11
|
-
# Convert to ruby by Hideo NAKAMURA,
|
11
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
12
12
|
#
|
13
13
|
|
14
14
|
require 'write_xlsx/package/xml_writer_simple'
|
@@ -8,7 +8,7 @@
|
|
8
8
|
# See formatting note in Chart.
|
9
9
|
#
|
10
10
|
# Copyright 2000-2011, John McNamara, jmcnamara@cpan.org
|
11
|
-
# Convert to ruby by Hideo NAKAMURA,
|
11
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
12
12
|
#
|
13
13
|
|
14
14
|
require 'write_xlsx/package/xml_writer_simple'
|
@@ -8,7 +8,7 @@
|
|
8
8
|
# See formatting note in Excel::Writer::XLSX::Chart.
|
9
9
|
#
|
10
10
|
# Copyright 2000-2014, John McNamara, jmcnamara@cpan.org
|
11
|
-
# Convert to ruby by Hideo NAKAMURA,
|
11
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
12
12
|
#
|
13
13
|
|
14
14
|
require 'write_xlsx/package/xml_writer_simple'
|
@@ -8,7 +8,7 @@
|
|
8
8
|
# See formatting note in Chart.
|
9
9
|
#
|
10
10
|
# Copyright 2000-2011, John McNamara, jmcnamara@cpan.org
|
11
|
-
# Convert to ruby by Hideo NAKAMURA,
|
11
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
12
12
|
#
|
13
13
|
|
14
14
|
require 'write_xlsx/package/xml_writer_simple'
|
@@ -22,9 +22,17 @@ class Line < self
|
|
22
22
|
|
23
23
|
def initialize(subtype)
|
24
24
|
super(subtype)
|
25
|
+
@subtype = @subtype || 'standard'
|
25
26
|
@default_marker = Marker.new(:type => 'none')
|
26
27
|
@smooth_allowed = 1
|
27
28
|
|
29
|
+
# Override and reset the default axis values.
|
30
|
+
if @subtype == 'percent_stacked'
|
31
|
+
@y_axis.defaults[:num_format] = '0%'
|
32
|
+
end
|
33
|
+
|
34
|
+
set_y_axis
|
35
|
+
|
28
36
|
# Set the available data label positions for this chart type.
|
29
37
|
@label_position_default = 'right'
|
30
38
|
@label_positions = {
|
@@ -54,9 +62,15 @@ def write_line_chart(params)
|
|
54
62
|
series = axes_series(params)
|
55
63
|
return if series.empty?
|
56
64
|
|
65
|
+
if @subtype == 'percent_stacked'
|
66
|
+
subtype = 'percentStacked'
|
67
|
+
else
|
68
|
+
subtype = @subtype
|
69
|
+
end
|
70
|
+
|
57
71
|
@writer.tag_elements('c:lineChart') do
|
58
72
|
# Write the c:grouping element.
|
59
|
-
write_grouping(
|
73
|
+
write_grouping(subtype)
|
60
74
|
# Write the series elements.
|
61
75
|
series.each {|s| write_series(s)}
|
62
76
|
|
data/lib/write_xlsx/chart/pie.rb
CHANGED
@@ -8,7 +8,7 @@
|
|
8
8
|
# See formatting note in Chart.
|
9
9
|
#
|
10
10
|
# Copyright 2000-2011, John McNamara, jmcnamara@cpan.org
|
11
|
-
# Convert to ruby by Hideo NAKAMURA,
|
11
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
12
12
|
#
|
13
13
|
|
14
14
|
require 'write_xlsx/package/xml_writer_simple'
|
@@ -42,13 +42,6 @@ def initialize(subtype)
|
|
42
42
|
}
|
43
43
|
end
|
44
44
|
|
45
|
-
#
|
46
|
-
# Override parent method to add a warning.
|
47
|
-
#
|
48
|
-
def combine(chart)
|
49
|
-
raise "Combined chart not currently supported for Pie charts"
|
50
|
-
end
|
51
|
-
|
52
45
|
#
|
53
46
|
# Set the Pie/Doughnut chart rotation: the angle of the first slice.
|
54
47
|
#
|
@@ -91,11 +84,31 @@ def write_pie_chart
|
|
91
84
|
# Write the <c:plotArea> element.
|
92
85
|
#
|
93
86
|
def write_plot_area
|
87
|
+
second_chart = @combined
|
88
|
+
|
94
89
|
@writer.tag_elements('c:plotArea') do
|
95
90
|
# Write the c:layout element.
|
96
91
|
write_layout(@plotarea.layout, 'plot')
|
97
92
|
# Write the subclass chart type element.
|
98
93
|
write_chart_type
|
94
|
+
# Configure a combined chart if present.
|
95
|
+
if second_chart
|
96
|
+
# Secondary axis has unique id otherwise use same as primary.
|
97
|
+
if second_chart.is_secondary?
|
98
|
+
second_chart.id = 1000 + @id
|
99
|
+
else
|
100
|
+
second_chart.id = @id
|
101
|
+
end
|
102
|
+
|
103
|
+
# Share the same filehandle for writing
|
104
|
+
second_chart.writer = @writer
|
105
|
+
|
106
|
+
# Share series index with primary chart.
|
107
|
+
second_chart.series_index = @series_index
|
108
|
+
|
109
|
+
# Write the subclass chart type elements for combined chart.
|
110
|
+
second_chart.write_chart_type
|
111
|
+
end
|
99
112
|
# Write the c:spPr eleent for the plotarea formatting.
|
100
113
|
write_sp_pr(@plotarea)
|
101
114
|
end
|
@@ -8,7 +8,7 @@
|
|
8
8
|
# See formatting note in Chart.
|
9
9
|
#
|
10
10
|
# Copyright 2000-2012, John McNamara, jmcnamara@cpan.org
|
11
|
-
# Convert to ruby by Hideo NAKAMURA,
|
11
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
12
12
|
#
|
13
13
|
|
14
14
|
require 'write_xlsx/package/xml_writer_simple'
|
@@ -8,7 +8,7 @@
|
|
8
8
|
# See formatting note in Chart.
|
9
9
|
#
|
10
10
|
# Copyright 2000-2011, John McNamara, jmcnamara@cpan.org
|
11
|
-
# Convert to ruby by Hideo NAKAMURA,
|
11
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
12
12
|
#
|
13
13
|
|
14
14
|
require 'write_xlsx/package/xml_writer_simple'
|
@@ -296,10 +296,110 @@ def labels_properties(labels) # :nodoc:
|
|
296
296
|
labels[:separator] = separators[separator]
|
297
297
|
end
|
298
298
|
|
299
|
+
|
300
|
+
# Set the line properties for the data labels.
|
301
|
+
line = line_properties( labels[:line] )
|
302
|
+
|
303
|
+
# Allow 'border' as a synonym for 'line'.
|
304
|
+
if labels[:border]
|
305
|
+
line = line_properties(labels[:border])
|
306
|
+
end
|
307
|
+
|
308
|
+
# Set the fill properties for the labels.
|
309
|
+
fill = fill_properties(labels[:fill])
|
310
|
+
|
311
|
+
# Set the pattern properties for the labels.
|
312
|
+
pattern = pattern_properties(labels[:pattern])
|
313
|
+
|
314
|
+
# Set the gradient fill properties for the labels.
|
315
|
+
gradient = gradient_properties(labels[:gradient])
|
316
|
+
|
317
|
+
# Pattern fill overrides solid fill.
|
318
|
+
if pattern
|
319
|
+
fill = nil
|
320
|
+
end
|
321
|
+
|
322
|
+
# Gradient fill overrides solid and pattern fills.
|
323
|
+
if gradient
|
324
|
+
pattern = nil
|
325
|
+
fill = nil
|
326
|
+
end
|
327
|
+
|
328
|
+
labels[:line] = line
|
329
|
+
labels[:fill] = fill
|
330
|
+
labels[:pattern] = pattern
|
331
|
+
labels[:gradient] = gradient
|
332
|
+
|
299
333
|
if labels[:font]
|
300
334
|
labels[:font] = convert_font_args(labels[:font])
|
301
335
|
end
|
302
336
|
|
337
|
+
if labels[:custom]
|
338
|
+
# Duplicate, and modify, the custom label properties.
|
339
|
+
custom = []
|
340
|
+
|
341
|
+
labels[:custom].each do |label|
|
342
|
+
if !label
|
343
|
+
custom << nil
|
344
|
+
next
|
345
|
+
end
|
346
|
+
|
347
|
+
property = label.dup
|
348
|
+
|
349
|
+
# Convert formula.
|
350
|
+
if property[:value] && property[:value] =~ /^=[^!]+!\$/
|
351
|
+
property[:formula] = property[:value]
|
352
|
+
end
|
353
|
+
|
354
|
+
if property[:formula]
|
355
|
+
property[:formula] = property[:formula].sub(/^=/, '')
|
356
|
+
|
357
|
+
data_id = @chart.data_id(property[:formula], property[:data])
|
358
|
+
property[:data_id] = data_id
|
359
|
+
end
|
360
|
+
|
361
|
+
if property[:font]
|
362
|
+
property[:font] = convert_font_args(property[:font])
|
363
|
+
end
|
364
|
+
|
365
|
+
# Allow 'border' as a synonym for 'line'.
|
366
|
+
if property[:border]
|
367
|
+
line = line_properties(property[:border])
|
368
|
+
else
|
369
|
+
# Set the line properties for the data labels.
|
370
|
+
line = line_properties(property[:line])
|
371
|
+
end
|
372
|
+
|
373
|
+
# Set the fill properties for the labels.
|
374
|
+
fill = fill_properties(property[:fill])
|
375
|
+
|
376
|
+
# Set the pattern properties for the labels.
|
377
|
+
pattern = pattern_properties(property[:pattern])
|
378
|
+
|
379
|
+
# Set the gradient fill properties for the labels.
|
380
|
+
gradient = gradient_properties(property[:gradient])
|
381
|
+
|
382
|
+
# Pattern fill overrides solid fill.
|
383
|
+
if pattern
|
384
|
+
fill = nil
|
385
|
+
end
|
386
|
+
|
387
|
+
# Gradient fill overrides solid and pattern fills.
|
388
|
+
if gradient
|
389
|
+
pattern = nil
|
390
|
+
fill = nil
|
391
|
+
end
|
392
|
+
|
393
|
+
property[:line] = line
|
394
|
+
property[:fill] = fill
|
395
|
+
property[:pattern] = pattern
|
396
|
+
property[:gradient] = gradient
|
397
|
+
|
398
|
+
custom << property
|
399
|
+
end
|
400
|
+
labels[:custom] = custom
|
401
|
+
end
|
402
|
+
|
303
403
|
labels
|
304
404
|
end
|
305
405
|
end
|
@@ -8,7 +8,7 @@
|
|
8
8
|
# See formatting note in Chart.
|
9
9
|
#
|
10
10
|
# Copyright 2000-2011, John McNamara, jmcnamara@cpan.org
|
11
|
-
# Convert to ruby by Hideo NAKAMURA,
|
11
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
12
12
|
#
|
13
13
|
|
14
14
|
require 'write_xlsx/package/xml_writer_simple'
|
@@ -6,7 +6,7 @@
|
|
6
6
|
# Used in conjunction with WriteXLSX
|
7
7
|
#
|
8
8
|
# Copyright 2000-2011, John McNamara, jmcnamara@cpan.org
|
9
|
-
# Convert to ruby by Hideo NAKAMURA,
|
9
|
+
# Convert to ruby by Hideo NAKAMURA, nakamura.hideo@gmail.com
|
10
10
|
#
|
11
11
|
|
12
12
|
require 'write_xlsx/worksheet'
|
@@ -19,7 +19,7 @@ class Chartsheet < Worksheet
|
|
19
19
|
|
20
20
|
def initialize(workbook, index, name)
|
21
21
|
super
|
22
|
-
@
|
22
|
+
@drawings = Drawings.new
|
23
23
|
@is_chartsheet = true
|
24
24
|
@chart = nil
|
25
25
|
@charts = [1]
|
@@ -176,9 +176,9 @@ def set_high_low_lines(*args)
|
|
176
176
|
def prepare_chart(index, chart_id, drawing_id) # :nodoc:
|
177
177
|
@chart.id = chart_id - 1
|
178
178
|
|
179
|
-
|
180
|
-
@
|
181
|
-
@
|
179
|
+
drawings = Drawings.new
|
180
|
+
@drawings = drawings
|
181
|
+
@drawings.orientation = @page_setup.orientation
|
182
182
|
|
183
183
|
@external_drawing_links << [ '/drawing', "../drawings/drawing#{drawing_id}.xml" ]
|
184
184
|
|
data/lib/write_xlsx/drawing.rb
CHANGED
@@ -4,6 +4,16 @@
|
|
4
4
|
|
5
5
|
module Writexlsx
|
6
6
|
class Drawing
|
7
|
+
attr_accessor :type, :dimensions, :width, :height, :description, :shape, :anchor, :rel_index, :url_rel_index
|
8
|
+
attr_reader :tip
|
9
|
+
|
10
|
+
def initialize(type, dimensions, width, height, description, shape, anchor, rel_index = nil, url_rel_index = nil, tip = nil)
|
11
|
+
@type, @dimensions, @width, @height, @description, @shape, @anchor, @rel_index, @url_rel_index, @tip =
|
12
|
+
type, dimensions, width, height, description, shape, anchor, rel_index, url_rel_index, tip
|
13
|
+
end
|
14
|
+
end
|
15
|
+
|
16
|
+
class Drawings
|
7
17
|
include Writexlsx::Utility
|
8
18
|
|
9
19
|
attr_writer :embedded, :orientation
|
@@ -32,10 +42,10 @@ def assemble_xml_file
|
|
32
42
|
write_drawing_workspace do
|
33
43
|
if @embedded
|
34
44
|
index = 0
|
35
|
-
@drawings.each do |
|
45
|
+
@drawings.each do |drawing|
|
36
46
|
# Write the xdr:twoCellAnchor element.
|
37
47
|
index += 1
|
38
|
-
write_two_cell_anchor(index,
|
48
|
+
write_two_cell_anchor(index, drawing)
|
39
49
|
end
|
40
50
|
else
|
41
51
|
# Write the xdr:absoluteAnchor element.
|
@@ -48,8 +58,8 @@ def assemble_xml_file
|
|
48
58
|
#
|
49
59
|
# Add a chart, image or shape sub object to the drawing.
|
50
60
|
#
|
51
|
-
def add_drawing_object(
|
52
|
-
@drawings <<
|
61
|
+
def add_drawing_object(drawing)
|
62
|
+
@drawings << drawing
|
53
63
|
end
|
54
64
|
|
55
65
|
private
|
@@ -71,14 +81,29 @@ def write_drawing_workspace
|
|
71
81
|
# Write the <xdr:twoCellAnchor> element.
|
72
82
|
#
|
73
83
|
def write_two_cell_anchor(*args)
|
74
|
-
index,
|
75
|
-
|
76
|
-
|
84
|
+
index, drawing = args
|
85
|
+
|
86
|
+
type = drawing.type
|
87
|
+
width = drawing.width
|
88
|
+
height = drawing.height
|
89
|
+
description = drawing.description
|
90
|
+
shape = drawing.shape
|
91
|
+
anchor = drawing.anchor
|
92
|
+
rel_index = drawing.rel_index
|
93
|
+
url_rel_index = drawing.url_rel_index
|
94
|
+
tip = drawing.tip
|
95
|
+
|
96
|
+
col_from, row_from, col_from_offset, row_from_offset,
|
97
|
+
col_to, row_to, col_to_offset, row_to_offset, col_absolute, row_absolute = drawing.dimensions
|
77
98
|
|
78
99
|
attributes = []
|
79
100
|
|
80
101
|
# Add attribute for images.
|
81
|
-
|
102
|
+
if anchor == 2
|
103
|
+
attributes << [:editAs, 'oneCell']
|
104
|
+
elsif anchor == 3
|
105
|
+
attributes << [:editAs, 'absolute']
|
106
|
+
end
|
82
107
|
|
83
108
|
# Add attribute for shapes.
|
84
109
|
attributes << [:editAs, shape.edit_as] if shape && shape.edit_as
|
@@ -93,10 +118,14 @@ def write_two_cell_anchor(*args)
|
|
93
118
|
# Graphic frame.
|
94
119
|
|
95
120
|
# Write the xdr:graphicFrame element for charts.
|
96
|
-
write_graphic_frame(index, description)
|
121
|
+
write_graphic_frame(index, rel_index, description)
|
97
122
|
elsif type == 2
|
98
123
|
# Write the xdr:pic element.
|
99
|
-
write_pic(
|
124
|
+
write_pic(
|
125
|
+
index, rel_index, col_absolute,
|
126
|
+
row_absolute, width, height,
|
127
|
+
description, url_rel_index , tip
|
128
|
+
)
|
100
129
|
else
|
101
130
|
# Write the xdr:sp element for shapes.
|
102
131
|
write_sp(index, col_absolute, row_absolute, width, height, shape)
|
@@ -129,7 +158,7 @@ def write_absolute_anchor(index)
|
|
129
158
|
end
|
130
159
|
|
131
160
|
# Write the xdr:graphicFrame element.
|
132
|
-
write_graphic_frame(index)
|
161
|
+
write_graphic_frame(index, index)
|
133
162
|
|
134
163
|
# Write the xdr:clientData element.
|
135
164
|
write_client_data
|
@@ -203,9 +232,9 @@ def write_row_off(data)
|
|
203
232
|
#
|
204
233
|
def write_pos(x, y)
|
205
234
|
attributes = [
|
206
|
-
|
207
|
-
|
208
|
-
|
235
|
+
['x', x],
|
236
|
+
['y', y]
|
237
|
+
]
|
209
238
|
|
210
239
|
@writer.empty_tag('xdr:pos', attributes)
|
211
240
|
end
|
@@ -215,9 +244,9 @@ def write_pos(x, y)
|
|
215
244
|
#
|
216
245
|
def write_ext(cx, cy)
|
217
246
|
attributes = [
|
218
|
-
|
219
|
-
|
220
|
-
|
247
|
+
['cx', cx],
|
248
|
+
['cy', cy]
|
249
|
+
]
|
221
250
|
|
222
251
|
@writer.empty_tag('xdr:ext', attributes)
|
223
252
|
end
|
@@ -225,7 +254,7 @@ def write_ext(cx, cy)
|
|
225
254
|
#
|
226
255
|
# Write the <xdr:graphicFrame> element.
|
227
256
|
#
|
228
|
-
def write_graphic_frame(index, name = nil)
|
257
|
+
def write_graphic_frame(index, rel_index, name = nil)
|
229
258
|
macro = ''
|
230
259
|
|
231
260
|
attributes = [ ['macro', macro] ]
|
@@ -236,7 +265,7 @@ def write_graphic_frame(index, name = nil)
|
|
236
265
|
# Write the xdr:xfrm element.
|
237
266
|
write_xfrm
|
238
267
|
# Write the a:graphic element.
|
239
|
-
write_atag_graphic(
|
268
|
+
write_atag_graphic(rel_index)
|
240
269
|
end
|
241
270
|
end
|
242
271
|
|
@@ -257,18 +286,42 @@ def write_nv_graphic_frame_pr(index, name = nil)
|
|
257
286
|
#
|
258
287
|
# Write the <xdr:cNvPr> element.
|
259
288
|
#
|
260
|
-
def write_c_nv_pr(
|
289
|
+
def write_c_nv_pr(index, name, description = nil, url_rel_index = nil, tip = nil)
|
261
290
|
attributes = [
|
262
|
-
|
263
|
-
|
291
|
+
['id', index],
|
292
|
+
['name', name]
|
264
293
|
]
|
265
294
|
|
266
295
|
# Add description attribute for images.
|
267
|
-
attributes << ['descr',
|
296
|
+
attributes << ['descr', description] if description
|
268
297
|
|
269
|
-
|
298
|
+
if ptrue?(url_rel_index)
|
299
|
+
@writer.tag_elements('xdr:cNvPr', attributes) do
|
300
|
+
# Write the a:hlinkClick element.
|
301
|
+
write_a_hlink_click(url_rel_index, tip)
|
302
|
+
end
|
303
|
+
else
|
304
|
+
@writer.empty_tag('xdr:cNvPr', attributes)
|
305
|
+
end
|
270
306
|
end
|
271
307
|
|
308
|
+
#
|
309
|
+
# Write the <a:hlinkClick> element.
|
310
|
+
#
|
311
|
+
def write_a_hlink_click(index, tip)
|
312
|
+
schema = 'http://schemas.openxmlformats.org/officeDocument/'
|
313
|
+
xmlns_r = "#{schema}2006/relationships"
|
314
|
+
r_id = "rId#{index}"
|
315
|
+
|
316
|
+
attributes = [
|
317
|
+
['xmlns:r', xmlns_r],
|
318
|
+
['r:id', r_id]
|
319
|
+
]
|
320
|
+
|
321
|
+
attributes << ['tooltip', tip] if tip
|
322
|
+
|
323
|
+
@writer.empty_tag('a:hlinkClick', attributes)
|
324
|
+
end
|
272
325
|
|
273
326
|
#
|
274
327
|
# Write the <xdr:cNvGraphicFramePr> element.
|
@@ -351,7 +404,7 @@ def write_atag_graphic(index)
|
|
351
404
|
# Write the <a:graphicData> element.
|
352
405
|
#
|
353
406
|
def write_atag_graphic_data(index)
|
354
|
-
uri
|
407
|
+
uri = 'http://schemas.openxmlformats.org/drawingml/2006/chart'
|
355
408
|
|
356
409
|
attributes = [ ['uri', uri] ]
|
357
410
|
|
@@ -474,12 +527,12 @@ def write_nv_sp_pr(index, shape)
|
|
474
527
|
#
|
475
528
|
# Write the <xdr:pic> element.
|
476
529
|
#
|
477
|
-
def write_pic(index, col_absolute, row_absolute, width, height, description)
|
530
|
+
def write_pic(index, rel_index, col_absolute, row_absolute, width, height, description, url_rel_index, tip)
|
478
531
|
@writer.tag_elements('xdr:pic') do
|
479
532
|
# Write the xdr:nvPicPr element.
|
480
|
-
write_nv_pic_pr(index, description)
|
533
|
+
write_nv_pic_pr(index, rel_index, description, url_rel_index, tip)
|
481
534
|
# Write the xdr:blipFill element.
|
482
|
-
write_blip_fill(
|
535
|
+
write_blip_fill(rel_index)
|
483
536
|
|
484
537
|
# Pictures are rectangle shapes by default.
|
485
538
|
shape = Shape.new
|
@@ -493,10 +546,13 @@ def write_pic(index, col_absolute, row_absolute, width, height, description)
|
|
493
546
|
#
|
494
547
|
# Write the <xdr:nvPicPr> element.
|
495
548
|
#
|
496
|
-
def write_nv_pic_pr(index, description)
|
549
|
+
def write_nv_pic_pr(index, rel_index, description, url_rel_index, tip)
|
497
550
|
@writer.tag_elements('xdr:nvPicPr') do
|
498
551
|
# Write the xdr:cNvPr element.
|
499
|
-
write_c_nv_pr(
|
552
|
+
write_c_nv_pr(
|
553
|
+
index + 1, "Picture #{index}", description,
|
554
|
+
url_rel_index, tip
|
555
|
+
)
|
500
556
|
# Write the xdr:cNvPicPr element.
|
501
557
|
write_c_nv_pic_pr
|
502
558
|
end
|