aspose_slides_cloud 20.8.0 → 20.10.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (176) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +61 -61
  3. data/TestData/Sections.pptx +0 -0
  4. data/TestData/TemplatingCVDataWithBase64.xml +22 -22
  5. data/lib/aspose_slides_cloud.rb +212 -209
  6. data/lib/aspose_slides_cloud/api/slides_api.rb +10979 -10105
  7. data/lib/aspose_slides_cloud/api/slides_api_requests.rb +4146 -3900
  8. data/lib/aspose_slides_cloud/api_client.rb +432 -432
  9. data/lib/aspose_slides_cloud/models/add_layout_slide.rb +244 -244
  10. data/lib/aspose_slides_cloud/models/add_master_slide.rb +259 -259
  11. data/lib/aspose_slides_cloud/models/add_shape.rb +239 -239
  12. data/lib/aspose_slides_cloud/models/add_slide.rb +269 -269
  13. data/lib/aspose_slides_cloud/models/api_info.rb +217 -217
  14. data/lib/aspose_slides_cloud/models/arrow_head_properties.rb +285 -285
  15. data/lib/aspose_slides_cloud/models/audio_frame.rb +359 -361
  16. data/lib/aspose_slides_cloud/models/axes.rb +237 -237
  17. data/lib/aspose_slides_cloud/models/axis.rb +699 -699
  18. data/lib/aspose_slides_cloud/models/base64_input_file.rb +230 -230
  19. data/lib/aspose_slides_cloud/models/blur_effect.rb +227 -227
  20. data/lib/aspose_slides_cloud/models/box_and_whisker_series.rb +299 -299
  21. data/lib/aspose_slides_cloud/models/bubble_chart_data_point.rb +212 -212
  22. data/lib/aspose_slides_cloud/models/bubble_series.rb +248 -248
  23. data/lib/aspose_slides_cloud/models/chart.rb +365 -367
  24. data/lib/aspose_slides_cloud/models/chart_category.rb +271 -261
  25. data/lib/aspose_slides_cloud/models/chart_title.rb +222 -222
  26. data/lib/aspose_slides_cloud/models/chart_wall.rb +281 -281
  27. data/lib/aspose_slides_cloud/models/color_scheme.rb +317 -317
  28. data/lib/aspose_slides_cloud/models/common_slide_view_properties.rb +217 -217
  29. data/lib/aspose_slides_cloud/models/connector.rb +275 -276
  30. data/lib/aspose_slides_cloud/models/custom_dash_pattern.rb +209 -209
  31. data/lib/aspose_slides_cloud/models/{resource_uri_element.rb → data_point.rb} +197 -207
  32. data/lib/aspose_slides_cloud/models/disc_usage.rb +227 -227
  33. data/lib/aspose_slides_cloud/models/document.rb +257 -257
  34. data/lib/aspose_slides_cloud/models/document_properties.rb +209 -209
  35. data/lib/aspose_slides_cloud/models/document_property.rb +232 -232
  36. data/lib/aspose_slides_cloud/models/document_replace_result.rb +218 -218
  37. data/lib/aspose_slides_cloud/models/effect.rb +424 -424
  38. data/lib/aspose_slides_cloud/models/effect_format.rb +277 -277
  39. data/lib/aspose_slides_cloud/models/entity_exists.rb +212 -212
  40. data/lib/aspose_slides_cloud/models/error.rb +237 -237
  41. data/lib/aspose_slides_cloud/models/error_details.rb +222 -222
  42. data/lib/aspose_slides_cloud/models/export_format.rb +60 -60
  43. data/lib/aspose_slides_cloud/models/export_options.rb +216 -216
  44. data/lib/aspose_slides_cloud/models/file_version.rb +225 -225
  45. data/lib/aspose_slides_cloud/models/file_versions.rb +209 -209
  46. data/lib/aspose_slides_cloud/models/files_list.rb +209 -209
  47. data/lib/aspose_slides_cloud/models/files_upload_result.rb +221 -221
  48. data/lib/aspose_slides_cloud/models/fill_format.rb +240 -240
  49. data/lib/aspose_slides_cloud/models/fill_overlay_effect.rb +246 -246
  50. data/lib/aspose_slides_cloud/models/font_scheme.rb +227 -227
  51. data/lib/aspose_slides_cloud/models/font_set.rb +227 -227
  52. data/lib/aspose_slides_cloud/models/format_scheme.rb +245 -245
  53. data/lib/aspose_slides_cloud/models/geometry_shape.rb +260 -261
  54. data/lib/aspose_slides_cloud/models/glow_effect.rb +222 -222
  55. data/lib/aspose_slides_cloud/models/gradient_fill.rb +342 -342
  56. data/lib/aspose_slides_cloud/models/gradient_fill_stop.rb +222 -222
  57. data/lib/aspose_slides_cloud/models/graphical_object.rb +234 -236
  58. data/lib/aspose_slides_cloud/models/group_shape.rb +234 -236
  59. data/lib/aspose_slides_cloud/models/header_footer.rb +247 -0
  60. data/lib/aspose_slides_cloud/models/html_export_options.rb +421 -421
  61. data/lib/aspose_slides_cloud/models/i_shape_export_options.rb +197 -207
  62. data/lib/aspose_slides_cloud/models/image.rb +237 -237
  63. data/lib/aspose_slides_cloud/models/image_export_format.rb +43 -43
  64. data/lib/aspose_slides_cloud/models/image_export_options.rb +299 -299
  65. data/lib/aspose_slides_cloud/models/images.rb +209 -209
  66. data/lib/aspose_slides_cloud/models/inner_shadow_effect.rb +252 -252
  67. data/lib/aspose_slides_cloud/models/input.rb +227 -227
  68. data/lib/aspose_slides_cloud/models/input_file.rb +250 -250
  69. data/lib/aspose_slides_cloud/models/interactive_sequence.rb +224 -224
  70. data/lib/aspose_slides_cloud/models/layout_slide.rb +278 -278
  71. data/lib/aspose_slides_cloud/models/layout_slides.rb +209 -209
  72. data/lib/aspose_slides_cloud/models/legend.rb +321 -321
  73. data/lib/aspose_slides_cloud/models/line_format.rb +389 -389
  74. data/lib/aspose_slides_cloud/models/master_slide.rb +231 -231
  75. data/lib/aspose_slides_cloud/models/master_slides.rb +209 -209
  76. data/lib/aspose_slides_cloud/models/merge.rb +231 -231
  77. data/lib/aspose_slides_cloud/models/merging_source.rb +219 -219
  78. data/lib/aspose_slides_cloud/models/no_fill.rb +219 -219
  79. data/lib/aspose_slides_cloud/models/normal_view_restored_properties.rb +217 -217
  80. data/lib/aspose_slides_cloud/models/notes_slide.rb +217 -217
  81. data/lib/aspose_slides_cloud/models/notes_slide_export_format.rb +43 -43
  82. data/lib/aspose_slides_cloud/models/notes_slide_header_footer.rb +267 -0
  83. data/lib/aspose_slides_cloud/models/object_exist.rb +227 -227
  84. data/lib/aspose_slides_cloud/models/ole_object_frame.rb +259 -261
  85. data/lib/aspose_slides_cloud/models/one_value_chart_data_point.rb +210 -210
  86. data/lib/aspose_slides_cloud/models/one_value_series.rb +248 -248
  87. data/lib/aspose_slides_cloud/models/ordered_merge_request.rb +209 -209
  88. data/lib/aspose_slides_cloud/models/outer_shadow_effect.rb +252 -252
  89. data/lib/aspose_slides_cloud/models/output_file.rb +240 -240
  90. data/lib/aspose_slides_cloud/models/paragraph.rb +517 -517
  91. data/lib/aspose_slides_cloud/models/paragraphs.rb +209 -209
  92. data/lib/aspose_slides_cloud/models/path_input_file.rb +240 -240
  93. data/lib/aspose_slides_cloud/models/path_output_file.rb +239 -239
  94. data/lib/aspose_slides_cloud/models/pattern_fill.rb +266 -266
  95. data/lib/aspose_slides_cloud/models/pdf_export_options.rb +547 -547
  96. data/lib/aspose_slides_cloud/models/picture_fill.rb +351 -351
  97. data/lib/aspose_slides_cloud/models/picture_frame.rb +245 -247
  98. data/lib/aspose_slides_cloud/models/pipeline.rb +219 -219
  99. data/lib/aspose_slides_cloud/models/placeholder.rb +325 -325
  100. data/lib/aspose_slides_cloud/models/placeholders.rb +209 -209
  101. data/lib/aspose_slides_cloud/models/plot_area.rb +311 -311
  102. data/lib/aspose_slides_cloud/models/portion.rb +589 -589
  103. data/lib/aspose_slides_cloud/models/portions.rb +209 -209
  104. data/lib/aspose_slides_cloud/models/pptx_export_options.rb +247 -247
  105. data/lib/aspose_slides_cloud/models/presentation_to_merge.rb +229 -229
  106. data/lib/aspose_slides_cloud/models/presentations_merge_request.rb +221 -221
  107. data/lib/aspose_slides_cloud/models/preset_shadow_effect.rb +286 -286
  108. data/lib/aspose_slides_cloud/models/reflection_effect.rb +441 -441
  109. data/lib/aspose_slides_cloud/models/remove_shape.rb +229 -229
  110. data/lib/aspose_slides_cloud/models/remove_slide.rb +234 -234
  111. data/lib/aspose_slides_cloud/models/reorder_slide.rb +249 -249
  112. data/lib/aspose_slides_cloud/models/replace_text.rb +269 -269
  113. data/lib/aspose_slides_cloud/models/request_input_file.rb +235 -235
  114. data/lib/aspose_slides_cloud/models/reset_slide.rb +234 -234
  115. data/lib/aspose_slides_cloud/models/resource_base.rb +219 -219
  116. data/lib/aspose_slides_cloud/models/resource_uri.rb +237 -237
  117. data/lib/aspose_slides_cloud/models/response_output_file.rb +219 -219
  118. data/lib/aspose_slides_cloud/models/save.rb +266 -266
  119. data/lib/aspose_slides_cloud/models/save_shape.rb +276 -276
  120. data/lib/aspose_slides_cloud/models/save_slide.rb +301 -301
  121. data/lib/aspose_slides_cloud/models/scale_type.rb +41 -41
  122. data/lib/aspose_slides_cloud/models/scatter_chart_data_point.rb +225 -225
  123. data/lib/aspose_slides_cloud/models/scatter_series.rb +248 -248
  124. data/lib/aspose_slides_cloud/models/section.rb +234 -0
  125. data/lib/aspose_slides_cloud/models/sections.rb +209 -0
  126. data/lib/aspose_slides_cloud/models/series.rb +422 -422
  127. data/lib/aspose_slides_cloud/models/series_marker.rb +281 -281
  128. data/lib/aspose_slides_cloud/models/shape.rb +255 -256
  129. data/lib/aspose_slides_cloud/models/shape_base.rb +375 -396
  130. data/lib/aspose_slides_cloud/models/shape_export_format.rb +44 -44
  131. data/lib/aspose_slides_cloud/models/shape_image_export_options.rb +286 -286
  132. data/lib/aspose_slides_cloud/models/shape_thumbnail_bounds.rb +41 -41
  133. data/lib/aspose_slides_cloud/models/shapes.rb +209 -209
  134. data/lib/aspose_slides_cloud/models/size_type.rb +55 -55
  135. data/lib/aspose_slides_cloud/models/slide.rb +322 -322
  136. data/lib/aspose_slides_cloud/models/slide_animation.rb +221 -221
  137. data/lib/aspose_slides_cloud/models/slide_background.rb +266 -266
  138. data/lib/aspose_slides_cloud/models/slide_comment.rb +239 -239
  139. data/lib/aspose_slides_cloud/models/slide_comments.rb +209 -209
  140. data/lib/aspose_slides_cloud/models/slide_export_format.rb +59 -59
  141. data/lib/aspose_slides_cloud/models/slide_replace_result.rb +223 -223
  142. data/lib/aspose_slides_cloud/models/slides.rb +209 -209
  143. data/lib/aspose_slides_cloud/models/smart_art.rb +342 -344
  144. data/lib/aspose_slides_cloud/models/smart_art_node.rb +293 -293
  145. data/lib/aspose_slides_cloud/models/smart_art_shape.rb +235 -236
  146. data/lib/aspose_slides_cloud/models/soft_edge_effect.rb +212 -212
  147. data/lib/aspose_slides_cloud/models/solid_fill.rb +229 -229
  148. data/lib/aspose_slides_cloud/models/split_document_result.rb +209 -209
  149. data/lib/aspose_slides_cloud/models/storage_exist.rb +212 -212
  150. data/lib/aspose_slides_cloud/models/storage_file.rb +257 -257
  151. data/lib/aspose_slides_cloud/models/svg_export_options.rb +379 -379
  152. data/lib/aspose_slides_cloud/models/swf_export_options.rb +529 -529
  153. data/lib/aspose_slides_cloud/models/table.rb +350 -352
  154. data/lib/aspose_slides_cloud/models/table_cell.rb +403 -403
  155. data/lib/aspose_slides_cloud/models/table_column.rb +212 -212
  156. data/lib/aspose_slides_cloud/models/table_row.rb +239 -239
  157. data/lib/aspose_slides_cloud/models/task.rb +240 -240
  158. data/lib/aspose_slides_cloud/models/text_item.rb +217 -217
  159. data/lib/aspose_slides_cloud/models/text_items.rb +209 -209
  160. data/lib/aspose_slides_cloud/models/theme.rb +237 -237
  161. data/lib/aspose_slides_cloud/models/tiff_export_options.rb +423 -423
  162. data/lib/aspose_slides_cloud/models/update_background.rb +241 -241
  163. data/lib/aspose_slides_cloud/models/update_shape.rb +239 -239
  164. data/lib/aspose_slides_cloud/models/video_frame.rb +329 -331
  165. data/lib/aspose_slides_cloud/models/view_properties.rb +357 -357
  166. data/lib/aspose_slides_cloud/models/waterfall_chart_data_point.rb +206 -0
  167. data/lib/aspose_slides_cloud/models/waterfall_series.rb +247 -247
  168. data/lib/aspose_slides_cloud/models/xps_export_options.rb +243 -243
  169. data/lib/aspose_slides_cloud/type_registry.rb +320 -313
  170. data/lib/aspose_slides_cloud/version.rb +25 -25
  171. data/spec/api/slides_api_spec.rb +35926 -30710
  172. data/spec/extra/extra_spec.rb +235 -236
  173. data/spec/spec_utils.rb +183 -183
  174. data/testConfig.json +7 -7
  175. data/testRules.json +472 -438
  176. metadata +9 -3
