rubyXL 3.3.29 → 3.4.33

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (466) hide show
  1. checksums.yaml +5 -5
  2. data/.circleci/config.yml +60 -0
  3. data/.rubocop.yml +124 -0
  4. data/CHANGELOG.md +12 -0
  5. data/Gemfile +11 -8
  6. data/LICENSE.txt +1 -1
  7. data/README.rdoc +57 -19
  8. data/Rakefile +29 -29
  9. data/VERSION +1 -1
  10. data/lib/rubyXL/cell.rb +2 -29
  11. data/lib/rubyXL/convenience_methods/cell.rb +276 -0
  12. data/lib/rubyXL/convenience_methods/color.rb +156 -0
  13. data/lib/rubyXL/convenience_methods/font.rb +63 -0
  14. data/lib/rubyXL/convenience_methods/workbook.rb +137 -0
  15. data/lib/rubyXL/convenience_methods/worksheet.rb +734 -0
  16. data/lib/rubyXL/convenience_methods.rb +5 -1122
  17. data/lib/rubyXL/objects/border.rb +0 -3
  18. data/lib/rubyXL/objects/calculation_chain.rb +2 -2
  19. data/lib/rubyXL/objects/cell_style.rb +4 -6
  20. data/lib/rubyXL/objects/chartsheet.rb +8 -12
  21. data/lib/rubyXL/objects/color.rb +4 -6
  22. data/lib/rubyXL/objects/column_range.rb +16 -15
  23. data/lib/rubyXL/objects/comments.rb +1 -4
  24. data/lib/rubyXL/objects/connection.rb +175 -0
  25. data/lib/rubyXL/objects/container_nodes.rb +1 -5
  26. data/lib/rubyXL/objects/content_types.rb +3 -6
  27. data/lib/rubyXL/objects/data_validation.rb +2 -2
  28. data/lib/rubyXL/objects/document_properties.rb +12 -15
  29. data/lib/rubyXL/objects/extensions.rb +0 -2
  30. data/lib/rubyXL/objects/external_links.rb +38 -8
  31. data/lib/rubyXL/objects/fill.rb +2 -5
  32. data/lib/rubyXL/objects/filters.rb +5 -7
  33. data/lib/rubyXL/objects/font.rb +2 -7
  34. data/lib/rubyXL/objects/formula.rb +3 -5
  35. data/lib/rubyXL/objects/ooxml_object.rb +40 -31
  36. data/lib/rubyXL/objects/query_table.rb +106 -0
  37. data/lib/rubyXL/objects/reference.rb +26 -17
  38. data/lib/rubyXL/objects/relationships.rb +14 -14
  39. data/lib/rubyXL/objects/root.rb +0 -2
  40. data/lib/rubyXL/objects/shared_strings.rb +4 -7
  41. data/lib/rubyXL/objects/sheet_common.rb +1 -3
  42. data/lib/rubyXL/objects/sheet_data.rb +44 -17
  43. data/lib/rubyXL/objects/simple_types.rb +19 -2
  44. data/lib/rubyXL/objects/storage.rb +60 -49
  45. data/lib/rubyXL/objects/stylesheet.rb +9 -17
  46. data/lib/rubyXL/objects/text.rb +6 -8
  47. data/lib/rubyXL/objects/theme.rb +23 -9
  48. data/lib/rubyXL/objects/workbook.rb +144 -36
  49. data/lib/rubyXL/objects/worksheet.rb +48 -34
  50. data/lib/rubyXL/parser.rb +1 -3
  51. data/lib/rubyXL/worksheet.rb +86 -86
  52. data/lib/rubyXL.rb +1 -1
  53. data/rdoc/README_rdoc.html +212 -153
  54. data/rdoc/RubyXL/AExtension.html +33 -69
  55. data/rdoc/RubyXL/AExtensionStorageArea.html +12 -18
  56. data/rdoc/RubyXL/ActiveX.html +26 -52
  57. data/rdoc/RubyXL/ActiveXBinary.html +12 -23
  58. data/rdoc/RubyXL/AdjustHandleList.html +13 -20
  59. data/rdoc/RubyXL/Alignment.html +13 -20
  60. data/rdoc/RubyXL/AlternateContent.html +12 -18
  61. data/rdoc/RubyXL/AlternateUrls.html +99 -0
  62. data/rdoc/RubyXL/Authors.html +13 -20
  63. data/rdoc/RubyXL/AutoFilter.html +13 -20
  64. data/rdoc/RubyXL/AutoFilterColumn.html +13 -20
  65. data/rdoc/RubyXL/BinaryImageFile.html +12 -26
  66. data/rdoc/RubyXL/BodyProperties.html +13 -20
  67. data/rdoc/RubyXL/BooleanNode.html +12 -18
  68. data/rdoc/RubyXL/BooleanValue.html +12 -18
  69. data/rdoc/RubyXL/Border.html +49 -101
  70. data/rdoc/RubyXL/BorderEdge.html +32 -61
  71. data/rdoc/RubyXL/Borders.html +25 -44
  72. data/rdoc/RubyXL/Break.html +13 -20
  73. data/rdoc/RubyXL/BreakList.html +13 -20
  74. data/rdoc/RubyXL/CT_AdjPoint2D.html +13 -20
  75. data/rdoc/RubyXL/CT_AlphaBiLevelEffect.html +13 -20
  76. data/rdoc/RubyXL/CT_AlphaModulateEffect.html +13 -20
  77. data/rdoc/RubyXL/CT_AlphaModulateFixedEffect.html +13 -20
  78. data/rdoc/RubyXL/CT_AlphaOutsetEffect.html +13 -20
  79. data/rdoc/RubyXL/CT_AlphaReplaceEffect.html +13 -20
  80. data/rdoc/RubyXL/CT_Backdrop.html +13 -20
  81. data/rdoc/RubyXL/CT_Bevel.html +13 -20
  82. data/rdoc/RubyXL/CT_BiLevelEffect.html +13 -20
  83. data/rdoc/RubyXL/CT_BlendEffect.html +13 -20
  84. data/rdoc/RubyXL/CT_Blip.html +13 -20
  85. data/rdoc/RubyXL/CT_BlipFillProperties.html +13 -20
  86. data/rdoc/RubyXL/CT_BlurEffect.html +13 -20
  87. data/rdoc/RubyXL/CT_Camera.html +13 -20
  88. data/rdoc/RubyXL/CT_Color.html +13 -20
  89. data/rdoc/RubyXL/CT_ColorChangeEffect.html +13 -20
  90. data/rdoc/RubyXL/CT_ColorMapping.html +13 -20
  91. data/rdoc/RubyXL/CT_ColorScheme.html +13 -20
  92. data/rdoc/RubyXL/CT_ColorSchemeAndMapping.html +13 -20
  93. data/rdoc/RubyXL/CT_ConnectionSite.html +13 -20
  94. data/rdoc/RubyXL/CT_ConnectionSiteList.html +13 -20
  95. data/rdoc/RubyXL/CT_DashStop.html +13 -20
  96. data/rdoc/RubyXL/CT_DashStopList.html +13 -20
  97. data/rdoc/RubyXL/CT_DefaultShapeDefinition.html +13 -20
  98. data/rdoc/RubyXL/CT_DuotoneEffect.html +13 -20
  99. data/rdoc/RubyXL/CT_EffectContainer.html +13 -20
  100. data/rdoc/RubyXL/CT_EffectList.html +13 -20
  101. data/rdoc/RubyXL/CT_EffectReference.html +13 -20
  102. data/rdoc/RubyXL/CT_EffectStyleItem.html +13 -20
  103. data/rdoc/RubyXL/CT_EffectStyleList.html +13 -20
  104. data/rdoc/RubyXL/CT_EmbeddedWAVAudioFile.html +13 -20
  105. data/rdoc/RubyXL/CT_FillEffect.html +13 -20
  106. data/rdoc/RubyXL/CT_FillOverlayEffect.html +13 -20
  107. data/rdoc/RubyXL/CT_FillStyleList.html +13 -20
  108. data/rdoc/RubyXL/CT_FlatText.html +13 -20
  109. data/rdoc/RubyXL/CT_FontCollection.html +13 -20
  110. data/rdoc/RubyXL/CT_FontReference.html +13 -20
  111. data/rdoc/RubyXL/CT_GeomGuideList.html +13 -20
  112. data/rdoc/RubyXL/CT_GlowEffect.html +13 -20
  113. data/rdoc/RubyXL/CT_GradientFillProperties.html +13 -20
  114. data/rdoc/RubyXL/CT_GradientStop.html +13 -20
  115. data/rdoc/RubyXL/CT_GradientStopList.html +13 -20
  116. data/rdoc/RubyXL/CT_HSLEffect.html +13 -20
  117. data/rdoc/RubyXL/CT_HslColor.html +13 -20
  118. data/rdoc/RubyXL/CT_Hyperlink.html +13 -20
  119. data/rdoc/RubyXL/CT_InnerShadowEffect.html +13 -20
  120. data/rdoc/RubyXL/CT_LightRig.html +13 -20
  121. data/rdoc/RubyXL/CT_LineEndProperties.html +13 -20
  122. data/rdoc/RubyXL/CT_LineJoinMiterProperties.html +13 -20
  123. data/rdoc/RubyXL/CT_LineProperties.html +13 -20
  124. data/rdoc/RubyXL/CT_LineStyleList.html +13 -20
  125. data/rdoc/RubyXL/CT_LinearShadeProperties.html +13 -20
  126. data/rdoc/RubyXL/CT_LuminanceEffect.html +13 -20
  127. data/rdoc/RubyXL/CT_ObjectStyleDefaults.html +13 -20
  128. data/rdoc/RubyXL/CT_OuterShadowEffect.html +13 -20
  129. data/rdoc/RubyXL/CT_Path2D.html +13 -20
  130. data/rdoc/RubyXL/CT_Path2DArcTo.html +13 -20
  131. data/rdoc/RubyXL/CT_Path2DCubicBezierTo.html +13 -20
  132. data/rdoc/RubyXL/CT_Path2DList.html +13 -20
  133. data/rdoc/RubyXL/CT_Path2DQuadBezierTo.html +13 -20
  134. data/rdoc/RubyXL/CT_Path2DTo.html +13 -20
  135. data/rdoc/RubyXL/CT_PathShadeProperties.html +13 -20
  136. data/rdoc/RubyXL/CT_PatternFillProperties.html +13 -20
  137. data/rdoc/RubyXL/CT_Point3D.html +13 -20
  138. data/rdoc/RubyXL/CT_PolarAdjustHandle.html +13 -20
  139. data/rdoc/RubyXL/CT_PresetColor.html +13 -20
  140. data/rdoc/RubyXL/CT_PresetLineDashProperties.html +13 -20
  141. data/rdoc/RubyXL/CT_PresetShadowEffect.html +13 -20
  142. data/rdoc/RubyXL/CT_PresetTextShape.html +13 -20
  143. data/rdoc/RubyXL/CT_ReflectionEffect.html +13 -20
  144. data/rdoc/RubyXL/CT_RelativeOffsetEffect.html +13 -20
  145. data/rdoc/RubyXL/CT_RelativeRect.html +13 -20
  146. data/rdoc/RubyXL/CT_SRgbColor.html +13 -20
  147. data/rdoc/RubyXL/CT_ScRgbColor.html +13 -20
  148. data/rdoc/RubyXL/CT_Scene3D.html +13 -20
  149. data/rdoc/RubyXL/CT_SchemeColor.html +13 -20
  150. data/rdoc/RubyXL/CT_Shape3D.html +13 -20
  151. data/rdoc/RubyXL/CT_ShapeStyle.html +13 -20
  152. data/rdoc/RubyXL/CT_SoftEdgesEffect.html +13 -20
  153. data/rdoc/RubyXL/CT_SphereCoords.html +13 -20
  154. data/rdoc/RubyXL/CT_StretchInfoProperties.html +13 -20
  155. data/rdoc/RubyXL/CT_StyleMatrix.html +13 -20
  156. data/rdoc/RubyXL/CT_StyleMatrixReference.html +13 -20
  157. data/rdoc/RubyXL/CT_SupplementalFont.html +13 -20
  158. data/rdoc/RubyXL/CT_SystemColor.html +13 -20
  159. data/rdoc/RubyXL/CT_TextAutonumberBullet.html +13 -20
  160. data/rdoc/RubyXL/CT_TextBlipBullet.html +13 -20
  161. data/rdoc/RubyXL/CT_TextCharBullet.html +13 -20
  162. data/rdoc/RubyXL/CT_TextCharacterProperties.html +13 -20
  163. data/rdoc/RubyXL/CT_TextFont.html +13 -20
  164. data/rdoc/RubyXL/CT_TextListStyle.html +13 -20
  165. data/rdoc/RubyXL/CT_TextNormalAutofit.html +13 -20
  166. data/rdoc/RubyXL/CT_TextParagraphProperties.html +13 -20
  167. data/rdoc/RubyXL/CT_TextSpacing.html +13 -20
  168. data/rdoc/RubyXL/CT_TextTabStop.html +13 -20
  169. data/rdoc/RubyXL/CT_TextTabStopList.html +13 -20
  170. data/rdoc/RubyXL/CT_TileInfoProperties.html +13 -20
  171. data/rdoc/RubyXL/CT_TintEffect.html +13 -20
  172. data/rdoc/RubyXL/CT_Transform2D.html +13 -20
  173. data/rdoc/RubyXL/CT_TransformEffect.html +13 -20
  174. data/rdoc/RubyXL/CT_Vector3D.html +13 -20
  175. data/rdoc/RubyXL/CT_XYAdjustHandle.html +13 -20
  176. data/rdoc/RubyXL/CalculationChain.html +23 -50
  177. data/rdoc/RubyXL/CalculationChainCell.html +13 -20
  178. data/rdoc/RubyXL/CalculationProperties.html +13 -20
  179. data/rdoc/RubyXL/Cell.html +210 -258
  180. data/rdoc/RubyXL/CellConvenienceMethods.html +438 -572
  181. data/rdoc/RubyXL/CellExt.html +13 -20
  182. data/rdoc/RubyXL/CellSmartTag.html +13 -20
  183. data/rdoc/RubyXL/CellSmartTagProperty.html +13 -20
  184. data/rdoc/RubyXL/CellSmartTags.html +13 -20
  185. data/rdoc/RubyXL/CellStyle.html +13 -20
  186. data/rdoc/RubyXL/CellStyleXFs.html +25 -44
  187. data/rdoc/RubyXL/CellStyles.html +25 -44
  188. data/rdoc/RubyXL/CellValue.html +24 -43
  189. data/rdoc/RubyXL/CellWatch.html +13 -20
  190. data/rdoc/RubyXL/CellWatches.html +13 -20
  191. data/rdoc/RubyXL/CellXFs.html +26 -48
  192. data/rdoc/RubyXL/ChartColorsFile.html +12 -26
  193. data/rdoc/RubyXL/ChartFile.html +25 -54
  194. data/rdoc/RubyXL/ChartStyleFile.html +12 -26
  195. data/rdoc/RubyXL/ChartUserShapesFile.html +12 -26
  196. data/rdoc/RubyXL/Chartsheet.html +26 -73
  197. data/rdoc/RubyXL/ChartsheetPageSetup.html +13 -20
  198. data/rdoc/RubyXL/ChartsheetProperties.html +13 -20
  199. data/rdoc/RubyXL/ChartsheetProtection.html +13 -20
  200. data/rdoc/RubyXL/ChartsheetView.html +13 -20
  201. data/rdoc/RubyXL/ChartsheetViews.html +13 -20
  202. data/rdoc/RubyXL/Color.html +24 -48
  203. data/rdoc/RubyXL/ColorConvenienceClasses/HlsColor.html +246 -0
  204. data/rdoc/RubyXL/ColorConvenienceClasses/RgbColor.html +285 -0
  205. data/rdoc/RubyXL/ColorConvenienceClasses.html +91 -0
  206. data/rdoc/RubyXL/ColorConvenienceMethods.html +139 -0
  207. data/rdoc/RubyXL/ColorFilter.html +13 -20
  208. data/rdoc/RubyXL/ColorScale.html +13 -20
  209. data/rdoc/RubyXL/ColorSet.html +13 -20
  210. data/rdoc/RubyXL/Colors.html +13 -20
  211. data/rdoc/RubyXL/ColumnRange.html +76 -91
  212. data/rdoc/RubyXL/ColumnRanges.html +54 -106
  213. data/rdoc/RubyXL/Comment.html +13 -20
  214. data/rdoc/RubyXL/CommentList.html +13 -20
  215. data/rdoc/RubyXL/CommentsFile.html +24 -56
  216. data/rdoc/RubyXL/ConditionalFormatValue.html +13 -20
  217. data/rdoc/RubyXL/ConditionalFormatting.html +13 -20
  218. data/rdoc/RubyXL/ConditionalFormattingRule.html +13 -20
  219. data/rdoc/RubyXL/Connection.html +99 -0
  220. data/rdoc/RubyXL/ConnectionTable.html +99 -0
  221. data/rdoc/RubyXL/ConnectionTables.html +99 -0
  222. data/rdoc/RubyXL/ConnectionTextField.html +99 -0
  223. data/rdoc/RubyXL/ConnectionTextFields.html +99 -0
  224. data/rdoc/RubyXL/Connections.html +149 -0
  225. data/rdoc/RubyXL/ContentTypeDefault.html +12 -18
  226. data/rdoc/RubyXL/ContentTypeOverride.html +12 -18
  227. data/rdoc/RubyXL/ContentTypes.html +35 -72
  228. data/rdoc/RubyXL/ControlPropertiesFile.html +14 -23
  229. data/rdoc/RubyXL/CorePropertiesFile.html +89 -208
  230. data/rdoc/RubyXL/CustomColor.html +13 -20
  231. data/rdoc/RubyXL/CustomColorList.html +13 -20
  232. data/rdoc/RubyXL/CustomFilter.html +13 -20
  233. data/rdoc/RubyXL/CustomFilters.html +13 -20
  234. data/rdoc/RubyXL/CustomGeometry.html +13 -20
  235. data/rdoc/RubyXL/CustomProperties.html +13 -20
  236. data/rdoc/RubyXL/CustomPropertiesFile.html +12 -26
  237. data/rdoc/RubyXL/CustomProperty.html +13 -20
  238. data/rdoc/RubyXL/CustomPropertyFile.html +108 -0
  239. data/rdoc/RubyXL/CustomSheetView.html +13 -20
  240. data/rdoc/RubyXL/CustomSheetViews.html +13 -20
  241. data/rdoc/RubyXL/CustomWorkbookView.html +13 -20
  242. data/rdoc/RubyXL/CustomWorkbookViews.html +13 -20
  243. data/rdoc/RubyXL/CustomXMLFile.html +12 -23
  244. data/rdoc/RubyXL/DXF.html +13 -20
  245. data/rdoc/RubyXL/DXFs.html +13 -20
  246. data/rdoc/RubyXL/DataBar.html +13 -20
  247. data/rdoc/RubyXL/DataConsolidate.html +13 -20
  248. data/rdoc/RubyXL/DataConsolidationReference.html +13 -20
  249. data/rdoc/RubyXL/DataConsolidationReferences.html +13 -20
  250. data/rdoc/RubyXL/DataType.html +11 -40
  251. data/rdoc/RubyXL/DataValidation.html +13 -20
  252. data/rdoc/RubyXL/DataValidations.html +13 -20
  253. data/rdoc/RubyXL/DateGroupItem.html +13 -20
  254. data/rdoc/RubyXL/DefinedName.html +13 -20
  255. data/rdoc/RubyXL/DefinedNameExt.html +13 -20
  256. data/rdoc/RubyXL/DefinedNames.html +13 -20
  257. data/rdoc/RubyXL/DefinedNamesExt.html +13 -20
  258. data/rdoc/RubyXL/DocumentPropertiesFile.html +34 -76
  259. data/rdoc/RubyXL/DrawingFile.html +25 -54
  260. data/rdoc/RubyXL/DynamicFilter.html +13 -20
  261. data/rdoc/RubyXL/EmbeddedControl.html +13 -20
  262. data/rdoc/RubyXL/EmbeddedControls.html +13 -20
  263. data/rdoc/RubyXL/Extension.html +13 -20
  264. data/rdoc/RubyXL/ExtensionStorageArea.html +13 -20
  265. data/rdoc/RubyXL/Extents.html +13 -20
  266. data/rdoc/RubyXL/ExternalBook.html +13 -20
  267. data/rdoc/RubyXL/ExternalLinksFile.html +25 -54
  268. data/rdoc/RubyXL/ExternalReference.html +13 -20
  269. data/rdoc/RubyXL/ExternalReferences.html +13 -20
  270. data/rdoc/RubyXL/ExtraColorSchemeList.html +13 -20
  271. data/rdoc/RubyXL/FieldItem.html +13 -20
  272. data/rdoc/RubyXL/FileRecoveryProperties.html +13 -20
  273. data/rdoc/RubyXL/FileSharing.html +13 -20
  274. data/rdoc/RubyXL/FileVersion.html +13 -20
  275. data/rdoc/RubyXL/Fill.html +25 -44
  276. data/rdoc/RubyXL/Fills.html +25 -44
  277. data/rdoc/RubyXL/FilterContainer.html +13 -20
  278. data/rdoc/RubyXL/FloatNode.html +12 -18
  279. data/rdoc/RubyXL/FloatValue.html +12 -18
  280. data/rdoc/RubyXL/Font.html +28 -64
  281. data/rdoc/RubyXL/FontConvenienceMethods.html +133 -294
  282. data/rdoc/RubyXL/FontScheme.html +13 -20
  283. data/rdoc/RubyXL/Fonts.html +25 -44
  284. data/rdoc/RubyXL/Formula.html +13 -20
  285. data/rdoc/RubyXL/FunctionGroup.html +13 -20
  286. data/rdoc/RubyXL/FunctionGroups.html +13 -20
  287. data/rdoc/RubyXL/GenericStorageObject.html +41 -98
  288. data/rdoc/RubyXL/GradientFill.html +13 -20
  289. data/rdoc/RubyXL/HeaderFooterSettings.html +13 -20
  290. data/rdoc/RubyXL/Hyperlink.html +13 -20
  291. data/rdoc/RubyXL/HyperlinkRelFile.html +12 -23
  292. data/rdoc/RubyXL/Hyperlinks.html +13 -20
  293. data/rdoc/RubyXL/IconFilter.html +13 -20
  294. data/rdoc/RubyXL/IconSet.html +13 -20
  295. data/rdoc/RubyXL/IgnoredError.html +13 -20
  296. data/rdoc/RubyXL/IgnoredErrors.html +13 -20
  297. data/rdoc/RubyXL/IndexedColors.html +13 -20
  298. data/rdoc/RubyXL/InputCells.html +13 -20
  299. data/rdoc/RubyXL/IntegerNode.html +12 -18
  300. data/rdoc/RubyXL/IntegerValue.html +12 -18
  301. data/rdoc/RubyXL/LegacyCell.html +20 -71
  302. data/rdoc/RubyXL/LegacyWorksheet.html +77 -126
  303. data/rdoc/RubyXL/MRUColors.html +13 -20
  304. data/rdoc/RubyXL/MacrosFile.html +12 -26
  305. data/rdoc/RubyXL/MergedCell.html +13 -20
  306. data/rdoc/RubyXL/MergedCells.html +13 -20
  307. data/rdoc/RubyXL/NumFmt.html +13 -20
  308. data/rdoc/RubyXL/NumberFormat.html +25 -44
  309. data/rdoc/RubyXL/NumberFormats.html +25 -50
  310. data/rdoc/RubyXL/OLEObject.html +13 -20
  311. data/rdoc/RubyXL/OLEObjectFile.html +12 -26
  312. data/rdoc/RubyXL/OLEObjects.html +13 -20
  313. data/rdoc/RubyXL/OLESize.html +13 -20
  314. data/rdoc/RubyXL/OOXMLContainerObject.html +72 -157
  315. data/rdoc/RubyXL/OOXMLIgnored.html +32 -62
  316. data/rdoc/RubyXL/OOXMLObject.html +15 -26
  317. data/rdoc/RubyXL/OOXMLObjectClassMethods.html +126 -203
  318. data/rdoc/RubyXL/OOXMLObjectInstanceMethods.html +104 -226
  319. data/rdoc/RubyXL/OOXMLRelationshipsFile.html +109 -242
  320. data/rdoc/RubyXL/OOXMLTopLevelObject.html +67 -154
  321. data/rdoc/RubyXL/OdbcOleDbProperties.html +99 -0
  322. data/rdoc/RubyXL/Offset.html +13 -20
  323. data/rdoc/RubyXL/OlapProperties.html +99 -0
  324. data/rdoc/RubyXL/OleItem.html +99 -0
  325. data/rdoc/RubyXL/OleItems.html +99 -0
  326. data/rdoc/RubyXL/OleLink.html +99 -0
  327. data/rdoc/RubyXL/OutlineProperties.html +13 -20
  328. data/rdoc/RubyXL/PageMargins.html +13 -20
  329. data/rdoc/RubyXL/PageSetup.html +13 -20
  330. data/rdoc/RubyXL/PageSetupProperties.html +13 -20
  331. data/rdoc/RubyXL/Pane.html +13 -20
  332. data/rdoc/RubyXL/Parser.html +35 -65
  333. data/rdoc/RubyXL/PatternFill.html +13 -20
  334. data/rdoc/RubyXL/PersonMetadata.html +108 -0
  335. data/rdoc/RubyXL/PhoneticProperties.html +13 -20
  336. data/rdoc/RubyXL/PhoneticRun.html +13 -20
  337. data/rdoc/RubyXL/PivotArea.html +13 -20
  338. data/rdoc/RubyXL/PivotCache.html +13 -20
  339. data/rdoc/RubyXL/PivotCacheDefinitionFile.html +14 -31
  340. data/rdoc/RubyXL/PivotCacheRecordsFile.html +12 -26
  341. data/rdoc/RubyXL/PivotCaches.html +13 -20
  342. data/rdoc/RubyXL/PivotReference.html +13 -20
  343. data/rdoc/RubyXL/PivotReferences.html +13 -20
  344. data/rdoc/RubyXL/PivotTableFile.html +14 -31
  345. data/rdoc/RubyXL/PivotTableSelection.html +13 -20
  346. data/rdoc/RubyXL/PresetGeometry.html +13 -20
  347. data/rdoc/RubyXL/PrintOptions.html +13 -20
  348. data/rdoc/RubyXL/PrinterSettingsFile.html +12 -26
  349. data/rdoc/RubyXL/ProtectedRange.html +13 -20
  350. data/rdoc/RubyXL/ProtectedRanges.html +13 -20
  351. data/rdoc/RubyXL/Protection.html +13 -20
  352. data/rdoc/RubyXL/QueryParameter.html +99 -0
  353. data/rdoc/RubyXL/QueryParameters.html +99 -0
  354. data/rdoc/RubyXL/QueryTable.html +157 -0
  355. data/rdoc/RubyXL/QueryTableDeletedField.html +99 -0
  356. data/rdoc/RubyXL/QueryTableDeletedFields.html +99 -0
  357. data/rdoc/RubyXL/QueryTableField.html +99 -0
  358. data/rdoc/RubyXL/QueryTableFields.html +99 -0
  359. data/rdoc/RubyXL/QueryTableRefresh.html +99 -0
  360. data/rdoc/RubyXL/RID.html +12 -18
  361. data/rdoc/RubyXL/RawOOXML.html +33 -69
  362. data/rdoc/RubyXL/Reference.html +156 -286
  363. data/rdoc/RubyXL/Relationship.html +12 -18
  364. data/rdoc/RubyXL/RelationshipSupport/ClassMehods.html +20 -37
  365. data/rdoc/RubyXL/RelationshipSupport.html +62 -145
  366. data/rdoc/RubyXL/RevisionPointer.html +13 -23
  367. data/rdoc/RubyXL/RichText.html +27 -45
  368. data/rdoc/RubyXL/RichTextRun.html +24 -43
  369. data/rdoc/RubyXL/Row.html +88 -205
  370. data/rdoc/RubyXL/RowExt.html +13 -20
  371. data/rdoc/RubyXL/RunProperties.html +13 -20
  372. data/rdoc/RubyXL/Scenario.html +13 -20
  373. data/rdoc/RubyXL/Scenarios.html +13 -20
  374. data/rdoc/RubyXL/Selection.html +23 -42
  375. data/rdoc/RubyXL/ShapeGuide.html +13 -20
  376. data/rdoc/RubyXL/ShapeTextRectangle.html +13 -20
  377. data/rdoc/RubyXL/SharedStringsTable.html +81 -177
  378. data/rdoc/RubyXL/Sheet.html +13 -20
  379. data/rdoc/RubyXL/SheetCalculationProperties.html +13 -20
  380. data/rdoc/RubyXL/SheetData.html +32 -62
  381. data/rdoc/RubyXL/SheetDataExt.html +13 -20
  382. data/rdoc/RubyXL/SheetDataSet.html +13 -20
  383. data/rdoc/RubyXL/SheetMetadata.html +108 -0
  384. data/rdoc/RubyXL/SheetName.html +13 -20
  385. data/rdoc/RubyXL/SheetNames.html +13 -20
  386. data/rdoc/RubyXL/Sheets.html +13 -20
  387. data/rdoc/RubyXL/SlicerCacheFile.html +12 -26
  388. data/rdoc/RubyXL/SlicerFile.html +12 -26
  389. data/rdoc/RubyXL/SmartTagProperties.html +13 -20
  390. data/rdoc/RubyXL/SmartTagType.html +13 -20
  391. data/rdoc/RubyXL/SmartTagTypes.html +13 -20
  392. data/rdoc/RubyXL/SmartTags.html +13 -20
  393. data/rdoc/RubyXL/SortCondition.html +13 -20
  394. data/rdoc/RubyXL/SortState.html +13 -20
  395. data/rdoc/RubyXL/Sqref.html +33 -63
  396. data/rdoc/RubyXL/Stop.html +13 -20
  397. data/rdoc/RubyXL/StringNode.html +12 -18
  398. data/rdoc/RubyXL/StringNodeW3C.html +33 -63
  399. data/rdoc/RubyXL/StringValue.html +12 -18
  400. data/rdoc/RubyXL/Stylesheet.html +65 -138
  401. data/rdoc/RubyXL/TableFile.html +12 -26
  402. data/rdoc/RubyXL/TableParts.html +12 -18
  403. data/rdoc/RubyXL/TableStyle.html +13 -20
  404. data/rdoc/RubyXL/TableStyles.html +13 -20
  405. data/rdoc/RubyXL/Text.html +35 -76
  406. data/rdoc/RubyXL/TextImportSettings.html +99 -0
  407. data/rdoc/RubyXL/Theme.html +72 -72
  408. data/rdoc/RubyXL/ThemeElements.html +13 -20
  409. data/rdoc/RubyXL/ThumbnailFile.html +12 -26
  410. data/rdoc/RubyXL/Top10.html +13 -20
  411. data/rdoc/RubyXL/VMLDrawingFile.html +15 -33
  412. data/rdoc/RubyXL/Variant.html +13 -20
  413. data/rdoc/RubyXL/Vector.html +24 -43
  414. data/rdoc/RubyXL/VectorValue.html +12 -18
  415. data/rdoc/RubyXL/VisualProperties.html +13 -20
  416. data/rdoc/RubyXL/WebPublishObject.html +13 -20
  417. data/rdoc/RubyXL/WebPublishObjects.html +13 -20
  418. data/rdoc/RubyXL/WebPublishingItem.html +13 -20
  419. data/rdoc/RubyXL/WebPublishingItems.html +13 -20
  420. data/rdoc/RubyXL/WebPublishingProperties.html +13 -20
  421. data/rdoc/RubyXL/WebQueryProperties.html +99 -0
  422. data/rdoc/RubyXL/Workbook.html +581 -266
  423. data/rdoc/RubyXL/WorkbookConvenienceMethods.html +226 -951
  424. data/rdoc/RubyXL/WorkbookProperties.html +13 -20
  425. data/rdoc/RubyXL/WorkbookProtection.html +13 -20
  426. data/rdoc/RubyXL/WorkbookRoot.html +58 -135
  427. data/rdoc/RubyXL/WorkbookView.html +13 -20
  428. data/rdoc/RubyXL/WorkbookViews.html +13 -20
  429. data/rdoc/RubyXL/Worksheet.html +122 -137
  430. data/rdoc/RubyXL/WorksheetConvenienceMethods.html +717 -1373
  431. data/rdoc/RubyXL/WorksheetDimensions.html +13 -20
  432. data/rdoc/RubyXL/WorksheetFormatProperties.html +12 -18
  433. data/rdoc/RubyXL/WorksheetProperties.html +13 -20
  434. data/rdoc/RubyXL/WorksheetProtection.html +13 -20
  435. data/rdoc/RubyXL/WorksheetView.html +13 -20
  436. data/rdoc/RubyXL/WorksheetViews.html +13 -20
  437. data/rdoc/RubyXL/XF.html +13 -20
  438. data/rdoc/RubyXL.html +46 -306
  439. data/rdoc/created.rid +45 -38
  440. data/rdoc/css/rdoc.css +109 -12
  441. data/rdoc/fonts/SourceCodePro-Bold.ttf +0 -0
  442. data/rdoc/fonts/SourceCodePro-Regular.ttf +0 -0
  443. data/rdoc/index.html +403 -726
  444. data/rdoc/js/darkfish.js +33 -97
  445. data/rdoc/js/navigation.js +12 -49
  446. data/rdoc/js/navigation.js.gz +0 -0
  447. data/rdoc/js/search.js +35 -34
  448. data/rdoc/js/search_index.js +1 -1
  449. data/rdoc/js/search_index.js.gz +0 -0
  450. data/rdoc/js/searcher.js +6 -6
  451. data/rdoc/js/searcher.js.gz +0 -0
  452. data/rdoc/table_of_contents.html +287 -45
  453. data/rubyXL.gemspec +77 -43
  454. data/spec/lib/cell_spec.rb +119 -6
  455. data/spec/lib/color_spec.rb +9 -1
  456. data/spec/lib/parser_spec.rb +28 -28
  457. data/spec/lib/reference_spec.rb +41 -5
  458. data/spec/lib/rgb_color_spec.rb +29 -0
  459. data/spec/lib/stylesheet_spec.rb +10 -11
  460. data/spec/lib/text_spec.rb +4 -6
  461. data/spec/lib/workbook_spec.rb +31 -8
  462. data/spec/lib/worksheet_spec.rb +886 -480
  463. data/spec/spec_helper.rb +2 -0
  464. data/test/test_parse_write.rb +15 -15
  465. metadata +76 -10
  466. data/rdoc/js/jquery.js +0 -4
