rubyXL 3.3.22 → 3.4.25

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 (465) hide show
  1. checksums.yaml +5 -5
  2. data/.circleci/config.yml +60 -0
  3. data/.codeclimate.yml +3 -0
  4. data/Gemfile +9 -8
  5. data/Gemfile.lock +124 -0
  6. data/LICENSE.txt +1 -1
  7. data/README.rdoc +54 -18
  8. data/Rakefile +29 -29
  9. data/VERSION +1 -1
  10. data/lib/rubyXL/cell.rb +3 -30
  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 +141 -0
  15. data/lib/rubyXL/convenience_methods/worksheet.rb +714 -0
  16. data/lib/rubyXL/convenience_methods.rb +5 -1045
  17. data/lib/rubyXL/objects/border.rb +2 -5
  18. data/lib/rubyXL/objects/calculation_chain.rb +4 -4
  19. data/lib/rubyXL/objects/cell_style.rb +9 -11
  20. data/lib/rubyXL/objects/chartsheet.rb +15 -19
  21. data/lib/rubyXL/objects/color.rb +7 -7
  22. data/lib/rubyXL/objects/column_range.rb +10 -13
  23. data/lib/rubyXL/objects/comments.rb +5 -8
  24. data/lib/rubyXL/objects/connection.rb +175 -0
  25. data/lib/rubyXL/objects/container_nodes.rb +3 -7
  26. data/lib/rubyXL/objects/content_types.rb +5 -8
  27. data/lib/rubyXL/objects/data_validation.rb +4 -4
  28. data/lib/rubyXL/objects/document_properties.rb +12 -16
  29. data/lib/rubyXL/objects/extensions.rb +19 -4
  30. data/lib/rubyXL/objects/external_links.rb +30 -8
  31. data/lib/rubyXL/objects/fill.rb +6 -9
  32. data/lib/rubyXL/objects/filters.rb +17 -19
  33. data/lib/rubyXL/objects/font.rb +4 -64
  34. data/lib/rubyXL/objects/formula.rb +4 -6
  35. data/lib/rubyXL/objects/ooxml_object.rb +25 -18
  36. data/lib/rubyXL/objects/query_table.rb +104 -0
  37. data/lib/rubyXL/objects/reference.rb +6 -8
  38. data/lib/rubyXL/objects/relationships.rb +13 -13
  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 +5 -7
  42. data/lib/rubyXL/objects/sheet_data.rb +50 -16
  43. data/lib/rubyXL/objects/simple_types.rb +21 -1
  44. data/lib/rubyXL/objects/storage.rb +67 -43
  45. data/lib/rubyXL/objects/stylesheet.rb +22 -29
  46. data/lib/rubyXL/objects/text.rb +12 -14
  47. data/lib/rubyXL/objects/theme.rb +142 -126
  48. data/lib/rubyXL/objects/workbook.rb +172 -64
  49. data/lib/rubyXL/objects/worksheet.rb +143 -128
  50. data/lib/rubyXL/parser.rb +1 -3
  51. data/lib/rubyXL/worksheet.rb +83 -78
  52. data/lib/rubyXL.rb +1 -1
  53. data/rdoc/README_rdoc.html +122 -114
  54. data/rdoc/RubyXL/AExtension.html +21 -60
  55. data/rdoc/RubyXL/AExtensionStorageArea.html +12 -17
  56. data/rdoc/RubyXL/ActiveX.html +154 -0
  57. data/rdoc/RubyXL/ActiveXBinary.html +106 -0
  58. data/rdoc/RubyXL/AdjustHandleList.html +13 -19
  59. data/rdoc/RubyXL/Alignment.html +13 -19
  60. data/rdoc/RubyXL/AlternateContent.html +12 -17
  61. data/rdoc/RubyXL/Authors.html +13 -19
  62. data/rdoc/RubyXL/AutoFilter.html +13 -19
  63. data/rdoc/RubyXL/AutoFilterColumn.html +13 -19
  64. data/rdoc/RubyXL/BinaryImageFile.html +12 -25
  65. data/rdoc/RubyXL/BodyProperties.html +13 -19
  66. data/rdoc/RubyXL/BooleanNode.html +12 -17
  67. data/rdoc/RubyXL/BooleanValue.html +12 -17
  68. data/rdoc/RubyXL/Border.html +25 -84
  69. data/rdoc/RubyXL/BorderEdge.html +20 -52
  70. data/rdoc/RubyXL/Borders.html +19 -39
  71. data/rdoc/RubyXL/Break.html +13 -19
  72. data/rdoc/RubyXL/BreakList.html +13 -19
  73. data/rdoc/RubyXL/CT_AdjPoint2D.html +13 -19
  74. data/rdoc/RubyXL/CT_AlphaBiLevelEffect.html +13 -19
  75. data/rdoc/RubyXL/CT_AlphaModulateEffect.html +13 -19
  76. data/rdoc/RubyXL/CT_AlphaModulateFixedEffect.html +13 -19
  77. data/rdoc/RubyXL/CT_AlphaOutsetEffect.html +13 -19
  78. data/rdoc/RubyXL/CT_AlphaReplaceEffect.html +13 -19
  79. data/rdoc/RubyXL/CT_Backdrop.html +13 -19
  80. data/rdoc/RubyXL/CT_Bevel.html +13 -19
  81. data/rdoc/RubyXL/CT_BiLevelEffect.html +13 -19
  82. data/rdoc/RubyXL/CT_BlendEffect.html +13 -19
  83. data/rdoc/RubyXL/CT_Blip.html +13 -19
  84. data/rdoc/RubyXL/CT_BlipFillProperties.html +13 -19
  85. data/rdoc/RubyXL/CT_BlurEffect.html +13 -19
  86. data/rdoc/RubyXL/CT_Camera.html +13 -19
  87. data/rdoc/RubyXL/CT_Color.html +13 -19
  88. data/rdoc/RubyXL/CT_ColorChangeEffect.html +13 -19
  89. data/rdoc/RubyXL/CT_ColorMapping.html +13 -19
  90. data/rdoc/RubyXL/CT_ColorScheme.html +13 -19
  91. data/rdoc/RubyXL/CT_ColorSchemeAndMapping.html +13 -19
  92. data/rdoc/RubyXL/CT_ConnectionSite.html +13 -19
  93. data/rdoc/RubyXL/CT_ConnectionSiteList.html +13 -19
  94. data/rdoc/RubyXL/CT_DashStop.html +13 -19
  95. data/rdoc/RubyXL/CT_DashStopList.html +13 -19
  96. data/rdoc/RubyXL/CT_DefaultShapeDefinition.html +13 -19
  97. data/rdoc/RubyXL/CT_DuotoneEffect.html +13 -19
  98. data/rdoc/RubyXL/CT_EffectContainer.html +13 -19
  99. data/rdoc/RubyXL/CT_EffectList.html +13 -19
  100. data/rdoc/RubyXL/CT_EffectReference.html +13 -19
  101. data/rdoc/RubyXL/CT_EffectStyleItem.html +13 -19
  102. data/rdoc/RubyXL/CT_EffectStyleList.html +13 -19
  103. data/rdoc/RubyXL/CT_EmbeddedWAVAudioFile.html +13 -19
  104. data/rdoc/RubyXL/CT_FillEffect.html +13 -19
  105. data/rdoc/RubyXL/CT_FillOverlayEffect.html +13 -19
  106. data/rdoc/RubyXL/CT_FillStyleList.html +13 -19
  107. data/rdoc/RubyXL/CT_FlatText.html +13 -19
  108. data/rdoc/RubyXL/CT_FontCollection.html +13 -19
  109. data/rdoc/RubyXL/CT_FontReference.html +13 -19
  110. data/rdoc/RubyXL/CT_GeomGuideList.html +13 -19
  111. data/rdoc/RubyXL/CT_GlowEffect.html +13 -19
  112. data/rdoc/RubyXL/CT_GradientFillProperties.html +13 -19
  113. data/rdoc/RubyXL/CT_GradientStop.html +13 -19
  114. data/rdoc/RubyXL/CT_GradientStopList.html +13 -19
  115. data/rdoc/RubyXL/CT_HSLEffect.html +13 -19
  116. data/rdoc/RubyXL/CT_HslColor.html +13 -19
  117. data/rdoc/RubyXL/CT_Hyperlink.html +13 -19
  118. data/rdoc/RubyXL/CT_InnerShadowEffect.html +13 -19
  119. data/rdoc/RubyXL/CT_LightRig.html +13 -19
  120. data/rdoc/RubyXL/CT_LineEndProperties.html +13 -19
  121. data/rdoc/RubyXL/CT_LineJoinMiterProperties.html +13 -19
  122. data/rdoc/RubyXL/CT_LineProperties.html +13 -19
  123. data/rdoc/RubyXL/CT_LineStyleList.html +13 -19
  124. data/rdoc/RubyXL/CT_LinearShadeProperties.html +13 -19
  125. data/rdoc/RubyXL/CT_LuminanceEffect.html +13 -19
  126. data/rdoc/RubyXL/CT_ObjectStyleDefaults.html +13 -19
  127. data/rdoc/RubyXL/CT_OuterShadowEffect.html +13 -19
  128. data/rdoc/RubyXL/CT_Path2D.html +13 -19
  129. data/rdoc/RubyXL/CT_Path2DArcTo.html +13 -19
  130. data/rdoc/RubyXL/CT_Path2DCubicBezierTo.html +13 -19
  131. data/rdoc/RubyXL/CT_Path2DList.html +13 -19
  132. data/rdoc/RubyXL/CT_Path2DQuadBezierTo.html +13 -19
  133. data/rdoc/RubyXL/CT_Path2DTo.html +13 -19
  134. data/rdoc/RubyXL/CT_PathShadeProperties.html +13 -19
  135. data/rdoc/RubyXL/CT_PatternFillProperties.html +13 -19
  136. data/rdoc/RubyXL/CT_Point3D.html +13 -19
  137. data/rdoc/RubyXL/CT_PolarAdjustHandle.html +13 -19
  138. data/rdoc/RubyXL/CT_PresetColor.html +13 -19
  139. data/rdoc/RubyXL/CT_PresetLineDashProperties.html +13 -19
  140. data/rdoc/RubyXL/CT_PresetShadowEffect.html +13 -19
  141. data/rdoc/RubyXL/CT_PresetTextShape.html +13 -19
  142. data/rdoc/RubyXL/CT_ReflectionEffect.html +13 -19
  143. data/rdoc/RubyXL/CT_RelativeOffsetEffect.html +13 -19
  144. data/rdoc/RubyXL/CT_RelativeRect.html +13 -19
  145. data/rdoc/RubyXL/CT_SRgbColor.html +13 -19
  146. data/rdoc/RubyXL/CT_ScRgbColor.html +13 -19
  147. data/rdoc/RubyXL/CT_Scene3D.html +13 -19
  148. data/rdoc/RubyXL/CT_SchemeColor.html +13 -19
  149. data/rdoc/RubyXL/CT_Shape3D.html +13 -19
  150. data/rdoc/RubyXL/CT_ShapeStyle.html +13 -19
  151. data/rdoc/RubyXL/CT_SoftEdgesEffect.html +13 -19
  152. data/rdoc/RubyXL/CT_SphereCoords.html +13 -19
  153. data/rdoc/RubyXL/CT_StretchInfoProperties.html +13 -19
  154. data/rdoc/RubyXL/CT_StyleMatrix.html +13 -19
  155. data/rdoc/RubyXL/CT_StyleMatrixReference.html +13 -19
  156. data/rdoc/RubyXL/CT_SupplementalFont.html +13 -19
  157. data/rdoc/RubyXL/CT_SystemColor.html +13 -19
  158. data/rdoc/RubyXL/CT_TextAutonumberBullet.html +13 -19
  159. data/rdoc/RubyXL/CT_TextBlipBullet.html +13 -19
  160. data/rdoc/RubyXL/CT_TextCharBullet.html +13 -19
  161. data/rdoc/RubyXL/CT_TextCharacterProperties.html +13 -19
  162. data/rdoc/RubyXL/CT_TextFont.html +13 -19
  163. data/rdoc/RubyXL/CT_TextListStyle.html +13 -19
  164. data/rdoc/RubyXL/CT_TextNormalAutofit.html +13 -19
  165. data/rdoc/RubyXL/CT_TextParagraphProperties.html +13 -19
  166. data/rdoc/RubyXL/CT_TextSpacing.html +13 -19
  167. data/rdoc/RubyXL/CT_TextTabStop.html +13 -19
  168. data/rdoc/RubyXL/CT_TextTabStopList.html +13 -19
  169. data/rdoc/RubyXL/CT_TileInfoProperties.html +13 -19
  170. data/rdoc/RubyXL/CT_TintEffect.html +13 -19
  171. data/rdoc/RubyXL/CT_Transform2D.html +13 -19
  172. data/rdoc/RubyXL/CT_TransformEffect.html +13 -19
  173. data/rdoc/RubyXL/CT_Vector3D.html +13 -19
  174. data/rdoc/RubyXL/CT_XYAdjustHandle.html +13 -19
  175. data/rdoc/RubyXL/CalculationChain.html +17 -45
  176. data/rdoc/RubyXL/CalculationChainCell.html +13 -19
  177. data/rdoc/RubyXL/CalculationProperties.html +13 -19
  178. data/rdoc/RubyXL/Cell.html +145 -205
  179. data/rdoc/RubyXL/CellConvenienceMethods.html +255 -460
  180. data/rdoc/RubyXL/CellExt.html +13 -19
  181. data/rdoc/RubyXL/CellSmartTag.html +13 -19
  182. data/rdoc/RubyXL/CellSmartTagProperty.html +13 -19
  183. data/rdoc/RubyXL/CellSmartTags.html +13 -19
  184. data/rdoc/RubyXL/CellStyle.html +13 -19
  185. data/rdoc/RubyXL/CellStyleXFs.html +19 -39
  186. data/rdoc/RubyXL/CellStyles.html +19 -39
  187. data/rdoc/RubyXL/CellValue.html +18 -38
  188. data/rdoc/RubyXL/CellWatch.html +13 -19
  189. data/rdoc/RubyXL/CellWatches.html +13 -19
  190. data/rdoc/RubyXL/CellXFs.html +20 -42
  191. data/rdoc/RubyXL/ChartColorsFile.html +12 -25
  192. data/rdoc/RubyXL/ChartFile.html +19 -49
  193. data/rdoc/RubyXL/ChartStyleFile.html +12 -25
  194. data/rdoc/RubyXL/ChartUserShapesFile.html +12 -25
  195. data/rdoc/RubyXL/Chartsheet.html +20 -68
  196. data/rdoc/RubyXL/ChartsheetPageSetup.html +13 -19
  197. data/rdoc/RubyXL/ChartsheetProperties.html +13 -19
  198. data/rdoc/RubyXL/ChartsheetProtection.html +13 -19
  199. data/rdoc/RubyXL/ChartsheetView.html +13 -19
  200. data/rdoc/RubyXL/ChartsheetViews.html +13 -19
  201. data/rdoc/RubyXL/Color.html +29 -40
  202. data/rdoc/RubyXL/ColorConvenienceClasses/HlsColor.html +242 -0
  203. data/rdoc/RubyXL/ColorConvenienceClasses/RgbColor.html +279 -0
  204. data/rdoc/RubyXL/ColorConvenienceClasses.html +91 -0
  205. data/rdoc/RubyXL/ColorConvenienceMethods.html +137 -0
  206. data/rdoc/RubyXL/ColorFilter.html +13 -19
  207. data/rdoc/RubyXL/ColorScale.html +13 -19
  208. data/rdoc/RubyXL/ColorSet.html +13 -19
  209. data/rdoc/RubyXL/Colors.html +13 -19
  210. data/rdoc/RubyXL/ColumnRange.html +23 -74
  211. data/rdoc/RubyXL/ColumnRanges.html +24 -83
  212. data/rdoc/RubyXL/Comment.html +13 -19
  213. data/rdoc/RubyXL/CommentList.html +13 -19
  214. data/rdoc/RubyXL/CommentsFile.html +18 -51
  215. data/rdoc/RubyXL/ConditionalFormatValue.html +13 -19
  216. data/rdoc/RubyXL/ConditionalFormatting.html +13 -19
  217. data/rdoc/RubyXL/ConditionalFormattingRule.html +13 -19
  218. data/rdoc/RubyXL/Connection.html +99 -0
  219. data/rdoc/RubyXL/ConnectionTable.html +99 -0
  220. data/rdoc/RubyXL/ConnectionTables.html +99 -0
  221. data/rdoc/RubyXL/ConnectionTextField.html +99 -0
  222. data/rdoc/RubyXL/ConnectionTextFields.html +99 -0
  223. data/rdoc/RubyXL/Connections.html +147 -0
  224. data/rdoc/RubyXL/ContentTypeDefault.html +12 -17
  225. data/rdoc/RubyXL/ContentTypeOverride.html +12 -17
  226. data/rdoc/RubyXL/ContentTypes.html +25 -65
  227. data/rdoc/RubyXL/ControlPropertiesFile.html +14 -22
  228. data/rdoc/RubyXL/CorePropertiesFile.html +35 -171
  229. data/rdoc/RubyXL/CustomColor.html +13 -19
  230. data/rdoc/RubyXL/CustomColorList.html +13 -19
  231. data/rdoc/RubyXL/CustomFilter.html +13 -19
  232. data/rdoc/RubyXL/CustomFilters.html +13 -19
  233. data/rdoc/RubyXL/CustomGeometry.html +13 -19
  234. data/rdoc/RubyXL/CustomProperties.html +13 -19
  235. data/rdoc/RubyXL/CustomPropertiesFile.html +12 -25
  236. data/rdoc/RubyXL/CustomProperty.html +13 -19
  237. data/rdoc/RubyXL/CustomPropertyFile.html +108 -0
  238. data/rdoc/RubyXL/CustomSheetView.html +13 -19
  239. data/rdoc/RubyXL/CustomSheetViews.html +13 -19
  240. data/rdoc/RubyXL/CustomWorkbookView.html +13 -19
  241. data/rdoc/RubyXL/CustomWorkbookViews.html +13 -19
  242. data/rdoc/RubyXL/CustomXMLFile.html +12 -22
  243. data/rdoc/RubyXL/DXF.html +13 -19
  244. data/rdoc/RubyXL/DXFs.html +13 -19
  245. data/rdoc/RubyXL/DataBar.html +13 -19
  246. data/rdoc/RubyXL/DataConsolidate.html +13 -19
  247. data/rdoc/RubyXL/DataConsolidationReference.html +13 -19
  248. data/rdoc/RubyXL/DataConsolidationReferences.html +13 -19
  249. data/rdoc/RubyXL/DataType.html +11 -39
  250. data/rdoc/RubyXL/DataValidation.html +13 -19
  251. data/rdoc/RubyXL/DataValidations.html +13 -19
  252. data/rdoc/RubyXL/DateGroupItem.html +13 -19
  253. data/rdoc/RubyXL/DefinedName.html +13 -19
  254. data/rdoc/RubyXL/DefinedNameExt.html +13 -19
  255. data/rdoc/RubyXL/DefinedNames.html +13 -19
  256. data/rdoc/RubyXL/DefinedNamesExt.html +13 -19
  257. data/rdoc/RubyXL/DocumentPropertiesFile.html +22 -68
  258. data/rdoc/RubyXL/DrawingFile.html +19 -49
  259. data/rdoc/RubyXL/DynamicFilter.html +13 -19
  260. data/rdoc/RubyXL/EmbeddedControl.html +13 -19
  261. data/rdoc/RubyXL/EmbeddedControls.html +13 -19
  262. data/rdoc/RubyXL/Extension.html +13 -19
  263. data/rdoc/RubyXL/ExtensionStorageArea.html +13 -19
  264. data/rdoc/RubyXL/Extents.html +13 -19
  265. data/rdoc/RubyXL/ExternalBook.html +13 -19
  266. data/rdoc/RubyXL/ExternalLinksFile.html +19 -49
  267. data/rdoc/RubyXL/ExternalReference.html +13 -19
  268. data/rdoc/RubyXL/ExternalReferences.html +13 -19
  269. data/rdoc/RubyXL/ExtraColorSchemeList.html +13 -19
  270. data/rdoc/RubyXL/FieldItem.html +13 -19
  271. data/rdoc/RubyXL/FileRecoveryProperties.html +13 -19
  272. data/rdoc/RubyXL/FileSharing.html +13 -19
  273. data/rdoc/RubyXL/FileVersion.html +13 -19
  274. data/rdoc/RubyXL/Fill.html +19 -39
  275. data/rdoc/RubyXL/Fills.html +19 -39
  276. data/rdoc/RubyXL/FilterContainer.html +13 -19
  277. data/rdoc/RubyXL/FloatNode.html +12 -17
  278. data/rdoc/RubyXL/FloatValue.html +12 -17
  279. data/rdoc/RubyXL/Font.html +20 -544
  280. data/rdoc/RubyXL/FontConvenienceMethods.html +414 -0
  281. data/rdoc/RubyXL/FontScheme.html +13 -19
  282. data/rdoc/RubyXL/Fonts.html +19 -39
  283. data/rdoc/RubyXL/Formula.html +13 -19
  284. data/rdoc/RubyXL/FunctionGroup.html +13 -19
  285. data/rdoc/RubyXL/FunctionGroups.html +13 -19
  286. data/rdoc/RubyXL/GenericStorageObject.html +22 -84
  287. data/rdoc/RubyXL/GradientFill.html +13 -19
  288. data/rdoc/RubyXL/HeaderFooterSettings.html +13 -19
  289. data/rdoc/RubyXL/Hyperlink.html +13 -19
  290. data/rdoc/RubyXL/HyperlinkRelFile.html +12 -22
  291. data/rdoc/RubyXL/Hyperlinks.html +13 -19
  292. data/rdoc/RubyXL/IconFilter.html +13 -19
  293. data/rdoc/RubyXL/IconSet.html +13 -19
  294. data/rdoc/RubyXL/IgnoredError.html +13 -19
  295. data/rdoc/RubyXL/IgnoredErrors.html +13 -19
  296. data/rdoc/RubyXL/IndexedColors.html +13 -19
  297. data/rdoc/RubyXL/InputCells.html +13 -19
  298. data/rdoc/RubyXL/IntegerNode.html +12 -17
  299. data/rdoc/RubyXL/IntegerValue.html +12 -17
  300. data/rdoc/RubyXL/LegacyCell.html +14 -66
  301. data/rdoc/RubyXL/LegacyWorksheet.html +40 -100
  302. data/rdoc/RubyXL/MRUColors.html +13 -19
  303. data/rdoc/RubyXL/MacrosFile.html +12 -25
  304. data/rdoc/RubyXL/MergedCell.html +13 -19
  305. data/rdoc/RubyXL/MergedCells.html +13 -19
  306. data/rdoc/RubyXL/NumFmt.html +13 -19
  307. data/rdoc/RubyXL/NumberFormat.html +19 -39
  308. data/rdoc/RubyXL/NumberFormats.html +19 -45
  309. data/rdoc/RubyXL/OLEObject.html +13 -19
  310. data/rdoc/RubyXL/OLEObjectFile.html +12 -25
  311. data/rdoc/RubyXL/OLEObjects.html +13 -19
  312. data/rdoc/RubyXL/OLESize.html +13 -19
  313. data/rdoc/RubyXL/OOXMLContainerObject.html +36 -132
  314. data/rdoc/RubyXL/OOXMLIgnored.html +163 -0
  315. data/rdoc/RubyXL/OOXMLObject.html +15 -25
  316. data/rdoc/RubyXL/OOXMLObjectClassMethods.html +92 -183
  317. data/rdoc/RubyXL/OOXMLObjectInstanceMethods.html +49 -185
  318. data/rdoc/RubyXL/OOXMLRelationshipsFile.html +48 -200
  319. data/rdoc/RubyXL/OOXMLTopLevelObject.html +37 -133
  320. data/rdoc/RubyXL/OdbcOleDbProperties.html +99 -0
  321. data/rdoc/RubyXL/Offset.html +13 -19
  322. data/rdoc/RubyXL/OlapProperties.html +99 -0
  323. data/rdoc/RubyXL/OleItem.html +99 -0
  324. data/rdoc/RubyXL/OleItems.html +99 -0
  325. data/rdoc/RubyXL/OleLink.html +99 -0
  326. data/rdoc/RubyXL/OutlineProperties.html +13 -19
  327. data/rdoc/RubyXL/PageMargins.html +13 -19
  328. data/rdoc/RubyXL/PageSetup.html +13 -19
  329. data/rdoc/RubyXL/PageSetupProperties.html +13 -19
  330. data/rdoc/RubyXL/Pane.html +13 -19
  331. data/rdoc/RubyXL/Parser.html +23 -56
  332. data/rdoc/RubyXL/PatternFill.html +13 -19
  333. data/rdoc/RubyXL/PhoneticProperties.html +13 -19
  334. data/rdoc/RubyXL/PhoneticRun.html +13 -19
  335. data/rdoc/RubyXL/PivotArea.html +13 -19
  336. data/rdoc/RubyXL/PivotCache.html +13 -19
  337. data/rdoc/RubyXL/PivotCacheDefinitionFile.html +14 -30
  338. data/rdoc/RubyXL/PivotCacheRecordsFile.html +12 -25
  339. data/rdoc/RubyXL/PivotCaches.html +13 -19
  340. data/rdoc/RubyXL/PivotReference.html +13 -19
  341. data/rdoc/RubyXL/PivotReferences.html +13 -19
  342. data/rdoc/RubyXL/PivotTableFile.html +14 -30
  343. data/rdoc/RubyXL/PivotTableSelection.html +13 -19
  344. data/rdoc/RubyXL/PresetGeometry.html +13 -19
  345. data/rdoc/RubyXL/PrintOptions.html +13 -19
  346. data/rdoc/RubyXL/PrinterSettingsFile.html +12 -25
  347. data/rdoc/RubyXL/ProtectedRange.html +13 -19
  348. data/rdoc/RubyXL/ProtectedRanges.html +13 -19
  349. data/rdoc/RubyXL/Protection.html +13 -19
  350. data/rdoc/RubyXL/QueryParameter.html +99 -0
  351. data/rdoc/RubyXL/QueryParameters.html +99 -0
  352. data/rdoc/RubyXL/QueryTable.html +155 -0
  353. data/rdoc/RubyXL/QueryTableDeletedField.html +99 -0
  354. data/rdoc/RubyXL/QueryTableDeletedFields.html +99 -0
  355. data/rdoc/RubyXL/QueryTableField.html +99 -0
  356. data/rdoc/RubyXL/QueryTableFields.html +99 -0
  357. data/rdoc/RubyXL/QueryTableRefresh.html +99 -0
  358. data/rdoc/RubyXL/RID.html +12 -17
  359. data/rdoc/RubyXL/RawOOXML.html +21 -60
  360. data/rdoc/RubyXL/Reference.html +63 -228
  361. data/rdoc/RubyXL/Relationship.html +12 -17
  362. data/rdoc/RubyXL/RelationshipSupport/ClassMehods.html +14 -32
  363. data/rdoc/RubyXL/RelationshipSupport.html +26 -120
  364. data/rdoc/RubyXL/RevisionPointer.html +99 -0
  365. data/rdoc/RubyXL/RichText.html +20 -39
  366. data/rdoc/RubyXL/RichTextRun.html +18 -38
  367. data/rdoc/RubyXL/Row.html +53 -152
  368. data/rdoc/RubyXL/RowExt.html +13 -19
  369. data/rdoc/RubyXL/RunProperties.html +13 -19
  370. data/rdoc/RubyXL/Scenario.html +13 -19
  371. data/rdoc/RubyXL/Scenarios.html +13 -19
  372. data/rdoc/RubyXL/Selection.html +19 -39
  373. data/rdoc/RubyXL/ShapeGuide.html +13 -19
  374. data/rdoc/RubyXL/ShapeTextRectangle.html +13 -19
  375. data/rdoc/RubyXL/SharedStringsTable.html +38 -147
  376. data/rdoc/RubyXL/Sheet.html +13 -19
  377. data/rdoc/RubyXL/SheetCalculationProperties.html +13 -19
  378. data/rdoc/RubyXL/SheetData.html +20 -53
  379. data/rdoc/RubyXL/SheetDataExt.html +13 -19
  380. data/rdoc/RubyXL/SheetDataSet.html +13 -19
  381. data/rdoc/RubyXL/SheetMetadata.html +108 -0
  382. data/rdoc/RubyXL/SheetName.html +13 -19
  383. data/rdoc/RubyXL/SheetNames.html +13 -19
  384. data/rdoc/RubyXL/Sheets.html +13 -19
  385. data/rdoc/RubyXL/SlicerCacheFile.html +12 -25
  386. data/rdoc/RubyXL/SlicerFile.html +12 -25
  387. data/rdoc/RubyXL/SmartTagProperties.html +13 -19
  388. data/rdoc/RubyXL/SmartTagType.html +13 -19
  389. data/rdoc/RubyXL/SmartTagTypes.html +13 -19
  390. data/rdoc/RubyXL/SmartTags.html +13 -19
  391. data/rdoc/RubyXL/SortCondition.html +13 -19
  392. data/rdoc/RubyXL/SortState.html +13 -19
  393. data/rdoc/RubyXL/Sqref.html +20 -53
  394. data/rdoc/RubyXL/Stop.html +13 -19
  395. data/rdoc/RubyXL/StringNode.html +12 -17
  396. data/rdoc/RubyXL/StringNodeW3C.html +21 -54
  397. data/rdoc/RubyXL/StringValue.html +12 -17
  398. data/rdoc/RubyXL/Stylesheet.html +35 -117
  399. data/rdoc/RubyXL/TableFile.html +12 -25
  400. data/rdoc/RubyXL/TableParts.html +12 -17
  401. data/rdoc/RubyXL/TableStyle.html +13 -19
  402. data/rdoc/RubyXL/TableStyles.html +13 -19
  403. data/rdoc/RubyXL/Text.html +23 -67
  404. data/rdoc/RubyXL/TextImportSettings.html +99 -0
  405. data/rdoc/RubyXL/Theme.html +57 -62
  406. data/rdoc/RubyXL/ThemeElements.html +13 -19
  407. data/rdoc/RubyXL/ThumbnailFile.html +12 -25
  408. data/rdoc/RubyXL/Top10.html +13 -19
  409. data/rdoc/RubyXL/VMLDrawingFile.html +15 -32
  410. data/rdoc/RubyXL/Variant.html +13 -19
  411. data/rdoc/RubyXL/Vector.html +18 -38
  412. data/rdoc/RubyXL/VectorValue.html +12 -17
  413. data/rdoc/RubyXL/VisualProperties.html +13 -19
  414. data/rdoc/RubyXL/WebPublishObject.html +13 -19
  415. data/rdoc/RubyXL/WebPublishObjects.html +13 -19
  416. data/rdoc/RubyXL/WebPublishingItem.html +13 -19
  417. data/rdoc/RubyXL/WebPublishingItems.html +13 -19
  418. data/rdoc/RubyXL/WebPublishingProperties.html +13 -19
  419. data/rdoc/RubyXL/WebQueryProperties.html +99 -0
  420. data/rdoc/RubyXL/Workbook.html +487 -227
  421. data/rdoc/RubyXL/WorkbookConvenienceMethods.html +163 -871
  422. data/rdoc/RubyXL/WorkbookProperties.html +13 -19
  423. data/rdoc/RubyXL/WorkbookProtection.html +13 -19
  424. data/rdoc/RubyXL/WorkbookRoot.html +28 -114
  425. data/rdoc/RubyXL/WorkbookView.html +13 -19
  426. data/rdoc/RubyXL/WorkbookViews.html +13 -19
  427. data/rdoc/RubyXL/Worksheet.html +93 -121
  428. data/rdoc/RubyXL/WorksheetConvenienceMethods.html +299 -1109
  429. data/rdoc/RubyXL/WorksheetDimensions.html +13 -19
  430. data/rdoc/RubyXL/WorksheetFormatProperties.html +12 -17
  431. data/rdoc/RubyXL/WorksheetProperties.html +13 -19
  432. data/rdoc/RubyXL/WorksheetProtection.html +13 -19
  433. data/rdoc/RubyXL/WorksheetView.html +13 -19
  434. data/rdoc/RubyXL/WorksheetViews.html +13 -19
  435. data/rdoc/RubyXL/XF.html +13 -19
  436. data/rdoc/RubyXL.html +41 -296
  437. data/rdoc/created.rid +45 -38
  438. data/rdoc/css/fonts.css +6 -6
  439. data/rdoc/css/rdoc.css +55 -6
  440. data/rdoc/fonts/SourceCodePro-Bold.ttf +0 -0
  441. data/rdoc/fonts/SourceCodePro-Regular.ttf +0 -0
  442. data/rdoc/index.html +44 -363
  443. data/rdoc/js/darkfish.js +23 -100
  444. data/rdoc/js/navigation.js +4 -41
  445. data/rdoc/js/navigation.js.gz +0 -0
  446. data/rdoc/js/search.js +32 -31
  447. data/rdoc/js/search_index.js +1 -1
  448. data/rdoc/js/search_index.js.gz +0 -0
  449. data/rdoc/js/searcher.js +7 -6
  450. data/rdoc/js/searcher.js.gz +0 -0
  451. data/rdoc/table_of_contents.html +347 -75
  452. data/rubyXL.gemspec +78 -43
  453. data/spec/lib/cell_spec.rb +115 -4
  454. data/spec/lib/color_spec.rb +2 -1
  455. data/spec/lib/parser_spec.rb +24 -27
  456. data/spec/lib/reference_spec.rb +9 -3
  457. data/spec/lib/rgb_color_spec.rb +27 -0
  458. data/spec/lib/stylesheet_spec.rb +8 -11
  459. data/spec/lib/text_spec.rb +8 -4
  460. data/spec/lib/workbook_spec.rb +26 -5
  461. data/spec/lib/worksheet_spec.rb +873 -479
  462. data/spec/spec_helper.rb +2 -0
  463. data/test/test_parse_write.rb +15 -15
  464. metadata +65 -10
  465. data/rdoc/js/jquery.js +0 -4