@@ -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
- # Layout slide list.
27
- class LayoutSlides < ResourceBase
28
- # List of layout slide links.
29
- attr_accessor :slide_list
30
-
31
- # Attribute mapping from ruby-style variable name to JSON key.
32
- def self.attribute_map
33
- super.merge({
34
- :'slide_list' => :'SlideList',
35
- })
36
- end
37
-
38
- # Attribute type mapping.
39
- def self.swagger_types
40
- super.merge({
41
- :'slide_list' => :'Array<ResourceUriElement>',
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?(:'SlideList')
51
- if (value = attributes[:'SlideList']).is_a?(Array)
52
- self.slide_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
- slide_list == o.slide_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, slide_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
+ # Layout slide list.
27
+ class LayoutSlides < ResourceBase
28
+ # List of layout slide links.
29
+ attr_accessor :slide_list
30
+
31
+ # Attribute mapping from ruby-style variable name to JSON key.
32
+ def self.attribute_map
33
+ super.merge({
34
+ :'slide_list' => :'SlideList',
35
+ })
36
+ end
37
+
38
+ # Attribute type mapping.
39
+ def self.swagger_types
40
+ super.merge({
41
+ :'slide_list' => :'Array<ResourceUri>',
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?(:'SlideList')
51
+ if (value = attributes[:'SlideList']).is_a?(Array)
52
+ self.slide_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
+ slide_list == o.slide_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, slide_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,321 +1,321 @@
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
- # Represents a chart legend
27
- class Legend
28
- # position
29
- attr_accessor :position
30
-
31
- # the X location
32
- attr_accessor :x
33
-
34
- # the Y location
35
- attr_accessor :y
36
-
37
- # Width
38
- attr_accessor :width
39
-
40
- # Height
41
- attr_accessor :height
42
-
43
- # true if other elements are allowed to overlay the legend
44
- attr_accessor :overlay
45
-
46
- # Get or sets the fill format.
47
- attr_accessor :fill_format
48
-
49
- # Get or sets the effect format.
50
- attr_accessor :effect_format
51
-
52
- # Get or sets the line format.
53
- attr_accessor :line_format
54
-
55
- class EnumAttributeValidator
56
- attr_reader :datatype
57
- attr_reader :allowable_values
58
-
59
- def initialize(datatype, allowable_values)
60
- @allowable_values = allowable_values.map do |value|
61
- case datatype.to_s
62
- when /Integer/i
63
- value.to_i
64
- when /Float/i
65
- value.to_f
66
- else
67
- value
68
- end
69
- end
70
- end
71
-
72
- def valid?(value)
73
- !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
74
- end
75
- end
76
-
77
- # Attribute mapping from ruby-style variable name to JSON key.
78
- def self.attribute_map
79
- {
80
- :'position' => :'Position',
81
- :'x' => :'X',
82
- :'y' => :'Y',
83
- :'width' => :'Width',
84
- :'height' => :'Height',
85
- :'overlay' => :'Overlay',
86
- :'fill_format' => :'FillFormat',
87
- :'effect_format' => :'EffectFormat',
88
- :'line_format' => :'LineFormat',
89
- }
90
- end
91
-
92
- # Attribute type mapping.
93
- def self.swagger_types
94
- {
95
- :'position' => :'String',
96
- :'x' => :'Float',
97
- :'y' => :'Float',
98
- :'width' => :'Float',
99
- :'height' => :'Float',
100
- :'overlay' => :'BOOLEAN',
101
- :'fill_format' => :'FillFormat',
102
- :'effect_format' => :'EffectFormat',
103
- :'line_format' => :'LineFormat',
104
- }
105
- end
106
-
107
- # Initializes the object
108
- # @param [Hash] attributes Model attributes in the form of hash
109
- def initialize(attributes = {})
110
- return unless attributes.is_a?(Hash)
111
-
112
- # convert string to symbol for hash key
113
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
114
-
115
- if attributes.has_key?(:'Position')
116
- self.position = attributes[:'Position']
117
- end
118
-
119
- if attributes.has_key?(:'X')
120
- self.x = attributes[:'X']
121
- end
122
-
123
- if attributes.has_key?(:'Y')
124
- self.y = attributes[:'Y']
125
- end
126
-
127
- if attributes.has_key?(:'Width')
128
- self.width = attributes[:'Width']
129
- end
130
-
131
- if attributes.has_key?(:'Height')
132
- self.height = attributes[:'Height']
133
- end
134
-
135
- if attributes.has_key?(:'Overlay')
136
- self.overlay = attributes[:'Overlay']
137
- end
138
-
139
- if attributes.has_key?(:'FillFormat')
140
- self.fill_format = attributes[:'FillFormat']
141
- end
142
-
143
- if attributes.has_key?(:'EffectFormat')
144
- self.effect_format = attributes[:'EffectFormat']
145
- end
146
-
147
- if attributes.has_key?(:'LineFormat')
148
- self.line_format = attributes[:'LineFormat']
149
- end
150
- end
151
-
152
- # Show invalid properties with the reasons. Usually used together with valid?
153
- # @return Array for valid properties with the reasons
154
- def list_invalid_properties
155
- invalid_properties = Array.new
156
- invalid_properties
157
- end
158
-
159
- # Check to see if the all the properties in the model are valid
160
- # @return true if the model is valid
161
- def valid?
162
- position_validator = EnumAttributeValidator.new('String', ['Bottom', 'Left', 'Right', 'Top', 'TopRight'])
163
- return false unless position_validator.valid?(@position)
164
- true
165
- end
166
-
167
- # Custom attribute writer method checking allowed values (enum).
168
- # @param [Object] position Object to be assigned
169
- def position=(position)
170
- validator = EnumAttributeValidator.new('String', ['Bottom', 'Left', 'Right', 'Top', 'TopRight'])
171
- unless validator.valid?(position)
172
- fail ArgumentError, 'invalid value for "position", must be one of #{validator.allowable_values}.'
173
- end
174
- @position = position
175
- end
176
-
177
- # Checks equality by comparing each attribute.
178
- # @param [Object] Object to be compared
179
- def ==(o)
180
- return true if self.equal?(o)
181
- self.class == o.class &&
182
- position == o.position &&
183
- x == o.x &&
184
- y == o.y &&
185
- width == o.width &&
186
- height == o.height &&
187
- overlay == o.overlay &&
188
- fill_format == o.fill_format &&
189
- effect_format == o.effect_format &&
190
- line_format == o.line_format
191
- end
192
-
193
- # @see the `==` method
194
- # @param [Object] Object to be compared
195
- def eql?(o)
196
- self == o
197
- end
198
-
199
- # Calculates hash code according to all attributes.
200
- # @return [Fixnum] Hash code
201
- def hash
202
- [position, x, y, width, height, overlay, fill_format, effect_format, line_format].hash
203
- end
204
-
205
- # Builds the object from hash
206
- # @param [Hash] attributes Model attributes in the form of hash
207
- # @return [Object] Returns the model itself
208
- def build_from_hash(attributes)
209
- return nil unless attributes.is_a?(Hash)
210
- self.class.swagger_types.each_pair do |key, type|
211
- mapKey = self.class.attribute_map[key]
212
- if !mapKey.nil?
213
- val = attributes[mapKey]
214
- if val.nil?
215
- mapKeyString = mapKey.to_s
216
- mapKeyString[0] = mapKeyString[0].downcase
217
- mapKey = mapKeyString.to_sym
218
- val = attributes[mapKey]
219
- end
220
- if !val.nil?
221
- if type =~ /\AArray<(.*)>/i
222
- # check to ensure the input is an array given that the the attribute
223
- # is documented as an array but the input is not
224
- if val.is_a?(Array)
225
- self.send("#{key}=", val.map { |v| _deserialize($1, v) })
226
- end
227
- else
228
- self.send("#{key}=", _deserialize(type, val))
229
- end
230
- end
231
- end
232
- end
233
-
234
- self
235
- end
236
-
237
- # Deserializes the data based on type
238
- # @param string type Data type
239
- # @param string value Value to be deserialized
240
- # @return [Object] Deserialized data
241
- def _deserialize(type, value)
242
- case type.to_sym
243
- when :DateTime
244
- DateTime.parse(value)
245
- when :Date
246
- Date.parse(value)
247
- when :String
248
- value.to_s
249
- when :Integer
250
- value.to_i
251
- when :Float
252
- value.to_f
253
- when :BOOLEAN
254
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
255
- true
256
- else
257
- false
258
- end
259
- when :Object
260
- # generic object (usually a Hash), return directly
261
- value
262
- when /\AArray<(?<inner_type>.+)>\z/
263
- inner_type = Regexp.last_match[:inner_type]
264
- value.map { |v| _deserialize(inner_type, v) }
265
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
266
- k_type = Regexp.last_match[:k_type]
267
- v_type = Regexp.last_match[:v_type]
268
- {}.tap do |hash|
269
- value.each do |k, v|
270
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
271
- end
272
- end
273
- else # model
274
- temp_model = AsposeSlidesCloud.const_get(type).new
275
- temp_model.build_from_hash(value)
276
- end
277
- end
278
-
279
- # Returns the string representation of the object
280
- # @return [String] String presentation of the object
281
- def to_s
282
- to_hash.to_s
283
- end
284
-
285
- # to_body is an alias to to_hash (backward compatibility)
286
- # @return [Hash] Returns the object in the form of hash
287
- def to_body
288
- to_hash
289
- end
290
-
291
- # Returns the object in the form of hash
292
- # @return [Hash] Returns the object in the form of hash
293
- def to_hash
294
- hash = {}
295
- self.class.attribute_map.each_pair do |attr, param|
296
- value = self.send(attr)
297
- next if value.nil?
298
- hash[param] = _to_hash(value)
299
- end
300
- hash
301
- end
302
-
303
- # Outputs non-array value in the form of hash
304
- # For object, use to_hash. Otherwise, just return the value
305
- # @param [Object] value Any valid value
306
- # @return [Hash] Returns the value in the form of hash
307
- def _to_hash(value)
308
- if value.is_a?(Array)
309
- value.compact.map { |v| _to_hash(v) }
310
- elsif value.is_a?(Hash)
311
- {}.tap do |hash|
312
- value.each { |k, v| hash[k] = _to_hash(v) }
313
- end
314
- elsif value.respond_to? :to_hash
315
- value.to_hash
316
- else
317
- value
318
- end
319
- end
320
- end
321
- 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
+ # Represents a chart legend
27
+ class Legend
28
+ # position
29
+ attr_accessor :position
30
+
31
+ # the X location
32
+ attr_accessor :x
33
+
34
+ # the Y location
35
+ attr_accessor :y
36
+
37
+ # Width
38
+ attr_accessor :width
39
+
40
+ # Height
41
+ attr_accessor :height
42
+
43
+ # true if other elements are allowed to overlay the legend
44
+ attr_accessor :overlay
45
+
46
+ # Get or sets the fill format.
47
+ attr_accessor :fill_format
48
+
49
+ # Get or sets the effect format.
50
+ attr_accessor :effect_format
51
+
52
+ # Get or sets the line format.
53
+ attr_accessor :line_format
54
+
55
+ class EnumAttributeValidator
56
+ attr_reader :datatype
57
+ attr_reader :allowable_values
58
+
59
+ def initialize(datatype, allowable_values)
60
+ @allowable_values = allowable_values.map do |value|
61
+ case datatype.to_s
62
+ when /Integer/i
63
+ value.to_i
64
+ when /Float/i
65
+ value.to_f
66
+ else
67
+ value
68
+ end
69
+ end
70
+ end
71
+
72
+ def valid?(value)
73
+ !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
74
+ end
75
+ end
76
+
77
+ # Attribute mapping from ruby-style variable name to JSON key.
78
+ def self.attribute_map
79
+ {
80
+ :'position' => :'Position',
81
+ :'x' => :'X',
82
+ :'y' => :'Y',
83
+ :'width' => :'Width',
84
+ :'height' => :'Height',
85
+ :'overlay' => :'Overlay',
86
+ :'fill_format' => :'FillFormat',
87
+ :'effect_format' => :'EffectFormat',
88
+ :'line_format' => :'LineFormat',
89
+ }
90
+ end
91
+
92
+ # Attribute type mapping.
93
+ def self.swagger_types
94
+ {
95
+ :'position' => :'String',
96
+ :'x' => :'Float',
97
+ :'y' => :'Float',
98
+ :'width' => :'Float',
99
+ :'height' => :'Float',
100
+ :'overlay' => :'BOOLEAN',
101
+ :'fill_format' => :'FillFormat',
102
+ :'effect_format' => :'EffectFormat',
103
+ :'line_format' => :'LineFormat',
104
+ }
105
+ end
106
+
107
+ # Initializes the object
108
+ # @param [Hash] attributes Model attributes in the form of hash
109
+ def initialize(attributes = {})
110
+ return unless attributes.is_a?(Hash)
111
+
112
+ # convert string to symbol for hash key
113
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
114
+
115
+ if attributes.has_key?(:'Position')
116
+ self.position = attributes[:'Position']
117
+ end
118
+
119
+ if attributes.has_key?(:'X')
120
+ self.x = attributes[:'X']
121
+ end
122
+
123
+ if attributes.has_key?(:'Y')
124
+ self.y = attributes[:'Y']
125
+ end
126
+
127
+ if attributes.has_key?(:'Width')
128
+ self.width = attributes[:'Width']
129
+ end
130
+
131
+ if attributes.has_key?(:'Height')
132
+ self.height = attributes[:'Height']
133
+ end
134
+
135
+ if attributes.has_key?(:'Overlay')
136
+ self.overlay = attributes[:'Overlay']
137
+ end
138
+
139
+ if attributes.has_key?(:'FillFormat')
140
+ self.fill_format = attributes[:'FillFormat']
141
+ end
142
+
143
+ if attributes.has_key?(:'EffectFormat')
144
+ self.effect_format = attributes[:'EffectFormat']
145
+ end
146
+
147
+ if attributes.has_key?(:'LineFormat')
148
+ self.line_format = attributes[:'LineFormat']
149
+ end
150
+ end
151
+
152
+ # Show invalid properties with the reasons. Usually used together with valid?
153
+ # @return Array for valid properties with the reasons
154
+ def list_invalid_properties
155
+ invalid_properties = Array.new
156
+ invalid_properties
157
+ end
158
+
159
+ # Check to see if the all the properties in the model are valid
160
+ # @return true if the model is valid
161
+ def valid?
162
+ position_validator = EnumAttributeValidator.new('String', ['Bottom', 'Left', 'Right', 'Top', 'TopRight'])
163
+ return false unless position_validator.valid?(@position)
164
+ true
165
+ end
166
+
167
+ # Custom attribute writer method checking allowed values (enum).
168
+ # @param [Object] position Object to be assigned
169
+ def position=(position)
170
+ validator = EnumAttributeValidator.new('String', ['Bottom', 'Left', 'Right', 'Top', 'TopRight'])
171
+ unless validator.valid?(position)
172
+ fail ArgumentError, 'invalid value for "position", must be one of #{validator.allowable_values}.'
173
+ end
174
+ @position = position
175
+ end
176
+
177
+ # Checks equality by comparing each attribute.
178
+ # @param [Object] Object to be compared
179
+ def ==(o)
180
+ return true if self.equal?(o)
181
+ self.class == o.class &&
182
+ position == o.position &&
183
+ x == o.x &&
184
+ y == o.y &&
185
+ width == o.width &&
186
+ height == o.height &&
187
+ overlay == o.overlay &&
188
+ fill_format == o.fill_format &&
189
+ effect_format == o.effect_format &&
190
+ line_format == o.line_format
191
+ end
192
+
193
+ # @see the `==` method
194
+ # @param [Object] Object to be compared
195
+ def eql?(o)
196
+ self == o
197
+ end
198
+
199
+ # Calculates hash code according to all attributes.
200
+ # @return [Fixnum] Hash code
201
+ def hash
202
+ [position, x, y, width, height, overlay, fill_format, effect_format, line_format].hash
203
+ end
204
+
205
+ # Builds the object from hash
206
+ # @param [Hash] attributes Model attributes in the form of hash
207
+ # @return [Object] Returns the model itself
208
+ def build_from_hash(attributes)
209
+ return nil unless attributes.is_a?(Hash)
210
+ self.class.swagger_types.each_pair do |key, type|
211
+ mapKey = self.class.attribute_map[key]
212
+ if !mapKey.nil?
213
+ val = attributes[mapKey]
214
+ if val.nil?
215
+ mapKeyString = mapKey.to_s
216
+ mapKeyString[0] = mapKeyString[0].downcase
217
+ mapKey = mapKeyString.to_sym
218
+ val = attributes[mapKey]
219
+ end
220
+ if !val.nil?
221
+ if type =~ /\AArray<(.*)>/i
222
+ # check to ensure the input is an array given that the the attribute
223
+ # is documented as an array but the input is not
224
+ if val.is_a?(Array)
225
+ self.send("#{key}=", val.map { |v| _deserialize($1, v) })
226
+ end
227
+ else
228
+ self.send("#{key}=", _deserialize(type, val))
229
+ end
230
+ end
231
+ end
232
+ end
233
+
234
+ self
235
+ end
236
+
237
+ # Deserializes the data based on type
238
+ # @param string type Data type
239
+ # @param string value Value to be deserialized
240
+ # @return [Object] Deserialized data
241
+ def _deserialize(type, value)
242
+ case type.to_sym
243
+ when :DateTime
244
+ DateTime.parse(value)
245
+ when :Date
246
+ Date.parse(value)
247
+ when :String
248
+ value.to_s
249
+ when :Integer
250
+ value.to_i
251
+ when :Float
252
+ value.to_f
253
+ when :BOOLEAN
254
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
255
+ true
256
+ else
257
+ false
258
+ end
259
+ when :Object
260
+ # generic object (usually a Hash), return directly
261
+ value
262
+ when /\AArray<(?<inner_type>.+)>\z/
263
+ inner_type = Regexp.last_match[:inner_type]
264
+ value.map { |v| _deserialize(inner_type, v) }
265
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
266
+ k_type = Regexp.last_match[:k_type]
267
+ v_type = Regexp.last_match[:v_type]
268
+ {}.tap do |hash|
269
+ value.each do |k, v|
270
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
271
+ end
272
+ end
273
+ else # model
274
+ temp_model = AsposeSlidesCloud.const_get(type).new
275
+ temp_model.build_from_hash(value)
276
+ end
277
+ end
278
+
279
+ # Returns the string representation of the object
280
+ # @return [String] String presentation of the object
281
+ def to_s
282
+ to_hash.to_s
283
+ end
284
+
285
+ # to_body is an alias to to_hash (backward compatibility)
286
+ # @return [Hash] Returns the object in the form of hash
287
+ def to_body
288
+ to_hash
289
+ end
290
+
291
+ # Returns the object in the form of hash
292
+ # @return [Hash] Returns the object in the form of hash
293
+ def to_hash
294
+ hash = {}
295
+ self.class.attribute_map.each_pair do |attr, param|
296
+ value = self.send(attr)
297
+ next if value.nil?
298
+ hash[param] = _to_hash(value)
299
+ end
300
+ hash
301
+ end
302
+
303
+ # Outputs non-array value in the form of hash
304
+ # For object, use to_hash. Otherwise, just return the value
305
+ # @param [Object] value Any valid value
306
+ # @return [Hash] Returns the value in the form of hash
307
+ def _to_hash(value)
308
+ if value.is_a?(Array)
309
+ value.compact.map { |v| _to_hash(v) }
310
+ elsif value.is_a?(Hash)
311
+ {}.tap do |hash|
312
+ value.each { |k, v| hash[k] = _to_hash(v) }
313
+ end
314
+ elsif value.respond_to? :to_hash
315
+ value.to_hash
316
+ else
317
+ value
318
+ end
319
+ end
320
+ end
321
+ end