caxlsx 3.2.0 → 3.4.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (301) hide show
  1. checksums.yaml +4 -4
  2. data/.yardopts +9 -9
  3. data/.yardopts_guide +18 -18
  4. data/CHANGELOG.md +394 -354
  5. data/LICENSE +21 -21
  6. data/README.md +184 -168
  7. data/Rakefile +28 -29
  8. data/examples/generate.rb +15 -15
  9. data/lib/axlsx/content_type/abstract_content_type.rb +29 -32
  10. data/lib/axlsx/content_type/content_type.rb +22 -26
  11. data/lib/axlsx/content_type/default.rb +21 -25
  12. data/lib/axlsx/content_type/override.rb +21 -25
  13. data/lib/axlsx/doc_props/app.rb +230 -235
  14. data/lib/axlsx/doc_props/core.rb +34 -39
  15. data/lib/axlsx/drawing/area_chart.rb +96 -99
  16. data/lib/axlsx/drawing/area_series.rb +107 -110
  17. data/lib/axlsx/drawing/ax_data_source.rb +21 -26
  18. data/lib/axlsx/drawing/axes.rb +60 -61
  19. data/lib/axlsx/drawing/axis.rb +185 -190
  20. data/lib/axlsx/drawing/bar_3D_chart.rb +145 -148
  21. data/lib/axlsx/drawing/bar_chart.rb +135 -138
  22. data/lib/axlsx/drawing/bar_series.rb +91 -97
  23. data/lib/axlsx/drawing/bubble_chart.rb +56 -59
  24. data/lib/axlsx/drawing/bubble_series.rb +60 -63
  25. data/lib/axlsx/drawing/cat_axis.rb +80 -85
  26. data/lib/axlsx/drawing/chart.rb +294 -276
  27. data/lib/axlsx/drawing/d_lbls.rb +92 -90
  28. data/lib/axlsx/drawing/drawing.rb +163 -167
  29. data/lib/axlsx/drawing/graphic_frame.rb +51 -54
  30. data/lib/axlsx/drawing/hyperlink.rb +97 -100
  31. data/lib/axlsx/drawing/line_3D_chart.rb +64 -68
  32. data/lib/axlsx/drawing/line_chart.rb +96 -99
  33. data/lib/axlsx/drawing/line_series.rb +107 -110
  34. data/lib/axlsx/drawing/marker.rb +80 -84
  35. data/lib/axlsx/drawing/num_data.rb +47 -52
  36. data/lib/axlsx/drawing/num_data_source.rb +58 -62
  37. data/lib/axlsx/drawing/num_val.rb +31 -34
  38. data/lib/axlsx/drawing/one_cell_anchor.rb +97 -99
  39. data/lib/axlsx/drawing/pic.rb +244 -211
  40. data/lib/axlsx/drawing/picture_locking.rb +39 -42
  41. data/lib/axlsx/drawing/pie_3D_chart.rb +42 -47
  42. data/lib/axlsx/drawing/pie_series.rb +69 -74
  43. data/lib/axlsx/drawing/scaling.rb +57 -60
  44. data/lib/axlsx/drawing/scatter_chart.rb +71 -74
  45. data/lib/axlsx/drawing/scatter_series.rb +126 -129
  46. data/lib/axlsx/drawing/ser_axis.rb +41 -45
  47. data/lib/axlsx/drawing/series.rb +67 -69
  48. data/lib/axlsx/drawing/series_title.rb +23 -25
  49. data/lib/axlsx/drawing/str_data.rb +37 -42
  50. data/lib/axlsx/drawing/str_val.rb +31 -34
  51. data/lib/axlsx/drawing/title.rb +104 -97
  52. data/lib/axlsx/drawing/two_cell_anchor.rb +95 -97
  53. data/lib/axlsx/drawing/val_axis.rb +34 -37
  54. data/lib/axlsx/drawing/view_3D.rb +115 -115
  55. data/lib/axlsx/drawing/vml_drawing.rb +39 -42
  56. data/lib/axlsx/drawing/vml_shape.rb +63 -66
  57. data/lib/axlsx/package.rb +397 -388
  58. data/lib/axlsx/rels/relationship.rb +127 -130
  59. data/lib/axlsx/rels/relationships.rb +29 -32
  60. data/lib/axlsx/stylesheet/border.rb +70 -73
  61. data/lib/axlsx/stylesheet/border_pr.rb +69 -71
  62. data/lib/axlsx/stylesheet/cell_alignment.rb +124 -132
  63. data/lib/axlsx/stylesheet/cell_protection.rb +38 -41
  64. data/lib/axlsx/stylesheet/cell_style.rb +68 -72
  65. data/lib/axlsx/stylesheet/color.rb +77 -76
  66. data/lib/axlsx/stylesheet/dxf.rb +75 -79
  67. data/lib/axlsx/stylesheet/fill.rb +31 -35
  68. data/lib/axlsx/stylesheet/font.rb +157 -156
  69. data/lib/axlsx/stylesheet/gradient_fill.rb +101 -103
  70. data/lib/axlsx/stylesheet/gradient_stop.rb +36 -37
  71. data/lib/axlsx/stylesheet/num_fmt.rb +83 -86
  72. data/lib/axlsx/stylesheet/pattern_fill.rb +71 -73
  73. data/lib/axlsx/stylesheet/styles.rb +543 -494
  74. data/lib/axlsx/stylesheet/table_style.rb +51 -54
  75. data/lib/axlsx/stylesheet/table_style_element.rb +74 -77
  76. data/lib/axlsx/stylesheet/table_styles.rb +42 -46
  77. data/lib/axlsx/stylesheet/xf.rb +144 -147
  78. data/lib/axlsx/util/accessors.rb +62 -64
  79. data/lib/axlsx/util/constants.rb +414 -410
  80. data/lib/axlsx/util/mime_type_utils.rb +24 -11
  81. data/lib/axlsx/util/options_parser.rb +15 -16
  82. data/lib/axlsx/util/serialized_attributes.rb +88 -89
  83. data/lib/axlsx/util/simple_typed_list.rb +180 -179
  84. data/lib/axlsx/util/storage.rb +142 -146
  85. data/lib/axlsx/util/validators.rb +315 -312
  86. data/lib/axlsx/util/zip_command.rb +71 -73
  87. data/lib/axlsx/version.rb +4 -5
  88. data/lib/axlsx/workbook/defined_name.rb +129 -128
  89. data/lib/axlsx/workbook/defined_names.rb +20 -21
  90. data/lib/axlsx/workbook/shared_strings_table.rb +74 -77
  91. data/lib/axlsx/workbook/workbook.rb +430 -395
  92. data/lib/axlsx/workbook/workbook_view.rb +75 -80
  93. data/lib/axlsx/workbook/workbook_views.rb +20 -22
  94. data/lib/axlsx/workbook/worksheet/auto_filter/auto_filter.rb +78 -77
  95. data/lib/axlsx/workbook/worksheet/auto_filter/filter_column.rb +94 -94
  96. data/lib/axlsx/workbook/worksheet/auto_filter/filters.rb +243 -244
  97. data/lib/axlsx/workbook/worksheet/border_creator.rb +79 -0
  98. data/lib/axlsx/workbook/worksheet/break.rb +32 -35
  99. data/lib/axlsx/workbook/worksheet/cell.rb +552 -506
  100. data/lib/axlsx/workbook/worksheet/cell_serializer.rb +164 -164
  101. data/lib/axlsx/workbook/worksheet/cfvo.rb +60 -60
  102. data/lib/axlsx/workbook/worksheet/cfvos.rb +16 -18
  103. data/lib/axlsx/workbook/worksheet/col.rb +142 -145
  104. data/lib/axlsx/workbook/worksheet/col_breaks.rb +34 -35
  105. data/lib/axlsx/workbook/worksheet/color_scale.rb +108 -110
  106. data/lib/axlsx/workbook/worksheet/cols.rb +23 -23
  107. data/lib/axlsx/workbook/worksheet/comment.rb +90 -91
  108. data/lib/axlsx/workbook/worksheet/comments.rb +78 -82
  109. data/lib/axlsx/workbook/worksheet/conditional_formatting.rb +81 -82
  110. data/lib/axlsx/workbook/worksheet/conditional_formatting_rule.rb +216 -220
  111. data/lib/axlsx/workbook/worksheet/conditional_formattings.rb +23 -25
  112. data/lib/axlsx/workbook/worksheet/data_bar.rb +127 -129
  113. data/lib/axlsx/workbook/worksheet/data_validation.rb +266 -246
  114. data/lib/axlsx/workbook/worksheet/data_validations.rb +25 -28
  115. data/lib/axlsx/workbook/worksheet/date_time_converter.rb +28 -30
  116. data/lib/axlsx/workbook/worksheet/dimension.rb +65 -64
  117. data/lib/axlsx/workbook/worksheet/header_footer.rb +51 -52
  118. data/lib/axlsx/workbook/worksheet/icon_set.rb +80 -81
  119. data/lib/axlsx/workbook/worksheet/merged_cells.rb +37 -37
  120. data/lib/axlsx/workbook/worksheet/outline_pr.rb +32 -33
  121. data/lib/axlsx/workbook/worksheet/page_margins.rb +97 -97
  122. data/lib/axlsx/workbook/worksheet/page_set_up_pr.rb +42 -44
  123. data/lib/axlsx/workbook/worksheet/page_setup.rb +237 -240
  124. data/lib/axlsx/workbook/worksheet/pane.rb +138 -139
  125. data/lib/axlsx/workbook/worksheet/pivot_table.rb +332 -296
  126. data/lib/axlsx/workbook/worksheet/pivot_table_cache_definition.rb +63 -66
  127. data/lib/axlsx/workbook/worksheet/pivot_tables.rb +23 -24
  128. data/lib/axlsx/workbook/worksheet/print_options.rb +38 -39
  129. data/lib/axlsx/workbook/worksheet/protected_range.rb +46 -47
  130. data/lib/axlsx/workbook/worksheet/protected_ranges.rb +37 -37
  131. data/lib/axlsx/workbook/worksheet/rich_text.rb +53 -55
  132. data/lib/axlsx/workbook/worksheet/rich_text_run.rb +266 -250
  133. data/lib/axlsx/workbook/worksheet/row.rb +173 -164
  134. data/lib/axlsx/workbook/worksheet/row_breaks.rb +32 -33
  135. data/lib/axlsx/workbook/worksheet/selection.rb +99 -101
  136. data/lib/axlsx/workbook/worksheet/sheet_calc_pr.rb +28 -29
  137. data/lib/axlsx/workbook/worksheet/sheet_data.rb +25 -27
  138. data/lib/axlsx/workbook/worksheet/sheet_format_pr.rb +18 -18
  139. data/lib/axlsx/workbook/worksheet/sheet_pr.rb +87 -87
  140. data/lib/axlsx/workbook/worksheet/sheet_protection.rb +117 -118
  141. data/lib/axlsx/workbook/worksheet/sheet_view.rb +206 -213
  142. data/lib/axlsx/workbook/worksheet/table.rb +100 -102
  143. data/lib/axlsx/workbook/worksheet/table_style_info.rb +48 -49
  144. data/lib/axlsx/workbook/worksheet/tables.rb +34 -34
  145. data/lib/axlsx/workbook/worksheet/worksheet.rb +857 -786
  146. data/lib/axlsx/workbook/worksheet/worksheet_comments.rb +58 -58
  147. data/lib/axlsx/workbook/worksheet/worksheet_drawing.rb +59 -58
  148. data/lib/axlsx/workbook/worksheet/worksheet_hyperlink.rb +73 -74
  149. data/lib/axlsx/workbook/worksheet/worksheet_hyperlinks.rb +38 -38
  150. data/lib/axlsx.rb +218 -185
  151. data/lib/caxlsx.rb +1 -2
  152. data/lib/schema/dc.xsd +118 -118
  153. data/lib/schema/dcmitype.xsd +51 -51
  154. data/lib/schema/dcterms.xsd +331 -331
  155. data/lib/schema/dml-chartDrawing.xsd +146 -146
  156. data/lib/schema/dml-compatibility.xsd +14 -14
  157. data/lib/schema/dml-lockedCanvas.xsd +11 -11
  158. data/lib/schema/dml-main.xsd +3048 -3048
  159. data/lib/schema/dml-picture.xsd +23 -23
  160. data/lib/schema/dml-spreadsheetDrawing.xsd +185 -185
  161. data/lib/schema/dml-wordprocessingDrawing.xsd +185 -185
  162. data/lib/schema/shared-additionalCharacteristics.xsd +28 -28
  163. data/lib/schema/shared-bibliography.xsd +144 -144
  164. data/lib/schema/shared-commonSimpleTypes.xsd +166 -166
  165. data/lib/schema/shared-customXmlDataProperties.xsd +25 -25
  166. data/lib/schema/shared-customXmlSchemaProperties.xsd +18 -18
  167. data/lib/schema/shared-documentPropertiesCustom.xsd +59 -59
  168. data/lib/schema/shared-documentPropertiesExtended.xsd +56 -56
  169. data/lib/schema/shared-documentPropertiesVariantTypes.xsd +195 -195
  170. data/lib/schema/shared-relationshipReference.xsd +25 -25
  171. data/lib/schema/vml-main.xsd +569 -569
  172. data/lib/schema/vml-officeDrawing.xsd +509 -509
  173. data/lib/schema/vml-presentationDrawing.xsd +12 -12
  174. data/lib/schema/vml-spreadsheetDrawing.xsd +108 -108
  175. data/lib/schema/vml-wordprocessingDrawing.xsd +96 -96
  176. data/lib/schema/xml.xsd +116 -116
  177. metadata +5 -252
  178. data/test/benchmark.rb +0 -72
  179. data/test/content_type/tc_content_type.rb +0 -76
  180. data/test/content_type/tc_default.rb +0 -16
  181. data/test/content_type/tc_override.rb +0 -14
  182. data/test/doc_props/tc_app.rb +0 -43
  183. data/test/doc_props/tc_core.rb +0 -42
  184. data/test/drawing/tc_area_chart.rb +0 -39
  185. data/test/drawing/tc_area_series.rb +0 -71
  186. data/test/drawing/tc_axes.rb +0 -8
  187. data/test/drawing/tc_axis.rb +0 -112
  188. data/test/drawing/tc_bar_3D_chart.rb +0 -86
  189. data/test/drawing/tc_bar_chart.rb +0 -86
  190. data/test/drawing/tc_bar_series.rb +0 -46
  191. data/test/drawing/tc_bubble_chart.rb +0 -44
  192. data/test/drawing/tc_bubble_series.rb +0 -21
  193. data/test/drawing/tc_cat_axis.rb +0 -31
  194. data/test/drawing/tc_cat_axis_data.rb +0 -27
  195. data/test/drawing/tc_chart.rb +0 -123
  196. data/test/drawing/tc_d_lbls.rb +0 -57
  197. data/test/drawing/tc_data_source.rb +0 -23
  198. data/test/drawing/tc_drawing.rb +0 -80
  199. data/test/drawing/tc_graphic_frame.rb +0 -27
  200. data/test/drawing/tc_hyperlink.rb +0 -64
  201. data/test/drawing/tc_line_3d_chart.rb +0 -47
  202. data/test/drawing/tc_line_chart.rb +0 -39
  203. data/test/drawing/tc_line_series.rb +0 -71
  204. data/test/drawing/tc_marker.rb +0 -44
  205. data/test/drawing/tc_named_axis_data.rb +0 -27
  206. data/test/drawing/tc_num_data.rb +0 -31
  207. data/test/drawing/tc_num_val.rb +0 -29
  208. data/test/drawing/tc_one_cell_anchor.rb +0 -66
  209. data/test/drawing/tc_pic.rb +0 -103
  210. data/test/drawing/tc_picture_locking.rb +0 -72
  211. data/test/drawing/tc_pie_3D_chart.rb +0 -28
  212. data/test/drawing/tc_pie_series.rb +0 -33
  213. data/test/drawing/tc_scaling.rb +0 -36
  214. data/test/drawing/tc_scatter_chart.rb +0 -48
  215. data/test/drawing/tc_scatter_series.rb +0 -74
  216. data/test/drawing/tc_ser_axis.rb +0 -31
  217. data/test/drawing/tc_series.rb +0 -23
  218. data/test/drawing/tc_series_title.rb +0 -54
  219. data/test/drawing/tc_str_data.rb +0 -18
  220. data/test/drawing/tc_str_val.rb +0 -30
  221. data/test/drawing/tc_title.rb +0 -70
  222. data/test/drawing/tc_two_cell_anchor.rb +0 -36
  223. data/test/drawing/tc_val_axis.rb +0 -24
  224. data/test/drawing/tc_view_3D.rb +0 -54
  225. data/test/drawing/tc_vml_drawing.rb +0 -25
  226. data/test/drawing/tc_vml_shape.rb +0 -106
  227. data/test/fixtures/image1.gif +0 -0
  228. data/test/fixtures/image1.jpeg +0 -0
  229. data/test/fixtures/image1.jpg +0 -0
  230. data/test/fixtures/image1.png +0 -0
  231. data/test/fixtures/image1_fake.jpg +0 -0
  232. data/test/profile.rb +0 -24
  233. data/test/rels/tc_relationship.rb +0 -52
  234. data/test/rels/tc_relationships.rb +0 -37
  235. data/test/stylesheet/tc_border.rb +0 -37
  236. data/test/stylesheet/tc_border_pr.rb +0 -32
  237. data/test/stylesheet/tc_cell_alignment.rb +0 -81
  238. data/test/stylesheet/tc_cell_protection.rb +0 -29
  239. data/test/stylesheet/tc_cell_style.rb +0 -57
  240. data/test/stylesheet/tc_color.rb +0 -43
  241. data/test/stylesheet/tc_dxf.rb +0 -81
  242. data/test/stylesheet/tc_fill.rb +0 -18
  243. data/test/stylesheet/tc_font.rb +0 -133
  244. data/test/stylesheet/tc_gradient_fill.rb +0 -72
  245. data/test/stylesheet/tc_gradient_stop.rb +0 -31
  246. data/test/stylesheet/tc_num_fmt.rb +0 -30
  247. data/test/stylesheet/tc_pattern_fill.rb +0 -43
  248. data/test/stylesheet/tc_styles.rb +0 -309
  249. data/test/stylesheet/tc_table_style.rb +0 -44
  250. data/test/stylesheet/tc_table_style_element.rb +0 -45
  251. data/test/stylesheet/tc_table_styles.rb +0 -29
  252. data/test/stylesheet/tc_xf.rb +0 -120
  253. data/test/tc_axlsx.rb +0 -109
  254. data/test/tc_helper.rb +0 -10
  255. data/test/tc_package.rb +0 -317
  256. data/test/util/tc_mime_type_utils.rb +0 -13
  257. data/test/util/tc_serialized_attributes.rb +0 -19
  258. data/test/util/tc_simple_typed_list.rb +0 -77
  259. data/test/util/tc_validators.rb +0 -210
  260. data/test/workbook/tc_defined_name.rb +0 -49
  261. data/test/workbook/tc_shared_strings_table.rb +0 -59
  262. data/test/workbook/tc_workbook.rb +0 -165
  263. data/test/workbook/tc_workbook_view.rb +0 -50
  264. data/test/workbook/worksheet/auto_filter/tc_auto_filter.rb +0 -38
  265. data/test/workbook/worksheet/auto_filter/tc_filter_column.rb +0 -76
  266. data/test/workbook/worksheet/auto_filter/tc_filters.rb +0 -50
  267. data/test/workbook/worksheet/tc_break.rb +0 -49
  268. data/test/workbook/worksheet/tc_cell.rb +0 -465
  269. data/test/workbook/worksheet/tc_cfvo.rb +0 -31
  270. data/test/workbook/worksheet/tc_col.rb +0 -93
  271. data/test/workbook/worksheet/tc_color_scale.rb +0 -58
  272. data/test/workbook/worksheet/tc_comment.rb +0 -72
  273. data/test/workbook/worksheet/tc_comments.rb +0 -57
  274. data/test/workbook/worksheet/tc_conditional_formatting.rb +0 -224
  275. data/test/workbook/worksheet/tc_data_bar.rb +0 -46
  276. data/test/workbook/worksheet/tc_data_validation.rb +0 -265
  277. data/test/workbook/worksheet/tc_date_time_converter.rb +0 -124
  278. data/test/workbook/worksheet/tc_header_footer.rb +0 -151
  279. data/test/workbook/worksheet/tc_icon_set.rb +0 -45
  280. data/test/workbook/worksheet/tc_outline_pr.rb +0 -19
  281. data/test/workbook/worksheet/tc_page_margins.rb +0 -97
  282. data/test/workbook/worksheet/tc_page_set_up_pr.rb +0 -15
  283. data/test/workbook/worksheet/tc_page_setup.rb +0 -143
  284. data/test/workbook/worksheet/tc_pane.rb +0 -54
  285. data/test/workbook/worksheet/tc_pivot_table.rb +0 -180
  286. data/test/workbook/worksheet/tc_pivot_table_cache_definition.rb +0 -62
  287. data/test/workbook/worksheet/tc_print_options.rb +0 -72
  288. data/test/workbook/worksheet/tc_protected_range.rb +0 -17
  289. data/test/workbook/worksheet/tc_rich_text.rb +0 -44
  290. data/test/workbook/worksheet/tc_rich_text_run.rb +0 -173
  291. data/test/workbook/worksheet/tc_row.rb +0 -160
  292. data/test/workbook/worksheet/tc_selection.rb +0 -55
  293. data/test/workbook/worksheet/tc_sheet_calc_pr.rb +0 -18
  294. data/test/workbook/worksheet/tc_sheet_format_pr.rb +0 -88
  295. data/test/workbook/worksheet/tc_sheet_pr.rb +0 -49
  296. data/test/workbook/worksheet/tc_sheet_protection.rb +0 -117
  297. data/test/workbook/worksheet/tc_sheet_view.rb +0 -214
  298. data/test/workbook/worksheet/tc_table.rb +0 -77
  299. data/test/workbook/worksheet/tc_table_style_info.rb +0 -53
  300. data/test/workbook/worksheet/tc_worksheet.rb +0 -632
  301. data/test/workbook/worksheet/tc_worksheet_hyperlink.rb +0 -55