@@ -2,7 +2,6 @@ require 'rubyXL/objects/ooxml_object'
2
2
  require 'rubyXL/objects/simple_types'
3
3
 
4
4
  module RubyXL
5
-
6
5
  class BorderEdge < OOXMLObject
7
6
  define_attribute(:style, RubyXL::ST_BorderStyle, :default => 'none')
8
7
  define_child_node(RubyXL::Color)
@@ -16,7 +15,7 @@ module RubyXL
16
15
  end
17
16
  end
18
17
 
19
- # http://www.schemacentral.com/sc/ooxml/e-ssml_border-2.html
18
+ # http://www.datypic.com/sc/ooxml/e-ssml_border-2.html
20
19
  class Border < OOXMLObject
21
20
  define_attribute(:diagonalUp, :bool)
22
21
  define_attribute(:diagonalDown, :bool)
@@ -60,7 +59,7 @@ module RubyXL
60
59
  end
61
60
  end
62
61
 
63
- # http://www.schemacentral.com/sc/ooxml/e-ssml_borders-1.html
62
+ # http://www.datypic.com/sc/ooxml/e-ssml_borders-1.html
64
63
  class Borders < OOXMLContainerObject
65
64
  define_child_node(RubyXL::Border, :collection => :with_count)
66
65
  define_element_name 'borders'
