bonio-axlsx 2.2.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (325) hide show
  1. checksums.yaml +7 -0
  2. data/.yardopts +9 -0
  3. data/.yardopts_guide +19 -0
  4. data/CHANGELOG.md +239 -0
  5. data/LICENSE +22 -0
  6. data/README.md +258 -0
  7. data/Rakefile +30 -0
  8. data/examples/2010_comments.rb +17 -0
  9. data/examples/anchor_swapping.rb +28 -0
  10. data/examples/auto_filter.rb +25 -0
  11. data/examples/basic_charts.rb +58 -0
  12. data/examples/chart_colors.rb +88 -0
  13. data/examples/colored_links.rb +59 -0
  14. data/examples/conditional_formatting/example_conditional_formatting.rb +89 -0
  15. data/examples/conditional_formatting/getting_barred.rb +37 -0
  16. data/examples/conditional_formatting/hitting_the_high_notes.rb +37 -0
  17. data/examples/conditional_formatting/scaled_colors.rb +39 -0
  18. data/examples/conditional_formatting/stop_and_go.rb +37 -0
  19. data/examples/data_validation.rb +50 -0
  20. data/examples/example.rb +875 -0
  21. data/examples/extractive.rb +45 -0
  22. data/examples/image1.jpeg +0 -0
  23. data/examples/ios_preview.rb +14 -0
  24. data/examples/merge_cells.rb +17 -0
  25. data/examples/no_grid_with_borders.rb +18 -0
  26. data/examples/page_setup.rb +11 -0
  27. data/examples/pivot_table.rb +39 -0
  28. data/examples/pivot_test.rb +63 -0
  29. data/examples/sheet_protection.rb +10 -0
  30. data/examples/skydrive/real_example.rb +63 -0
  31. data/examples/split.rb +16 -0
  32. data/examples/styles.rb +66 -0
  33. data/examples/underline.rb +13 -0
  34. data/examples/wrap_text.rb +21 -0
  35. data/lib/axlsx.rb +168 -0
  36. data/lib/axlsx/content_type/abstract_content_type.rb +32 -0
  37. data/lib/axlsx/content_type/content_type.rb +26 -0
  38. data/lib/axlsx/content_type/default.rb +25 -0
  39. data/lib/axlsx/content_type/override.rb +25 -0
  40. data/lib/axlsx/doc_props/app.rb +235 -0
  41. data/lib/axlsx/doc_props/core.rb +39 -0
  42. data/lib/axlsx/drawing/ax_data_source.rb +26 -0
  43. data/lib/axlsx/drawing/axes.rb +61 -0
  44. data/lib/axlsx/drawing/axis.rb +190 -0
  45. data/lib/axlsx/drawing/bar_3D_chart.rb +151 -0
  46. data/lib/axlsx/drawing/bar_series.rb +82 -0
  47. data/lib/axlsx/drawing/bubble_chart.rb +59 -0
  48. data/lib/axlsx/drawing/bubble_series.rb +63 -0
  49. data/lib/axlsx/drawing/cat_axis.rb +85 -0
  50. data/lib/axlsx/drawing/chart.rb +274 -0
  51. data/lib/axlsx/drawing/d_lbls.rb +90 -0
  52. data/lib/axlsx/drawing/drawing.rb +164 -0
  53. data/lib/axlsx/drawing/graphic_frame.rb +54 -0
  54. data/lib/axlsx/drawing/hyperlink.rb +100 -0
  55. data/lib/axlsx/drawing/line_3D_chart.rb +68 -0
  56. data/lib/axlsx/drawing/line_chart.rb +99 -0
  57. data/lib/axlsx/drawing/line_series.rb +110 -0
  58. data/lib/axlsx/drawing/marker.rb +84 -0
  59. data/lib/axlsx/drawing/num_data.rb +52 -0
  60. data/lib/axlsx/drawing/num_data_source.rb +62 -0
  61. data/lib/axlsx/drawing/num_val.rb +34 -0
  62. data/lib/axlsx/drawing/one_cell_anchor.rb +98 -0
  63. data/lib/axlsx/drawing/pic.rb +213 -0
  64. data/lib/axlsx/drawing/picture_locking.rb +42 -0
  65. data/lib/axlsx/drawing/pie_3D_chart.rb +47 -0
  66. data/lib/axlsx/drawing/pie_series.rb +74 -0
  67. data/lib/axlsx/drawing/scaling.rb +60 -0
  68. data/lib/axlsx/drawing/scatter_chart.rb +74 -0
  69. data/lib/axlsx/drawing/scatter_series.rb +98 -0
  70. data/lib/axlsx/drawing/ser_axis.rb +45 -0
  71. data/lib/axlsx/drawing/series.rb +69 -0
  72. data/lib/axlsx/drawing/series_title.rb +23 -0
  73. data/lib/axlsx/drawing/str_data.rb +42 -0
  74. data/lib/axlsx/drawing/str_val.rb +34 -0
  75. data/lib/axlsx/drawing/title.rb +96 -0
  76. data/lib/axlsx/drawing/two_cell_anchor.rb +92 -0
  77. data/lib/axlsx/drawing/val_axis.rb +37 -0
  78. data/lib/axlsx/drawing/view_3D.rb +115 -0
  79. data/lib/axlsx/drawing/vml_drawing.rb +42 -0
  80. data/lib/axlsx/drawing/vml_shape.rb +66 -0
  81. data/lib/axlsx/package.rb +363 -0
  82. data/lib/axlsx/rels/relationship.rb +129 -0
  83. data/lib/axlsx/rels/relationships.rb +29 -0
  84. data/lib/axlsx/stylesheet/border.rb +71 -0
  85. data/lib/axlsx/stylesheet/border_pr.rb +71 -0
  86. data/lib/axlsx/stylesheet/cell_alignment.rb +132 -0
  87. data/lib/axlsx/stylesheet/cell_protection.rb +41 -0
  88. data/lib/axlsx/stylesheet/cell_style.rb +72 -0
  89. data/lib/axlsx/stylesheet/color.rb +76 -0
  90. data/lib/axlsx/stylesheet/dxf.rb +79 -0
  91. data/lib/axlsx/stylesheet/fill.rb +35 -0
  92. data/lib/axlsx/stylesheet/font.rb +148 -0
  93. data/lib/axlsx/stylesheet/gradient_fill.rb +103 -0
  94. data/lib/axlsx/stylesheet/gradient_stop.rb +37 -0
  95. data/lib/axlsx/stylesheet/num_fmt.rb +86 -0
  96. data/lib/axlsx/stylesheet/pattern_fill.rb +73 -0
  97. data/lib/axlsx/stylesheet/styles.rb +420 -0
  98. data/lib/axlsx/stylesheet/table_style.rb +54 -0
  99. data/lib/axlsx/stylesheet/table_style_element.rb +77 -0
  100. data/lib/axlsx/stylesheet/table_styles.rb +46 -0
  101. data/lib/axlsx/stylesheet/xf.rb +147 -0
  102. data/lib/axlsx/util/accessors.rb +64 -0
  103. data/lib/axlsx/util/constants.rb +397 -0
  104. data/lib/axlsx/util/mime_type_utils.rb +11 -0
  105. data/lib/axlsx/util/options_parser.rb +16 -0
  106. data/lib/axlsx/util/parser.rb +44 -0
  107. data/lib/axlsx/util/serialized_attributes.rb +89 -0
  108. data/lib/axlsx/util/simple_typed_list.rb +179 -0
  109. data/lib/axlsx/util/storage.rb +146 -0
  110. data/lib/axlsx/util/string.rb +7 -0
  111. data/lib/axlsx/util/validators.rb +311 -0
  112. data/lib/axlsx/version.rb +5 -0
  113. data/lib/axlsx/workbook/defined_name.rb +128 -0
  114. data/lib/axlsx/workbook/defined_names.rb +21 -0
  115. data/lib/axlsx/workbook/shared_strings_table.rb +77 -0
  116. data/lib/axlsx/workbook/workbook.rb +375 -0
  117. data/lib/axlsx/workbook/workbook_view.rb +78 -0
  118. data/lib/axlsx/workbook/workbook_views.rb +22 -0
  119. data/lib/axlsx/workbook/worksheet/auto_filter/auto_filter.rb +77 -0
  120. data/lib/axlsx/workbook/worksheet/auto_filter/filter_column.rb +94 -0
  121. data/lib/axlsx/workbook/worksheet/auto_filter/filters.rb +244 -0
  122. data/lib/axlsx/workbook/worksheet/break.rb +35 -0
  123. data/lib/axlsx/workbook/worksheet/cell.rb +475 -0
  124. data/lib/axlsx/workbook/worksheet/cell_serializer.rb +166 -0
  125. data/lib/axlsx/workbook/worksheet/cfvo.rb +60 -0
  126. data/lib/axlsx/workbook/worksheet/cfvos.rb +15 -0
  127. data/lib/axlsx/workbook/worksheet/col.rb +141 -0
  128. data/lib/axlsx/workbook/worksheet/col_breaks.rb +35 -0
  129. data/lib/axlsx/workbook/worksheet/color_scale.rb +110 -0
  130. data/lib/axlsx/workbook/worksheet/cols.rb +20 -0
  131. data/lib/axlsx/workbook/worksheet/comment.rb +91 -0
  132. data/lib/axlsx/workbook/worksheet/comments.rb +82 -0
  133. data/lib/axlsx/workbook/worksheet/conditional_formatting.rb +82 -0
  134. data/lib/axlsx/workbook/worksheet/conditional_formatting_rule.rb +220 -0
  135. data/lib/axlsx/workbook/worksheet/conditional_formattings.rb +25 -0
  136. data/lib/axlsx/workbook/worksheet/data_bar.rb +129 -0
  137. data/lib/axlsx/workbook/worksheet/data_validation.rb +246 -0
  138. data/lib/axlsx/workbook/worksheet/data_validations.rb +28 -0
  139. data/lib/axlsx/workbook/worksheet/date_time_converter.rb +30 -0
  140. data/lib/axlsx/workbook/worksheet/dimension.rb +64 -0
  141. data/lib/axlsx/workbook/worksheet/header_footer.rb +52 -0
  142. data/lib/axlsx/workbook/worksheet/icon_set.rb +81 -0
  143. data/lib/axlsx/workbook/worksheet/merged_cells.rb +37 -0
  144. data/lib/axlsx/workbook/worksheet/outline_pr.rb +33 -0
  145. data/lib/axlsx/workbook/worksheet/page_margins.rb +97 -0
  146. data/lib/axlsx/workbook/worksheet/page_set_up_pr.rb +44 -0
  147. data/lib/axlsx/workbook/worksheet/page_setup.rb +240 -0
  148. data/lib/axlsx/workbook/worksheet/pane.rb +139 -0
  149. data/lib/axlsx/workbook/worksheet/pivot_table.rb +289 -0
  150. data/lib/axlsx/workbook/worksheet/pivot_table_cache_definition.rb +66 -0
  151. data/lib/axlsx/workbook/worksheet/pivot_tables.rb +24 -0
  152. data/lib/axlsx/workbook/worksheet/print_options.rb +39 -0
  153. data/lib/axlsx/workbook/worksheet/protected_range.rb +47 -0
  154. data/lib/axlsx/workbook/worksheet/protected_ranges.rb +34 -0
  155. data/lib/axlsx/workbook/worksheet/rich_text.rb +35 -0
  156. data/lib/axlsx/workbook/worksheet/rich_text_run.rb +254 -0
  157. data/lib/axlsx/workbook/worksheet/row.rb +161 -0
  158. data/lib/axlsx/workbook/worksheet/row_breaks.rb +33 -0
  159. data/lib/axlsx/workbook/worksheet/selection.rb +101 -0
  160. data/lib/axlsx/workbook/worksheet/sheet_calc_pr.rb +29 -0
  161. data/lib/axlsx/workbook/worksheet/sheet_data.rb +27 -0
  162. data/lib/axlsx/workbook/worksheet/sheet_format_pr.rb +60 -0
  163. data/lib/axlsx/workbook/worksheet/sheet_pr.rb +87 -0
  164. data/lib/axlsx/workbook/worksheet/sheet_protection.rb +118 -0
  165. data/lib/axlsx/workbook/worksheet/sheet_view.rb +213 -0
  166. data/lib/axlsx/workbook/worksheet/table.rb +102 -0
  167. data/lib/axlsx/workbook/worksheet/table_style_info.rb +49 -0
  168. data/lib/axlsx/workbook/worksheet/tables.rb +31 -0
  169. data/lib/axlsx/workbook/worksheet/worksheet.rb +799 -0
  170. data/lib/axlsx/workbook/worksheet/worksheet_comments.rb +58 -0
  171. data/lib/axlsx/workbook/worksheet/worksheet_drawing.rb +58 -0
  172. data/lib/axlsx/workbook/worksheet/worksheet_hyperlink.rb +74 -0
  173. data/lib/axlsx/workbook/worksheet/worksheet_hyperlinks.rb +38 -0
  174. data/lib/schema/dc.xsd +118 -0
  175. data/lib/schema/dcmitype.xsd +52 -0
  176. data/lib/schema/dcterms.xsd +331 -0
  177. data/lib/schema/dml-chart.xsd +1499 -0
  178. data/lib/schema/dml-chartDrawing.xsd +146 -0
  179. data/lib/schema/dml-compatibility.xsd +14 -0
  180. data/lib/schema/dml-diagram.xsd +1091 -0
  181. data/lib/schema/dml-lockedCanvas.xsd +11 -0
  182. data/lib/schema/dml-main.xsd +3048 -0
  183. data/lib/schema/dml-picture.xsd +23 -0
  184. data/lib/schema/dml-spreadsheetDrawing.xsd +185 -0
  185. data/lib/schema/dml-wordprocessingDrawing.xsd +185 -0
  186. data/lib/schema/opc-contentTypes.xsd +42 -0
  187. data/lib/schema/opc-coreProperties.xsd +54 -0
  188. data/lib/schema/opc-digSig.xsd +49 -0
  189. data/lib/schema/opc-relationships.xsd +33 -0
  190. data/lib/schema/pml.xsd +1676 -0
  191. data/lib/schema/shared-additionalCharacteristics.xsd +28 -0
  192. data/lib/schema/shared-bibliography.xsd +144 -0
  193. data/lib/schema/shared-commonSimpleTypes.xsd +166 -0
  194. data/lib/schema/shared-customXmlDataProperties.xsd +25 -0
  195. data/lib/schema/shared-customXmlSchemaProperties.xsd +18 -0
  196. data/lib/schema/shared-documentPropertiesCustom.xsd +59 -0
  197. data/lib/schema/shared-documentPropertiesExtended.xsd +56 -0
  198. data/lib/schema/shared-documentPropertiesVariantTypes.xsd +195 -0
  199. data/lib/schema/shared-math.xsd +582 -0
  200. data/lib/schema/shared-relationshipReference.xsd +25 -0
  201. data/lib/schema/sml.xsd +4434 -0
  202. data/lib/schema/vml-main.xsd +569 -0
  203. data/lib/schema/vml-officeDrawing.xsd +509 -0
  204. data/lib/schema/vml-presentationDrawing.xsd +12 -0
  205. data/lib/schema/vml-spreadsheetDrawing.xsd +108 -0
  206. data/lib/schema/vml-wordprocessingDrawing.xsd +96 -0
  207. data/lib/schema/wml.xsd +3644 -0
  208. data/lib/schema/xml.xsd +116 -0
  209. data/test/benchmark.rb +72 -0
  210. data/test/content_type/tc_content_type.rb +76 -0
  211. data/test/content_type/tc_default.rb +16 -0
  212. data/test/content_type/tc_override.rb +14 -0
  213. data/test/doc_props/tc_app.rb +43 -0
  214. data/test/doc_props/tc_core.rb +42 -0
  215. data/test/drawing/tc_axes.rb +8 -0
  216. data/test/drawing/tc_axis.rb +112 -0
  217. data/test/drawing/tc_bar_3D_chart.rb +71 -0
  218. data/test/drawing/tc_bar_series.rb +37 -0
  219. data/test/drawing/tc_bubble_chart.rb +44 -0
  220. data/test/drawing/tc_bubble_series.rb +21 -0
  221. data/test/drawing/tc_cat_axis.rb +31 -0
  222. data/test/drawing/tc_cat_axis_data.rb +27 -0
  223. data/test/drawing/tc_chart.rb +110 -0
  224. data/test/drawing/tc_d_lbls.rb +57 -0
  225. data/test/drawing/tc_data_source.rb +23 -0
  226. data/test/drawing/tc_drawing.rb +80 -0
  227. data/test/drawing/tc_graphic_frame.rb +27 -0
  228. data/test/drawing/tc_hyperlink.rb +64 -0
  229. data/test/drawing/tc_line_3d_chart.rb +47 -0
  230. data/test/drawing/tc_line_chart.rb +39 -0
  231. data/test/drawing/tc_line_series.rb +71 -0
  232. data/test/drawing/tc_marker.rb +44 -0
  233. data/test/drawing/tc_named_axis_data.rb +27 -0
  234. data/test/drawing/tc_num_data.rb +31 -0
  235. data/test/drawing/tc_num_val.rb +29 -0
  236. data/test/drawing/tc_one_cell_anchor.rb +66 -0
  237. data/test/drawing/tc_pic.rb +106 -0
  238. data/test/drawing/tc_picture_locking.rb +72 -0
  239. data/test/drawing/tc_pie_3D_chart.rb +28 -0
  240. data/test/drawing/tc_pie_series.rb +32 -0
  241. data/test/drawing/tc_scaling.rb +36 -0
  242. data/test/drawing/tc_scatter_chart.rb +48 -0
  243. data/test/drawing/tc_scatter_series.rb +45 -0
  244. data/test/drawing/tc_ser_axis.rb +31 -0
  245. data/test/drawing/tc_series.rb +23 -0
  246. data/test/drawing/tc_series_title.rb +33 -0
  247. data/test/drawing/tc_str_data.rb +18 -0
  248. data/test/drawing/tc_str_val.rb +30 -0
  249. data/test/drawing/tc_title.rb +49 -0
  250. data/test/drawing/tc_two_cell_anchor.rb +36 -0
  251. data/test/drawing/tc_val_axis.rb +24 -0
  252. data/test/drawing/tc_view_3D.rb +54 -0
  253. data/test/drawing/tc_vml_drawing.rb +25 -0
  254. data/test/drawing/tc_vml_shape.rb +106 -0
  255. data/test/profile.rb +24 -0
  256. data/test/rels/tc_relationship.rb +44 -0
  257. data/test/rels/tc_relationships.rb +37 -0
  258. data/test/stylesheet/tc_border.rb +37 -0
  259. data/test/stylesheet/tc_border_pr.rb +32 -0
  260. data/test/stylesheet/tc_cell_alignment.rb +81 -0
  261. data/test/stylesheet/tc_cell_protection.rb +29 -0
  262. data/test/stylesheet/tc_cell_style.rb +57 -0
  263. data/test/stylesheet/tc_color.rb +43 -0
  264. data/test/stylesheet/tc_dxf.rb +81 -0
  265. data/test/stylesheet/tc_fill.rb +18 -0
  266. data/test/stylesheet/tc_font.rb +121 -0
  267. data/test/stylesheet/tc_gradient_fill.rb +72 -0
  268. data/test/stylesheet/tc_gradient_stop.rb +31 -0
  269. data/test/stylesheet/tc_num_fmt.rb +30 -0
  270. data/test/stylesheet/tc_pattern_fill.rb +43 -0
  271. data/test/stylesheet/tc_styles.rb +235 -0
  272. data/test/stylesheet/tc_table_style.rb +44 -0
  273. data/test/stylesheet/tc_table_style_element.rb +45 -0
  274. data/test/stylesheet/tc_table_styles.rb +29 -0
  275. data/test/stylesheet/tc_xf.rb +120 -0
  276. data/test/tc_axlsx.rb +82 -0
  277. data/test/tc_helper.rb +10 -0
  278. data/test/tc_package.rb +233 -0
  279. data/test/util/tc_mime_type_utils.rb +13 -0
  280. data/test/util/tc_serialized_attributes.rb +19 -0
  281. data/test/util/tc_simple_typed_list.rb +77 -0
  282. data/test/util/tc_validators.rb +210 -0
  283. data/test/workbook/tc_defined_name.rb +49 -0
  284. data/test/workbook/tc_shared_strings_table.rb +58 -0
  285. data/test/workbook/tc_workbook.rb +145 -0
  286. data/test/workbook/tc_workbook_view.rb +50 -0
  287. data/test/workbook/worksheet/auto_filter/tc_auto_filter.rb +38 -0
  288. data/test/workbook/worksheet/auto_filter/tc_filter_column.rb +76 -0
  289. data/test/workbook/worksheet/auto_filter/tc_filters.rb +50 -0
  290. data/test/workbook/worksheet/tc_break.rb +49 -0
  291. data/test/workbook/worksheet/tc_cell.rb +373 -0
  292. data/test/workbook/worksheet/tc_cfvo.rb +31 -0
  293. data/test/workbook/worksheet/tc_col.rb +78 -0
  294. data/test/workbook/worksheet/tc_color_scale.rb +58 -0
  295. data/test/workbook/worksheet/tc_comment.rb +72 -0
  296. data/test/workbook/worksheet/tc_comments.rb +57 -0
  297. data/test/workbook/worksheet/tc_conditional_formatting.rb +224 -0
  298. data/test/workbook/worksheet/tc_data_bar.rb +46 -0
  299. data/test/workbook/worksheet/tc_data_validation.rb +265 -0
  300. data/test/workbook/worksheet/tc_date_time_converter.rb +124 -0
  301. data/test/workbook/worksheet/tc_header_footer.rb +151 -0
  302. data/test/workbook/worksheet/tc_icon_set.rb +45 -0
  303. data/test/workbook/worksheet/tc_outline_pr.rb +19 -0
  304. data/test/workbook/worksheet/tc_page_margins.rb +97 -0
  305. data/test/workbook/worksheet/tc_page_set_up_pr.rb +15 -0
  306. data/test/workbook/worksheet/tc_page_setup.rb +143 -0
  307. data/test/workbook/worksheet/tc_pane.rb +54 -0
  308. data/test/workbook/worksheet/tc_pivot_table.rb +140 -0
  309. data/test/workbook/worksheet/tc_pivot_table_cache_definition.rb +54 -0
  310. data/test/workbook/worksheet/tc_print_options.rb +72 -0
  311. data/test/workbook/worksheet/tc_protected_range.rb +17 -0
  312. data/test/workbook/worksheet/tc_rich_text.rb +44 -0
  313. data/test/workbook/worksheet/tc_rich_text_run.rb +172 -0
  314. data/test/workbook/worksheet/tc_row.rb +122 -0
  315. data/test/workbook/worksheet/tc_selection.rb +55 -0
  316. data/test/workbook/worksheet/tc_sheet_calc_pr.rb +18 -0
  317. data/test/workbook/worksheet/tc_sheet_format_pr.rb +88 -0
  318. data/test/workbook/worksheet/tc_sheet_pr.rb +49 -0
  319. data/test/workbook/worksheet/tc_sheet_protection.rb +117 -0
  320. data/test/workbook/worksheet/tc_sheet_view.rb +214 -0
  321. data/test/workbook/worksheet/tc_table.rb +68 -0
  322. data/test/workbook/worksheet/tc_table_style_info.rb +53 -0
  323. data/test/workbook/worksheet/tc_worksheet.rb +594 -0
  324. data/test/workbook/worksheet/tc_worksheet_hyperlink.rb +55 -0
  325. metadata +582 -0
