aspose_slides_cloud 21.4.0 → 21.6.0

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 (176) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +89 -61
  3. data/TestData/TemplatingCVDataWithBase64.xml +22 -22
  4. data/lib/aspose_slides_cloud.rb +212 -213
  5. data/lib/aspose_slides_cloud/api/slides_api.rb +15206 -17689
  6. data/lib/aspose_slides_cloud/api_client.rb +439 -439
  7. data/lib/aspose_slides_cloud/models/add_layout_slide.rb +244 -244
  8. data/lib/aspose_slides_cloud/models/add_master_slide.rb +259 -259
  9. data/lib/aspose_slides_cloud/models/add_shape.rb +239 -239
  10. data/lib/aspose_slides_cloud/models/add_slide.rb +269 -269
  11. data/lib/aspose_slides_cloud/models/api_info.rb +217 -217
  12. data/lib/aspose_slides_cloud/models/arrow_head_properties.rb +285 -285
  13. data/lib/aspose_slides_cloud/models/audio_frame.rb +359 -359
  14. data/lib/aspose_slides_cloud/models/axes.rb +237 -237
  15. data/lib/aspose_slides_cloud/models/axis.rb +699 -699
  16. data/lib/aspose_slides_cloud/models/base64_input_file.rb +230 -230
  17. data/lib/aspose_slides_cloud/models/blur_effect.rb +227 -227
  18. data/lib/aspose_slides_cloud/models/box_and_whisker_series.rb +299 -299
  19. data/lib/aspose_slides_cloud/models/bubble_chart_data_point.rb +212 -212
  20. data/lib/aspose_slides_cloud/models/bubble_series.rb +248 -248
  21. data/lib/aspose_slides_cloud/models/chart.rb +365 -365
  22. data/lib/aspose_slides_cloud/models/chart_category.rb +271 -271
  23. data/lib/aspose_slides_cloud/models/chart_title.rb +222 -222
  24. data/lib/aspose_slides_cloud/models/chart_wall.rb +281 -281
  25. data/lib/aspose_slides_cloud/models/color_scheme.rb +317 -317
  26. data/lib/aspose_slides_cloud/models/common_slide_view_properties.rb +217 -217
  27. data/lib/aspose_slides_cloud/models/connector.rb +275 -275
  28. data/lib/aspose_slides_cloud/models/custom_dash_pattern.rb +209 -209
  29. data/lib/aspose_slides_cloud/models/data_point.rb +197 -197
  30. data/lib/aspose_slides_cloud/models/disc_usage.rb +227 -227
  31. data/lib/aspose_slides_cloud/models/document.rb +257 -257
  32. data/lib/aspose_slides_cloud/models/document_properties.rb +209 -209
  33. data/lib/aspose_slides_cloud/models/document_property.rb +232 -232
  34. data/lib/aspose_slides_cloud/models/document_replace_result.rb +218 -218
  35. data/lib/aspose_slides_cloud/models/effect.rb +424 -424
  36. data/lib/aspose_slides_cloud/models/effect_format.rb +277 -277
  37. data/lib/aspose_slides_cloud/models/entity_exists.rb +212 -212
  38. data/lib/aspose_slides_cloud/models/error.rb +237 -237
  39. data/lib/aspose_slides_cloud/models/error_details.rb +222 -222
  40. data/lib/aspose_slides_cloud/models/export_format.rb +60 -60
  41. data/lib/aspose_slides_cloud/models/export_options.rb +216 -216
  42. data/lib/aspose_slides_cloud/models/file_version.rb +225 -225
  43. data/lib/aspose_slides_cloud/models/file_versions.rb +209 -209
  44. data/lib/aspose_slides_cloud/models/files_list.rb +209 -209
  45. data/lib/aspose_slides_cloud/models/files_upload_result.rb +221 -221
  46. data/lib/aspose_slides_cloud/models/fill_format.rb +240 -240
  47. data/lib/aspose_slides_cloud/models/fill_overlay_effect.rb +246 -246
  48. data/lib/aspose_slides_cloud/models/font_scheme.rb +227 -227
  49. data/lib/aspose_slides_cloud/models/font_set.rb +227 -227
  50. data/lib/aspose_slides_cloud/models/format_scheme.rb +245 -245
  51. data/lib/aspose_slides_cloud/models/geometry_shape.rb +260 -260
  52. data/lib/aspose_slides_cloud/models/glow_effect.rb +222 -222
  53. data/lib/aspose_slides_cloud/models/gradient_fill.rb +342 -342
  54. data/lib/aspose_slides_cloud/models/gradient_fill_stop.rb +222 -222
  55. data/lib/aspose_slides_cloud/models/graphical_object.rb +234 -234
  56. data/lib/aspose_slides_cloud/models/group_shape.rb +234 -234
  57. data/lib/aspose_slides_cloud/models/header_footer.rb +247 -247
  58. data/lib/aspose_slides_cloud/models/html_export_options.rb +421 -421
  59. data/lib/aspose_slides_cloud/models/i_shape_export_options.rb +197 -197
  60. data/lib/aspose_slides_cloud/models/image.rb +237 -237
  61. data/lib/aspose_slides_cloud/models/image_export_format.rb +43 -43
  62. data/lib/aspose_slides_cloud/models/image_export_options.rb +299 -299
  63. data/lib/aspose_slides_cloud/models/images.rb +209 -209
  64. data/lib/aspose_slides_cloud/models/inner_shadow_effect.rb +252 -252
  65. data/lib/aspose_slides_cloud/models/input.rb +227 -227
  66. data/lib/aspose_slides_cloud/models/input_file.rb +250 -250
  67. data/lib/aspose_slides_cloud/models/interactive_sequence.rb +224 -224
  68. data/lib/aspose_slides_cloud/models/layout_slide.rb +278 -278
  69. data/lib/aspose_slides_cloud/models/layout_slides.rb +209 -209
  70. data/lib/aspose_slides_cloud/models/legend.rb +321 -321
  71. data/lib/aspose_slides_cloud/models/line_format.rb +411 -411
  72. data/lib/aspose_slides_cloud/models/master_slide.rb +231 -231
  73. data/lib/aspose_slides_cloud/models/master_slides.rb +209 -209
  74. data/lib/aspose_slides_cloud/models/merge.rb +231 -231
  75. data/lib/aspose_slides_cloud/models/merging_source.rb +219 -219
  76. data/lib/aspose_slides_cloud/models/no_fill.rb +219 -219
  77. data/lib/aspose_slides_cloud/models/normal_view_restored_properties.rb +217 -217
  78. data/lib/aspose_slides_cloud/models/notes_slide.rb +217 -217
  79. data/lib/aspose_slides_cloud/models/notes_slide_export_format.rb +43 -43
  80. data/lib/aspose_slides_cloud/models/notes_slide_header_footer.rb +267 -267
  81. data/lib/aspose_slides_cloud/models/object_exist.rb +227 -227
  82. data/lib/aspose_slides_cloud/models/ole_object_frame.rb +259 -259
  83. data/lib/aspose_slides_cloud/models/one_value_chart_data_point.rb +210 -210
  84. data/lib/aspose_slides_cloud/models/one_value_series.rb +248 -248
  85. data/lib/aspose_slides_cloud/models/ordered_merge_request.rb +209 -209
  86. data/lib/aspose_slides_cloud/models/outer_shadow_effect.rb +252 -252
  87. data/lib/aspose_slides_cloud/models/output_file.rb +240 -240
  88. data/lib/aspose_slides_cloud/models/paragraph.rb +517 -517
  89. data/lib/aspose_slides_cloud/models/paragraphs.rb +209 -209
  90. data/lib/aspose_slides_cloud/models/path_input_file.rb +240 -240
  91. data/lib/aspose_slides_cloud/models/path_output_file.rb +239 -239
  92. data/lib/aspose_slides_cloud/models/pattern_fill.rb +266 -266
  93. data/lib/aspose_slides_cloud/models/pdf_export_options.rb +547 -547
  94. data/lib/aspose_slides_cloud/models/picture_fill.rb +351 -351
  95. data/lib/aspose_slides_cloud/models/picture_frame.rb +245 -245
  96. data/lib/aspose_slides_cloud/models/pipeline.rb +219 -219
  97. data/lib/aspose_slides_cloud/models/placeholder.rb +325 -325
  98. data/lib/aspose_slides_cloud/models/placeholders.rb +209 -209
  99. data/lib/aspose_slides_cloud/models/plot_area.rb +311 -311
  100. data/lib/aspose_slides_cloud/models/portion.rb +589 -589
  101. data/lib/aspose_slides_cloud/models/portions.rb +209 -209
  102. data/lib/aspose_slides_cloud/models/pptx_export_options.rb +247 -247
  103. data/lib/aspose_slides_cloud/models/presentation_to_merge.rb +273 -273
  104. data/lib/aspose_slides_cloud/models/presentations_merge_request.rb +221 -221
  105. data/lib/aspose_slides_cloud/models/preset_shadow_effect.rb +286 -286
  106. data/lib/aspose_slides_cloud/models/protection_properties.rb +267 -267
  107. data/lib/aspose_slides_cloud/models/reflection_effect.rb +441 -441
  108. data/lib/aspose_slides_cloud/models/remove_shape.rb +229 -229
  109. data/lib/aspose_slides_cloud/models/remove_slide.rb +234 -234
  110. data/lib/aspose_slides_cloud/models/reorder_slide.rb +249 -249
  111. data/lib/aspose_slides_cloud/models/replace_text.rb +269 -269
  112. data/lib/aspose_slides_cloud/models/request_input_file.rb +235 -235
  113. data/lib/aspose_slides_cloud/models/reset_slide.rb +234 -234
  114. data/lib/aspose_slides_cloud/models/resource_base.rb +219 -219
  115. data/lib/aspose_slides_cloud/models/resource_uri.rb +237 -237
  116. data/lib/aspose_slides_cloud/models/response_output_file.rb +219 -219
  117. data/lib/aspose_slides_cloud/models/save.rb +266 -266
  118. data/lib/aspose_slides_cloud/models/save_shape.rb +276 -276
  119. data/lib/aspose_slides_cloud/models/save_slide.rb +301 -301
  120. data/lib/aspose_slides_cloud/models/scatter_chart_data_point.rb +225 -225
  121. data/lib/aspose_slides_cloud/models/scatter_series.rb +248 -248
  122. data/lib/aspose_slides_cloud/models/section.rb +234 -234
  123. data/lib/aspose_slides_cloud/models/sections.rb +209 -209
  124. data/lib/aspose_slides_cloud/models/series.rb +422 -422
  125. data/lib/aspose_slides_cloud/models/series_marker.rb +281 -281
  126. data/lib/aspose_slides_cloud/models/shape.rb +255 -255
  127. data/lib/aspose_slides_cloud/models/shape_base.rb +375 -375
  128. data/lib/aspose_slides_cloud/models/shape_export_format.rb +44 -44
  129. data/lib/aspose_slides_cloud/models/shape_image_export_options.rb +286 -286
  130. data/lib/aspose_slides_cloud/models/shape_thumbnail_bounds.rb +41 -41
  131. data/lib/aspose_slides_cloud/models/shapes.rb +209 -209
  132. data/lib/aspose_slides_cloud/models/shapes_alignment_type.rb +46 -46
  133. data/lib/aspose_slides_cloud/models/slide.rb +322 -322
  134. data/lib/aspose_slides_cloud/models/slide_animation.rb +221 -221
  135. data/lib/aspose_slides_cloud/models/slide_background.rb +266 -266
  136. data/lib/aspose_slides_cloud/models/slide_comment.rb +239 -239
  137. data/lib/aspose_slides_cloud/models/slide_comments.rb +209 -209
  138. data/lib/aspose_slides_cloud/models/slide_export_format.rb +59 -59
  139. data/lib/aspose_slides_cloud/models/slide_properties.rb +315 -315
  140. data/lib/aspose_slides_cloud/models/slide_replace_result.rb +223 -223
  141. data/lib/aspose_slides_cloud/models/slides.rb +209 -209
  142. data/lib/aspose_slides_cloud/models/smart_art.rb +342 -342
  143. data/lib/aspose_slides_cloud/models/smart_art_node.rb +293 -293
  144. data/lib/aspose_slides_cloud/models/smart_art_shape.rb +235 -235
  145. data/lib/aspose_slides_cloud/models/soft_edge_effect.rb +212 -212
  146. data/lib/aspose_slides_cloud/models/solid_fill.rb +229 -229
  147. data/lib/aspose_slides_cloud/models/split_document_result.rb +209 -209
  148. data/lib/aspose_slides_cloud/models/storage_exist.rb +212 -212
  149. data/lib/aspose_slides_cloud/models/storage_file.rb +257 -257
  150. data/lib/aspose_slides_cloud/models/svg_export_options.rb +379 -379
  151. data/lib/aspose_slides_cloud/models/swf_export_options.rb +529 -529
  152. data/lib/aspose_slides_cloud/models/table.rb +350 -350
  153. data/lib/aspose_slides_cloud/models/table_cell.rb +403 -403
  154. data/lib/aspose_slides_cloud/models/table_column.rb +212 -212
  155. data/lib/aspose_slides_cloud/models/table_row.rb +239 -239
  156. data/lib/aspose_slides_cloud/models/task.rb +240 -240
  157. data/lib/aspose_slides_cloud/models/text_item.rb +217 -217
  158. data/lib/aspose_slides_cloud/models/text_items.rb +209 -209
  159. data/lib/aspose_slides_cloud/models/theme.rb +237 -237
  160. data/lib/aspose_slides_cloud/models/tiff_export_options.rb +423 -423
  161. data/lib/aspose_slides_cloud/models/update_background.rb +241 -241
  162. data/lib/aspose_slides_cloud/models/update_shape.rb +239 -239
  163. data/lib/aspose_slides_cloud/models/video_frame.rb +329 -329
  164. data/lib/aspose_slides_cloud/models/view_properties.rb +357 -357
  165. data/lib/aspose_slides_cloud/models/waterfall_chart_data_point.rb +206 -206
  166. data/lib/aspose_slides_cloud/models/waterfall_series.rb +247 -247
  167. data/lib/aspose_slides_cloud/models/xps_export_options.rb +243 -243
  168. data/lib/aspose_slides_cloud/type_registry.rb +323 -323
  169. data/lib/aspose_slides_cloud/version.rb +25 -25
  170. data/spec/api/slides_api_spec.rb +40213 -39435
  171. data/spec/extra/extra_spec.rb +202 -202
  172. data/spec/spec_utils.rb +182 -182
  173. data/testConfig.json +7 -7
  174. data/testRules.json +513 -511
  175. metadata +2 -3
  176. data/lib/aspose_slides_cloud/api/slides_api_requests.rb +0 -4742