@@ -68,7 +67,5 @@ module RubyXL
68
67
  def self.default
69
68
  self.new(:_ => [ RubyXL::Border.new ])
70
69
  end
71
-
72
70
  end
73
-
74
71
  end
@@ -2,7 +2,7 @@ require 'rubyXL/objects/ooxml_object'
2
2
  require 'rubyXL/objects/extensions'
3
3
 
4
4
  module RubyXL
5
- # http://www.schemacentral.com/sc/ooxml/e-ssml_c-1.html
5
+ # http://www.datypic.com/sc/ooxml/e-ssml_c-1.html
6
6
  class CalculationChainCell < OOXMLObject
7
7
  define_attribute(:r, :ref, :accessor => :ref)
8
8
  define_attribute(:i, :int, :accessor => :sheet_id, :default => 0)
@@ -13,10 +13,10 @@ module RubyXL
13
13
  define_element_name 'c'
14
14
  end
15
15
 
16
- # http://www.schemacentral.com/sc/ooxml/e-ssml_calcChain.html
16
+ # http://www.datypic.com/sc/ooxml/e-ssml_calcChain.html
17
17
  class CalculationChain < OOXMLTopLevelObject
18
- CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.calcChain+xml'
19
- REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/calcChain'
18
+ CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.calcChain+xml'.freeze
19
+ REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/calcChain'.freeze
20
20
 