@@ -0,0 +1,37 @@
1
+ # encoding: UTF-8
2
+ module Axlsx
3
+ # the ValAxis class defines a chart value axis.
4
+ class ValAxis < Axis
5
+
6
+ # This element specifies how the value axis crosses the category axis.
7
+ # must be one of [:between, :midCat]
8
+ # @return [Symbol]
9
+ attr_reader :cross_between
10
+ alias :crossBetween :cross_between
11
+
12
+ # Creates a new ValAxis object
13
+ # @option options [Symbol] crosses_between
14
+ def initialize(options={})
15
+ self.cross_between = :between
16
+ super(options)
17
+ end
18
+
19
+ # @see cross_between
20
+ def cross_between=(v)
21
+ RestrictionValidator.validate "ValAxis.cross_between", [:between, :midCat], v
22
+ @cross_between = v
23
+ end
24
+ alias :crossBetween= :cross_between=
25
+
26
+ # Serializes the object
27
+ # @param [String] str
28
+ # @return [String]
29
+ def to_xml_string(str = '')
30
+ str << '<c:valAx>'
31
+ super(str)
32
+ str << ('<c:crossBetween val="' << @cross_between.to_s << '"/>')
33
+ str << '</c:valAx>'
34
+ end
35
+
36
+ end
37
+ end
@@ -0,0 +1,115 @@
1
+ # encoding: UTF-8
2
+ module Axlsx
3
+ # 3D attributes for a chart.
4
+ class View3D
5
+
6
+ include Axlsx::OptionsParser
7
+
8
+ # Creates a new View3D for charts
9
+ # @option options [Integer] rot_x
10
+ # @option options [String] h_percent
11
+ # @option options [Integer] rot_y
12
+ # @option options [String] depth_percent
13
+ # @option options [Boolean] r_ang_ax
14
+ # @option options [Integer] perspective
15
+ def initialize(options={})
16
+ @rot_x, @h_percent, @rot_y, @depth_percent, @r_ang_ax, @perspective = nil, nil, nil, nil, nil, nil
17
+ parse_options options
18
+ end
19
+
20
+ # Validation for hPercent
21
+ H_PERCENT_REGEX = /0*(([5-9])|([1-9][0-9])|([1-4][0-9][0-9])|500)/
22
+
23
+ # validation for depthPercent
24
+ DEPTH_PERCENT_REGEX = /0*(([2-9][0-9])|([1-9][0-9][0-9])|(1[0-9][0-9][0-9])|2000)/
25
+
26
+ # x rotation for the chart
27
+ # must be between -90 and 90
28
+ # @return [Integer]
29
+ attr_reader :rot_x
30
+ alias :rotX :rot_x
31
+
32
+ # height of chart as % of chart width
33
+ # must be between 5% and 500%
34
+ # @return [String]
35
+ attr_reader :h_percent
36
+ alias :hPercent :h_percent
37
+
38
+ # y rotation for the chart
39
+ # must be between 0 and 360
40
+ # @return [Integer]
41
+ attr_reader :rot_y
42
+ alias :rotY :rot_y
43
+
44
+ # depth or chart as % of chart width
45
+ # must be between 20% and 2000%
46
+ # @return [String]
47
+ attr_reader :depth_percent
48
+ alias :depthPercent :depth_percent
49
+
50
+ # Chart axis are at right angles
51
+ # @return [Boolean]
52
+ attr_reader :r_ang_ax
53
+ alias :rAngAx :r_ang_ax
54
+
55
+ # field of view angle
56
+ # @return [Integer]
57
+ attr_reader :perspective
58
+
59
+ # @see rot_x
60
+ def rot_x=(v)
61
+ RangeValidator.validate "View3D.rot_x", -90, 90, v
62
+ @rot_x = v
63
+ end
64
+ alias :rotX= :rot_x=
65
+
66
+ # @see h_percent
67
+ def h_percent=(v)
68
+ RegexValidator.validate "#{self.class}.h_percent", H_PERCENT_REGEX, v
69
+ @h_percent = v
70
+ end
71
+ alias :hPercent= :h_percent=
72
+
73
+ # @see rot_y
74
+ def rot_y=(v)
75
+ RangeValidator.validate "View3D.rot_y", 0, 360, v
76
+ @rot_y = v
77
+ end
78
+ alias :rotY= :rot_y=
79
+
80
+ # @see depth_percent
81
+ def depth_percent=(v) RegexValidator.validate "#{self.class}.depth_percent", DEPTH_PERCENT_REGEX, v; @depth_percent = v; end
82
+ alias :depthPercent= :depth_percent=
83
+
84
+ # @see r_ang_ax
85
+ def r_ang_ax=(v) Axlsx::validate_boolean(v); @r_ang_ax = v; end
86
+ alias :rAngAx= :r_ang_ax=
87
+
88
+ # @see perspective
89
+ def perspective=(v)
90
+ RangeValidator.validate "View3D.perspective", 0, 240, v
91
+ @perspective = v
92
+ end
93
+
94
+ # DataTypeValidator.validate "#{self.class}.perspective", [Integer], v, lambda {|arg| arg >= 0 && arg <= 240 }; @perspective = v; end
95
+
96
+ # Serializes the object
97
+ # @param [String] str
98
+ # @return [String]
99
+ def to_xml_string(str = '')
100
+ str << '<c:view3D>'
101
+ %w(rot_x h_percent rot_y depth_percent r_ang_ax perspective).each do |key|
102
+ str << element_for_attribute(key, 'c')
103
+ end
104
+ str << '</c:view3D>'
105
+ end
106
+
107
+ private
108
+ # Note: move this to Axlsx module if we find the smae pattern elsewhere.
109
+ def element_for_attribute(name, namespace='')
110
+ val = instance_values[name]
111
+ return "" if val == nil
112
+ "<%s:%s val='%s'/>" % [namespace, Axlsx::camel(name, false), val]
113
+ end
114
+ end
115
+ end
@@ -0,0 +1,42 @@
1
+ module Axlsx
2
+
3
+ # a vml drawing used for comments in excel.
4
+ class VmlDrawing
5
+
6
+ # creates a new Vml Drawing object.
7
+ # @param [Comments] comments the comments object this drawing is associated with
8
+ def initialize(comments)
9
+ raise ArgumentError, "you must provide a comments object" unless comments.is_a?(Comments)
10
+ @comments = comments
11
+ end
12
+
13
+ # The part name for this vml drawing
14
+ # @return [String]
15
+ def pn
16
+ "#{VML_DRAWING_PN}" % (@comments.worksheet.index + 1)
17
+ end
18
+
19
+ # serialize the vml_drawing to xml.
20
+ # @param [String] str
21
+ # @return [String]
22
+ def to_xml_string(str = '')
23
+ str << <<BAD_PROGRAMMER
24
+ <xml xmlns:v="urn:schemas-microsoft-com:vml"
25
+ xmlns:o="urn:schemas-microsoft-com:office:office"
26
+ xmlns:x="urn:schemas-microsoft-com:office:excel">
27
+ <o:shapelayout v:ext="edit">
28
+ <o:idmap v:ext="edit" data="#{@comments.worksheet.index+1}"/>
29
+ </o:shapelayout>
30
+ <v:shapetype id="_x0000_t202" coordsize="21600,21600" o:spt="202"
31
+ path="m0,0l0,21600,21600,21600,21600,0xe">
32
+ <v:stroke joinstyle="miter"/>
33
+ <v:path gradientshapeok="t" o:connecttype="rect"/>
34
+ </v:shapetype>
35
+ BAD_PROGRAMMER
36
+ @comments.each { |comment| comment.vml_shape.to_xml_string str }
37
+ str << "</xml>"
38
+
39
+ end
40
+
41
+ end
42
+ end
@@ -0,0 +1,66 @@
1
+ module Axlsx
2
+
3
+ # A VmlShape is used to position and render a comment.
4
+ class VmlShape
5
+
6
+ include Axlsx::OptionsParser
7
+ include Axlsx::Accessors
8
+
9
+ # Creates a new VmlShape
10
+ # @option options [Integer] row
11
+ # @option options [Integer] column
12
+ # @option options [Integer] left_column
13
+ # @option options [Integer] left_offset
14
+ # @option options [Integer] top_row
15
+ # @option options [Integer] top_offset
16
+ # @option options [Integer] right_column
17
+ # @option options [Integer] right_offset
18
+ # @option options [Integer] bottom_row
19
+ # @option options [Integer] bottom_offset
20
+ def initialize(options={})
21
+ @row = @column = @left_column = @top_row = @right_column = @bottom_row = 0
22
+ @left_offset = 15
23
+ @top_offset = 2
24
+ @right_offset = 50
25
+ @bottom_offset = 5
26
+ @visible = true
27
+ @id = (0...8).map{65.+(rand(25)).chr}.join
28
+ parse_options options
29
+ yield self if block_given?
30
+ end
31
+
32
+ unsigned_int_attr_accessor :row, :column, :left_column, :left_offset, :top_row, :top_offset,
33
+ :right_column, :right_offset, :bottom_row, :bottom_offset
34
+
35
+ boolean_attr_accessor :visible
36
+
37
+ # serialize the shape to a string
38
+ # @param [String] str
39
+ # @return [String]
40
+ def to_xml_string(str ='')
41
+ str << <<SHAME_ON_YOU
42
+
43
+ <v:shape id="#{@id}" type="#_x0000_t202" fillcolor="#ffffa1 [80]" o:insetmode="auto"
44
+ style="visibility:#{@visible ? 'visible' : 'hidden'}">
45
+ <v:fill color2="#ffffa1 [80]"/>
46
+ <v:shadow on="t" obscured="t"/>
47
+ <v:path o:connecttype="none"/>
48
+ <v:textbox style='mso-fit-text-with-word-wrap:t'>
49
+ <div style='text-align:left'></div>
50
+ </v:textbox>
51
+
52
+ <x:ClientData ObjectType="Note">
53
+ <x:MoveWithCells/>
54
+ <x:SizeWithCells/>
55
+ <x:Anchor>#{left_column}, #{left_offset}, #{top_row}, #{top_offset}, #{right_column}, #{right_offset}, #{bottom_row}, #{bottom_offset}</x:Anchor>
56
+ <x:AutoFill>False</x:AutoFill>
57
+ <x:Row>#{row}</x:Row>
58
+ <x:Column>#{column}</x:Column>
59
+ #{@visible ? '<x:Visible/>' : ''}
60
+ </x:ClientData>
61
+ </v:shape>
62
+ SHAME_ON_YOU
63
+
64
+ end
65
+ end
66
+ end
@@ -0,0 +1,363 @@
1
+ # encoding: UTF-8
2
+ module Axlsx
3
+ # Package is responsible for managing all the bits and peices that Open Office XML requires to make a valid
4
+ # xlsx document including valdation and serialization.
5
+ class Package
6
+ include Axlsx::OptionsParser
7
+
8
+ # provides access to the app doc properties for this package
9
+ # see App
10
+ attr_reader :app
11
+
12
+ # provides access to the core doc properties for the package
13
+ # see Core
14
+ attr_reader :core
15
+
16
+ # Initializes your package
17
+ #
18
+ # @param [Hash] options A hash that you can use to specify the author and workbook for this package.
19
+ # @option options [String] :author The author of the document
20
+ # @option options [Time] :created_at Timestamp in the document properties (defaults to current time).
21
+ # @option options [Boolean] :use_shared_strings This is passed to the workbook to specify that shared strings should be used when serializing the package.
22
+ # @example Package.new :author => 'you!', :workbook => Workbook.new
23
+ def initialize(options={})
24
+ @workbook = nil
25
+ @core, @app = Core.new, App.new
26
+ @core.creator = options[:author] || @core.creator
27
+ @core.created = options[:created_at]
28
+ parse_options options
29
+ yield self if block_given?
30
+ end
31
+
32
+ # Shortcut to specify that the workbook should use autowidth
33
+ # @see Workbook#use_autowidth
34
+ def use_autowidth=(v)
35
+ Axlsx::validate_boolean(v);
36
+ workbook.use_autowidth = v
37
+ end
38
+
39
+
40
+
41
+ # Shortcut to determine if the workbook is configured to use shared strings
42
+ # @see Workbook#use_shared_strings
43
+ def use_shared_strings
44
+ workbook.use_shared_strings
45
+ end
46
+
47
+ # Shortcut to specify that the workbook should use shared strings
48
+ # @see Workbook#use_shared_strings
49
+ def use_shared_strings=(v)
50
+ Axlsx::validate_boolean(v);
51
+ workbook.use_shared_strings = v
52
+ end
53
+ # The workbook this package will serialize or validate.
54
+ # @return [Workbook] If no workbook instance has been assigned with this package a new Workbook instance is returned.
55
+ # @raise ArgumentError if workbook parameter is not a Workbook instance.
56
+ # @note As there are multiple ways to instantiate a workbook for the package,
57
+ # here are a few examples:
58
+ # # assign directly during package instanciation
59
+ # wb = Package.new(:workbook => Workbook.new).workbook
60
+ #
61
+ # # get a fresh workbook automatically from the package
62
+ # wb = Pacakge.new().workbook
63
+ # # # set the workbook after creating the package
64
+ # wb = Package.new().workbook = Workbook.new
65
+ def workbook
66
+ @workbook || @workbook = Workbook.new
67
+ yield @workbook if block_given?
68
+ @workbook
69
+ end
70
+
71
+ #def self.parse(input, confirm_valid = false)
72
+ # p = Package.new
73
+ # z = Zip::File.open(input)
74
+ # p.workbook = Workbook.parse z.get_entry(WORKBOOK_PN)
75
+ # p
76
+ #end
77
+
78
+ # @see workbook
79
+ def workbook=(workbook) DataTypeValidator.validate :Package_workbook, Workbook, workbook; @workbook = workbook; end
80
+
81
+ # Serialize your workbook to disk as an xlsx document.
82
+ #
83
+ # @param [String] output The name of the file you want to serialize your package to
84
+ # @param [Boolean] confirm_valid Validate the package prior to serialization.
85
+ # @return [Boolean] False if confirm_valid and validation errors exist. True if the package was serialized
86
+ # @note A tremendous amount of effort has gone into ensuring that you cannot create invalid xlsx documents.
87
+ # confirm_valid should be used in the rare case that you cannot open the serialized file.
88
+ # @see Package#validate
89
+ # @example
90
+ # # This is how easy it is to create a valid xlsx file. Of course you might want to add a sheet or two, and maybe some data, styles and charts.
91
+ # # Take a look at the README for an example of how to do it!
92
+ #
93
+ # #serialize to a file
94
+ # p = Axlsx::Package.new
95
+ # # ......add cool stuff to your workbook......
96
+ # p.serialize("example.xlsx")
97
+ #
98
+ # # Serialize to a stream
99
+ # s = p.to_stream()
100
+ # File.open('example_streamed.xlsx', 'w') { |f| f.write(s.read) }
101
+ def serialize(output, confirm_valid=false)
102
+ return false unless !confirm_valid || self.validate.empty?
103
+ Relationship.clear_cached_instances
104
+ Zip::OutputStream.open(output) do |zip|
105
+ write_parts(zip)
106
+ end
107
+ true
108
+ end
109
+
110
+
111
+ # Serialize your workbook to a StringIO instance
112
+ # @param [Boolean] confirm_valid Validate the package prior to serialization.
113
+ # @return [StringIO|Boolean] False if confirm_valid and validation errors exist. rewound string IO if not.
114
+ def to_stream(confirm_valid=false)
115
+ return false unless !confirm_valid || self.validate.empty?
116
+ Relationship.clear_cached_instances
117
+ zip = write_parts(Zip::OutputStream.new(StringIO.new, true))
118
+ stream = zip.close_buffer
119
+ stream.rewind
120
+ stream
121
+ end
122
+
123
+ # Encrypt the package into a CFB using the password provided
124
+ # This is not ready yet
125
+ def encrypt(file_name, password)
126
+ return false
127
+ # moc = MsOffCrypto.new(file_name, password)
128
+ # moc.save
129
+ end
130
+
131
+ # Validate all parts of the package against xsd schema.
132
+ # @return [Array] An array of all validation errors found.
133
+ # @note This gem includes all schema from OfficeOpenXML-XMLSchema-Transitional.zip and OpenPackagingConventions-XMLSchema.zip
134
+ # as per ECMA-376, Third edition. opc schema require an internet connection to import remote schema from dublin core for dc,
135
+ # dcterms and xml namespaces. Those remote schema are included in this gem, and the original files have been altered to
136
+ # refer to the local versions.
137
+ #
138
+ # If by chance you are able to creat a package that does not validate it indicates that the internal
139
+ # validation is not robust enough and needs to be improved. Please report your errors to the gem author.
140
+ # @see http://www.ecma-international.org/publications/standards/Ecma-376.htm
141
+ # @example
142
+ # # The following will output any error messages found in serialization.
143
+ # p = Axlsx::Package.new
144
+ # # ... code to create sheets, charts, styles etc.
145
+ # p.validate.each { |error| puts error.message }
146
+ def validate
147
+ errors = []
148
+ parts.each do |part|
149
+ unless part[:schema].nil?
150
+ if part[:doc].is_a? String
151
+ errors.concat validate_single_doc(part[:schema], part[:doc])
152
+ else
153
+ errors.concat validate_single_doc(part[:schema], part[:doc].to_xml_string)
154
+ end
155
+ end
156
+ end
157
+ errors
158
+ end
159
+
160
+ private
161
+
162
+ # Writes the package parts to a zip archive.
163
+ # @param [Zip::OutputStream] zip
164
+ # @return [Zip::OutputStream]
165
+ def write_parts(zip)
166
+ p = parts
167
+ p.each do |part|
168
+ #next unless part[:entry] == CORE_PN
169
+ unless part[:doc].nil?
170
+ zip.put_next_entry(zip_entry_for_part(part))
171
+ if part[:doc].is_a? String
172
+ entry = ['1.9.2', '1.9.3'].include?(RUBY_VERSION) ? part[:doc].force_encoding('BINARY') : part[:doc]
173
+ zip.puts(entry)
174
+ else
175
+ part[:doc].to_xml_string(zip)
176
+ end
177
+ end
178
+ unless part[:path].nil?
179
+ zip.put_next_entry(zip_entry_for_part(part))
180
+ # binread for 1.9.3
181
+ zip.write IO.respond_to?(:binread) ? IO.binread(part[:path]) : IO.read(part[:path])
182
+ end
183
+ end
184
+ zip
185
+ end
186
+
187
+ # Generate a Entry for the given package part.
188
+ # The important part here is to explicitly set the timestamp for the zip entry: Serializing axlsx packages
189
+ # with identical contents should result in identical zip files – however, the timestamp of a zip entry
190
+ # defaults to the time of serialization and therefore the zip file contents would be different every time
191
+ # the package is serialized.
192
+ #
193
+ # Note: {Core#created} also defaults to the current time – so to generate identical axlsx packages you have
194
+ # to set this explicitly, too (eg. with `Package.new(created_at: Time.local(2013, 1, 1))`).
195
+ #
196
+ # @param part A hash describing a part of this pacakge (see {#parts})
197
+ # @return [Zip::Entry]
198
+ def zip_entry_for_part(part)
199
+ timestamp = Zip::DOSTime.at(@core.created.to_i)
200
+ Zip::Entry.new("", part[:entry], "", "", 0, 0, Zip::Entry::DEFLATED, 0, timestamp)
201
+ end
202
+
203
+ # The parts of a package
204
+ # @return [Array] An array of hashes that define the entry, document and schema for each part of the package.
205
+ # @private
206
+ def parts
207
+ parts = [
208
+ {:entry => RELS_PN, :doc => relationships, :schema => RELS_XSD},
209
+ {:entry => "xl/#{STYLES_PN}", :doc => workbook.styles, :schema => SML_XSD},
210
+ {:entry => CORE_PN, :doc => @core, :schema => CORE_XSD},
211
+ {:entry => APP_PN, :doc => @app, :schema => APP_XSD},
212
+ {:entry => WORKBOOK_RELS_PN, :doc => workbook.relationships, :schema => RELS_XSD},
213
+ {:entry => CONTENT_TYPES_PN, :doc => content_types, :schema => CONTENT_TYPES_XSD},
214
+ {:entry => WORKBOOK_PN, :doc => workbook, :schema => SML_XSD}
215
+ ]
216
+
217
+ workbook.drawings.each do |drawing|
218
+ parts << {:entry => "xl/#{drawing.rels_pn}", :doc => drawing.relationships, :schema => RELS_XSD}
219
+ parts << {:entry => "xl/#{drawing.pn}", :doc => drawing, :schema => DRAWING_XSD}
220
+ end
221
+
222
+
223
+ workbook.tables.each do |table|
224
+ parts << {:entry => "xl/#{table.pn}", :doc => table, :schema => SML_XSD}
225
+ end
226
+ workbook.pivot_tables.each do |pivot_table|
227
+ cache_definition = pivot_table.cache_definition
228
+ parts << {:entry => "xl/#{pivot_table.rels_pn}", :doc => pivot_table.relationships, :schema => RELS_XSD}
229
+ parts << {:entry => "xl/#{pivot_table.pn}", :doc => pivot_table} #, :schema => SML_XSD}
230
+ parts << {:entry => "xl/#{cache_definition.pn}", :doc => cache_definition} #, :schema => SML_XSD}
231
+ end
232
+
233
+ workbook.comments.each do|comment|
234
+ if comment.size > 0
235
+ parts << { :entry => "xl/#{comment.pn}", :doc => comment, :schema => SML_XSD }
236
+ parts << { :entry => "xl/#{comment.vml_drawing.pn}", :doc => comment.vml_drawing, :schema => nil }
237
+ end
238
+ end
239
+
240
+ workbook.charts.each do |chart|
241
+ parts << {:entry => "xl/#{chart.pn}", :doc => chart, :schema => DRAWING_XSD}
242
+ end
243
+
244
+ workbook.images.each do |image|
245
+ parts << {:entry => "xl/#{image.pn}", :path => image.image_src}
246
+ end
247
+
248
+ if use_shared_strings
249
+ parts << {:entry => "xl/#{SHARED_STRINGS_PN}", :doc => workbook.shared_strings, :schema => SML_XSD}
250
+ end
251
+
252
+ workbook.worksheets.each do |sheet|
253
+ parts << {:entry => "xl/#{sheet.rels_pn}", :doc => sheet.relationships, :schema => RELS_XSD}
254
+ parts << {:entry => "xl/#{sheet.pn}", :doc => sheet, :schema => SML_XSD}
255
+ end
256
+ parts
257
+ end
258
+
259
+ # Performs xsd validation for a signle document
260
+ #
261
+ # @param [String] schema path to the xsd schema to be used in validation.
262
+ # @param [String] doc The xml text to be validated
263
+ # @return [Array] An array of all validation errors encountered.
264
+ # @private
265
+ def validate_single_doc(schema, doc)
266
+ schema = Nokogiri::XML::Schema(File.open(schema))
267
+ doc = Nokogiri::XML(doc)
268
+ errors = []
269
+ schema.validate(doc).each do |error|
270
+ errors << error
271
+ end
272
+ errors
273
+ end
274
+
275
+ # Appends override objects for drawings, charts, and sheets as they exist in your workbook to the default content types.
276
+ # @return [ContentType]
277
+ # @private
278
+ def content_types
279
+ c_types = base_content_types
280
+ workbook.drawings.each do |drawing|
281
+ c_types << Axlsx::Override.new(:PartName => "/xl/#{drawing.pn}",
282
+ :ContentType => DRAWING_CT)
283
+ end
284
+
285
+ workbook.charts.each do |chart|
286
+ c_types << Axlsx::Override.new(:PartName => "/xl/#{chart.pn}",
287
+ :ContentType => CHART_CT)
288
+ end
289
+
290
+ workbook.tables.each do |table|
291
+ c_types << Axlsx::Override.new(:PartName => "/xl/#{table.pn}",
292
+ :ContentType => TABLE_CT)
293
+ end
294
+
295
+ workbook.pivot_tables.each do |pivot_table|
296
+ c_types << Axlsx::Override.new(:PartName => "/xl/#{pivot_table.pn}",
297
+ :ContentType => PIVOT_TABLE_CT)
298
+ c_types << Axlsx::Override.new(:PartName => "/xl/#{pivot_table.cache_definition.pn}",
299
+ :ContentType => PIVOT_TABLE_CACHE_DEFINITION_CT)
300
+ end
301
+
302
+ workbook.comments.each do |comment|
303
+ if comment.size > 0
304
+ c_types << Axlsx::Override.new(:PartName => "/xl/#{comment.pn}",
305
+ :ContentType => COMMENT_CT)
306
+ end
307
+ end
308
+
309
+ if workbook.comments.size > 0
310
+ c_types << Axlsx::Default.new(:Extension => "vml", :ContentType => VML_DRAWING_CT)
311
+ end
312
+
313
+ workbook.worksheets.each do |sheet|
314
+ c_types << Axlsx::Override.new(:PartName => "/xl/#{sheet.pn}",
315
+ :ContentType => WORKSHEET_CT)
316
+ end
317
+ exts = workbook.images.map { |image| image.extname.downcase }
318
+ exts.uniq.each do |ext|
319
+ ct = if ['jpeg', 'jpg'].include?(ext)
320
+ JPEG_CT
321
+ elsif ext == 'gif'
322
+ GIF_CT
323
+ elsif ext == 'png'
324
+ PNG_CT
325
+ end
326
+ c_types << Axlsx::Default.new(:ContentType => ct, :Extension => ext )
327
+ end
328
+ if use_shared_strings
329
+ c_types << Axlsx::Override.new(:PartName => "/xl/#{SHARED_STRINGS_PN}",
330
+ :ContentType => SHARED_STRINGS_CT)
331
+ end
332
+ c_types
333
+ end
334
+
335
+ # Creates the minimum content types for generating a valid xlsx document.
336
+ # @return [ContentType]
337
+ # @private
338
+ def base_content_types
339
+ c_types = ContentType.new()
340
+ c_types << Default.new(:ContentType => RELS_CT, :Extension => RELS_EX)
341
+ c_types << Default.new(:Extension => XML_EX, :ContentType => XML_CT)
342
+ c_types << Override.new(:PartName => "/#{APP_PN}", :ContentType => APP_CT)
343
+ c_types << Override.new(:PartName => "/#{CORE_PN}", :ContentType => CORE_CT)
344
+ c_types << Override.new(:PartName => "/xl/#{STYLES_PN}", :ContentType => STYLES_CT)
345
+ c_types << Axlsx::Override.new(:PartName => "/#{WORKBOOK_PN}", :ContentType => WORKBOOK_CT)
346
+ c_types.lock
347
+ c_types
348
+ end
349
+
350
+ # Creates the relationships required for a valid xlsx document
351
+ # @return [Relationships]
352
+ # @private
353
+ def relationships
354
+ rels = Axlsx::Relationships.new
355
+ rels << Relationship.new(self, WORKBOOK_R, WORKBOOK_PN)
356
+ rels << Relationship.new(self, CORE_R, CORE_PN)
357
+ rels << Relationship.new(self, APP_R, APP_PN)
358
+ rels.lock
359
+ rels
360
+ end
361
+ end
362
+ end
363
+