@@ -4,7 +4,6 @@ require 'rubyXL/objects/container_nodes'
4
4
  require 'rubyXL/objects/color'
5
5
 
6
6
  module RubyXL
7
-
8
7
  # http://www.datypic.com/sc/ooxml/e-ssml_t-1.html
9
8
  class Text < OOXMLObject
10
9
  define_attribute(:_, :string, :accessor => :value)
@@ -19,12 +18,12 @@ module RubyXL
19
18
 
20
19
  def before_write_xml
21
20
  preserve_whitespace
22
- self.value.gsub!(INVALID_XML10_CHARS) { |c| "_x%04x_" % c.ord }
21
+ self.value.gsub(INVALID_XML10_CHARS) { |bad_char| format('_x%04x_', bad_char.ord) }
23
22
  true
24
23
  end
25
24
 
26
25
  def to_s
27
- value.to_s.gsub(ESCAPED_UNICODE) { |m| $1.hex.chr(::Encoding::UTF_8) }
26
+ value.to_s.gsub(ESCAPED_UNICODE) { Regexp.last_match(1).hex.chr(::Encoding::UTF_8) }
28
27
  end
29
28
  end
30
29
 
@@ -57,7 +56,6 @@ module RubyXL
57
56
  def to_s
58
57
  t.to_s