21
21
  define_child_node(RubyXL::CalculationChainCell, :collection => true, :accessor => :cells)
22
22
  define_child_node(RubyXL::ExtensionStorageArea)
@@ -2,11 +2,10 @@ require 'rubyXL/objects/ooxml_object'
2
2
  require 'rubyXL/objects/simple_types'
3
3
 
4
4
  module RubyXL
5
-
6
- # http://www.schemacentral.com/sc/ooxml/e-ssml_cellStyle-1.html
5
+ # http://www.datypic.com/sc/ooxml/e-ssml_cellStyle-1.html
7
6
  class CellStyle < OOXMLObject
8
7
  define_attribute(:name, :string)
9
- define_attribute(:xfId, :int, :required => true)
8
+ define_attribute(:xfId, :int, :required => true)
10
9
  define_attribute(:builtinId, :int)
11
10
  define_attribute(:iLevel, :int)
12
11
  define_attribute(:hidden, :bool)
@@ -14,28 +13,28 @@ module RubyXL
14
13
  define_element_name 'cellStyle'
15
14
  end
16
15
 
17
- # http://www.schemacentral.com/sc/ooxml/e-ssml_alignment-1.html
16
+ # http://www.datypic.com/sc/ooxml/e-ssml_alignment-1.html
18
17
  class Alignment < OOXMLObject
