axlsx 1.0.7 → 1.0.8
Sign up to get free protection for your applications and to get access to all the features.
- data/README.md +21 -3
- data/doc/Axlsx.html +150 -6
- data/doc/Axlsx/App.html +1 -1
- data/doc/Axlsx/Axis.html +1 -1
- data/doc/Axlsx/Bar3DChart.html +1 -1
- data/doc/Axlsx/BarSeries.html +1 -1
- data/doc/Axlsx/Border.html +1 -1
- data/doc/Axlsx/BorderPr.html +1 -1
- data/doc/Axlsx/CatAxis.html +1 -1
- data/doc/Axlsx/CatAxisData.html +7 -5
- data/doc/Axlsx/Cell.html +1 -1
- data/doc/Axlsx/CellAlignment.html +1 -1
- data/doc/Axlsx/CellProtection.html +1 -1
- data/doc/Axlsx/CellStyle.html +1 -1
- data/doc/Axlsx/Chart.html +16 -16
- data/doc/Axlsx/Color.html +1 -1
- data/doc/Axlsx/ContentType.html +1 -1
- data/doc/Axlsx/Core.html +1 -1
- data/doc/Axlsx/DataTypeValidator.html +1 -1
- data/doc/Axlsx/Default.html +1 -1
- data/doc/Axlsx/Drawing.html +243 -65
- data/doc/Axlsx/Fill.html +1 -1
- data/doc/Axlsx/Font.html +1 -1
- data/doc/Axlsx/GradientFill.html +1 -1
- data/doc/Axlsx/GradientStop.html +1 -1
- data/doc/Axlsx/GraphicFrame.html +21 -21
- data/doc/Axlsx/Line3DChart.html +1 -1
- data/doc/Axlsx/LineSeries.html +6 -8
- data/doc/Axlsx/Marker.html +1 -1
- data/doc/Axlsx/NumFmt.html +1 -1
- data/doc/Axlsx/OneCellAnchor.html +988 -0
- data/doc/Axlsx/Override.html +1 -1
- data/doc/Axlsx/Package.html +127 -75
- data/doc/Axlsx/PatternFill.html +1 -1
- data/doc/Axlsx/Pic.html +1532 -0
- data/doc/Axlsx/Pie3DChart.html +5 -7
- data/doc/Axlsx/PieSeries.html +1 -1
- data/doc/Axlsx/RegexValidator.html +1 -1
- data/doc/Axlsx/Relationship.html +6 -6
- data/doc/Axlsx/Relationships.html +1 -1
- data/doc/Axlsx/RestrictionValidator.html +1 -1
- data/doc/Axlsx/Row.html +1 -1
- data/doc/Axlsx/Scaling.html +1 -1
- data/doc/Axlsx/SerAxis.html +1 -1
- data/doc/Axlsx/Series.html +1 -1
- data/doc/Axlsx/SeriesTitle.html +1 -1
- data/doc/Axlsx/SimpleTypedList.html +1 -1
- data/doc/Axlsx/Styles.html +1 -1
- data/doc/Axlsx/TableStyle.html +1 -1
- data/doc/Axlsx/TableStyleElement.html +1 -1
- data/doc/Axlsx/TableStyles.html +1 -1
- data/doc/Axlsx/Title.html +1 -1
- data/doc/Axlsx/TwoCellAnchor.html +165 -61
- data/doc/Axlsx/ValAxis.html +1 -1
- data/doc/Axlsx/ValAxisData.html +1 -1
- data/doc/Axlsx/View3D.html +1 -1
- data/doc/Axlsx/Workbook.html +151 -47
- data/doc/Axlsx/Worksheet.html +172 -35
- data/doc/Axlsx/Xf.html +1 -1
- data/doc/_index.html +15 -1
- data/doc/class_list.html +1 -1
- data/doc/file.README.html +29 -4
- data/doc/index.html +29 -4
- data/doc/method_list.html +571 -363
- data/doc/top-level-namespace.html +1 -1
- data/examples/example.rb +13 -0
- data/examples/image1.gif +0 -0
- data/examples/image1.jpeg +0 -0
- data/examples/image1.jpg +0 -0
- data/examples/image1.png +0 -0
- data/lib/axlsx/drawing/bar_series.rb +0 -1
- data/lib/axlsx/drawing/cat_axis_data.rb +1 -0
- data/lib/axlsx/drawing/chart.rb +0 -1
- data/lib/axlsx/drawing/drawing.rb +31 -7
- data/lib/axlsx/drawing/graphic_frame.rb +0 -2
- data/lib/axlsx/drawing/line_series.rb +0 -1
- data/lib/axlsx/drawing/one_cell_anchor.rb +89 -0
- data/lib/axlsx/drawing/pic.rb +158 -0
- data/lib/axlsx/drawing/pie_3D_chart.rb +0 -1
- data/lib/axlsx/drawing/two_cell_anchor.rb +17 -4
- data/lib/axlsx/package.rb +31 -5
- data/lib/axlsx/rels/relationship.rb +1 -2
- data/lib/axlsx/util/constants.rb +24 -0
- data/lib/axlsx/util/validators.rb +2 -2
- data/lib/axlsx/version.rb +1 -1
- data/lib/axlsx/workbook/workbook.rb +8 -0
- data/lib/axlsx/workbook/worksheet/worksheet.rb +10 -1
- data/test/drawing/tc_drawing.rb +10 -1
- data/test/drawing/tc_one_cell_anchor.rb +67 -0
- data/test/drawing/tc_pic.rb +71 -0
- data/test/tc_package.rb +0 -2
- metadata +13 -118
- data/examples/#example.rb# +0 -87
- data/examples/example.rb~ +0 -79
- data/examples/multi_chart.xlsx +0 -0
- data/lib/axlsx.rb~ +0 -67
- data/lib/axlsx/content_type/content_type.rb~ +0 -20
- data/lib/axlsx/content_type/default.rb~ +0 -32
- data/lib/axlsx/content_type/override.rb~ +0 -30
- data/lib/axlsx/doc_props/app.rb~ +0 -127
- data/lib/axlsx/doc_props/core.rb~ +0 -25
- data/lib/axlsx/drawing/#bar_series.rb# +0 -62
- data/lib/axlsx/drawing/axis.rb~ +0 -0
- data/lib/axlsx/drawing/bar_3D_chart.rb~ +0 -64
- data/lib/axlsx/drawing/bar_series.rb~ +0 -92
- data/lib/axlsx/drawing/cat_axis.rb~ +0 -32
- data/lib/axlsx/drawing/cat_axis_data.rb~ +0 -28
- data/lib/axlsx/drawing/chart.rb~ +0 -0
- data/lib/axlsx/drawing/drawing.rb~ +0 -102
- data/lib/axlsx/drawing/graphic_frame.rb~ +0 -40
- data/lib/axlsx/drawing/line_3D_chart.rb~ +0 -138
- data/lib/axlsx/drawing/line_series.rb~ +0 -91
- data/lib/axlsx/drawing/marker.rb~ +0 -50
- data/lib/axlsx/drawing/pie_3D_chart.rb~ +0 -132
- data/lib/axlsx/drawing/pie_series.rb~ +0 -0
- data/lib/axlsx/drawing/scaling.rb~ +0 -0
- data/lib/axlsx/drawing/ser_axis.rb~ +0 -48
- data/lib/axlsx/drawing/series.rb~ +0 -114
- data/lib/axlsx/drawing/series_title.rb~ +0 -18
- data/lib/axlsx/drawing/title.rb~ +0 -69
- data/lib/axlsx/drawing/two_cell_anchor.rb~ +0 -70
- data/lib/axlsx/drawing/val_axis.rb~ +0 -34
- data/lib/axlsx/drawing/val_axis_data.rb~ +0 -29
- data/lib/axlsx/drawing/view_3D.rb~ +0 -21
- data/lib/axlsx/package.rb~ +0 -181
- data/lib/axlsx/rels/relationship.rb~ +0 -18
- data/lib/axlsx/rels/relationships.rb~ +0 -23
- data/lib/axlsx/stylesheet/border.rb~ +0 -24
- data/lib/axlsx/stylesheet/border_pr.rb~ +0 -64
- data/lib/axlsx/stylesheet/cell_alignment.rb~ +0 -93
- data/lib/axlsx/stylesheet/cell_protection.rb~ +0 -16
- data/lib/axlsx/stylesheet/cell_style.rb~ +0 -61
- data/lib/axlsx/stylesheet/color.rb~ +0 -56
- data/lib/axlsx/stylesheet/fill.rb~ +0 -31
- data/lib/axlsx/stylesheet/font.rb~ +0 -33
- data/lib/axlsx/stylesheet/gradient_fill.rb~ +0 -70
- data/lib/axlsx/stylesheet/gradient_stop.rb~ +0 -15
- data/lib/axlsx/stylesheet/num_fmt.rb~ +0 -60
- data/lib/axlsx/stylesheet/pattern_fill.rb~ +0 -63
- data/lib/axlsx/stylesheet/styles.rb~ +0 -279
- data/lib/axlsx/stylesheet/table_style.rb~ +0 -43
- data/lib/axlsx/stylesheet/table_style_element.rb~ +0 -66
- data/lib/axlsx/stylesheet/table_styles.rb~ +0 -36
- data/lib/axlsx/stylesheet/xf.rb~ +0 -37
- data/lib/axlsx/util/constants.rb~ +0 -187
- data/lib/axlsx/util/monkey_patches_for_true_zip_stream.rb~ +0 -61
- data/lib/axlsx/util/simple_typed_list.rb~ +0 -79
- data/lib/axlsx/util/validators.rb~ +0 -132
- data/lib/axlsx/util/xml_escape.rb~ +0 -6
- data/lib/axlsx/workbook/workbook.rb~ +0 -130
- data/lib/axlsx/workbook/worksheet/cell.rb~ +0 -185
- data/lib/axlsx/workbook/worksheet/row.rb~ +0 -92
- data/lib/axlsx/workbook/worksheet/worksheet.rb~ +0 -194
- data/test/content_type/tc_content_type.rb~ +0 -81
- data/test/content_type/tc_default.rb~ +0 -40
- data/test/content_type/tc_override.rb~ +0 -40
- data/test/doc_props/tc_app.rb~ +0 -19
- data/test/drawing/tc_axis.rb~ +0 -0
- data/test/drawing/tc_bar_3D_chart.rb~ +0 -66
- data/test/drawing/tc_bar_series.rb~ +0 -31
- data/test/drawing/tc_cat_axis.rb~ +0 -39
- data/test/drawing/tc_cat_axis_data.rb~ +0 -32
- data/test/drawing/tc_chart.rb~ +0 -59
- data/test/drawing/tc_graphic_frame.rb~ +0 -21
- data/test/drawing/tc_line_3d_chart.rb~ +0 -48
- data/test/drawing/tc_line_series.rb~ +0 -34
- data/test/drawing/tc_marker.rb~ +0 -26
- data/test/drawing/tc_pie_3D_chart.rb~ +0 -33
- data/test/drawing/tc_pie_series.rb~ +0 -26
- data/test/drawing/tc_scaling.rb~ +0 -45
- data/test/drawing/tc_ser_axis.rb~ +0 -20
- data/test/drawing/tc_series.rb~ +0 -31
- data/test/drawing/tc_series_title.rb~ +0 -34
- data/test/drawing/tc_title.rb~ +0 -34
- data/test/drawing/tc_two_cell_anchor.rb~ +0 -37
- data/test/drawing/tc_val_axis.rb~ +0 -32
- data/test/drawing/tc_val_axis_data.rb~ +0 -18
- data/test/drawing/tc_view_3D.rb~ +0 -37
- data/test/rels/tc_relationship.rb~ +0 -39
- data/test/rels/tc_relationships.rb~ +0 -37
- data/test/stylesheet/tc_border.rb~ +0 -31
- data/test/stylesheet/tc_border_pr.rb~ +0 -31
- data/test/stylesheet/tc_cell_alignment.rb~ +0 -38
- data/test/stylesheet/tc_cell_protection.rb~ +0 -77
- data/test/stylesheet/tc_cell_style.rb~ +0 -30
- data/test/stylesheet/tc_color.rb~ +0 -38
- data/test/stylesheet/tc_fill.rb~ +0 -19
- data/test/stylesheet/tc_font.rb~ +0 -19
- data/test/stylesheet/tc_gradient_fill.rb~ +0 -114
- data/test/stylesheet/tc_gradient_stop.rb~ +0 -65
- data/test/stylesheet/tc_num_fmt.rb~ +0 -32
- data/test/stylesheet/tc_pattern_fill.rb~ +0 -31
- data/test/stylesheet/tc_table_style.rb~ +0 -38
- data/test/stylesheet/tc_table_style_element.rb~ +0 -37
- data/test/stylesheet/tc_table_styles.rb~ +0 -37
- data/test/stylesheet/tc_xf.rb~ +0 -30
- data/test/tc_app.rb~ +0 -19
- data/test/tc_border_pr.rb~ +0 -21
- data/test/tc_package.rb~ +0 -64
- data/test/tc_pie_3D_chart.rb~ +0 -66
- data/test/tc_relationships.rb~ +0 -37
- data/test/tc_series.rb~ +0 -31
- data/test/tc_styles.rb~ +0 -64
- data/test/tc_validators.rb~ +0 -77
- data/test/tc_worksheet.rb~ +0 -85
- data/test/workbook/worksheet/tc_row.rb~ +0 -30
- data/test/workbook/worksheet/tc_worksheet.rb~ +0 -85
data/test/tc_worksheet.rb~
DELETED
@@ -1,85 +0,0 @@
|
|
1
|
-
require 'test/unit'
|
2
|
-
require 'axlsx.rb'
|
3
|
-
|
4
|
-
class TestWorksheet < Test::Unit::TestCase
|
5
|
-
def setup
|
6
|
-
p = Axlsx::Package.new
|
7
|
-
@ws = p.workbook.add_worksheet
|
8
|
-
end
|
9
|
-
|
10
|
-
def test_pn
|
11
|
-
assert_equal(@ws.pn, "worksheets/sheet1.xml")
|
12
|
-
ws = @ws.workbook.add_worksheet
|
13
|
-
assert_equal(ws.pn, "worksheets/sheet2.xml")
|
14
|
-
end
|
15
|
-
|
16
|
-
def test_rels_pn
|
17
|
-
assert_equal(@ws.rels_pn, "worksheets/_rels/sheet1.xml.rels")
|
18
|
-
ws = @ws.workbook.add_worksheet
|
19
|
-
assert_equal(ws.rels_pn, "worksheets/_rels/sheet2.xml.rels")
|
20
|
-
end
|
21
|
-
|
22
|
-
def test_rId
|
23
|
-
assert_equal(@ws.rId, "rId1")
|
24
|
-
ws = @ws.workbook.add_worksheet
|
25
|
-
assert_equal(ws.rId, "rId2")
|
26
|
-
end
|
27
|
-
|
28
|
-
def test_index
|
29
|
-
assert_equal(@ws.index, @ws.workbook.worksheets.index(@ws))
|
30
|
-
end
|
31
|
-
|
32
|
-
def test_add_row
|
33
|
-
assert(@ws.rows.empty?, "sheet has no rows by default")
|
34
|
-
r = @ws.add_row([1,2,3])
|
35
|
-
assert_equal(@ws.rows.size, 1, "add_row adds a row")
|
36
|
-
assert_equal(@ws.rows.first, r, "the row returned is the row added")
|
37
|
-
end
|
38
|
-
|
39
|
-
def test_add_chart
|
40
|
-
assert(@ws.workbook.charts.empty?, "the sheet's workbook should not have any charts by default")
|
41
|
-
@ws.add_chart Axlsx::Pie3DChart
|
42
|
-
assert_equal(@ws.workbook.charts.size, 1, "add_chart adds a chart to the workbook")
|
43
|
-
end
|
44
|
-
|
45
|
-
def test_drawing
|
46
|
-
assert @ws.drawing.is_a? Axlsx::Drawing
|
47
|
-
end
|
48
|
-
|
49
|
-
|
50
|
-
def test_to_xml
|
51
|
-
schema = Nokogiri::XML::Schema(File.open(Axlsx::SML_XSD))
|
52
|
-
doc = Nokogiri::XML(@ws.to_xml)
|
53
|
-
errors = []
|
54
|
-
schema.validate(doc).each do |error|
|
55
|
-
errors.push error
|
56
|
-
puts error.message
|
57
|
-
end
|
58
|
-
assert(errors.empty?, "error free validation")
|
59
|
-
end
|
60
|
-
|
61
|
-
def test_relationships
|
62
|
-
assert(@ws.relationships.empty?, "No Drawing relationship until you add a chart")
|
63
|
-
c = @ws.add_chart Axlsx::Pie3DChart
|
64
|
-
assert_equal(@ws.relationships.size, 1, "adding a chart creates the relationship")
|
65
|
-
c = @ws.add_chart Axlsx::Pie3DChart
|
66
|
-
assert_equal(@ws.relationships.size, 1, "multiple charts still only result in one relationship")
|
67
|
-
end
|
68
|
-
|
69
|
-
|
70
|
-
def test_update_auto_with_data
|
71
|
-
small = @ws.workbook.styles.add_style(:sz=>2)
|
72
|
-
big = @ws.workbook.styles.add_style(:sz=>10)
|
73
|
-
@ws.add_row ["chasing windmills", "penut"], :style=>small
|
74
|
-
assert(@ws.auto_fit_data.size == 2, "a data item for each column")
|
75
|
-
assert_equal(@ws.auto_fit_data[0], {:sz=>2,:longest=>"chasing windmills"}, "adding a row updates auto_fit_data if the product of the string length and font is greater for the column")
|
76
|
-
@ws.add_row ["mule"], :style=>big
|
77
|
-
assert_equal(@ws.auto_fit_data[0], {:sz=>10,:longest=>"mule"}, "adding a row updates auto_fit_data if the product of the string length and font is greater for the column")
|
78
|
-
end
|
79
|
-
|
80
|
-
def test_auto_width
|
81
|
-
assert(@ws.send(:auto_width, {:sz=>11, :longest=>"fisheries"}) > @ws.send(:auto_width, {:sz=>11, :longest=>"fish"}), "longer strings get a longer auto_width at the same font size")
|
82
|
-
assert(@ws.send(:auto_width, {:sz=>12, :longest=>"fish"}) > @ws.send(:auto_width, {:sz=>11, :longest=>"fish"}), "larger font size gets a longer auto_width using the same text")
|
83
|
-
end
|
84
|
-
|
85
|
-
end
|
@@ -1,30 +0,0 @@
|
|
1
|
-
require 'test/unit'
|
2
|
-
require 'axlsx.rb'
|
3
|
-
|
4
|
-
class TestRow < Test::Unit::TestCase
|
5
|
-
|
6
|
-
def setup
|
7
|
-
p = Axlsx::Package.new
|
8
|
-
@ws = p.workbook.add_worksheet :name=>"hmmm"
|
9
|
-
@row = @ws.add_row
|
10
|
-
end
|
11
|
-
|
12
|
-
def test_initialize
|
13
|
-
assert(@row.cells.empty?, "no cells by default")
|
14
|
-
assert_equal(@row.worksheet, @ws, "has a reference to the worksheet")
|
15
|
-
end
|
16
|
-
|
17
|
-
def test_index
|
18
|
-
assert_equal(@row.index, @row.worksheet.rows.index(@row))
|
19
|
-
end
|
20
|
-
|
21
|
-
def test_add_cell
|
22
|
-
c = @row.add_cell(1)
|
23
|
-
assert_equal(@row.cells.last, c)
|
24
|
-
end
|
25
|
-
|
26
|
-
def test_array_to_cells
|
27
|
-
r = @ws.add_row :values=>[1,2,3], :style=>0, :types=>:integer
|
28
|
-
assert_equal(r.cells.size, 3)
|
29
|
-
end
|
30
|
-
end
|
@@ -1,85 +0,0 @@
|
|
1
|
-
require 'test/unit'
|
2
|
-
require 'axlsx.rb'
|
3
|
-
|
4
|
-
class TestWorksheet < Test::Unit::TestCase
|
5
|
-
def setup
|
6
|
-
p = Axlsx::Package.new
|
7
|
-
@ws = p.workbook.add_worksheet
|
8
|
-
end
|
9
|
-
|
10
|
-
def test_pn
|
11
|
-
assert_equal(@ws.pn, "worksheets/sheet1.xml")
|
12
|
-
ws = @ws.workbook.add_worksheet
|
13
|
-
assert_equal(ws.pn, "worksheets/sheet2.xml")
|
14
|
-
end
|
15
|
-
|
16
|
-
def test_rels_pn
|
17
|
-
assert_equal(@ws.rels_pn, "worksheets/_rels/sheet1.xml.rels")
|
18
|
-
ws = @ws.workbook.add_worksheet
|
19
|
-
assert_equal(ws.rels_pn, "worksheets/_rels/sheet2.xml.rels")
|
20
|
-
end
|
21
|
-
|
22
|
-
def test_rId
|
23
|
-
assert_equal(@ws.rId, "rId1")
|
24
|
-
ws = @ws.workbook.add_worksheet
|
25
|
-
assert_equal(ws.rId, "rId2")
|
26
|
-
end
|
27
|
-
|
28
|
-
def test_index
|
29
|
-
assert_equal(@ws.index, @ws.workbook.worksheets.index(@ws))
|
30
|
-
end
|
31
|
-
|
32
|
-
def test_add_row
|
33
|
-
assert(@ws.rows.empty?, "sheet has no rows by default")
|
34
|
-
r = @ws.add_row(:values=>[1,2,3])
|
35
|
-
assert_equal(@ws.rows.size, 1, "add_row adds a row")
|
36
|
-
assert_equal(@ws.rows.first, r, "the row returned is the row added")
|
37
|
-
end
|
38
|
-
|
39
|
-
def test_add_chart
|
40
|
-
assert(@ws.workbook.charts.empty?, "the sheet's workbook should not have any charts by default")
|
41
|
-
@ws.add_chart Axlsx::Pie3DChart
|
42
|
-
assert_equal(@ws.workbook.charts.size, 1, "add_chart adds a chart to the workbook")
|
43
|
-
end
|
44
|
-
|
45
|
-
def test_drawing
|
46
|
-
assert @ws.drawing.is_a? Axlsx::Drawing
|
47
|
-
end
|
48
|
-
|
49
|
-
|
50
|
-
def test_to_xml
|
51
|
-
schema = Nokogiri::XML::Schema(File.open(Axlsx::SML_XSD))
|
52
|
-
doc = Nokogiri::XML(@ws.to_xml)
|
53
|
-
errors = []
|
54
|
-
schema.validate(doc).each do |error|
|
55
|
-
errors.push error
|
56
|
-
puts error.message
|
57
|
-
end
|
58
|
-
assert(errors.empty?, "error free validation")
|
59
|
-
end
|
60
|
-
|
61
|
-
def test_relationships
|
62
|
-
assert(@ws.relationships.empty?, "No Drawing relationship until you add a chart")
|
63
|
-
c = @ws.add_chart Axlsx::Pie3DChart
|
64
|
-
assert_equal(@ws.relationships.size, 1, "adding a chart creates the relationship")
|
65
|
-
c = @ws.add_chart Axlsx::Pie3DChart
|
66
|
-
assert_equal(@ws.relationships.size, 1, "multiple charts still only result in one relationship")
|
67
|
-
end
|
68
|
-
|
69
|
-
|
70
|
-
def test_update_auto_with_data
|
71
|
-
small = @ws.workbook.styles.add_style(:sz=>2)
|
72
|
-
big = @ws.workbook.styles.add_style(:sz=>10)
|
73
|
-
@ws.add_row :values=>["chasing windmills", "penut"], :style=>small
|
74
|
-
assert(@ws.auto_fit_data.size == 2, "a data item for each column")
|
75
|
-
assert_equal(@ws.auto_fit_data[0], {:sz=>2,:longest=>"chasing windmills"}, "adding a row updates auto_fit_data if the product of the string length and font is greater for the column")
|
76
|
-
@ws.add_row :values=> ["mule"], :style=>big
|
77
|
-
assert_equal(@ws.auto_fit_data[0], {:sz=>10,:longest=>"mule"}, "adding a row updates auto_fit_data if the product of the string length and font is greater for the column")
|
78
|
-
end
|
79
|
-
|
80
|
-
def test_auto_width
|
81
|
-
assert(@ws.send(:auto_width, {:sz=>11, :longest=>"fisheries"}) > @ws.send(:auto_width, {:sz=>11, :longest=>"fish"}), "longer strings get a longer auto_width at the same font size")
|
82
|
-
assert(@ws.send(:auto_width, {:sz=>12, :longest=>"fish"}) > @ws.send(:auto_width, {:sz=>11, :longest=>"fish"}), "larger font size gets a longer auto_width using the same text")
|
83
|
-
end
|
84
|
-
|
85
|
-
end
|