59
58
  end
60
-
61
59
  end
62
60
 
63
61
  # http://www.datypic.com/sc/ooxml/e-ssml_rPh-1.html
@@ -70,7 +68,7 @@ module RubyXL
70
68
 
71
69
  # http://www.datypic.com/sc/ooxml/e-ssml_phoneticPr-1.html
72
70
  class PhoneticProperties < OOXMLObject
73
- define_attribute(:fontId, :int, :required => true)
71
+ define_attribute(:fontId, :int, :required => true)
74
72
  define_attribute(:type, RubyXL::ST_PhoneticType, :default => 'fullwidthKatakana')
75
73
  define_attribute(:alignment, RubyXL::ST_PhoneticAlignment, :default => 'left')
76
74
  define_element_name 'phoneticPr'
@@ -85,10 +83,10 @@ module RubyXL
85
83
  define_element_name 'is'
86
84
 
87
85
  def to_s
88
- str = t.to_s
89
- r && r.each { |rtr| str << rtr.to_s if rtr }
86
+ # `dup` here unfreezes the string since it's not a constant but initial value
87
+ str = t.nil? ? ''.dup : t.to_s
88
+ r&.each { |rtr| str << rtr.to_s if rtr }
90
89
  str
91
90
  end
92
91
  end
93
-
94
92
  end