@@ -1,54 +1,51 @@
1
- # encoding: UTF-8
2
- module Axlsx
3
- # A single table style definition and is a collection for tableStyleElements
4
- # @note Table are not supported in this version and only the defaults required for a valid workbook are created.
5
- class TableStyle < SimpleTypedList
6
-
7
- include Axlsx::OptionsParser
8
- include Axlsx::SerializedAttributes
9
-
10
- # creates a new TableStyle object
11
- # @raise [ArgumentError] if name option is not provided.
12
- # @param [String] name
13
- # @option options [Boolean] pivot
14
- # @option options [Boolean] table
15
- def initialize(name, options={})
16
- self.name = name
17
- parse_options options
18
- super TableStyleElement
19
- end
20
-
21
- serializable_attributes :name, :pivot, :table
22
-
23
- # The name of this table style
24
- # @return [string]
25
- attr_reader :name
26
-
27
- # indicates if this style should be applied to pivot tables
28
- # @return [Boolean]
29
- attr_reader :pivot
30
-
31
- # indicates if this style should be applied to tables
32
- # @return [Boolean]
33
- attr_reader :table
34
-
35
- # @see name
36
- def name=(v) Axlsx::validate_string v; @name=v end
37
- # @see pivot
38
- def pivot=(v) Axlsx::validate_boolean v; @pivot=v end
39
- # @see table
40
- def table=(v) Axlsx::validate_boolean v; @table=v end
41
-
42
- # Serializes the object
43
- # @param [String] str
44
- # @return [String]
45
- def to_xml_string(str = '')
46
- str << '<tableStyle '
47
- serialized_attributes str, {:count => self.size}
48
- str << '>'
49
- each { |table_style_el| table_style_el.to_xml_string(str) }
50
- str << '</tableStyle>'
51
- end
52
-
53
- end
54
- end
1
+ module Axlsx
2
+ # A single table style definition and is a collection for tableStyleElements
3
+ # @note Table are not supported in this version and only the defaults required for a valid workbook are created.
4
+ class TableStyle < SimpleTypedList
5
+ include Axlsx::OptionsParser
6
+ include Axlsx::SerializedAttributes
7
+
8
+ # creates a new TableStyle object
9
+ # @raise [ArgumentError] if name option is not provided.
10
+ # @param [String] name
11
+ # @option options [Boolean] pivot
12
+ # @option options [Boolean] table
13
+ def initialize(name, options = {})
14
+ self.name = name
15
+ parse_options options
16
+ super TableStyleElement
17
+ end
18
+
19
+ serializable_attributes :name, :pivot, :table
20
+
21
+ # The name of this table style
22
+ # @return [string]
23
+ attr_reader :name
24
+
25
+ # indicates if this style should be applied to pivot tables
26
+ # @return [Boolean]
27
+ attr_reader :pivot
28
+
29
+ # indicates if this style should be applied to tables
30
+ # @return [Boolean]
31
+ attr_reader :table
32
+
33
+ # @see name
34
+ def name=(v) Axlsx::validate_string v; @name = v end
35
+ # @see pivot
36
+ def pivot=(v) Axlsx::validate_boolean v; @pivot = v end
37
+ # @see table
38
+ def table=(v) Axlsx::validate_boolean v; @table = v end
39
+
40
+ # Serializes the object
41
+ # @param [String] str
42
+ # @return [String]
43
+ def to_xml_string(str = '')
44
+ str << '<tableStyle '
45
+ serialized_attributes str, { :count => self.size }
46
+ str << '>'
47
+ each { |table_style_el| table_style_el.to_xml_string(str) }
48
+ str << '</tableStyle>'
49
+ end
50
+ end
51
+ end
@@ -1,77 +1,74 @@
1
- # encoding: UTF-8
2
- module Axlsx
3
- # an element of style that belongs to a table style.
4
- # @note tables and table styles are not supported in this version. This class exists in preparation for that support.
5
- class TableStyleElement
6
-
7
- include Axlsx::OptionsParser
8
- include Axlsx::SerializedAttributes
9
-
10
- # creates a new TableStyleElement object
11
- # @option options [Symbol] type
12
- # @option options [Integer] size
13
- # @option options [Integer] dxfId
14
- def initialize(options={})
15
- parse_options options
16
- end
17
-
18
- serializable_attributes :type, :size, :dxfId
19
-
20
- # The type of style element. The following type are allowed
21
- # :wholeTable
22
- # :headerRow
23
- # :totalRow
24
- # :firstColumn
25
- # :lastColumn
26
- # :firstRowStripe
27
- # :secondRowStripe
28
- # :firstColumnStripe
29
- # :secondColumnStripe
30
- # :firstHeaderCell
31
- # :lastHeaderCell
32
- # :firstTotalCell
33
- # :lastTotalCell
34
- # :firstSubtotalColumn
35
- # :secondSubtotalColumn
36
- # :thirdSubtotalColumn
37
- # :firstSubtotalRow
38
- # :secondSubtotalRow
39
- # :thirdSubtotalRow
40
- # :blankRow
41
- # :firstColumnSubheading
42
- # :secondColumnSubheading
43
- # :thirdColumnSubheading
44
- # :firstRowSubheading
45
- # :secondRowSubheading
46
- # :thirdRowSubheading
47
- # :pageFieldLabels
48
- # :pageFieldValues
49
- # @return [Symbol]
50
- attr_reader :type
51
-
52
- # Number of rows or columns used in striping when the type is firstRowStripe, secondRowStripe, firstColumnStripe, or secondColumnStripe.
53
- # @return [Integer]
54
- attr_reader :size
55
-
56
- # The dxfId this style element points to
57
- # @return [Integer]
58
- attr_reader :dxfId
59
-
60
- # @see type
61
- def type=(v) Axlsx::validate_table_element_type v; @type = v end
62
-
63
- # @see size
64
- def size=(v) Axlsx::validate_unsigned_int v; @size = v end
65
-
66
- # @see dxfId
67
- def dxfId=(v) Axlsx::validate_unsigned_int v; @dxfId = v end
68
-
69
- # Serializes the object
70
- # @param [String] str
71
- # @return [String]
72
- def to_xml_string(str = '')
73
- serialized_tag('tableStyleElement', str)
74
- end
75
-
76
- end
77
- end
1
+ module Axlsx
2
+ # an element of style that belongs to a table style.
3
+ # @note tables and table styles are not supported in this version. This class exists in preparation for that support.
4
+ class TableStyleElement
5
+ include Axlsx::OptionsParser
6
+ include Axlsx::SerializedAttributes
7
+
8
+ # creates a new TableStyleElement object
9
+ # @option options [Symbol] type
10
+ # @option options [Integer] size
11
+ # @option options [Integer] dxfId
12
+ def initialize(options = {})
13
+ parse_options options
14
+ end
15
+
16
+ serializable_attributes :type, :size, :dxfId
17
+
18
+ # The type of style element. The following type are allowed
19
+ # :wholeTable
20
+ # :headerRow
21
+ # :totalRow
22
+ # :firstColumn
23
+ # :lastColumn
24
+ # :firstRowStripe
25
+ # :secondRowStripe
26
+ # :firstColumnStripe
27
+ # :secondColumnStripe
28
+ # :firstHeaderCell
29
+ # :lastHeaderCell
30
+ # :firstTotalCell
31
+ # :lastTotalCell
32
+ # :firstSubtotalColumn
33
+ # :secondSubtotalColumn
34
+ # :thirdSubtotalColumn
35
+ # :firstSubtotalRow
36
+ # :secondSubtotalRow
37
+ # :thirdSubtotalRow
38
+ # :blankRow
39
+ # :firstColumnSubheading
40
+ # :secondColumnSubheading
41
+ # :thirdColumnSubheading
42
+ # :firstRowSubheading
43
+ # :secondRowSubheading
44
+ # :thirdRowSubheading
45
+ # :pageFieldLabels
46
+ # :pageFieldValues
47
+ # @return [Symbol]
48
+ attr_reader :type
49
+
50
+ # Number of rows or columns used in striping when the type is firstRowStripe, secondRowStripe, firstColumnStripe, or secondColumnStripe.
51
+ # @return [Integer]
52
+ attr_reader :size
53
+
54
+ # The dxfId this style element points to
55
+ # @return [Integer]
56
+ attr_reader :dxfId
57
+
58
+ # @see type
59
+ def type=(v) Axlsx::validate_table_element_type v; @type = v end
60
+
61
+ # @see size
62
+ def size=(v) Axlsx::validate_unsigned_int v; @size = v end
63
+
64
+ # @see dxfId
65
+ def dxfId=(v) Axlsx::validate_unsigned_int v; @dxfId = v end
66
+
67
+ # Serializes the object
68
+ # @param [String] str
69
+ # @return [String]
70
+ def to_xml_string(str = '')
71
+ serialized_tag('tableStyleElement', str)
72
+ end
73
+ end
74
+ end
@@ -1,46 +1,42 @@
1
- # encoding: UTF-8
2
- module Axlsx
3
- # TableStyles represents a collection of style definitions for table styles and pivot table styles.
4
- # @note Support for custom table styles does not exist in this version. Many of the classes required are defined in preparation for future release. Please do not attempt to add custom table styles.
5
- class TableStyles < SimpleTypedList
6
-
7
- include Axlsx::SerializedAttributes
8
-
9
- # Creates a new TableStyles object that is a container for TableStyle objects
10
- # @option options [String] defaultTableStyle
11
- # @option options [String] defaultPivotStyle
12
- def initialize(options={})
13
- @defaultTableStyle = options[:defaultTableStyle] || "TableStyleMedium9"
14
- @defaultPivotStyle = options[:defaultPivotStyle] || "PivotStyleLight16"
15
- super TableStyle
16
- end
17
-
18
- serializable_attributes :defaultTableStyle, :defaultPivotStyle
19
-
20
- # The default table style. The default value is 'TableStyleMedium9'
21
- # @return [String]
22
- attr_reader :defaultTableStyle
23
-
24
- # The default pivot table style. The default value is 'PivotStyleLight6'
25
- # @return [String]
26
- attr_reader :defaultPivotStyle
27
-
28
- # @see defaultTableStyle
29
- def defaultTableStyle=(v) Axlsx::validate_string(v); @defaultTableStyle = v; end
30
- # @see defaultPivotStyle
31
- def defaultPivotStyle=(v) Axlsx::validate_string(v); @defaultPivotStyle = v; end
32
-
33
- # Serializes the object
34
- # @param [String] str
35
- # @return [String]
36
- def to_xml_string(str = '')
37
- str << '<tableStyles '
38
- serialized_attributes str, {:count => self.size }
39
- str << '>'
40
- each { |table_style| table_style.to_xml_string(str) }
41
- str << '</tableStyles>'
42
- end
43
-
44
- end
45
-
46
- end
1
+ module Axlsx
2
+ # TableStyles represents a collection of style definitions for table styles and pivot table styles.
3
+ # @note Support for custom table styles does not exist in this version. Many of the classes required are defined in preparation for future release. Please do not attempt to add custom table styles.
4
+ class TableStyles < SimpleTypedList
5
+ include Axlsx::SerializedAttributes
6
+
7
+ # Creates a new TableStyles object that is a container for TableStyle objects
8
+ # @option options [String] defaultTableStyle
9
+ # @option options [String] defaultPivotStyle
10
+ def initialize(options = {})
11
+ @defaultTableStyle = options[:defaultTableStyle] || "TableStyleMedium9"
12
+ @defaultPivotStyle = options[:defaultPivotStyle] || "PivotStyleLight16"
13
+ super TableStyle
14
+ end
15
+
16
+ serializable_attributes :defaultTableStyle, :defaultPivotStyle
17
+
18
+ # The default table style. The default value is 'TableStyleMedium9'
19
+ # @return [String]
20
+ attr_reader :defaultTableStyle
21
+
22
+ # The default pivot table style. The default value is 'PivotStyleLight6'
23
+ # @return [String]
24
+ attr_reader :defaultPivotStyle
25
+
26
+ # @see defaultTableStyle
27
+ def defaultTableStyle=(v) Axlsx::validate_string(v); @defaultTableStyle = v; end
28
+ # @see defaultPivotStyle
29
+ def defaultPivotStyle=(v) Axlsx::validate_string(v); @defaultPivotStyle = v; end
30
+
31
+ # Serializes the object
32
+ # @param [String] str
33
+ # @return [String]
34
+ def to_xml_string(str = '')
35
+ str << '<tableStyles '
36
+ serialized_attributes str, { :count => self.size }
37
+ str << '>'
38
+ each { |table_style| table_style.to_xml_string(str) }
39
+ str << '</tableStyles>'
40
+ end
41
+ end
42
+ end
@@ -1,147 +1,144 @@
1
- # encoding: UTF-8
2
- module Axlsx
3
- # The Xf class defines a formatting record for use in Styles. The recommended way to manage styles for your workbook is with Styles#add_style
4
- # @see Styles#add_style
5
- class Xf
6
- #does not support extList (ExtensionList)
7
-
8
- include Axlsx::SerializedAttributes
9
- include Axlsx::OptionsParser
10
- # Creates a new Xf object
11
- # @option options [Integer] numFmtId
12
- # @option options [Integer] fontId
13
- # @option options [Integer] fillId
14
- # @option options [Integer] borderId
15
- # @option options [Integer] xfId
16
- # @option options [Boolean] quotePrefix
17
- # @option options [Boolean] pivotButton
18
- # @option options [Boolean] applyNumberFormat
19
- # @option options [Boolean] applyFont
20
- # @option options [Boolean] applyFill
21
- # @option options [Boolean] applyBorder
22
- # @option options [Boolean] applyAlignment
23
- # @option options [Boolean] applyProtection
24
- # @option options [CellAlignment] alignment
25
- # @option options [CellProtection] protection
26
- def initialize(options={})
27
- parse_options options
28
- end
29
-
30
- serializable_attributes :numFmtId, :fontId, :fillId, :borderId, :xfId, :quotePrefix,
31
- :pivotButton, :applyNumberFormat, :applyFont, :applyFill, :applyBorder, :applyAlignment,
32
- :applyProtection
33
-
34
- # The cell alignment for this style
35
- # @return [CellAlignment]
36
- # @see CellAlignment
37
- attr_reader :alignment
38
-
39
- # The cell protection for this style
40
- # @return [CellProtection]
41
- # @see CellProtection
42
- attr_reader :protection
43
-
44
- # id of the numFmt to apply to this style
45
- # @return [Integer]
46
- attr_reader :numFmtId
47
-
48
- # index (0 based) of the font to be used in this style
49
- # @return [Integer]
50
- attr_reader :fontId
51
-
52
- # index (0 based) of the fill to be used in this style
53
- # @return [Integer]
54
- attr_reader :fillId
55
-
56
- # index (0 based) of the border to be used in this style
57
- # @return [Integer]
58
- attr_reader :borderId
59
-
60
- # index (0 based) of cellStylesXfs item to be used in this style. Only applies to cellXfs items
61
- # @return [Integer]
62
- attr_reader :xfId
63
-
64
- # indecates if text should be prefixed by a single quote in the cell
65
- # @return [Boolean]
66
- attr_reader :quotePrefix
67
-
68
- # indicates if the cell has a pivot table drop down button
69
- # @return [Boolean]
70
- attr_reader :pivotButton
71
-
72
- # indicates if the numFmtId should be applied
73
- # @return [Boolean]
74
- attr_reader :applyNumberFormat
75
-
76
- # indicates if the fontId should be applied
77
- # @return [Boolean]
78
- attr_reader :applyFont
79
-
80
- # indicates if the fillId should be applied
81
- # @return [Boolean]
82
- attr_reader :applyFill
83
-
84
- # indicates if the borderId should be applied
85
- # @return [Boolean]
86
- attr_reader :applyBorder
87
-
88
- # Indicates if the alignment options should be applied
89
- # @return [Boolean]
90
- attr_reader :applyAlignment
91
-
92
- # Indicates if the protection options should be applied
93
- # @return [Boolean]
94
- attr_reader :applyProtection
95
-
96
- # @see Xf#alignment
97
- def alignment=(v) DataTypeValidator.validate "Xf.alignment", CellAlignment, v; @alignment = v end
98
-
99
- # @see protection
100
- def protection=(v) DataTypeValidator.validate "Xf.protection", CellProtection, v; @protection = v end
101
-
102
- # @see numFmtId
103
- def numFmtId=(v) Axlsx::validate_unsigned_int v; @numFmtId = v end
104
-
105
- # @see fontId
106
- def fontId=(v) Axlsx::validate_unsigned_int v; @fontId = v end
107
- # @see fillId
108
- def fillId=(v) Axlsx::validate_unsigned_int v; @fillId = v end
109
- # @see borderId
110
- def borderId=(v) Axlsx::validate_unsigned_int v; @borderId = v end
111
- # @see xfId
112
- def xfId=(v) Axlsx::validate_unsigned_int v; @xfId = v end
113
- # @see quotePrefix
114
- def quotePrefix=(v) Axlsx::validate_boolean v; @quotePrefix = v end
115
- # @see pivotButton
116
- def pivotButton=(v) Axlsx::validate_boolean v; @pivotButton = v end
117
- # @see applyNumberFormat
118
- def applyNumberFormat=(v) Axlsx::validate_boolean v; @applyNumberFormat = v end
119
- # @see applyFont
120
- def applyFont=(v) Axlsx::validate_boolean v; @applyFont = v end
121
- # @see applyFill
122
- def applyFill=(v) Axlsx::validate_boolean v; @applyFill = v end
123
-
124
- # @see applyBorder
125
- def applyBorder=(v) Axlsx::validate_boolean v; @applyBorder = v end
126
-
127
- # @see applyAlignment
128
- def applyAlignment=(v) Axlsx::validate_boolean v; @applyAlignment = v end
129
-
130
- # @see applyProtection
131
- def applyProtection=(v) Axlsx::validate_boolean v; @applyProtection = v end
132
-
133
- # Serializes the object
134
- # @param [String] str
135
- # @return [String]
136
- def to_xml_string(str = '')
137
- str << '<xf '
138
- serialized_attributes str
139
- str << '>'
140
- alignment.to_xml_string(str) if self.alignment
141
- protection.to_xml_string(str) if self.protection
142
- str << '</xf>'
143
- end
144
-
145
-
146
- end
147
- end
1
+ module Axlsx
2
+ # The Xf class defines a formatting record for use in Styles. The recommended way to manage styles for your workbook is with Styles#add_style
3
+ # @see Styles#add_style
4
+ class Xf
5
+ # does not support extList (ExtensionList)
6
+
7
+ include Axlsx::SerializedAttributes
8
+ include Axlsx::OptionsParser
9
+ # Creates a new Xf object
10
+ # @option options [Integer] numFmtId
11
+ # @option options [Integer] fontId
12
+ # @option options [Integer] fillId
13
+ # @option options [Integer] borderId
14
+ # @option options [Integer] xfId
15
+ # @option options [Boolean] quotePrefix
16
+ # @option options [Boolean] pivotButton
17
+ # @option options [Boolean] applyNumberFormat
18
+ # @option options [Boolean] applyFont
19
+ # @option options [Boolean] applyFill
20
+ # @option options [Boolean] applyBorder
21
+ # @option options [Boolean] applyAlignment
22
+ # @option options [Boolean] applyProtection
23
+ # @option options [CellAlignment] alignment
24
+ # @option options [CellProtection] protection
25
+ def initialize(options = {})
26
+ parse_options options
27
+ end
28
+
29
+ serializable_attributes :numFmtId, :fontId, :fillId, :borderId, :xfId, :quotePrefix,
30
+ :pivotButton, :applyNumberFormat, :applyFont, :applyFill, :applyBorder, :applyAlignment,
31
+ :applyProtection
32
+
33
+ # The cell alignment for this style
34
+ # @return [CellAlignment]
35
+ # @see CellAlignment
36
+ attr_reader :alignment
37
+
38
+ # The cell protection for this style
39
+ # @return [CellProtection]
40
+ # @see CellProtection
41
+ attr_reader :protection
42
+
43
+ # id of the numFmt to apply to this style
44
+ # @return [Integer]
45
+ attr_reader :numFmtId
46
+
47
+ # index (0 based) of the font to be used in this style
48
+ # @return [Integer]
49
+ attr_reader :fontId
50
+
51
+ # index (0 based) of the fill to be used in this style
52
+ # @return [Integer]
53
+ attr_reader :fillId
54
+
55
+ # index (0 based) of the border to be used in this style
56
+ # @return [Integer]
57
+ attr_reader :borderId
58
+
59
+ # index (0 based) of cellStylesXfs item to be used in this style. Only applies to cellXfs items
60
+ # @return [Integer]
61
+ attr_reader :xfId
62
+
63
+ # indecates if text should be prefixed by a single quote in the cell
64
+ # @return [Boolean]
65
+ attr_reader :quotePrefix
66
+
67
+ # indicates if the cell has a pivot table drop down button
68
+ # @return [Boolean]
69
+ attr_reader :pivotButton
70
+
71
+ # indicates if the numFmtId should be applied
72
+ # @return [Boolean]
73
+ attr_reader :applyNumberFormat
74
+
75
+ # indicates if the fontId should be applied
76
+ # @return [Boolean]
77
+ attr_reader :applyFont
78
+
79
+ # indicates if the fillId should be applied
80
+ # @return [Boolean]
81
+ attr_reader :applyFill
82
+
83
+ # indicates if the borderId should be applied
84
+ # @return [Boolean]
85
+ attr_reader :applyBorder
86
+
87
+ # Indicates if the alignment options should be applied
88
+ # @return [Boolean]
89
+ attr_reader :applyAlignment
90
+
91
+ # Indicates if the protection options should be applied
92
+ # @return [Boolean]
93
+ attr_reader :applyProtection
94
+
95
+ # @see Xf#alignment
96
+ def alignment=(v) DataTypeValidator.validate "Xf.alignment", CellAlignment, v; @alignment = v end
97
+
98
+ # @see protection
99
+ def protection=(v) DataTypeValidator.validate "Xf.protection", CellProtection, v; @protection = v end
100
+
101
+ # @see numFmtId
102
+ def numFmtId=(v) Axlsx::validate_unsigned_int v; @numFmtId = v end
103
+
104
+ # @see fontId
105
+ def fontId=(v) Axlsx::validate_unsigned_int v; @fontId = v end
106
+ # @see fillId
107
+ def fillId=(v) Axlsx::validate_unsigned_int v; @fillId = v end
108
+ # @see borderId
109
+ def borderId=(v) Axlsx::validate_unsigned_int v; @borderId = v end
110
+ # @see xfId
111
+ def xfId=(v) Axlsx::validate_unsigned_int v; @xfId = v end
112
+ # @see quotePrefix
113
+ def quotePrefix=(v) Axlsx::validate_boolean v; @quotePrefix = v end
114
+ # @see pivotButton
115
+ def pivotButton=(v) Axlsx::validate_boolean v; @pivotButton = v end
116
+ # @see applyNumberFormat
117
+ def applyNumberFormat=(v) Axlsx::validate_boolean v; @applyNumberFormat = v end
118
+ # @see applyFont
119
+ def applyFont=(v) Axlsx::validate_boolean v; @applyFont = v end
120
+ # @see applyFill
121
+ def applyFill=(v) Axlsx::validate_boolean v; @applyFill = v end
122
+
123
+ # @see applyBorder
124
+ def applyBorder=(v) Axlsx::validate_boolean v; @applyBorder = v end
125
+
126
+ # @see applyAlignment
127
+ def applyAlignment=(v) Axlsx::validate_boolean v; @applyAlignment = v end
128
+
129
+ # @see applyProtection
130
+ def applyProtection=(v) Axlsx::validate_boolean v; @applyProtection = v end
131
+
132
+ # Serializes the object
133
+ # @param [String] str
134
+ # @return [String]
135
+ def to_xml_string(str = '')
136
+ str << '<xf '
137
+ serialized_attributes str
138
+ str << '>'
139
+ alignment.to_xml_string(str) if self.alignment
140
+ protection.to_xml_string(str) if self.protection
141
+ str << '</xf>'
142
+ end
143
+ end
144
+ end