@@ -1,209 +1,209 @@
1
- =begin
2
- Copyright (c) 2019 Aspose Pty Ltd
3
-
4
- Permission is hereby granted, free of charge, to any person obtaining a copy
5
- of this software and associated documentation files (the "Software"), to deal
6
- in the Software without restriction, including without limitation the rights
7
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
- copies of the Software, and to permit persons to whom the Software is
9
- furnished to do so, subject to the following conditions:
10
-
11
- The above copyright notice and this permission notice shall be included in all
12
- copies or substantial portions of the Software.
13
-
14
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20
- SOFTWARE.
21
- =end
22
-
23
- require 'date'
24
-
25
- module AsposeSlidesCloud
26
- # Section list.
27
- class Sections < ResourceBase
28
- # List of slide links.
29
- attr_accessor :section_list
30
-
31
- # Attribute mapping from ruby-style variable name to JSON key.
32
- def self.attribute_map
33
- super.merge({
34
- :'section_list' => :'SectionList',
35
- })
36
- end
37
-
38
- # Attribute type mapping.
39
- def self.swagger_types
40
- super.merge({
41
- :'section_list' => :'Array<Section>',
42
- })
43
- end
44
-
45
- # Initializes the object
46
- # @param [Hash] attributes Model attributes in the form of hash
47
- def initialize(attributes = {})
48
- super
49
-
50
- if attributes.has_key?(:'SectionList')
51
- if (value = attributes[:'SectionList']).is_a?(Array)
52
- self.section_list = value
53
- end
54
- end
55
- end
56
-
57
- # Show invalid properties with the reasons. Usually used together with valid?
58
- # @return Array for valid properties with the reasons
59
- def list_invalid_properties
60
- invalid_properties = super
61
- invalid_properties
62
- end
63
-
64
- # Check to see if the all the properties in the model are valid
65
- # @return true if the model is valid
66
- def valid?
67
- return false if !super
68
- true
69
- end
70
-
71
- # Checks equality by comparing each attribute.
72
- # @param [Object] Object to be compared
73
- def ==(o)
74
- return true if self.equal?(o)
75
- self.class == o.class &&
76
- self_uri == o.self_uri &&
77
- alternate_links == o.alternate_links &&
78
- section_list == o.section_list
79
- end
80
-
81
- # @see the `==` method
82
- # @param [Object] Object to be compared
83
- def eql?(o)
84
- self == o
85
- end
86
-
87
- # Calculates hash code according to all attributes.
88
- # @return [Fixnum] Hash code
89
- def hash
90
- [self_uri, alternate_links, section_list].hash
91
- end
92
-
93
- # Builds the object from hash
94
- # @param [Hash] attributes Model attributes in the form of hash
95
- # @return [Object] Returns the model itself
96
- def build_from_hash(attributes)
97
- return nil unless attributes.is_a?(Hash)
98
- self.class.swagger_types.each_pair do |key, type|
99
- mapKey = self.class.attribute_map[key]
100
- if !mapKey.nil?
101
- val = attributes[mapKey]
102
- if val.nil?
103
- mapKeyString = mapKey.to_s
104
- mapKeyString[0] = mapKeyString[0].downcase
105
- mapKey = mapKeyString.to_sym
106
- val = attributes[mapKey]
107
- end
108
- if !val.nil?
109
- if type =~ /\AArray<(.*)>/i
110
- # check to ensure the input is an array given that the the attribute
111
- # is documented as an array but the input is not
112
- if val.is_a?(Array)
113
- self.send("#{key}=", val.map { |v| _deserialize($1, v) })
114
- end
115
- else
116
- self.send("#{key}=", _deserialize(type, val))
117
- end
118
- end
119
- end
120
- end
121
-
122
- self
123
- end
124
-
125
- # Deserializes the data based on type
126
- # @param string type Data type
127
- # @param string value Value to be deserialized
128
- # @return [Object] Deserialized data
129
- def _deserialize(type, value)
130
- case type.to_sym
131
- when :DateTime
132
- DateTime.parse(value)
133
- when :Date
134
- Date.parse(value)
135
- when :String
136
- value.to_s
137
- when :Integer
138
- value.to_i
139
- when :Float
140
- value.to_f
141
- when :BOOLEAN
142
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
143
- true
144
- else
145
- false
146
- end
147
- when :Object
148
- # generic object (usually a Hash), return directly
149
- value
150
- when /\AArray<(?<inner_type>.+)>\z/
151
- inner_type = Regexp.last_match[:inner_type]
152
- value.map { |v| _deserialize(inner_type, v) }
153
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
154
- k_type = Regexp.last_match[:k_type]
155
- v_type = Regexp.last_match[:v_type]
156
- {}.tap do |hash|
157
- value.each do |k, v|
158
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
159
- end
160
- end
161
- else # model
162
- temp_model = AsposeSlidesCloud.const_get(type).new
163
- temp_model.build_from_hash(value)
164
- end
165
- end
166
-
167
- # Returns the string representation of the object
168
- # @return [String] String presentation of the object
169
- def to_s
170
- to_hash.to_s
171
- end
172
-
173
- # to_body is an alias to to_hash (backward compatibility)
174
- # @return [Hash] Returns the object in the form of hash
175
- def to_body
176
- to_hash
177
- end
178
-
179
- # Returns the object in the form of hash
180
- # @return [Hash] Returns the object in the form of hash
181
- def to_hash
182
- hash = {}
183
- self.class.attribute_map.each_pair do |attr, param|
184
- value = self.send(attr)
185
- next if value.nil?
186
- hash[param] = _to_hash(value)
187
- end
188
- hash
189
- end
190
-
191
- # Outputs non-array value in the form of hash
192
- # For object, use to_hash. Otherwise, just return the value
193
- # @param [Object] value Any valid value
194
- # @return [Hash] Returns the value in the form of hash
195
- def _to_hash(value)
196
- if value.is_a?(Array)
197
- value.compact.map { |v| _to_hash(v) }
198
- elsif value.is_a?(Hash)
199
- {}.tap do |hash|
200
- value.each { |k, v| hash[k] = _to_hash(v) }
201
- end
202
- elsif value.respond_to? :to_hash
203
- value.to_hash
204
- else
205
- value
206
- end
207
- end
208
- end
209
- end
1
+ =begin
2
+ Copyright (c) 2019 Aspose Pty Ltd
3
+
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy
5
+ of this software and associated documentation files (the "Software"), to deal
6
+ in the Software without restriction, including without limitation the rights
7
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
+ copies of the Software, and to permit persons to whom the Software is
9
+ furnished to do so, subject to the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be included in all
12
+ copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20
+ SOFTWARE.
21
+ =end
22
+
23
+ require 'date'
24
+
25
+ module AsposeSlidesCloud
26
+ # Section list.
27
+ class Sections < ResourceBase
28
+ # List of slide links.
29
+ attr_accessor :section_list
30
+
31
+ # Attribute mapping from ruby-style variable name to JSON key.
32
+ def self.attribute_map
33
+ super.merge({
34
+ :'section_list' => :'SectionList',
35
+ })
36
+ end
37
+
38
+ # Attribute type mapping.
39
+ def self.swagger_types
40
+ super.merge({
41
+ :'section_list' => :'Array<Section>',
42
+ })
43
+ end
44
+
45
+ # Initializes the object
46
+ # @param [Hash] attributes Model attributes in the form of hash
47
+ def initialize(attributes = {})
48
+ super
49
+
50
+ if attributes.has_key?(:'SectionList')
51
+ if (value = attributes[:'SectionList']).is_a?(Array)
52
+ self.section_list = value
53
+ end
54
+ end
55
+ end
56
+
57
+ # Show invalid properties with the reasons. Usually used together with valid?
58
+ # @return Array for valid properties with the reasons
59
+ def list_invalid_properties
60
+ invalid_properties = super
61
+ invalid_properties
62
+ end
63
+
64
+ # Check to see if the all the properties in the model are valid
65
+ # @return true if the model is valid
66
+ def valid?
67
+ return false if !super
68
+ true
69
+ end
70
+
71
+ # Checks equality by comparing each attribute.
72
+ # @param [Object] Object to be compared
73
+ def ==(o)
74
+ return true if self.equal?(o)
75
+ self.class == o.class &&
76
+ self_uri == o.self_uri &&
77
+ alternate_links == o.alternate_links &&
78
+ section_list == o.section_list
79
+ end
80
+
81
+ # @see the `==` method
82
+ # @param [Object] Object to be compared
83
+ def eql?(o)
84
+ self == o
85
+ end
86
+
87
+ # Calculates hash code according to all attributes.
88
+ # @return [Fixnum] Hash code
89
+ def hash
90
+ [self_uri, alternate_links, section_list].hash
91
+ end
92
+
93
+ # Builds the object from hash
94
+ # @param [Hash] attributes Model attributes in the form of hash
95
+ # @return [Object] Returns the model itself
96
+ def build_from_hash(attributes)
97
+ return nil unless attributes.is_a?(Hash)
98
+ self.class.swagger_types.each_pair do |key, type|
99
+ mapKey = self.class.attribute_map[key]
100
+ if !mapKey.nil?
101
+ val = attributes[mapKey]
102
+ if val.nil?
103
+ mapKeyString = mapKey.to_s
104
+ mapKeyString[0] = mapKeyString[0].downcase
105
+ mapKey = mapKeyString.to_sym
106
+ val = attributes[mapKey]
107
+ end
108
+ if !val.nil?
109
+ if type =~ /\AArray<(.*)>/i
110
+ # check to ensure the input is an array given that the the attribute
111
+ # is documented as an array but the input is not
112
+ if val.is_a?(Array)
113
+ self.send("#{key}=", val.map { |v| _deserialize($1, v) })
114
+ end
115
+ else
116
+ self.send("#{key}=", _deserialize(type, val))
117
+ end
118
+ end
119
+ end
120
+ end
121
+
122
+ self
123
+ end
124
+
125
+ # Deserializes the data based on type
126
+ # @param string type Data type
127
+ # @param string value Value to be deserialized
128
+ # @return [Object] Deserialized data
129
+ def _deserialize(type, value)
130
+ case type.to_sym
131
+ when :DateTime
132
+ DateTime.parse(value)
133
+ when :Date
134
+ Date.parse(value)
135
+ when :String
136
+ value.to_s
137
+ when :Integer
138
+ value.to_i
139
+ when :Float
140
+ value.to_f
141
+ when :BOOLEAN
142
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
143
+ true
144
+ else
145
+ false
146
+ end
147
+ when :Object
148
+ # generic object (usually a Hash), return directly
149
+ value
150
+ when /\AArray<(?<inner_type>.+)>\z/
151
+ inner_type = Regexp.last_match[:inner_type]
152
+ value.map { |v| _deserialize(inner_type, v) }
153
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
154
+ k_type = Regexp.last_match[:k_type]
155
+ v_type = Regexp.last_match[:v_type]
156
+ {}.tap do |hash|
157
+ value.each do |k, v|
158
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
159
+ end
160
+ end
161
+ else # model
162
+ temp_model = AsposeSlidesCloud.const_get(type).new
163
+ temp_model.build_from_hash(value)
164
+ end
165
+ end
166
+
167
+ # Returns the string representation of the object
168
+ # @return [String] String presentation of the object
169
+ def to_s
170
+ to_hash.to_s
171
+ end
172
+
173
+ # to_body is an alias to to_hash (backward compatibility)
174
+ # @return [Hash] Returns the object in the form of hash
175
+ def to_body
176
+ to_hash
177
+ end
178
+
179
+ # Returns the object in the form of hash
180
+ # @return [Hash] Returns the object in the form of hash
181
+ def to_hash
182
+ hash = {}
183
+ self.class.attribute_map.each_pair do |attr, param|
184
+ value = self.send(attr)
185
+ next if value.nil?
186
+ hash[param] = _to_hash(value)
187
+ end
188
+ hash
189
+ end
190
+
191
+ # Outputs non-array value in the form of hash
192
+ # For object, use to_hash. Otherwise, just return the value
193
+ # @param [Object] value Any valid value
194
+ # @return [Hash] Returns the value in the form of hash
195
+ def _to_hash(value)
196
+ if value.is_a?(Array)
197
+ value.compact.map { |v| _to_hash(v) }
198
+ elsif value.is_a?(Hash)
199
+ {}.tap do |hash|
200
+ value.each { |k, v| hash[k] = _to_hash(v) }
201
+ end
202
+ elsif value.respond_to? :to_hash
203
+ value.to_hash
204
+ else
205
+ value
206
+ end
207
+ end
208
+ end
209
+ end
@@ -1,422 +1,422 @@
1
- =begin
2
- Copyright (c) 2019 Aspose Pty Ltd
3
-
4
- Permission is hereby granted, free of charge, to any person obtaining a copy
5
- of this software and associated documentation files (the "Software"), to deal
6
- in the Software without restriction, including without limitation the rights
7
- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
- copies of the Software, and to permit persons to whom the Software is
9
- furnished to do so, subject to the following conditions:
10
-
11
- The above copyright notice and this permission notice shall be included in all
12
- copies or substantial portions of the Software.
13
-
14
- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20
- SOFTWARE.
21
- =end
22
-
23
- require 'date'
24
-
25
- module AsposeSlidesCloud
26
- # A chart series.
27
- class Series
28
- # Series type.
29
- attr_accessor :type
30
-
31
- # Series name.
32
- attr_accessor :name
33
-
34
- # True if each data marker in the series has a different color.
35
- attr_accessor :is_color_varied
36
-
37
- # Invert solid color for the series.
38
- attr_accessor :inverted_solid_fill_color
39
-
40
- # True if curve smoothing is turned on. Applies only to line and scatter connected by lines charts.
41
- attr_accessor :smooth
42
-
43
- # True if the series is plotted on second value axis.
44
- attr_accessor :plot_on_second_axis
45
-
46
- # Series order.
47
- attr_accessor :order
48
-
49
- # The number format for the series y values.
50
- attr_accessor :number_format_of_y_values
51
-
52
- # The number format for the series x values.
53
- attr_accessor :number_format_of_x_values
54
-
55
- # The number format for the series values.
56
- attr_accessor :number_format_of_values
57
-
58
- # The number format for the series bubble sizes.
59
- attr_accessor :number_format_of_bubble_sizes
60
-
61
- # True if the series shall invert its colors if the value is negative. Applies to bar, column and bubble series.
62
- attr_accessor :invert_if_negative
63
-
64
- # The distance of an open pie slice from the center of the pie chart is expressed as a percentage of the pie diameter.
65
- attr_accessor :explosion
66
-
67
- # Series marker.
68
- attr_accessor :marker
69
-
70
- # Fill properties set for the series.
71
- attr_accessor :fill_format
72
-
73
- # Effect properties set for the series.
74
- attr_accessor :effect_format
75
-
76
- # Line properties set for the series.
77
- attr_accessor :line_format
78
-
79
- attr_accessor :data_point_type
80
-
81
- class EnumAttributeValidator
82
- attr_reader :datatype
83
- attr_reader :allowable_values
84
-
85
- def initialize(datatype, allowable_values)
86
- @allowable_values = allowable_values.map do |value|
87
- case datatype.to_s
88
- when /Integer/i
89
- value.to_i
90
- when /Float/i
91
- value.to_f
92
- else
93
- value
94
- end
95
- end
96
- end
97
-
98
- def valid?(value)
99
- !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
100
- end
101
- end
102
-
103
- # Attribute mapping from ruby-style variable name to JSON key.
104
- def self.attribute_map
105
- {
106
- :'type' => :'Type',
107
- :'name' => :'Name',
108
- :'is_color_varied' => :'IsColorVaried',
109
- :'inverted_solid_fill_color' => :'InvertedSolidFillColor',
110
- :'smooth' => :'Smooth',
111
- :'plot_on_second_axis' => :'PlotOnSecondAxis',
112
- :'order' => :'Order',
113
- :'number_format_of_y_values' => :'NumberFormatOfYValues',
114
- :'number_format_of_x_values' => :'NumberFormatOfXValues',
115
- :'number_format_of_values' => :'NumberFormatOfValues',
116
- :'number_format_of_bubble_sizes' => :'NumberFormatOfBubbleSizes',
117
- :'invert_if_negative' => :'InvertIfNegative',
118
- :'explosion' => :'Explosion',
119
- :'marker' => :'Marker',
120
- :'fill_format' => :'FillFormat',
121
- :'effect_format' => :'EffectFormat',
122
- :'line_format' => :'LineFormat',
123
- :'data_point_type' => :'DataPointType',
124
- }
125
- end
126
-
127
- # Attribute type mapping.
128
- def self.swagger_types
129
- {
130
- :'type' => :'String',
131
- :'name' => :'String',
132
- :'is_color_varied' => :'BOOLEAN',
133
- :'inverted_solid_fill_color' => :'String',
134
- :'smooth' => :'BOOLEAN',
135
- :'plot_on_second_axis' => :'BOOLEAN',
136
- :'order' => :'Integer',
137
- :'number_format_of_y_values' => :'String',
138
- :'number_format_of_x_values' => :'String',
139
- :'number_format_of_values' => :'String',
140
- :'number_format_of_bubble_sizes' => :'String',
141
- :'invert_if_negative' => :'BOOLEAN',
142
- :'explosion' => :'Integer',
143
- :'marker' => :'SeriesMarker',
144
- :'fill_format' => :'FillFormat',
145
- :'effect_format' => :'EffectFormat',
146
- :'line_format' => :'LineFormat',
147
- :'data_point_type' => :'String',
148
- }
149
- end
150
-
151
- # Initializes the object
152
- # @param [Hash] attributes Model attributes in the form of hash
153
- def initialize(attributes = {})
154
- return unless attributes.is_a?(Hash)
155
-
156
- # convert string to symbol for hash key
157
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
158
-
159
- if attributes.has_key?(:'Type')
160
- self.type = attributes[:'Type']
161
- end
162
-
163
- if attributes.has_key?(:'Name')
164
- self.name = attributes[:'Name']
165
- end
166
-
167
- if attributes.has_key?(:'IsColorVaried')
168
- self.is_color_varied = attributes[:'IsColorVaried']
169
- end
170
-
171
- if attributes.has_key?(:'InvertedSolidFillColor')
172
- self.inverted_solid_fill_color = attributes[:'InvertedSolidFillColor']
173
- end
174
-
175
- if attributes.has_key?(:'Smooth')
176
- self.smooth = attributes[:'Smooth']
177
- end
178
-
179
- if attributes.has_key?(:'PlotOnSecondAxis')
180
- self.plot_on_second_axis = attributes[:'PlotOnSecondAxis']
181
- end
182
-
183
- if attributes.has_key?(:'Order')
184
- self.order = attributes[:'Order']
185
- end
186
-
187
- if attributes.has_key?(:'NumberFormatOfYValues')
188
- self.number_format_of_y_values = attributes[:'NumberFormatOfYValues']
189
- end
190
-
191
- if attributes.has_key?(:'NumberFormatOfXValues')
192
- self.number_format_of_x_values = attributes[:'NumberFormatOfXValues']
193
- end
194
-
195
- if attributes.has_key?(:'NumberFormatOfValues')
196
- self.number_format_of_values = attributes[:'NumberFormatOfValues']
197
- end
198
-
199
- if attributes.has_key?(:'NumberFormatOfBubbleSizes')
200
- self.number_format_of_bubble_sizes = attributes[:'NumberFormatOfBubbleSizes']
201
- end
202
-
203
- if attributes.has_key?(:'InvertIfNegative')
204
- self.invert_if_negative = attributes[:'InvertIfNegative']
205
- end
206
-
207
- if attributes.has_key?(:'Explosion')
208
- self.explosion = attributes[:'Explosion']
209
- end
210
-
211
- if attributes.has_key?(:'Marker')
212
- self.marker = attributes[:'Marker']
213
- end
214
-
215
- if attributes.has_key?(:'FillFormat')
216
- self.fill_format = attributes[:'FillFormat']
217
- end
218
-
219
- if attributes.has_key?(:'EffectFormat')
220
- self.effect_format = attributes[:'EffectFormat']
221
- end
222
-
223
- if attributes.has_key?(:'LineFormat')
224
- self.line_format = attributes[:'LineFormat']
225
- end
226
-
227
- if attributes.has_key?(:'DataPointType')
228
- self.data_point_type = attributes[:'DataPointType']
229
- end
230
- end
231
-
232
- # Show invalid properties with the reasons. Usually used together with valid?
233
- # @return Array for valid properties with the reasons
234
- def list_invalid_properties
235
- invalid_properties = Array.new
236
- invalid_properties
237
- end
238
-
239
- # Check to see if the all the properties in the model are valid
240
- # @return true if the model is valid
241
- def valid?
242
- type_validator = EnumAttributeValidator.new('String', ['ClusteredColumn', 'StackedColumn', 'PercentsStackedColumn', 'ClusteredColumn3D', 'StackedColumn3D', 'PercentsStackedColumn3D', 'Column3D', 'ClusteredCylinder', 'StackedCylinder', 'PercentsStackedCylinder', 'Cylinder3D', 'ClusteredCone', 'StackedCone', 'PercentsStackedCone', 'Cone3D', 'ClusteredPyramid', 'StackedPyramid', 'PercentsStackedPyramid', 'Pyramid3D', 'Line', 'StackedLine', 'PercentsStackedLine', 'LineWithMarkers', 'StackedLineWithMarkers', 'PercentsStackedLineWithMarkers', 'Line3D', 'Pie', 'Pie3D', 'PieOfPie', 'ExplodedPie', 'ExplodedPie3D', 'BarOfPie', 'PercentsStackedBar', 'ClusteredBar3D', 'ClusteredBar', 'StackedBar', 'StackedBar3D', 'PercentsStackedBar3D', 'ClusteredHorizontalCylinder', 'StackedHorizontalCylinder', 'PercentsStackedHorizontalCylinder', 'ClusteredHorizontalCone', 'StackedHorizontalCone', 'PercentsStackedHorizontalCone', 'ClusteredHorizontalPyramid', 'StackedHorizontalPyramid', 'PercentsStackedHorizontalPyramid', 'Area', 'StackedArea', 'PercentsStackedArea', 'Area3D', 'StackedArea3D', 'PercentsStackedArea3D', 'ScatterWithMarkers', 'ScatterWithSmoothLinesAndMarkers', 'ScatterWithSmoothLines', 'ScatterWithStraightLinesAndMarkers', 'ScatterWithStraightLines', 'HighLowClose', 'OpenHighLowClose', 'VolumeHighLowClose', 'VolumeOpenHighLowClose', 'Surface3D', 'WireframeSurface3D', 'Contour', 'WireframeContour', 'Doughnut', 'ExplodedDoughnut', 'Bubble', 'BubbleWith3D', 'Radar', 'RadarWithMarkers', 'FilledRadar', 'SeriesOfMixedTypes', 'Treemap', 'Sunburst', 'Histogram', 'ParetoLine', 'BoxAndWhisker', 'Waterfall', 'Funnel', 'Map'])
243
- return false unless type_validator.valid?(@type)
244
- data_point_type_validator = EnumAttributeValidator.new('String', ['OneValue', 'Scatter', 'Bubble'])
245
- return false unless data_point_type_validator.valid?(@data_point_type)
246
- true
247
- end
248
-
249
- # Custom attribute writer method checking allowed values (enum).
250
- # @param [Object] type Object to be assigned
251
- def type=(type)
252
- validator = EnumAttributeValidator.new('String', ['ClusteredColumn', 'StackedColumn', 'PercentsStackedColumn', 'ClusteredColumn3D', 'StackedColumn3D', 'PercentsStackedColumn3D', 'Column3D', 'ClusteredCylinder', 'StackedCylinder', 'PercentsStackedCylinder', 'Cylinder3D', 'ClusteredCone', 'StackedCone', 'PercentsStackedCone', 'Cone3D', 'ClusteredPyramid', 'StackedPyramid', 'PercentsStackedPyramid', 'Pyramid3D', 'Line', 'StackedLine', 'PercentsStackedLine', 'LineWithMarkers', 'StackedLineWithMarkers', 'PercentsStackedLineWithMarkers', 'Line3D', 'Pie', 'Pie3D', 'PieOfPie', 'ExplodedPie', 'ExplodedPie3D', 'BarOfPie', 'PercentsStackedBar', 'ClusteredBar3D', 'ClusteredBar', 'StackedBar', 'StackedBar3D', 'PercentsStackedBar3D', 'ClusteredHorizontalCylinder', 'StackedHorizontalCylinder', 'PercentsStackedHorizontalCylinder', 'ClusteredHorizontalCone', 'StackedHorizontalCone', 'PercentsStackedHorizontalCone', 'ClusteredHorizontalPyramid', 'StackedHorizontalPyramid', 'PercentsStackedHorizontalPyramid', 'Area', 'StackedArea', 'PercentsStackedArea', 'Area3D', 'StackedArea3D', 'PercentsStackedArea3D', 'ScatterWithMarkers', 'ScatterWithSmoothLinesAndMarkers', 'ScatterWithSmoothLines', 'ScatterWithStraightLinesAndMarkers', 'ScatterWithStraightLines', 'HighLowClose', 'OpenHighLowClose', 'VolumeHighLowClose', 'VolumeOpenHighLowClose', 'Surface3D', 'WireframeSurface3D', 'Contour', 'WireframeContour', 'Doughnut', 'ExplodedDoughnut', 'Bubble', 'BubbleWith3D', 'Radar', 'RadarWithMarkers', 'FilledRadar', 'SeriesOfMixedTypes', 'Treemap', 'Sunburst', 'Histogram', 'ParetoLine', 'BoxAndWhisker', 'Waterfall', 'Funnel', 'Map'])
253
- unless validator.valid?(type)
254
- fail ArgumentError, 'invalid value for "type", must be one of #{validator.allowable_values}.'
255
- end
256
- @type = type
257
- end
258
-
259
- # Custom attribute writer method checking allowed values (enum).
260
- # @param [Object] data_point_type Object to be assigned
261
- def data_point_type=(data_point_type)
262
- validator = EnumAttributeValidator.new('String', ['OneValue', 'Scatter', 'Bubble'])
263
- unless validator.valid?(data_point_type)
264
- fail ArgumentError, 'invalid value for "data_point_type", must be one of #{validator.allowable_values}.'
265
- end
266
- @data_point_type = data_point_type
267
- end
268
-
269
- # Checks equality by comparing each attribute.
270
- # @param [Object] Object to be compared
271
- def ==(o)
272
- return true if self.equal?(o)
273
- self.class == o.class &&
274
- type == o.type &&
275
- name == o.name &&
276
- is_color_varied == o.is_color_varied &&
277
- inverted_solid_fill_color == o.inverted_solid_fill_color &&
278
- smooth == o.smooth &&
279
- plot_on_second_axis == o.plot_on_second_axis &&
280
- order == o.order &&
281
- number_format_of_y_values == o.number_format_of_y_values &&
282
- number_format_of_x_values == o.number_format_of_x_values &&
283
- number_format_of_values == o.number_format_of_values &&
284
- number_format_of_bubble_sizes == o.number_format_of_bubble_sizes &&
285
- invert_if_negative == o.invert_if_negative &&
286
- explosion == o.explosion &&
287
- marker == o.marker &&
288
- fill_format == o.fill_format &&
289
- effect_format == o.effect_format &&
290
- line_format == o.line_format &&
291
- data_point_type == o.data_point_type
292
- end
293
-
294
- # @see the `==` method
295
- # @param [Object] Object to be compared
296
- def eql?(o)
297
- self == o
298
- end
299
-
300
- # Calculates hash code according to all attributes.
301
- # @return [Fixnum] Hash code
302
- def hash
303
- [type, name, is_color_varied, inverted_solid_fill_color, smooth, plot_on_second_axis, order, number_format_of_y_values, number_format_of_x_values, number_format_of_values, number_format_of_bubble_sizes, invert_if_negative, explosion, marker, fill_format, effect_format, line_format, data_point_type].hash
304
- end
305
-
306
- # Builds the object from hash
307
- # @param [Hash] attributes Model attributes in the form of hash
308
- # @return [Object] Returns the model itself
309
- def build_from_hash(attributes)
310
- return nil unless attributes.is_a?(Hash)
311
- self.class.swagger_types.each_pair do |key, type|
312
- mapKey = self.class.attribute_map[key]
313
- if !mapKey.nil?
314
- val = attributes[mapKey]
315
- if val.nil?
316
- mapKeyString = mapKey.to_s
317
- mapKeyString[0] = mapKeyString[0].downcase
318
- mapKey = mapKeyString.to_sym
319
- val = attributes[mapKey]
320
- end
321
- if !val.nil?
322
- if type =~ /\AArray<(.*)>/i
323
- # check to ensure the input is an array given that the the attribute
324
- # is documented as an array but the input is not
325
- if val.is_a?(Array)
326
- self.send("#{key}=", val.map { |v| _deserialize($1, v) })
327
- end
328
- else
329
- self.send("#{key}=", _deserialize(type, val))
330
- end
331
- end
332
- end
333
- end
334
-
335
- self
336
- end
337
-
338
- # Deserializes the data based on type
339
- # @param string type Data type
340
- # @param string value Value to be deserialized
341
- # @return [Object] Deserialized data
342
- def _deserialize(type, value)
343
- case type.to_sym
344
- when :DateTime
345
- DateTime.parse(value)
346
- when :Date
347
- Date.parse(value)
348
- when :String
349
- value.to_s
350
- when :Integer
351
- value.to_i
352
- when :Float
353
- value.to_f
354
- when :BOOLEAN
355
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
356
- true
357
- else
358
- false
359
- end
360
- when :Object
361
- # generic object (usually a Hash), return directly
362
- value
363
- when /\AArray<(?<inner_type>.+)>\z/
364
- inner_type = Regexp.last_match[:inner_type]
365
- value.map { |v| _deserialize(inner_type, v) }
366
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
367
- k_type = Regexp.last_match[:k_type]
368
- v_type = Regexp.last_match[:v_type]
369
- {}.tap do |hash|
370
- value.each do |k, v|
371
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
372
- end
373
- end
374
- else # model
375
- temp_model = AsposeSlidesCloud.const_get(type).new
376
- temp_model.build_from_hash(value)
377
- end
378
- end
379
-
380
- # Returns the string representation of the object
381
- # @return [String] String presentation of the object
382
- def to_s
383
- to_hash.to_s
384
- end
385
-
386
- # to_body is an alias to to_hash (backward compatibility)
387
- # @return [Hash] Returns the object in the form of hash
388
- def to_body
389
- to_hash
390
- end
391
-
392
- # Returns the object in the form of hash
393
- # @return [Hash] Returns the object in the form of hash
394
- def to_hash
395
- hash = {}
396
- self.class.attribute_map.each_pair do |attr, param|
397
- value = self.send(attr)
398
- next if value.nil?
399
- hash[param] = _to_hash(value)
400
- end
401
- hash
402
- end
403
-
404
- # Outputs non-array value in the form of hash
405
- # For object, use to_hash. Otherwise, just return the value
406
- # @param [Object] value Any valid value
407
- # @return [Hash] Returns the value in the form of hash
408
- def _to_hash(value)
409
- if value.is_a?(Array)
410
- value.compact.map { |v| _to_hash(v) }
411
- elsif value.is_a?(Hash)
412
- {}.tap do |hash|
413
- value.each { |k, v| hash[k] = _to_hash(v) }
414
- end
415
- elsif value.respond_to? :to_hash
416
- value.to_hash
417
- else
418
- value
419
- end
420
- end
421
- end
422
- end
1
+ =begin
2
+ Copyright (c) 2019 Aspose Pty Ltd
3
+
4
+ Permission is hereby granted, free of charge, to any person obtaining a copy
5
+ of this software and associated documentation files (the "Software"), to deal
6
+ in the Software without restriction, including without limitation the rights
7
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
8
+ copies of the Software, and to permit persons to whom the Software is
9
+ furnished to do so, subject to the following conditions:
10
+
11
+ The above copyright notice and this permission notice shall be included in all
12
+ copies or substantial portions of the Software.
13
+
14
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
15
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
16
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
17
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
18
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
19
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
20
+ SOFTWARE.
21
+ =end
22
+
23
+ require 'date'
24
+
25
+ module AsposeSlidesCloud
26
+ # A chart series.
27
+ class Series
28
+ # Series type.
29
+ attr_accessor :type
30
+
31
+ # Series name.
32
+ attr_accessor :name
33
+
34
+ # True if each data marker in the series has a different color.
35
+ attr_accessor :is_color_varied
36
+
37
+ # Invert solid color for the series.
38
+ attr_accessor :inverted_solid_fill_color
39
+
40
+ # True if curve smoothing is turned on. Applies only to line and scatter connected by lines charts.
41
+ attr_accessor :smooth
42
+
43
+ # True if the series is plotted on second value axis.
44
+ attr_accessor :plot_on_second_axis
45
+
46
+ # Series order.
47
+ attr_accessor :order
48
+
49
+ # The number format for the series y values.
50
+ attr_accessor :number_format_of_y_values
51
+
52
+ # The number format for the series x values.
53
+ attr_accessor :number_format_of_x_values
54
+
55
+ # The number format for the series values.
56
+ attr_accessor :number_format_of_values
57
+
58
+ # The number format for the series bubble sizes.
59
+ attr_accessor :number_format_of_bubble_sizes
60
+
61
+ # True if the series shall invert its colors if the value is negative. Applies to bar, column and bubble series.
62
+ attr_accessor :invert_if_negative
63
+
64
+ # The distance of an open pie slice from the center of the pie chart is expressed as a percentage of the pie diameter.
65
+ attr_accessor :explosion
66
+
67
+ # Series marker.
68
+ attr_accessor :marker
69
+
70
+ # Fill properties set for the series.
71
+ attr_accessor :fill_format
72
+
73
+ # Effect properties set for the series.
74
+ attr_accessor :effect_format
75
+
76
+ # Line properties set for the series.
77
+ attr_accessor :line_format
78
+
79
+ attr_accessor :data_point_type
80
+
81
+ class EnumAttributeValidator
82
+ attr_reader :datatype
83
+ attr_reader :allowable_values
84
+
85
+ def initialize(datatype, allowable_values)
86
+ @allowable_values = allowable_values.map do |value|
87
+ case datatype.to_s
88
+ when /Integer/i
89
+ value.to_i
90
+ when /Float/i
91
+ value.to_f
92
+ else
93
+ value
94
+ end
95
+ end
96
+ end
97
+
98
+ def valid?(value)
99
+ !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
100
+ end
101
+ end
102
+
103
+ # Attribute mapping from ruby-style variable name to JSON key.
104
+ def self.attribute_map
105
+ {
106
+ :'type' => :'Type',
107
+ :'name' => :'Name',
108
+ :'is_color_varied' => :'IsColorVaried',
109
+ :'inverted_solid_fill_color' => :'InvertedSolidFillColor',
110
+ :'smooth' => :'Smooth',
111
+ :'plot_on_second_axis' => :'PlotOnSecondAxis',
112
+ :'order' => :'Order',
113
+ :'number_format_of_y_values' => :'NumberFormatOfYValues',
114
+ :'number_format_of_x_values' => :'NumberFormatOfXValues',
115
+ :'number_format_of_values' => :'NumberFormatOfValues',
116
+ :'number_format_of_bubble_sizes' => :'NumberFormatOfBubbleSizes',
117
+ :'invert_if_negative' => :'InvertIfNegative',
118
+ :'explosion' => :'Explosion',
119
+ :'marker' => :'Marker',
120
+ :'fill_format' => :'FillFormat',
121
+ :'effect_format' => :'EffectFormat',
122
+ :'line_format' => :'LineFormat',
123
+ :'data_point_type' => :'DataPointType',
124
+ }
125
+ end
126
+
127
+ # Attribute type mapping.
128
+ def self.swagger_types
129
+ {
130
+ :'type' => :'String',
131
+ :'name' => :'String',
132
+ :'is_color_varied' => :'BOOLEAN',
133
+ :'inverted_solid_fill_color' => :'String',
134
+ :'smooth' => :'BOOLEAN',
135
+ :'plot_on_second_axis' => :'BOOLEAN',
136
+ :'order' => :'Integer',
137
+ :'number_format_of_y_values' => :'String',
138
+ :'number_format_of_x_values' => :'String',
139
+ :'number_format_of_values' => :'String',
140
+ :'number_format_of_bubble_sizes' => :'String',
141
+ :'invert_if_negative' => :'BOOLEAN',
142
+ :'explosion' => :'Integer',
143
+ :'marker' => :'SeriesMarker',
144
+ :'fill_format' => :'FillFormat',
145
+ :'effect_format' => :'EffectFormat',
146
+ :'line_format' => :'LineFormat',
147
+ :'data_point_type' => :'String',
148
+ }
149
+ end
150
+
151
+ # Initializes the object
152
+ # @param [Hash] attributes Model attributes in the form of hash
153
+ def initialize(attributes = {})
154
+ return unless attributes.is_a?(Hash)
155
+
156
+ # convert string to symbol for hash key
157
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
158
+
159
+ if attributes.has_key?(:'Type')
160
+ self.type = attributes[:'Type']
161
+ end
162
+
163
+ if attributes.has_key?(:'Name')
164
+ self.name = attributes[:'Name']
165
+ end
166
+
167
+ if attributes.has_key?(:'IsColorVaried')
168
+ self.is_color_varied = attributes[:'IsColorVaried']
169
+ end
170
+
171
+ if attributes.has_key?(:'InvertedSolidFillColor')
172
+ self.inverted_solid_fill_color = attributes[:'InvertedSolidFillColor']
173
+ end
174
+
175
+ if attributes.has_key?(:'Smooth')
176
+ self.smooth = attributes[:'Smooth']
177
+ end
178
+
179
+ if attributes.has_key?(:'PlotOnSecondAxis')
180
+ self.plot_on_second_axis = attributes[:'PlotOnSecondAxis']
181
+ end
182
+
183
+ if attributes.has_key?(:'Order')
184
+ self.order = attributes[:'Order']
185
+ end
186
+
187
+ if attributes.has_key?(:'NumberFormatOfYValues')
188
+ self.number_format_of_y_values = attributes[:'NumberFormatOfYValues']
189
+ end
190
+
191
+ if attributes.has_key?(:'NumberFormatOfXValues')
192
+ self.number_format_of_x_values = attributes[:'NumberFormatOfXValues']
193
+ end
194
+
195
+ if attributes.has_key?(:'NumberFormatOfValues')
196
+ self.number_format_of_values = attributes[:'NumberFormatOfValues']
197
+ end
198
+
199
+ if attributes.has_key?(:'NumberFormatOfBubbleSizes')
200
+ self.number_format_of_bubble_sizes = attributes[:'NumberFormatOfBubbleSizes']
201
+ end
202
+
203
+ if attributes.has_key?(:'InvertIfNegative')
204
+ self.invert_if_negative = attributes[:'InvertIfNegative']
205
+ end
206
+
207
+ if attributes.has_key?(:'Explosion')
208
+ self.explosion = attributes[:'Explosion']
209
+ end
210
+
211
+ if attributes.has_key?(:'Marker')
212
+ self.marker = attributes[:'Marker']
213
+ end
214
+
215
+ if attributes.has_key?(:'FillFormat')
216
+ self.fill_format = attributes[:'FillFormat']
217
+ end
218
+
219
+ if attributes.has_key?(:'EffectFormat')
220
+ self.effect_format = attributes[:'EffectFormat']
221
+ end
222
+
223
+ if attributes.has_key?(:'LineFormat')
224
+ self.line_format = attributes[:'LineFormat']
225
+ end
226
+
227
+ if attributes.has_key?(:'DataPointType')
228
+ self.data_point_type = attributes[:'DataPointType']
229
+ end
230
+ end
231
+
232
+ # Show invalid properties with the reasons. Usually used together with valid?
233
+ # @return Array for valid properties with the reasons
234
+ def list_invalid_properties
235
+ invalid_properties = Array.new
236
+ invalid_properties
237
+ end
238
+
239
+ # Check to see if the all the properties in the model are valid
240
+ # @return true if the model is valid
241
+ def valid?
242
+ type_validator = EnumAttributeValidator.new('String', ['ClusteredColumn', 'StackedColumn', 'PercentsStackedColumn', 'ClusteredColumn3D', 'StackedColumn3D', 'PercentsStackedColumn3D', 'Column3D', 'ClusteredCylinder', 'StackedCylinder', 'PercentsStackedCylinder', 'Cylinder3D', 'ClusteredCone', 'StackedCone', 'PercentsStackedCone', 'Cone3D', 'ClusteredPyramid', 'StackedPyramid', 'PercentsStackedPyramid', 'Pyramid3D', 'Line', 'StackedLine', 'PercentsStackedLine', 'LineWithMarkers', 'StackedLineWithMarkers', 'PercentsStackedLineWithMarkers', 'Line3D', 'Pie', 'Pie3D', 'PieOfPie', 'ExplodedPie', 'ExplodedPie3D', 'BarOfPie', 'PercentsStackedBar', 'ClusteredBar3D', 'ClusteredBar', 'StackedBar', 'StackedBar3D', 'PercentsStackedBar3D', 'ClusteredHorizontalCylinder', 'StackedHorizontalCylinder', 'PercentsStackedHorizontalCylinder', 'ClusteredHorizontalCone', 'StackedHorizontalCone', 'PercentsStackedHorizontalCone', 'ClusteredHorizontalPyramid', 'StackedHorizontalPyramid', 'PercentsStackedHorizontalPyramid', 'Area', 'StackedArea', 'PercentsStackedArea', 'Area3D', 'StackedArea3D', 'PercentsStackedArea3D', 'ScatterWithMarkers', 'ScatterWithSmoothLinesAndMarkers', 'ScatterWithSmoothLines', 'ScatterWithStraightLinesAndMarkers', 'ScatterWithStraightLines', 'HighLowClose', 'OpenHighLowClose', 'VolumeHighLowClose', 'VolumeOpenHighLowClose', 'Surface3D', 'WireframeSurface3D', 'Contour', 'WireframeContour', 'Doughnut', 'ExplodedDoughnut', 'Bubble', 'BubbleWith3D', 'Radar', 'RadarWithMarkers', 'FilledRadar', 'SeriesOfMixedTypes', 'Treemap', 'Sunburst', 'Histogram', 'ParetoLine', 'BoxAndWhisker', 'Waterfall', 'Funnel', 'Map'])
243
+ return false unless type_validator.valid?(@type)
244
+ data_point_type_validator = EnumAttributeValidator.new('String', ['OneValue', 'Scatter', 'Bubble'])
245
+ return false unless data_point_type_validator.valid?(@data_point_type)
246
+ true
247
+ end
248
+
249
+ # Custom attribute writer method checking allowed values (enum).
250
+ # @param [Object] type Object to be assigned
251
+ def type=(type)
252
+ validator = EnumAttributeValidator.new('String', ['ClusteredColumn', 'StackedColumn', 'PercentsStackedColumn', 'ClusteredColumn3D', 'StackedColumn3D', 'PercentsStackedColumn3D', 'Column3D', 'ClusteredCylinder', 'StackedCylinder', 'PercentsStackedCylinder', 'Cylinder3D', 'ClusteredCone', 'StackedCone', 'PercentsStackedCone', 'Cone3D', 'ClusteredPyramid', 'StackedPyramid', 'PercentsStackedPyramid', 'Pyramid3D', 'Line', 'StackedLine', 'PercentsStackedLine', 'LineWithMarkers', 'StackedLineWithMarkers', 'PercentsStackedLineWithMarkers', 'Line3D', 'Pie', 'Pie3D', 'PieOfPie', 'ExplodedPie', 'ExplodedPie3D', 'BarOfPie', 'PercentsStackedBar', 'ClusteredBar3D', 'ClusteredBar', 'StackedBar', 'StackedBar3D', 'PercentsStackedBar3D', 'ClusteredHorizontalCylinder', 'StackedHorizontalCylinder', 'PercentsStackedHorizontalCylinder', 'ClusteredHorizontalCone', 'StackedHorizontalCone', 'PercentsStackedHorizontalCone', 'ClusteredHorizontalPyramid', 'StackedHorizontalPyramid', 'PercentsStackedHorizontalPyramid', 'Area', 'StackedArea', 'PercentsStackedArea', 'Area3D', 'StackedArea3D', 'PercentsStackedArea3D', 'ScatterWithMarkers', 'ScatterWithSmoothLinesAndMarkers', 'ScatterWithSmoothLines', 'ScatterWithStraightLinesAndMarkers', 'ScatterWithStraightLines', 'HighLowClose', 'OpenHighLowClose', 'VolumeHighLowClose', 'VolumeOpenHighLowClose', 'Surface3D', 'WireframeSurface3D', 'Contour', 'WireframeContour', 'Doughnut', 'ExplodedDoughnut', 'Bubble', 'BubbleWith3D', 'Radar', 'RadarWithMarkers', 'FilledRadar', 'SeriesOfMixedTypes', 'Treemap', 'Sunburst', 'Histogram', 'ParetoLine', 'BoxAndWhisker', 'Waterfall', 'Funnel', 'Map'])
253
+ unless validator.valid?(type)
254
+ fail ArgumentError, 'invalid value for "type", must be one of #{validator.allowable_values}.'
255
+ end
256
+ @type = type
257
+ end
258
+
259
+ # Custom attribute writer method checking allowed values (enum).
260
+ # @param [Object] data_point_type Object to be assigned
261
+ def data_point_type=(data_point_type)
262
+ validator = EnumAttributeValidator.new('String', ['OneValue', 'Scatter', 'Bubble'])
263
+ unless validator.valid?(data_point_type)
264
+ fail ArgumentError, 'invalid value for "data_point_type", must be one of #{validator.allowable_values}.'
265
+ end
266
+ @data_point_type = data_point_type
267
+ end
268
+
269
+ # Checks equality by comparing each attribute.
270
+ # @param [Object] Object to be compared
271
+ def ==(o)
272
+ return true if self.equal?(o)
273
+ self.class == o.class &&
274
+ type == o.type &&
275
+ name == o.name &&
276
+ is_color_varied == o.is_color_varied &&
277
+ inverted_solid_fill_color == o.inverted_solid_fill_color &&
278
+ smooth == o.smooth &&
279
+ plot_on_second_axis == o.plot_on_second_axis &&
280
+ order == o.order &&
281
+ number_format_of_y_values == o.number_format_of_y_values &&
282
+ number_format_of_x_values == o.number_format_of_x_values &&
283
+ number_format_of_values == o.number_format_of_values &&
284
+ number_format_of_bubble_sizes == o.number_format_of_bubble_sizes &&
285
+ invert_if_negative == o.invert_if_negative &&
286
+ explosion == o.explosion &&
287
+ marker == o.marker &&
288
+ fill_format == o.fill_format &&
289
+ effect_format == o.effect_format &&
290
+ line_format == o.line_format &&
291
+ data_point_type == o.data_point_type
292
+ end
293
+
294
+ # @see the `==` method
295
+ # @param [Object] Object to be compared
296
+ def eql?(o)
297
+ self == o
298
+ end
299
+
300
+ # Calculates hash code according to all attributes.
301
+ # @return [Fixnum] Hash code
302
+ def hash
303
+ [type, name, is_color_varied, inverted_solid_fill_color, smooth, plot_on_second_axis, order, number_format_of_y_values, number_format_of_x_values, number_format_of_values, number_format_of_bubble_sizes, invert_if_negative, explosion, marker, fill_format, effect_format, line_format, data_point_type].hash
304
+ end
305
+
306
+ # Builds the object from hash
307
+ # @param [Hash] attributes Model attributes in the form of hash
308
+ # @return [Object] Returns the model itself
309
+ def build_from_hash(attributes)
310
+ return nil unless attributes.is_a?(Hash)
311
+ self.class.swagger_types.each_pair do |key, type|
312
+ mapKey = self.class.attribute_map[key]
313
+ if !mapKey.nil?
314
+ val = attributes[mapKey]
315
+ if val.nil?
316
+ mapKeyString = mapKey.to_s
317
+ mapKeyString[0] = mapKeyString[0].downcase
318
+ mapKey = mapKeyString.to_sym
319
+ val = attributes[mapKey]
320
+ end
321
+ if !val.nil?
322
+ if type =~ /\AArray<(.*)>/i
323
+ # check to ensure the input is an array given that the the attribute
324
+ # is documented as an array but the input is not
325
+ if val.is_a?(Array)
326
+ self.send("#{key}=", val.map { |v| _deserialize($1, v) })
327
+ end
328
+ else
329
+ self.send("#{key}=", _deserialize(type, val))
330
+ end
331
+ end
332
+ end
333
+ end
334
+
335
+ self
336
+ end
337
+
338
+ # Deserializes the data based on type
339
+ # @param string type Data type
340
+ # @param string value Value to be deserialized
341
+ # @return [Object] Deserialized data
342
+ def _deserialize(type, value)
343
+ case type.to_sym
344
+ when :DateTime
345
+ DateTime.parse(value)
346
+ when :Date
347
+ Date.parse(value)
348
+ when :String
349
+ value.to_s
350
+ when :Integer
351
+ value.to_i
352
+ when :Float
353
+ value.to_f
354
+ when :BOOLEAN
355
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
356
+ true
357
+ else
358
+ false
359
+ end
360
+ when :Object
361
+ # generic object (usually a Hash), return directly
362
+ value
363
+ when /\AArray<(?<inner_type>.+)>\z/
364
+ inner_type = Regexp.last_match[:inner_type]
365
+ value.map { |v| _deserialize(inner_type, v) }
366
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
367
+ k_type = Regexp.last_match[:k_type]
368
+ v_type = Regexp.last_match[:v_type]
369
+ {}.tap do |hash|
370
+ value.each do |k, v|
371
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
372
+ end
373
+ end
374
+ else # model
375
+ temp_model = AsposeSlidesCloud.const_get(type).new
376
+ temp_model.build_from_hash(value)
377
+ end
378
+ end
379
+
380
+ # Returns the string representation of the object
381
+ # @return [String] String presentation of the object
382
+ def to_s
383
+ to_hash.to_s
384
+ end
385
+
386
+ # to_body is an alias to to_hash (backward compatibility)
387
+ # @return [Hash] Returns the object in the form of hash
388
+ def to_body
389
+ to_hash
390
+ end
391
+
392
+ # Returns the object in the form of hash
393
+ # @return [Hash] Returns the object in the form of hash
394
+ def to_hash
395
+ hash = {}
396
+ self.class.attribute_map.each_pair do |attr, param|
397
+ value = self.send(attr)
398
+ next if value.nil?
399
+ hash[param] = _to_hash(value)
400
+ end
401
+ hash
402
+ end
403
+
404
+ # Outputs non-array value in the form of hash
405
+ # For object, use to_hash. Otherwise, just return the value
406
+ # @param [Object] value Any valid value
407
+ # @return [Hash] Returns the value in the form of hash
408
+ def _to_hash(value)
409
+ if value.is_a?(Array)
410
+ value.compact.map { |v| _to_hash(v) }
411
+ elsif value.is_a?(Hash)
412
+ {}.tap do |hash|
413
+ value.each { |k, v| hash[k] = _to_hash(v) }
414
+ end
415
+ elsif value.respond_to? :to_hash
416
+ value.to_hash
417
+ else
418
+ value
419
+ end
420
+ end
421
+ end
422
+ end