@@ -1,9 +1,7 @@
1
- # encoding: UTF-8 <-- magic comment, need this because of sime fancy fonts in the default scheme below. See http://stackoverflow.com/questions/6444826/ruby-utf-8-file-encoding
2
1
  require 'rubyXL/objects/ooxml_object'
3
2
  require 'rubyXL/objects/extensions'
4
3
 
5
4
  module RubyXL
6
-
7
5
  # http://www.datypic.com/sc/ooxml/e-a_ext-1.html
8
6
  class AExtension < OOXMLObject
9
7
  define_attribute(:uri, :string)
@@ -19,7 +17,6 @@ module RubyXL
19
17
  def write_xml(xml, node_name_override = nil)
20
18
  self.raw_xml
21
19
  end
22
-
23
20
  end
24
21
 
25
22
  class AExtensionStorageArea < OOXMLObject
@@ -1164,7 +1161,7 @@ module RubyXL
1164
1161
  class CT_Hyperlink < OOXMLObject
1165
1162
  define_child_node(RubyXL::CT_EmbeddedWAVAudioFile)
1166
1163
  define_child_node(RubyXL::AExtensionStorageArea)
1167
- define_attribute(:'r:id', :string)
1164
+ define_relationship
1168
1165
  define_attribute(:invalidUrl, :string, :default => '')