19
18
  define_attribute(:horizontal, RubyXL::ST_HorizontalAlignment)
20
19
  define_attribute(:vertical, RubyXL::ST_VerticalAlignment)
21
- define_attribute(:textRotation, :int)
20
+ define_attribute(:textRotation, :uint)
22
21
  define_attribute(:wrapText, :bool)
23
- define_attribute(:indent, :int)
22
+ define_attribute(:indent, :uint)
24
23
  define_attribute(:relativeIndent, :int)
25
24
  define_attribute(:justifyLastLine, :bool)
26
25
  define_attribute(:shrinkToFit, :bool)
27
- define_attribute(:readingOrder, :int)
26
+ define_attribute(:readingOrder, :uint)
28
27
  define_element_name 'alignment'
29
28
  end
30
29
 
31
- # http://www.schemacentral.com/sc/ooxml/e-ssml_protection-1.html
30
+ # http://www.datypic.com/sc/ooxml/e-ssml_protection-1.html
32
31
  class Protection < OOXMLObject
33
32
  define_attribute(:locked, :bool)
34
33
  define_attribute(:hidden, :bool)
35
34
  define_element_name 'protection'
36
35
  end
37
36
 
38
- # http://www.schemacentral.com/sc/ooxml/e-ssml_xf-1.html
37
+ # http://www.datypic.com/sc/ooxml/e-ssml_xf-1.html
39
38
  class XF < OOXMLObject
40
39
  define_attribute(:numFmtId, :int)
41
40
  define_attribute(:fontId, :int)
@@ -55,11 +54,10 @@ module RubyXL
55
54
  define_element_name 'xf'
56
55
  end
57
56
 
58
- # http://www.schemacentral.com/sc/ooxml/e-ssml_numFmt-1.html
57
+ # http://www.datypic.com/sc/ooxml/e-ssml_numFmt-1.html
59
58
  class NumFmt < OOXMLObject
60
59
  define_attribute(:numFmtId, :int, :required => true)
61
60
  define_attribute(:formatCode, :string, :required => true)
62
61
  define_element_name 'numFmt'
63
62
  end
64
-
65
63
  end
@@ -5,24 +5,23 @@ require 'rubyXL/objects/relationships'
5
5
  require 'rubyXL/objects/sheet_common'
6
6
 
7
7
  module RubyXL
8
-
9
- # http://www.schemacentral.com/sc/ooxml/e-ssml_sheetProtection-4.html
8
+ # http://www.datypic.com/sc/ooxml/e-ssml_sheetProtection-4.html
10
9
  class ChartsheetProtection < OOXMLObject
11
- define_attribute(:password, :string)
10
+ define_attribute(:password, RubyXL::ST_UnsignedShortHex)
12
11
  define_attribute(:content, :bool, :default => false)
13
12
  define_attribute(:objects, :bool, :default => false)
14
13
  define_element_name 'sheetProtection'
15
14
  end
16
15
 
17
- # http://www.schemacentral.com/sc/ooxml/e-ssml_sheetPr-4.html
16
+ # http://www.datypic.com/sc/ooxml/e-ssml_sheetPr-4.html
18
17
  class ChartsheetProperties < OOXMLObject
19
- define_attribute(:published, :bool, :default => true)
20
- define_attribute(:codeName, :string)
18
+ define_attribute(:published, :bool, :default => true)
19
+ define_attribute(:codeName, :string)
21
20
  define_child_node(RubyXL::Color, :node_name => :tabColor)
22
21
  define_element_name 'sheetPr'
23
22
  end
24
23
 
25
- # http://www.schemacentral.com/sc/ooxml/e-ssml_pageSetup-5.html
24
+ # http://www.datypic.com/sc/ooxml/e-ssml_pageSetup-5.html
26
25
  class ChartsheetPageSetup < OOXMLObject
27
26
  define_attribute(:paperSize, :int, :default => 1)
28
27
  define_attribute(:firstPageNumber, :int, :default => 1)
@@ -34,37 +33,36 @@ module RubyXL
34
33
  define_attribute(:horizontalDpi, :int, :default => 600)
35
34
  define_attribute(:verticalDpi, :int, :default => 600)
36
35
  define_attribute(:copies, :int, :default => 1)
37
- define_attribute(:'r:id', :string)
36
+ define_relationship
38
37
  define_element_name 'pageSetup'
39
38
  end
40
39
 
41
- # http://www.schemacentral.com/sc/ooxml/e-ssml_sheetView-2.html
40
+ # http://www.datypic.com/sc/ooxml/e-ssml_sheetView-2.html
42
41
  class ChartsheetView < OOXMLObject
43
42
  define_attribute(:tabSelected, :bool, :default => false)
44
43
  define_attribute(:zoomScale, :int, :default => 100)
45
- define_attribute(:workbookViewId, :int, :required => true, :default => 0 )
44
+ define_attribute(:workbookViewId, :int, :required => true, :default => 0)
46
45
  define_attribute(:zoomToFit, :bool, :default => false)
47
46
  define_child_node(RubyXL::ExtensionStorageArea)
48
47
  define_element_name 'sheetView'
49
48
  end
50
49
 
51
- # http://www.schemacentral.com/sc/ooxml/e-ssml_sheetViews-4.html
50
+ # http://www.datypic.com/sc/ooxml/e-ssml_sheetViews-4.html
52
51
  class ChartsheetViews < OOXMLObject
53
52
  define_child_node(RubyXL::ChartsheetView, :collection => true)
54
53
  define_child_node(RubyXL::ExtensionStorageArea)
55
54
  define_element_name 'sheetViews'
56
55
  end
57
56
 
58
- # http://www.schemacentral.com/sc/ooxml/e-ssml_chartsheet.html
57
+ # http://www.datypic.com/sc/ooxml/e-ssml_chartsheet.html
59
58
  class Chartsheet < OOXMLTopLevelObject
60
- CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml'
61
- REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/chartsheet'
59
+ CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.chartsheet+xml'.freeze
60
+ REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/chartsheet'.freeze
62
61
 
63
62
  include RubyXL::RelationshipSupport
64
63
  define_relationship(RubyXL::DrawingFile)
65
64
 
66
- attr_accessor :state, :rels
67
- attr_accessor :workbook, :sheet_name, :sheet_id
65
+ attr_accessor :state, :rels, :workbook, :sheet_name, :sheet_id
68
66
 
69
67
  define_child_node(RubyXL::ChartsheetProperties)
70
68
  define_child_node(RubyXL::ChartsheetViews)
@@ -80,13 +78,11 @@ module RubyXL
80
78
  define_child_node(RubyXL::WebPublishingItems)
81
79
  define_child_node(RubyXL::ExtensionStorageArea)
82
80
  define_element_name 'chartsheet'