1169
1166
  define_attribute(:action, :string, :default => '')
1170
1167
  define_attribute(:tgtFrame, :string, :default => '')
@@ -1183,7 +1180,7 @@ module RubyXL
1183
1180
  define_child_node(RubyXL::CT_GradientFillProperties)
1184
1181
  define_child_node(RubyXL::CT_BlipFillProperties)
1185
1182
  define_child_node(RubyXL::CT_PatternFillProperties)
1186
- define_child_node(RubyXL::BooleanValue, :node_name => 'a:grpFill')
1183
+ define_child_node(RubyXL::BooleanValue, :node_name => 'a:grpFill')
1187
1184
  # -- EG_EffectProperties
1188
1185
  define_child_node(RubyXL::CT_EffectList)
1189
1186
  define_child_node(RubyXL::CT_EffectContainer, :node_name => 'a:effectDag')
@@ -1373,8 +1370,8 @@ module RubyXL
1373
1370
 
1374
1371
  # http://www.datypic.com/sc/ooxml/e-a_theme.html
1375
1372
  class Theme < OOXMLTopLevelObject
1376
- CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.theme+xml'
1377
- REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme'
1373
+ CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.theme+xml'.freeze
1374
+ REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/theme'.freeze
1378
1375
 
1379
1376
  define_attribute(:name, :string, :default => '')
1380
1377
  define_child_node(RubyXL::ThemeElements)
@@ -1391,6 +1388,25 @@ module RubyXL
1391
1388
  ROOT.join('xl', 'theme', 'theme1.xml')
1392
1389
  end
1393
1390
 
1391
+ def get_theme_color(idx)
1392
+ color_scheme = a_theme_elements&.a_clr_scheme
1393
+
1394
+ return unless color_scheme
1395
+
1396
+ case idx
1397
+ when 0 then color_scheme.a_lt1
1398
+ when 1 then color_scheme.a_dk1
1399
+ when 2 then color_scheme.a_lt2
1400
+ when 3 then color_scheme.a_dk2
1401
+ when 4 then color_scheme.a_accent1
1402
+ when 5 then color_scheme.a_accent2
1403
+ when 6 then color_scheme.a_accent3
1404
+ when 7 then color_scheme.a_accent4
1405
+ when 8 then color_scheme.a_accent5
1406
+ when 9 then color_scheme.a_accent6
1407
+ end
1408
+ end
1409
+
1394
1410
  def self.default
1395
1411
  default_theme = '<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
1396
1412
  <a:theme xmlns:a="http://schemas.openxmlformats.org/drawingml/2006/main" name="Office Theme">
@@ -1710,7 +1726,5 @@ module RubyXL
1710
1726
  </a:theme>'
1711
1727
  self.parse(default_theme)
1712
1728
  end
1713
-
1714
1729
  end
1715
-
1716
1730
  end
@@ -1,4 +1,3 @@
1
- #require 'tmpdir'
2
1
  require 'date'
3
2
  require 'rubyXL/objects/ooxml_object'
4
3
  require 'rubyXL/objects/shared_strings'
@@ -7,14 +6,13 @@ require 'rubyXL/objects/theme'
7
6
  require 'rubyXL/objects/calculation_chain'
8
7
  require 'rubyXL/objects/worksheet'
9
8
  require 'rubyXL/objects/chartsheet'
9
+ require 'rubyXL/objects/connection'
10
10
  require 'rubyXL/objects/relationships'
11
11
  require 'rubyXL/objects/simple_types'
12
12
  require 'rubyXL/objects/extensions'
13
13
  require 'rubyXL/objects/external_links'
14
- require 'rubyXL/convenience_methods'
15
14
 
16
15
  module RubyXL
17
-
18
16
  # Eventually, the entire code for Workbook will be moved here.
19
17
 
20
18
  # http://www.datypic.com/sc/ooxml/e-ssml_fileVersion-1.html
@@ -37,7 +35,7 @@ module RubyXL
37
35
 
38
36
  # http://www.datypic.com/sc/ooxml/e-ssml_workbookPr-1.html
39
37
  class WorkbookProperties < OOXMLObject
40
- define_attribute(:date1904, :bool, :default => false)
38
+ define_attribute(:date1904, :bool, :default => false)
41
39
  define_attribute(:showObjects, RubyXL::ST_Objects, :default => 'all')
42
40
  define_attribute(:showBorderUnselectedTables, :bool, :default => true)
43
41
  define_attribute(:filterPrivacy, :bool, :default => false)
@@ -98,7 +96,7 @@ module RubyXL
98
96
  define_attribute(:name, :string, :required => true)
99
97
  define_attribute(:sheetId, :int, :required => true)
100
98
  define_attribute(:state, RubyXL::ST_Visibility, :default => 'visible')
101
- define_attribute(:'r:id', :string, :required => true)
99
+ define_relationship(:required => true)
102
100
  define_element_name 'sheet'
103
101
  end
104
102
 
@@ -110,7 +108,7 @@ module RubyXL
110
108
 