83
- set_namespaces('http://schemas.openxmlformats.org/spreadsheetml/2006/main' => nil,
81
+ set_namespaces('http://schemas.openxmlformats.org/spreadsheetml/2006/main' => nil,
84
82
  'http://schemas.openxmlformats.org/officeDocument/2006/relationships' => 'r')
85
83
 
86
84
  def xlsx_path
87
85
  ROOT.join('xl', 'chartsheets', "sheet#{file_index}.xml")
88
86
  end
89
-
90
87
  end
91
-
92
88
  end
@@ -1,25 +1,25 @@
1
1
  require 'rubyXL/objects/ooxml_object'
2
+ require 'rubyXL/objects/simple_types'
2
3
 
3
4
  module RubyXL
4
-
5
- # http://www.schemacentral.com/sc/ooxml/e-ssml_color-4.html
5
+ # http://www.datypic.com/sc/ooxml/e-ssml_color-4.html
6
6
  class Color < OOXMLObject
7
+ COLOR_REGEXP = /\A([a-f]|[A-F]|[0-9]){6}\Z/
8
+
7
9
  define_attribute(:auto, :bool)
8
10
  define_attribute(:indexed, :uint)
9
- define_attribute(:rgb, :string)
11
+ define_attribute(:rgb, RubyXL::ST_UnsignedIntHex)
10
12
  define_attribute(:theme, :uint)
11
13
  define_attribute(:tint, :double, :default => 0.0)
12
14
  define_element_name 'color'
13
15
 
14
- #validates hex color code, no '#' allowed
16
+ # validates hex color code, no '#' allowed
15
17
  def self.validate_color(color)
16
- if color =~ /\A([a-f]|[A-F]|[0-9]){6}\Z/
18
+ if color =~ COLOR_REGEXP
17
19
  return true
18
20
  else
19
21
  raise 'invalid color'
20
22
  end
21
23
  end
22
-
23
24
  end
24
-
25
25
  end
@@ -1,19 +1,18 @@
1
1
  require 'rubyXL/objects/ooxml_object'
2
2
 
3
3
  module RubyXL
4
-
5
- # http://www.schemacentral.com/sc/ooxml/e-ssml_col-1.html
4
+ # http://www.datypic.com/sc/ooxml/e-ssml_col-1.html
6
5
  class ColumnRange < OOXMLObject
7
- define_attribute(:min, :uint, :required => true)
8
- define_attribute(:max, :uint, :required => true)
6
+ define_attribute(:min, :uint, :required => true)
7
+ define_attribute(:max, :uint, :required => true)
9
8
  define_attribute(:width, :double)
10
- define_attribute(:style, :uint, :default => 0, :accessor => :style_index)
11
- define_attribute(:hidden, :bool, :default => false)
12
- define_attribute(:bestFit, :bool, :default => false)
13
- define_attribute(:customWidth, :bool, :default => false)
14
- define_attribute(:phonetic, :bool, :default => false)
15
- define_attribute(:outlineLevel, :int, :default => 0)
16
- define_attribute(:collapsed, :bool, :default => false)
9
+ define_attribute(:style, :uint, :default => 0, :accessor => :style_index)
10
+ define_attribute(:hidden, :bool, :default => false)
11
+ define_attribute(:bestFit, :bool, :default => false)
12
+ define_attribute(:customWidth, :bool, :default => false)
13
+ define_attribute(:phonetic, :bool, :default => false)
14
+ define_attribute(:outlineLevel, :int, :default => 0)
15
+ define_attribute(:collapsed, :bool, :default => false)
17
16
  define_element_name 'col'
18
17
 
19
18
  def delete_column(col_index)
@@ -86,7 +85,5 @@ module RubyXL
86
85
  self.sort_by!{ |r| r.min }
87
86
  !(self.empty?)
88
87
  end
89
-
90
88
  end
91
-
92
89
  end
@@ -2,8 +2,7 @@ require 'rubyXL/objects/ooxml_object'
2
2
  require 'rubyXL/objects/extensions'
3
3
 
4
4
  module RubyXL
5
-
6
- # http://www.schemacentral.com/sc/ooxml/e-ssml_comment-1.html
5
+ # http://www.datypic.com/sc/ooxml/e-ssml_comment-1.html
7
6
  class Comment < OOXMLObject
8
7
  define_child_node(RubyXL::RichText, :node_name => 'text')
9
8
  define_child_node(RubyXL::AlternateContent)
@@ -13,22 +12,22 @@ module RubyXL
13
12
  define_element_name 'comment'
14
13
  end
15
14
 
16
- # http://www.schemacentral.com/sc/ooxml/e-ssml_authors-1.html
15
+ # http://www.datypic.com/sc/ooxml/e-ssml_authors-1.html
17
16
  class CommentList < OOXMLContainerObject
18
17
  define_child_node(RubyXL::Comment, :collection => [0..-1])
19
18
  define_element_name 'commentList'
20
19
  end
21
20
 
22
- # http://www.schemacentral.com/sc/ooxml/e-ssml_authors-1.html
21
+ # http://www.datypic.com/sc/ooxml/e-ssml_authors-1.html
23
22
  class Authors < OOXMLContainerObject
24
23
  define_child_node(RubyXL::StringNode, :node_name => :author, :collection => [0..-1])
25
24
  define_element_name 'authors'
26
25
  end
27
26
 
28
- # http://www.schemacentral.com/sc/ooxml/e-ssml_comments.html
27
+ # http://www.datypic.com/sc/ooxml/e-ssml_comments.html
29
28
  class CommentsFile < OOXMLTopLevelObject
30
29
  CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.comments+xml'
31
- REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/comments'
30
+ REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/comments'.freeze
32
31
 
33
32
  define_child_node(RubyXL::Authors)
34
33
  define_child_node(RubyXL::CommentList)
@@ -41,7 +40,5 @@ module RubyXL
41
40
  def xlsx_path
42
41
  ROOT.join('xl', "comments#{file_index}.xml")
43
42
  end
44
-
45
43
  end
46
-
47
44
  end
@@ -0,0 +1,175 @@
1
+ require 'rubyXL/objects/ooxml_object'
2
+ require 'rubyXL/objects/simple_types'
3
+ require 'rubyXL/objects/extensions'
4
+
5
+ # Connections
6
+ # https://msdn.microsoft.com/en-us/library/dd908547(v=office.12).aspx
7
+ # http://www.datypic.com/sc/ooxml/s-sml-externalConnections.xsd.html
8
+
9
+ module RubyXL
10
+ # http://www.datypic.com/sc/ooxml/e-ssml_dbPr-1.html
11
+ class OdbcOleDbProperties < OOXMLObject
12
+ define_attribute(:connection, RubyXL::ST_Xstring, :required => true)
13
+ define_attribute(:command, RubyXL::ST_Xstring)
14
+ define_attribute(:serverCommand, RubyXL::ST_Xstring)
15
+ define_attribute(:commandType, :uint, :default => 2)
16
+
17
+ define_element_name 'dbPr'
18
+ end
19
+
20
+ # http://www.datypic.com/sc/ooxml/e-ssml_olapPr-1.html
21
+ class OlapProperties < OOXMLObject
22
+ define_attribute(:local, :bool, :default => false)
23
+ define_attribute(:localConnection, RubyXL::ST_Xstring)
24
+ define_attribute(:localRefresh, :bool, :default => true)
25
+ define_attribute(:sendLocale, :bool, :default => false)
26
+ define_attribute(:rowDrillCount, :uint)
27
+ define_attribute(:serverFill, :bool, :default => true)
28
+ define_attribute(:serverNumberFormat, :bool, :default => true)
29
+ define_attribute(:serverFont, :bool, :default => true)
30
+ define_attribute(:serverFontColor, :bool, :default => true)
31
+
32
+ define_element_name 'olapPr'
33
+ end
34
+
35
+ # http://www.datypic.com/sc/ooxml/e-ssml_s-1.html
36
+ # TODO: ssml:m & ssml:x... but how?
37
+ class ConnectionTable < OOXMLObject
38
+ define_attribute(:v, RubyXL::ST_Xstring, :required => true)
39
+
40
+ define_element_name 's'
41
+ end
42
+
43
+ # http://www.datypic.com/sc/ooxml/e-ssml_tables-1.html
44
+ class ConnectionTables < OOXMLObject
45
+ define_child_node(RubyXL::ConnectionTable, :collection => :with_count, :accessor => :tables, :node_name => :table)
46
+ define_element_name 'tables'
47
+ end
48
+
49
+ # http://www.datypic.com/sc/ooxml/e-ssml_webPr-1.html
50
+ class WebQueryProperties < OOXMLObject
51
+ define_attribute(:xml, :bool, :default => false)
52
+ define_attribute(:sourceData, :bool, :default => false)
53
+ define_attribute(:parsePre, :bool, :default => false)
54
+ define_attribute(:consecutive, :bool, :default => false)
55
+ define_attribute(:firstRow, :bool, :default => false)
56
+ define_attribute(:xl97, :bool, :default => false)
57
+ define_attribute(:textDates, :bool, :default => false)
58
+ define_attribute(:xl2000, :bool, :default => false)
59
+ define_attribute(:url, RubyXL::ST_Xstring)
60
+ define_attribute(:post, RubyXL::ST_Xstring)
61
+ define_attribute(:htmlTables, :bool, :default => false)
62
+ define_attribute(:htmlFormat, ssml:ST_HtmlFmt, :default => 'none')
63
+ define_attribute(:editPage, RubyXL::ST_Xstring)
64
+
65
+ define_child_node(RubyXL::ConnectionTables)
66
+
67
+ define_element_name 'webPr'
68
+ end
69
+
70
+ # http://www.datypic.com/sc/ooxml/e-ssml_textField-1.html
71
+ class ConnectionTextField < OOXMLObject
72
+ define_attribute(:type, RubyXL::ST_ExternalConnectionType, :default => 'general')
73
+ define_attribute(:position, :uint, :default => 0)
74
+ end
75
+
76
+ # http://www.datypic.com/sc/ooxml/e-ssml_textFields-1.html
77
+ class ConnectionTextFields < OOXMLObject
78
+ define_child_node(RubyXL::ConnectionTextField, :collection => :with_count, :accessor => :text_fields, :node_name => :textField)
79
+
80
+ define_element_name 'textFields'
81
+ end
82
+
83
+ # http://www.datypic.com/sc/ooxml/e-ssml_textPr-1.html
84
+ class TextImportSettings < OOXMLObject
85
+ define_attribute(:prompt, :bool, :default => true)
86
+ define_attribute(:fileType, RubyXL::ST_FileType, :default => 'win')
87
+ define_attribute(:codePage, :uint, :default => 1252)
88
+ define_attribute(:firstRow, :uint, :default => 1)
89
+ define_attribute(:sourceFile, RubyXL::ST_Xstring, :default => '')
90
+ define_attribute(:delimited, :bool, :default => true)
91
+ define_attribute(:decimal, RubyXL::ST_Xstring, :default => '.')
92
+ define_attribute(:thousands, RubyXL::ST_Xstring, :default => ',')
93
+ define_attribute(:tab, :bool, :default => true)
94
+ define_attribute(:space, :bool, :default => false)
95
+ define_attribute(:comma, :bool, :default => false)
96
+ define_attribute(:semicolon, :bool, :default => false)
97
+ define_attribute(:consecutive, :bool, :default => false)
98
+ define_attribute(:qualifier, ssml:ST_Qualifier, :default => 'doubleQuote')
99
+ define_attribute(:delimiter, RubyXL::ST_Xstring)
100
+
101
+ define_child_node(RubyXL::ConnectionTextFields)
102
+
103
+ define_element_name 'textPr'
104
+ end
105
+
106
+ # http://www.datypic.com/sc/ooxml/e-ssml_parameter-1.html
107
+ class QueryParameter < OOXMLObject
108
+ define_attribute(:name, RubyXL::ST_Xstring)
109
+ define_attribute(:sqlType, :int, :default => 0)
110
+ define_attribute(:parameterType, RubyXL::ST_ParameterType, :default => 'prompt')
111
+ define_attribute(:refreshOnChange, :bool, :default => false)
112
+ define_attribute(:prompt, RubyXL::ST_Xstring)
113
+ define_attribute(:boolean, :bool)
114
+ define_attribute(:double, :double)
115
+ define_attribute(:integer, :int)
116
+ define_attribute(:string, RubyXL::ST_Xstring)
117
+ define_attribute(:cell, RubyXL::ST_Xstring)
118
+ define_element_name 'parameter'
119
+ end
120
+
121
+ # http://www.datypic.com/sc/ooxml/e-ssml_parameters-1.html
122
+ class QueryParameters < OOXMLObject
123
+ define_child_node(RubyXL::QueryParameter, :collection => :with_count, :accessor => :parameters, :node_name => :parameter)
124
+ define_element_name 'parameters'
125
+ end
126
+
127
+ # http://www.datypic.com/sc/ooxml/e-ssml_connection-1.html
128
+ class Connection < OOXMLObject
129
+ define_attribute(:id, :uint, :required => true)
130
+ define_attribute(:sourceFile, RubyXL::ST_Xstring)
131
+ define_attribute(:odcFile, RubyXL::ST_Xstring)
132
+ define_attribute(:keepAlive, :bool, :default => false)
133
+ define_attribute(:interval, :uint, :default => 0)
134
+ define_attribute(:name, RubyXL::ST_Xstring)
135
+ define_attribute(:description, RubyXL::ST_Xstring)
136
+ define_attribute(:type, :uint)
137
+ define_attribute(:reconnectionMethod, :uint, :default => 1)
138
+ define_attribute(:refreshedVersion, :uint, :required => true)
139
+ define_attribute(:minRefreshableVersion, :uint, :default => 0)
140
+ define_attribute(:savePassword, :bool, :default => false)
141
+ define_attribute(:new, :bool, :default => false)
142
+ define_attribute(:deleted, :bool, :default => false)
143
+ define_attribute(:onlyUseConnectionFile, :bool, :default => false)
144
+ define_attribute(:background, :bool, :default => false)
145
+ define_attribute(:refreshOnLoad, :bool, :default => false)
146
+ define_attribute(:saveData, :bool, :default => false)
147
+ define_attribute(:credentials, RubyXL::ST_CredMethod, :default => 'integrated')
148
+ define_attribute(:singleSignOnId, RubyXL::ST_Xstring)
149
+
150
+ define_child_node(RubyXL::OdbcOleDbProperties)
151
+ define_child_node(RubyXL::OlapProperties)
152
+ define_child_node(RubyXL::WebQueryProperties)
153
+ define_child_node(RubyXL::TextImportSettings)
154
+ define_child_node(RubyXL::QueryParameters)
155
+ define_child_node(RubyXL::ExtensionStorageArea)
156
+
157
+ define_element_name 'connection'
158
+ end
159
+
160
+ # http://www.datypic.com/sc/ooxml/e-ssml_connections.html
161
+ class Connections < OOXMLTopLevelObject
162
+ CONTENT_TYPE = 'application/vnd.openxmlformats-officedocument.spreadsheetml.connections+xml'.freeze
163
+ REL_TYPE = 'http://schemas.openxmlformats.org/officeDocument/2006/relationships/connections'.freeze
164
+
165
+ define_child_node(RubyXL::Connection, :collection => true, :accessor => :connections)
166
+
167
+ define_element_name 'connections'
168
+
169
+ set_namespaces('http://schemas.openxmlformats.org/spreadsheetml/2006/main' => nil)
170
+
171
+ def xlsx_path
172
+ ROOT.join('xl', 'connections.xml')
173
+ end
174
+ end
175
+ end
@@ -2,7 +2,6 @@ require 'rubyXL/objects/ooxml_object'
2
2
  require 'rubyXL/objects/simple_types'
3
3
 
4
4
  module RubyXL
5
-
6
5
  class BooleanValue < OOXMLObject
7
6
  define_attribute(:val, :bool, :required => true, :default => true)
8
7
  end
@@ -46,12 +45,11 @@ module RubyXL
46
45
  def self.default(v)
47
46
  v && self.new(:value => v.to_datetime.iso8601)
48
47
  end
49
-
50
48
  end
51
49
 
52
- # http://www.schemacentral.com/sc/ooxml/e-docPropsVTypes_variant.html
50
+ # http://www.datypic.com/sc/ooxml/e-docPropsVTypes_variant.html
53
51
  class Variant < OOXMLObject
54
- define_child_node(RubyXL::Variant, :node_name => 'vt:variant')
52
+ define_child_node(RubyXL::Variant, :node_name => 'vt:variant')
55
53
 
56
54
  # vector Vector
57
55
  # array Array
@@ -91,7 +89,7 @@ module RubyXL
91
89
  define_element_name 'vt:vector'
92
90
  end
93
91
 
94
- # http://www.schemacentral.com/sc/ooxml/e-docPropsVTypes_vector.html
92
+ # http://www.datypic.com/sc/ooxml/e-docPropsVTypes_vector.html
95
93
  class Vector < OOXMLObject
96
94
  define_attribute(:baseType, RubyXL::ST_VectorBaseType, :required => true)
97
95
  define_attribute(:size, :int, :required => true)
@@ -125,11 +123,9 @@ module RubyXL
125
123
  known_child_nodes.values.each { |v| self.size += self.send(v[:accessor]).size }
126
124
  true
127
125
  end
128
-
129
126
  end
130
127
 
131
128
  class VectorValue < OOXMLObject
132
129
  define_child_node(RubyXL::Vector)
133
130
  end
134
-
135
131
  end
@@ -1,7 +1,6 @@
1
1
  require 'rubyXL/objects/ooxml_object'
2
2
 
3
3
  module RubyXL
4
-
5
4
  class ContentTypeDefault < OOXMLObject
6
5
  define_attribute(:Extension, :string)
7
6
  define_attribute(:ContentType, :string)
@@ -9,7 +8,7 @@ module RubyXL
9
8
  end
10
9
 
11
10
  class ContentTypeOverride < OOXMLObject
12
- define_attribute(:PartName, :string)
11
+ define_attribute(:PartName, :string)
13
12
  define_attribute(:ContentType, :string)
14
13
  define_element_name 'Override'
15
14
  end
@@ -38,7 +37,7 @@ module RubyXL
38
37
  ext = obj.xlsx_path.extname[1..-1]
39
38
  next if ext.nil?
40
39
  content_types_by_ext[ext] ||= []
41
- content_types_by_ext[ext] << klass::CONTENT_TYPE
40
+ content_types_by_ext[ext] << klass::CONTENT_TYPE
42
41
  }