111
109
  # http://www.datypic.com/sc/ooxml/e-ssml_externalReference-1.html
112
110
  class ExternalReference < OOXMLObject
113
- define_attribute(:'r:id', :string, :required => true)
111
+ define_relationship(:required => true)
114
112
  define_element_name 'externalReference'
115
113
  end
116
114
 
@@ -152,8 +150,8 @@ module RubyXL
152
150
 
153
151
  # http://www.datypic.com/sc/ooxml/e-ssml_pivotCache-1.html
154
152
  class PivotCache < OOXMLObject
155
- define_attribute(:cacheId, :int, :required => true)
156
- define_attribute(:'r:id', :string, :required => true)
153
+ define_attribute(:cacheId, :int, :required => true)
154
+ define_relationship(:required => true)
157
155
  define_element_name 'pivotCache'
158
156
  end
159
157
 
@@ -186,7 +184,7 @@ module RubyXL
186
184
  define_attribute(:vml, :bool, :default => false)
187
185
  define_attribute(:allowPng, :bool, :default => false)
188
186
  define_attribute(:targetScreenSize, RubyXL::ST_TargetScreenSize, :default => '800x600')
189
- define_attribute(:dpi, :int, :default => 96)
187
+ define_attribute(:dpi, :int, :default => 96)
190
188
  define_attribute(:codePage, :int)
191
189
  define_element_name 'webPublishing'
192
190
  end
@@ -195,7 +193,7 @@ module RubyXL
195
193
  class CalculationProperties < OOXMLObject
196
194
  define_attribute(:calcId, :int)
197
195
  define_attribute(:calcMode, RubyXL::ST_CalcMode, :default => 'auto')
198
- define_attribute(:fullCalcOnLoad, :bool, :default => false)
196
+ define_attribute(:fullCalcOnLoad, :bool, :default => false)
199
197
  define_attribute(:refMode, RubyXL::ST_RefMode, :default => 'A1')
200
198
  define_attribute(:iterate, :bool, :default => false)
201
199
  define_attribute(:iterateCount, :int, :default => 100)
@@ -216,7 +214,7 @@ module RubyXL
216
214
  define_attribute(:sourceObject, :string)
217
215
  define_attribute(:destinationFile, :string, :required => true)
218
216
  define_attribute(:title, :string)
219
- define_attribute(:autoRepublish, :bool, :default => false)
217
+ define_attribute(:autoRepublish, :bool, :default => false)
220
218
  define_element_name 'webPublishObject'
221
219
  end
222
220
 
@@ -228,7 +226,7 @@ module RubyXL
228
226
 
229
227
  # http://www.datypic.com/sc/ooxml/e-ssml_smartTagPr-1.html
230
228
  class SmartTagProperties < OOXMLObject
231
- define_attribute(:embed, :bool, :default => false)
229
+ define_attribute(:embed, :bool, :default => false)
232
230
  define_attribute(:show, RubyXL::ST_SmartTagShow, :default => 'all')
233
231
  define_element_name 'smartTagPr'
234
232
  end
@@ -280,7 +278,7 @@ module RubyXL
280
278
  define_attribute(:yWindow, :int, :default => 0)
281
279
  define_attribute(:windowWidth, :int)
282
280
  define_attribute(:windowHeight, :int)
283
- define_attribute(:tabRatio, :int, :default => 600)
281
+ define_attribute(:tabRatio, :int, :default => 600)
284
282
  define_attribute(:activeSheetId, :int)
285
283
  define_attribute(:showFormulaBar, :bool, :default => true)
286
284
  define_attribute(:showStatusbar, :bool, :default => true)
@@ -298,18 +296,25 @@ module RubyXL
298
296
 
299
297
  # http://www.datypic.com/sc/ooxml/e-ssml_workbook.html
300
298
  class Workbook < OOXMLTopLevelObject
301
- CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml'
302
- CONTENT_TYPE_WITH_MACROS = 'application/vnd.ms-excel.sheet.macroEnabled.main+xml'
303
- REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument'
299
+ CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet.main+xml'.freeze
300
+ CONTENT_TYPE_TEMPLATE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.template.main+xml'.freeze
301
+ CONTENT_TYPE_TEMPLATE_WITH_MACROS = 'application/vnd.ms-excel.template.macroEnabled.main+xml'.freeze
302
+ CONTENT_TYPE_WITH_MACROS = 'application/vnd.ms-excel.sheet.macroEnabled.main+xml'.freeze
303
+ REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/officeDocument'.freeze
304
304
 
305
305
  # http://www.accountingweb.com/technology/excel/seven-characters-you-cant-use-in-worksheet-names
306
- SHEET_NAME_FORBIDDEN_CHARS = /[\/\\\*\[\]\:\?]/
307
- #SHEET_NAME_FORBIDDEN_NAMES = [ 'History' ]
306
+ SHEET_NAME_FORBIDDEN_CHARS = %r{[/\\*\[\]:?]}
307
+
308
+ # https://answers.microsoft.com/en-us/msoffice/forum/all/excel-history-is-a-reserved-name-help/f8a398a4-b72c-48e3-82da-4f132c305e91
309
+ SHEET_NAME_FORBIDDEN_NAMES = [ 'History' ]
308
310
 
309
311
  include RubyXL::RelationshipSupport
310
312
 
311
313
  def content_type
312
- if macros then CONTENT_TYPE_WITH_MACROS else CONTENT_TYPE end
314
+ content_type_name = 'CONTENT_TYPE'
315
+ content_type_name << '_TEMPLATE' if is_template
316
+ content_type_name << '_WITH_MACROS' if macros
317
+ self.class.const_get(content_type_name)
313
318
  end
314
319
 
315
320
  def related_objects
@@ -322,12 +327,14 @@ module RubyXL
322
327
  define_relationship(RubyXL::CalculationChain, :calculation_chain)
323
328
  define_relationship(RubyXL::Worksheet, false)
324
329
  define_relationship(RubyXL::Chartsheet, false)
330
+ define_relationship(RubyXL::Connections)
325
331
  define_relationship(RubyXL::ExternalLinksFile)
326
332
  define_relationship(RubyXL::PivotCacheDefinitionFile)
327
333
  define_relationship(RubyXL::PivotCacheRecordsFile)
328
334
  define_relationship(RubyXL::CustomXMLFile)
329
- define_relationship(RubyXL::MacrosFile, :macros)
335
+ define_relationship(RubyXL::MacrosFile, :macros)
330
336
  define_relationship(RubyXL::SlicerCacheFile)
337
+ define_relationship(RubyXL::PersonMetadata)
331
338
 
332
339
  define_child_node(RubyXL::FileVersion)
333
340
  define_child_node(RubyXL::FileSharing)
@@ -352,12 +359,12 @@ module RubyXL
352
359
  define_child_node(RubyXL::ExtensionStorageArea)
353
360
 
354
361
  define_element_name 'workbook'
355
- set_namespaces('http://schemas.openxmlformats.org/spreadsheetml/2006/main' => nil,
362
+ set_namespaces('http://schemas.openxmlformats.org/spreadsheetml/2006/main' => nil,
356
363
  'http://schemas.openxmlformats.org/officeDocument/2006/relationships' => 'r',
357
- 'http://schemas.openxmlformats.org/markup-compatibility/2006' => 'mc',
358
- 'http://schemas.microsoft.com/office/spreadsheetml/2010/11/main' => 'x15')
364
+ 'http://schemas.openxmlformats.org/markup-compatibility/2006' => 'mc',
365
+ 'http://schemas.microsoft.com/office/spreadsheetml/2010/11/main' => 'x15')
359
366
 