43
42
  }
44
43
 
@@ -46,9 +45,9 @@ module RubyXL
46
45
 
47
46
  # Determine which content types are used most often, and add them to the list of defaults
48
47
  content_types_by_ext.each_pair { |ext, content_types_arr|
49
- next if ext.nil? || defaults.any? { |d| d.extension == ext }
48
+ next if ext.nil? || defaults.any? { |d| d.extension == ext }
50
49
  most_frequent_ct = content_types_arr.group_by { |ct| ct }.values.max_by(&:size).first
51
- defaults << RubyXL::ContentTypeDefault.new(:extension => ext, :content_type => most_frequent_ct )
50
+ defaults << RubyXL::ContentTypeDefault.new(:extension => ext, :content_type => most_frequent_ct)
52
51
  }
53
52
 
54
53
  self.overrides = []
@@ -64,14 +63,12 @@ module RubyXL
64
63
 
65
64
  ext = obj.xlsx_path.extname[1..-1]
66
65
  next if defaults.any? { |d| (d.extension == ext) && (d.content_type == obj_content_type) }
67
- overrides << RubyXL::ContentTypeOverride.new(:part_name => obj.xlsx_path,
66
+ overrides << RubyXL::ContentTypeOverride.new(:part_name => obj.xlsx_path,
68
67
  :content_type => obj_content_type)
69
68
  }
70
69
  }
71
70
 
72
71
  true
73
72
  end
74
-
75
73
  end
76
-
77
74
  end
@@ -3,14 +3,15 @@ require 'rubyXL/objects/simple_types'
3
3
  require 'rubyXL/objects/formula'
4
4
 
5
5
  module RubyXL
6
-
7
- # http://www.schemacentral.com/sc/ooxml/e-ssml_dataValidation-1.html
6
+ # http://www.datypic.com/sc/ooxml/e-ssml_dataValidation-1.html
8
7
  class DataValidation < OOXMLObject
9
8
  define_attribute(:type, RubyXL::ST_DataValidationType, :default => 'none')
10
9
  define_attribute(:errorStyle, RubyXL::ST_DataValidationErrorStyle, :default => 'stop')
11
10
  define_attribute(:imeMode, RubyXL::ST_DataValidationImeMode, :default => 'noControl')
12
11
  define_attribute(:operator, RubyXL::ST_DataValidationOperator, :default => 'between')
13
12
  define_attribute(:allowBlank, :bool, :default => false)
13
+ # Documentation lies. This property should have been called "HIDE dropdown",
14
+ # since that's what happens when it is set to true.
14
15
  define_attribute(:showDropDown, :bool, :default => false)
15
16
  define_attribute(:showInputMessage, :bool, :default => false)
16
17
  define_attribute(:showErrorMessage, :bool, :default => false)
@@ -25,7 +26,7 @@ module RubyXL
25
26
  define_element_name 'dataValidation'
26
27
  end
27
28
 
28
- # http://www.schemacentral.com/sc/ooxml/e-ssml_dataValidations-1.html
29
+ # http://www.datypic.com/sc/ooxml/e-ssml_dataValidations-1.html
29
30
  class DataValidations < OOXMLContainerObject
30
31
  define_attribute(:disablePrompts, :bool, :default => false)
31
32
  define_attribute(:xWindow, :int)
@@ -33,5 +34,4 @@ module RubyXL
33
34
  define_child_node(RubyXL::DataValidation, :collection => :with_count)
34
35
  define_element_name 'dataValidations'
35
36
  end
36
-
37
37
  end