360
- attr_accessor :worksheets
367
+ attr_accessor :worksheets, :is_template
361
368
 
362
369
  def before_write_xml
363
370
  max_sheet_id = worksheets.collect(&:sheet_id).compact.max || 0
@@ -368,6 +375,7 @@ module RubyXL
368
375
  rel = relationship_container.find_by_target(sheet.xlsx_path)
369
376
 
370
377
  raise "Worksheet name '#{sheet.sheet_name}' contains forbidden characters" if sheet.sheet_name =~ SHEET_NAME_FORBIDDEN_CHARS
378
+ raise "Worksheet name '#{sheet.sheet_name}' is forbidden" if SHEET_NAME_FORBIDDEN_NAMES.include?(sheet.sheet_name)
371
379
 
372
380
  sheets << RubyXL::Sheet.new(:name => sheet.sheet_name[0..30], # Max sheet name length is 31 char
373
381
  :sheet_id => sheet.sheet_id || (max_sheet_id += 1),
@@ -392,37 +400,43 @@ module RubyXL
392
400
  dst_file_path ||= root.source_file_path
393
401
 
394
402
  extension = File.extname(dst_file_path)
395
- unless %w{.xlsx .xlsm}.include?(extension.downcase)
396
- raise "Unsupported extension: #{extension} (only .xlsx and .xlsm files are supported)."
403
+ unless %w{.xlsx .xlsm .xltx .xltm}.include?(extension.downcase)
404
+ raise "Unsupported extension: #{extension} (only .xlsx, .xlsm, .xltx and .xltm files are supported)."
397
405
  end
398
406
 
399
- File.open(dst_file_path, "wb") { |output_file| FileUtils.copy_stream(root.stream, output_file) }
407
+ File.open(dst_file_path, 'wb') { |output_file| FileUtils.copy_stream(root.stream, output_file) }
400
408
 
401
409
  return dst_file_path
402
410
  end
403
411
  alias_method :write, :save
404
412
 
405
413
  DATE1904 = DateTime.new(1904, 1, 1)
406
- # Subtracting one day to accomodate for erroneous 1900 leap year compatibility only for 1900 based dates
414
+ # Subtracting one day to accommodate for erroneous 1900 leap year compatibility only for 1900 based dates
407
415
  DATE1899 = DateTime.new(1899, 12, 31) - 1
408
416
  MARCH_1_1900 = 61
409
417
 
410
418
  def base_date
411
- (workbook_properties && workbook_properties.date1904) ? DATE1904 : DATE1899
419
+ workbook_properties&.date1904 ? DATE1904 : DATE1899
412
420
  end
413
421
  private :base_date
414
422
 
415
423
  def date_to_num(date)
416
- date && (date.ajd - base_date().ajd).to_f
424
+ case date
425
+ when Date, DateTime then (date.ajd - base_date.ajd).to_f
426
+ when Time then ((date.to_r - base_date.to_time.to_r) / 86400).to_f
427
+ end
417
428
  end
418
429
 
419
430
  def num_to_date(num)
431
+ return nil if num.nil?
432
+
420
433
  # Bug-for-bug Excel compatibility (https://support.microsoft.com/kb/214058/)
421
- if num && num < MARCH_1_1900 then
422
- num += 1 unless workbook_properties && workbook_properties.date1904
434
+ if num < MARCH_1_1900 then
435
+ num += 1 unless workbook_properties&.date1904
423
436
  end
424
437
 
425
- num && (base_date + num)
438
+ dateparts = num.divmod(1)
439
+ base_date + (dateparts[0] + ((dateparts[1] * 86400).round(6) / 86400))
426
440
  end
427
441
 
428
442
  include Enumerable
@@ -431,7 +445,8 @@ module RubyXL
431
445
  APPVERSION = '12.0000'
432
446
 
433
447
  def initialize(worksheets = [], src_file_path = nil, creator = nil, modifier = nil, created_at = nil,
434
- company = '', application = APPLICATION, appversion = APPVERSION, date1904 = 0)
448
+ company = '', application = APPLICATION, appversion = APPVERSION, date1904 = 0,
449
+ is_template = false)
435
450
  super()
436
451
 
437
452
  # Order of sheets in the +worksheets+ array corresponds to the order of pages in Excel UI.
@@ -456,9 +471,102 @@ module RubyXL
456
471
  self.creator = creator
457
472
  self.modifier = modifier
458
473
  self.date1904 = date1904 > 0
474
+ self.is_template = is_template
459
475
  end
460
476
 
461
- include WorkbookConvenienceMethods
462
- end
477
+ SHEET_NAME_TEMPLATE = 'Sheet%d'
478
+
479
+ # Finds worksheet by its name or numerical index
480
+ def [](ind)
481
+ case ind
482
+ when Integer then worksheets[ind]
483
+ when String then worksheets.find { |ws| ws.sheet_name == ind }
484
+ end
485
+ end
486
+
487
+ # Create new simple worksheet and add it to the workbook worksheets
488
+ #
489
+ # @param [String] The name for the new worksheet
490
+ def add_worksheet(name = nil)
491
+ if name.nil? then
492
+ n = 0
493
+
494
+ begin
495
+ name = SHEET_NAME_TEMPLATE % (n += 1)
496
+ end until self[name].nil?
497
+ end
498
+
499
+ new_worksheet = Worksheet.new(:workbook => self, :sheet_name => name)
500
+ worksheets << new_worksheet
501
+ new_worksheet
502
+ end
503
+
504
+ def created_at
505
+ root.core_properties.created_at
506
+ end
507
+
508
+ def created_at=(v)
509
+ root.core_properties.created_at = v
510
+ end
511
+
512
+ def modified_at
513
+ root.core_properties.modified_at
514
+ end
515
+
516
+ def modified_at=(v)
517
+ root.core_properties.modified_at = v
518
+ end
519
+
520
+ def company
521
+ root.document_properties.company&.value
522
+ end
463
523
 
524
+ def company=(v)
525
+ root.document_properties.company ||= StringNode.new
526
+ root.document_properties.company.value = v
527
+ end
528
+
529
+ def application
530
+ root.document_properties.application&.value
531
+ end
532
+
533
+ def application=(v)
534
+ root.document_properties.application ||= StringNode.new
535
+ root.document_properties.application.value = v
536
+ end
537
+
538
+ def appversion
539
+ root.document_properties.app_version&.value
540
+ end
541
+
542
+ def appversion=(v)
543
+ root.document_properties.app_version ||= StringNode.new
544
+ root.document_properties.app_version.value = v
545
+ end
546
+
547
+ def creator
548
+ root.core_properties.creator
549
+ end
550
+
551
+ def creator=(v)
552
+ root.core_properties.creator = v
553
+ end
554
+
555
+ def modifier
556
+ root.core_properties.modifier
557
+ end
558
+
559
+ def modifier=(v)
560
+ root.core_properties.modifier = v
561
+ end
562
+
563
+ def date1904
564
+ workbook_properties&.date1904
565
+ end
566
+
567
+ def date1904=(v)
568
+ self.workbook_properties ||= RubyXL::WorkbookProperties.new
569
+ workbook_properties.date1904 = v
570
+ end
571
+ end
464
572
  end