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,224 +1,224 @@
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 comments collection of slide
27
- class InteractiveSequence
28
- # Effect list.
29
- attr_accessor :effects
30
-
31
- # Index of the shape that triggers the sequence.
32
- attr_accessor :trigger_shape_index
33
-
34
- # Attribute mapping from ruby-style variable name to JSON key.
35
- def self.attribute_map
36
- {
37
- :'effects' => :'Effects',
38
- :'trigger_shape_index' => :'TriggerShapeIndex',
39
- }
40
- end
41
-
42
- # Attribute type mapping.
43
- def self.swagger_types
44
- {
45
- :'effects' => :'Array<Effect>',
46
- :'trigger_shape_index' => :'Integer',
47
- }
48
- end
49
-
50
- # Initializes the object
51
- # @param [Hash] attributes Model attributes in the form of hash
52
- def initialize(attributes = {})
53
- return unless attributes.is_a?(Hash)
54
-
55
- # convert string to symbol for hash key
56
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
57
-
58
- if attributes.has_key?(:'Effects')
59
- if (value = attributes[:'Effects']).is_a?(Array)
60
- self.effects = value
61
- end
62
- end
63
-
64
- if attributes.has_key?(:'TriggerShapeIndex')
65
- self.trigger_shape_index = attributes[:'TriggerShapeIndex']
66
- end
67
- end
68
-
69
- # Show invalid properties with the reasons. Usually used together with valid?
70
- # @return Array for valid properties with the reasons
71
- def list_invalid_properties
72
- invalid_properties = Array.new
73
- if @trigger_shape_index.nil?
74
- invalid_properties.push('invalid value for "trigger_shape_index", trigger_shape_index cannot be nil.')
75
- end
76
-
77
- invalid_properties
78
- end
79
-
80
- # Check to see if the all the properties in the model are valid
81
- # @return true if the model is valid
82
- def valid?
83
- return false if @trigger_shape_index.nil?
84
- true
85
- end
86
-
87
- # Checks equality by comparing each attribute.
88
- # @param [Object] Object to be compared
89
- def ==(o)
90
- return true if self.equal?(o)
91
- self.class == o.class &&
92
- effects == o.effects &&
93
- trigger_shape_index == o.trigger_shape_index
94
- end
95
-
96
- # @see the `==` method
97
- # @param [Object] Object to be compared
98
- def eql?(o)
99
- self == o
100
- end
101
-
102
- # Calculates hash code according to all attributes.
103
- # @return [Fixnum] Hash code
104
- def hash
105
- [effects, trigger_shape_index].hash
106
- end
107
-
108
- # Builds the object from hash
109
- # @param [Hash] attributes Model attributes in the form of hash
110
- # @return [Object] Returns the model itself
111
- def build_from_hash(attributes)
112
- return nil unless attributes.is_a?(Hash)
113
- self.class.swagger_types.each_pair do |key, type|
114
- mapKey = self.class.attribute_map[key]
115
- if !mapKey.nil?
116
- val = attributes[mapKey]
117
- if val.nil?
118
- mapKeyString = mapKey.to_s
119
- mapKeyString[0] = mapKeyString[0].downcase
120
- mapKey = mapKeyString.to_sym
121
- val = attributes[mapKey]
122
- end
123
- if !val.nil?
124
- if type =~ /\AArray<(.*)>/i
125
- # check to ensure the input is an array given that the the attribute
126
- # is documented as an array but the input is not
127
- if val.is_a?(Array)
128
- self.send("#{key}=", val.map { |v| _deserialize($1, v) })
129
- end
130
- else
131
- self.send("#{key}=", _deserialize(type, val))
132
- end
133
- end
134
- end
135
- end
136
-
137
- self
138
- end
139
-
140
- # Deserializes the data based on type
141
- # @param string type Data type
142
- # @param string value Value to be deserialized
143
- # @return [Object] Deserialized data
144
- def _deserialize(type, value)
145
- case type.to_sym
146
- when :DateTime
147
- DateTime.parse(value)
148
- when :Date
149
- Date.parse(value)
150
- when :String
151
- value.to_s
152
- when :Integer
153
- value.to_i
154
- when :Float
155
- value.to_f
156
- when :BOOLEAN
157
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
158
- true
159
- else
160
- false
161
- end
162
- when :Object
163
- # generic object (usually a Hash), return directly
164
- value
165
- when /\AArray<(?<inner_type>.+)>\z/
166
- inner_type = Regexp.last_match[:inner_type]
167
- value.map { |v| _deserialize(inner_type, v) }
168
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
169
- k_type = Regexp.last_match[:k_type]
170
- v_type = Regexp.last_match[:v_type]
171
- {}.tap do |hash|
172
- value.each do |k, v|
173
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
174
- end
175
- end
176
- else # model
177
- temp_model = AsposeSlidesCloud.const_get(type).new
178
- temp_model.build_from_hash(value)
179
- end
180
- end
181
-
182
- # Returns the string representation of the object
183
- # @return [String] String presentation of the object
184
- def to_s
185
- to_hash.to_s
186
- end
187
-
188
- # to_body is an alias to to_hash (backward compatibility)
189
- # @return [Hash] Returns the object in the form of hash
190
- def to_body
191
- to_hash
192
- end
193
-
194
- # Returns the object in the form of hash
195
- # @return [Hash] Returns the object in the form of hash
196
- def to_hash
197
- hash = {}
198
- self.class.attribute_map.each_pair do |attr, param|
199
- value = self.send(attr)
200
- next if value.nil?
201
- hash[param] = _to_hash(value)
202
- end
203
- hash
204
- end
205
-
206
- # Outputs non-array value in the form of hash
207
- # For object, use to_hash. Otherwise, just return the value
208
- # @param [Object] value Any valid value
209
- # @return [Hash] Returns the value in the form of hash
210
- def _to_hash(value)
211
- if value.is_a?(Array)
212
- value.compact.map { |v| _to_hash(v) }
213
- elsif value.is_a?(Hash)
214
- {}.tap do |hash|
215
- value.each { |k, v| hash[k] = _to_hash(v) }
216
- end
217
- elsif value.respond_to? :to_hash
218
- value.to_hash
219
- else
220
- value
221
- end
222
- end
223
- end
224
- 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 comments collection of slide
27
+ class InteractiveSequence
28
+ # Effect list.
29
+ attr_accessor :effects
30
+
31
+ # Index of the shape that triggers the sequence.
32
+ attr_accessor :trigger_shape_index
33
+
34
+ # Attribute mapping from ruby-style variable name to JSON key.
35
+ def self.attribute_map
36
+ {
37
+ :'effects' => :'Effects',
38
+ :'trigger_shape_index' => :'TriggerShapeIndex',
39
+ }
40
+ end
41
+
42
+ # Attribute type mapping.
43
+ def self.swagger_types
44
+ {
45
+ :'effects' => :'Array<Effect>',
46
+ :'trigger_shape_index' => :'Integer',
47
+ }
48
+ end
49
+
50
+ # Initializes the object
51
+ # @param [Hash] attributes Model attributes in the form of hash
52
+ def initialize(attributes = {})
53
+ return unless attributes.is_a?(Hash)
54
+
55
+ # convert string to symbol for hash key
56
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
57
+
58
+ if attributes.has_key?(:'Effects')
59
+ if (value = attributes[:'Effects']).is_a?(Array)
60
+ self.effects = value
61
+ end
62
+ end
63
+
64
+ if attributes.has_key?(:'TriggerShapeIndex')
65
+ self.trigger_shape_index = attributes[:'TriggerShapeIndex']
66
+ end
67
+ end
68
+
69
+ # Show invalid properties with the reasons. Usually used together with valid?
70
+ # @return Array for valid properties with the reasons
71
+ def list_invalid_properties
72
+ invalid_properties = Array.new
73
+ if @trigger_shape_index.nil?
74
+ invalid_properties.push('invalid value for "trigger_shape_index", trigger_shape_index cannot be nil.')
75
+ end
76
+
77
+ invalid_properties
78
+ end
79
+
80
+ # Check to see if the all the properties in the model are valid
81
+ # @return true if the model is valid
82
+ def valid?
83
+ return false if @trigger_shape_index.nil?
84
+ true
85
+ end
86
+
87
+ # Checks equality by comparing each attribute.
88
+ # @param [Object] Object to be compared
89
+ def ==(o)
90
+ return true if self.equal?(o)
91
+ self.class == o.class &&
92
+ effects == o.effects &&
93
+ trigger_shape_index == o.trigger_shape_index
94
+ end
95
+
96
+ # @see the `==` method
97
+ # @param [Object] Object to be compared
98
+ def eql?(o)
99
+ self == o
100
+ end
101
+
102
+ # Calculates hash code according to all attributes.
103
+ # @return [Fixnum] Hash code
104
+ def hash
105
+ [effects, trigger_shape_index].hash
106
+ end
107
+
108
+ # Builds the object from hash
109
+ # @param [Hash] attributes Model attributes in the form of hash
110
+ # @return [Object] Returns the model itself
111
+ def build_from_hash(attributes)
112
+ return nil unless attributes.is_a?(Hash)
113
+ self.class.swagger_types.each_pair do |key, type|
114
+ mapKey = self.class.attribute_map[key]
115
+ if !mapKey.nil?
116
+ val = attributes[mapKey]
117
+ if val.nil?
118
+ mapKeyString = mapKey.to_s
119
+ mapKeyString[0] = mapKeyString[0].downcase
120
+ mapKey = mapKeyString.to_sym
121
+ val = attributes[mapKey]
122
+ end
123
+ if !val.nil?
124
+ if type =~ /\AArray<(.*)>/i
125
+ # check to ensure the input is an array given that the the attribute
126
+ # is documented as an array but the input is not
127
+ if val.is_a?(Array)
128
+ self.send("#{key}=", val.map { |v| _deserialize($1, v) })
129
+ end
130
+ else
131
+ self.send("#{key}=", _deserialize(type, val))
132
+ end
133
+ end
134
+ end
135
+ end
136
+
137
+ self
138
+ end
139
+
140
+ # Deserializes the data based on type
141
+ # @param string type Data type
142
+ # @param string value Value to be deserialized
143
+ # @return [Object] Deserialized data
144
+ def _deserialize(type, value)
145
+ case type.to_sym
146
+ when :DateTime
147
+ DateTime.parse(value)
148
+ when :Date
149
+ Date.parse(value)
150
+ when :String
151
+ value.to_s
152
+ when :Integer
153
+ value.to_i
154
+ when :Float
155
+ value.to_f
156
+ when :BOOLEAN
157
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
158
+ true
159
+ else
160
+ false
161
+ end
162
+ when :Object
163
+ # generic object (usually a Hash), return directly
164
+ value
165
+ when /\AArray<(?<inner_type>.+)>\z/
166
+ inner_type = Regexp.last_match[:inner_type]
167
+ value.map { |v| _deserialize(inner_type, v) }
168
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
169
+ k_type = Regexp.last_match[:k_type]
170
+ v_type = Regexp.last_match[:v_type]
171
+ {}.tap do |hash|
172
+ value.each do |k, v|
173
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
174
+ end
175
+ end
176
+ else # model
177
+ temp_model = AsposeSlidesCloud.const_get(type).new
178
+ temp_model.build_from_hash(value)
179
+ end
180
+ end
181
+
182
+ # Returns the string representation of the object
183
+ # @return [String] String presentation of the object
184
+ def to_s
185
+ to_hash.to_s
186
+ end
187
+
188
+ # to_body is an alias to to_hash (backward compatibility)
189
+ # @return [Hash] Returns the object in the form of hash
190
+ def to_body
191
+ to_hash
192
+ end
193
+
194
+ # Returns the object in the form of hash
195
+ # @return [Hash] Returns the object in the form of hash
196
+ def to_hash
197
+ hash = {}
198
+ self.class.attribute_map.each_pair do |attr, param|
199
+ value = self.send(attr)
200
+ next if value.nil?
201
+ hash[param] = _to_hash(value)
202
+ end
203
+ hash
204
+ end
205
+
206
+ # Outputs non-array value in the form of hash
207
+ # For object, use to_hash. Otherwise, just return the value
208
+ # @param [Object] value Any valid value
209
+ # @return [Hash] Returns the value in the form of hash
210
+ def _to_hash(value)
211
+ if value.is_a?(Array)
212
+ value.compact.map { |v| _to_hash(v) }
213
+ elsif value.is_a?(Hash)
214
+ {}.tap do |hash|
215
+ value.each { |k, v| hash[k] = _to_hash(v) }
216
+ end
217
+ elsif value.respond_to? :to_hash
218
+ value.to_hash
219
+ else
220
+ value
221
+ end
222
+ end
223
+ end
224
+ end
@@ -1,278 +1,278 @@
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.
27
- class LayoutSlide < ResourceBase
28
- # Name.
29
- attr_accessor :name
30
-
31
- # Layout slide type.
32
- attr_accessor :type
33
-
34
- # Master slide link.
35
- attr_accessor :master_slide
36
-
37
- # List of depending slides.
38
- attr_accessor :depending_slides
39
-
40
- class EnumAttributeValidator
41
- attr_reader :datatype
42
- attr_reader :allowable_values
43
-
44
- def initialize(datatype, allowable_values)
45
- @allowable_values = allowable_values.map do |value|
46
- case datatype.to_s
47
- when /Integer/i
48
- value.to_i
49
- when /Float/i
50
- value.to_f
51
- else
52
- value
53
- end
54
- end
55
- end
56
-
57
- def valid?(value)
58
- !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
59
- end
60
- end
61
-
62
- # Attribute mapping from ruby-style variable name to JSON key.
63
- def self.attribute_map
64
- super.merge({
65
- :'name' => :'Name',
66
- :'type' => :'Type',
67
- :'master_slide' => :'MasterSlide',
68
- :'depending_slides' => :'DependingSlides',
69
- })
70
- end
71
-
72
- # Attribute type mapping.
73
- def self.swagger_types
74
- super.merge({
75
- :'name' => :'String',
76
- :'type' => :'String',
77
- :'master_slide' => :'ResourceUri',
78
- :'depending_slides' => :'Array<ResourceUri>',
79
- })
80
- end
81
-
82
- # Initializes the object
83
- # @param [Hash] attributes Model attributes in the form of hash
84
- def initialize(attributes = {})
85
- super
86
-
87
- if attributes.has_key?(:'Name')
88
- self.name = attributes[:'Name']
89
- end
90
-
91
- if attributes.has_key?(:'Type')
92
- self.type = attributes[:'Type']
93
- end
94
-
95
- if attributes.has_key?(:'MasterSlide')
96
- self.master_slide = attributes[:'MasterSlide']
97
- end
98
-
99
- if attributes.has_key?(:'DependingSlides')
100
- if (value = attributes[:'DependingSlides']).is_a?(Array)
101
- self.depending_slides = value
102
- end
103
- end
104
- end
105
-
106
- # Show invalid properties with the reasons. Usually used together with valid?
107
- # @return Array for valid properties with the reasons
108
- def list_invalid_properties
109
- invalid_properties = super
110
- if @type.nil?
111
- invalid_properties.push('invalid value for "type", type cannot be nil.')
112
- end
113
-
114
- invalid_properties
115
- end
116
-
117
- # Check to see if the all the properties in the model are valid
118
- # @return true if the model is valid
119
- def valid?
120
- return false if !super
121
- return false if @type.nil?
122
- type_validator = EnumAttributeValidator.new('String', ['Title', 'Text', 'TwoColumnText', 'Table', 'TextAndChart', 'ChartAndText', 'Diagram', 'Chart', 'TextAndClipArt', 'ClipArtAndText', 'TitleOnly', 'Blank', 'TextAndObject', 'ObjectAndText', 'Object', 'TitleAndObject', 'TextAndMedia', 'MediaAndText', 'ObjectOverText', 'TextOverObject', 'TextAndTwoObjects', 'TwoObjectsAndText', 'TwoObjectsOverText', 'FourObjects', 'VerticalText', 'ClipArtAndVerticalText', 'VerticalTitleAndText', 'VerticalTitleAndTextOverChart', 'TwoObjects', 'ObjectAndTwoObject', 'TwoObjectsAndObject', 'SectionHeader', 'TwoTextAndTwoObjects', 'TitleObjectAndCaption', 'PictureAndCaption', 'Custom'])
123
- return false unless type_validator.valid?(@type)
124
- true
125
- end
126
-
127
- # Custom attribute writer method checking allowed values (enum).
128
- # @param [Object] type Object to be assigned
129
- def type=(type)
130
- validator = EnumAttributeValidator.new('String', ['Title', 'Text', 'TwoColumnText', 'Table', 'TextAndChart', 'ChartAndText', 'Diagram', 'Chart', 'TextAndClipArt', 'ClipArtAndText', 'TitleOnly', 'Blank', 'TextAndObject', 'ObjectAndText', 'Object', 'TitleAndObject', 'TextAndMedia', 'MediaAndText', 'ObjectOverText', 'TextOverObject', 'TextAndTwoObjects', 'TwoObjectsAndText', 'TwoObjectsOverText', 'FourObjects', 'VerticalText', 'ClipArtAndVerticalText', 'VerticalTitleAndText', 'VerticalTitleAndTextOverChart', 'TwoObjects', 'ObjectAndTwoObject', 'TwoObjectsAndObject', 'SectionHeader', 'TwoTextAndTwoObjects', 'TitleObjectAndCaption', 'PictureAndCaption', 'Custom'])
131
- unless validator.valid?(type)
132
- fail ArgumentError, 'invalid value for "type", must be one of #{validator.allowable_values}.'
133
- end
134
- @type = type
135
- end
136
-
137
- # Checks equality by comparing each attribute.
138
- # @param [Object] Object to be compared
139
- def ==(o)
140
- return true if self.equal?(o)
141
- self.class == o.class &&
142
- self_uri == o.self_uri &&
143
- alternate_links == o.alternate_links &&
144
- name == o.name &&
145
- type == o.type &&
146
- master_slide == o.master_slide &&
147
- depending_slides == o.depending_slides
148
- end
149
-
150
- # @see the `==` method
151
- # @param [Object] Object to be compared
152
- def eql?(o)
153
- self == o
154
- end
155
-
156
- # Calculates hash code according to all attributes.
157
- # @return [Fixnum] Hash code
158
- def hash
159
- [self_uri, alternate_links, name, type, master_slide, depending_slides].hash
160
- end
161
-
162
- # Builds the object from hash
163
- # @param [Hash] attributes Model attributes in the form of hash
164
- # @return [Object] Returns the model itself
165
- def build_from_hash(attributes)
166
- return nil unless attributes.is_a?(Hash)
167
- self.class.swagger_types.each_pair do |key, type|
168
- mapKey = self.class.attribute_map[key]
169
- if !mapKey.nil?
170
- val = attributes[mapKey]
171
- if val.nil?
172
- mapKeyString = mapKey.to_s
173
- mapKeyString[0] = mapKeyString[0].downcase
174
- mapKey = mapKeyString.to_sym
175
- val = attributes[mapKey]
176
- end
177
- if !val.nil?
178
- if type =~ /\AArray<(.*)>/i
179
- # check to ensure the input is an array given that the the attribute
180
- # is documented as an array but the input is not
181
- if val.is_a?(Array)
182
- self.send("#{key}=", val.map { |v| _deserialize($1, v) })
183
- end
184
- else
185
- self.send("#{key}=", _deserialize(type, val))
186
- end
187
- end
188
- end
189
- end
190
-
191
- self
192
- end
193
-
194
- # Deserializes the data based on type
195
- # @param string type Data type
196
- # @param string value Value to be deserialized
197
- # @return [Object] Deserialized data
198
- def _deserialize(type, value)
199
- case type.to_sym
200
- when :DateTime
201
- DateTime.parse(value)
202
- when :Date
203
- Date.parse(value)
204
- when :String
205
- value.to_s
206
- when :Integer
207
- value.to_i
208
- when :Float
209
- value.to_f
210
- when :BOOLEAN
211
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
212
- true
213
- else
214
- false
215
- end
216
- when :Object
217
- # generic object (usually a Hash), return directly
218
- value
219
- when /\AArray<(?<inner_type>.+)>\z/
220
- inner_type = Regexp.last_match[:inner_type]
221
- value.map { |v| _deserialize(inner_type, v) }
222
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
223
- k_type = Regexp.last_match[:k_type]
224
- v_type = Regexp.last_match[:v_type]
225
- {}.tap do |hash|
226
- value.each do |k, v|
227
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
228
- end
229
- end
230
- else # model
231
- temp_model = AsposeSlidesCloud.const_get(type).new
232
- temp_model.build_from_hash(value)
233
- end
234
- end
235
-
236
- # Returns the string representation of the object
237
- # @return [String] String presentation of the object
238
- def to_s
239
- to_hash.to_s
240
- end
241
-
242
- # to_body is an alias to to_hash (backward compatibility)
243
- # @return [Hash] Returns the object in the form of hash
244
- def to_body
245
- to_hash
246
- end
247
-
248
- # Returns the object in the form of hash
249
- # @return [Hash] Returns the object in the form of hash
250
- def to_hash
251
- hash = {}
252
- self.class.attribute_map.each_pair do |attr, param|
253
- value = self.send(attr)
254
- next if value.nil?
255
- hash[param] = _to_hash(value)
256
- end
257
- hash
258
- end
259
-
260
- # Outputs non-array value in the form of hash
261
- # For object, use to_hash. Otherwise, just return the value
262
- # @param [Object] value Any valid value
263
- # @return [Hash] Returns the value in the form of hash
264
- def _to_hash(value)
265
- if value.is_a?(Array)
266
- value.compact.map { |v| _to_hash(v) }
267
- elsif value.is_a?(Hash)
268
- {}.tap do |hash|
269
- value.each { |k, v| hash[k] = _to_hash(v) }
270
- end
271
- elsif value.respond_to? :to_hash
272
- value.to_hash
273
- else
274
- value
275
- end
276
- end
277
- end
278
- 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.
27
+ class LayoutSlide < ResourceBase
28
+ # Name.
29
+ attr_accessor :name
30
+
31
+ # Layout slide type.
32
+ attr_accessor :type
33
+
34
+ # Master slide link.
35
+ attr_accessor :master_slide
36
+
37
+ # List of depending slides.
38
+ attr_accessor :depending_slides
39
+
40
+ class EnumAttributeValidator
41
+ attr_reader :datatype
42
+ attr_reader :allowable_values
43
+
44
+ def initialize(datatype, allowable_values)
45
+ @allowable_values = allowable_values.map do |value|
46
+ case datatype.to_s
47
+ when /Integer/i
48
+ value.to_i
49
+ when /Float/i
50
+ value.to_f
51
+ else
52
+ value
53
+ end
54
+ end
55
+ end
56
+
57
+ def valid?(value)
58
+ !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
59
+ end
60
+ end
61
+
62
+ # Attribute mapping from ruby-style variable name to JSON key.
63
+ def self.attribute_map
64
+ super.merge({
65
+ :'name' => :'Name',
66
+ :'type' => :'Type',
67
+ :'master_slide' => :'MasterSlide',
68
+ :'depending_slides' => :'DependingSlides',
69
+ })
70
+ end
71
+
72
+ # Attribute type mapping.
73
+ def self.swagger_types
74
+ super.merge({
75
+ :'name' => :'String',
76
+ :'type' => :'String',
77
+ :'master_slide' => :'ResourceUri',
78
+ :'depending_slides' => :'Array<ResourceUri>',
79
+ })
80
+ end
81
+
82
+ # Initializes the object
83
+ # @param [Hash] attributes Model attributes in the form of hash
84
+ def initialize(attributes = {})
85
+ super
86
+
87
+ if attributes.has_key?(:'Name')
88
+ self.name = attributes[:'Name']
89
+ end
90
+
91
+ if attributes.has_key?(:'Type')
92
+ self.type = attributes[:'Type']
93
+ end
94
+
95
+ if attributes.has_key?(:'MasterSlide')
96
+ self.master_slide = attributes[:'MasterSlide']
97
+ end
98
+
99
+ if attributes.has_key?(:'DependingSlides')
100
+ if (value = attributes[:'DependingSlides']).is_a?(Array)
101
+ self.depending_slides = value
102
+ end
103
+ end
104
+ end
105
+
106
+ # Show invalid properties with the reasons. Usually used together with valid?
107
+ # @return Array for valid properties with the reasons
108
+ def list_invalid_properties
109
+ invalid_properties = super
110
+ if @type.nil?
111
+ invalid_properties.push('invalid value for "type", type cannot be nil.')
112
+ end
113
+
114
+ invalid_properties
115
+ end
116
+
117
+ # Check to see if the all the properties in the model are valid
118
+ # @return true if the model is valid
119
+ def valid?
120
+ return false if !super
121
+ return false if @type.nil?
122
+ type_validator = EnumAttributeValidator.new('String', ['Title', 'Text', 'TwoColumnText', 'Table', 'TextAndChart', 'ChartAndText', 'Diagram', 'Chart', 'TextAndClipArt', 'ClipArtAndText', 'TitleOnly', 'Blank', 'TextAndObject', 'ObjectAndText', 'Object', 'TitleAndObject', 'TextAndMedia', 'MediaAndText', 'ObjectOverText', 'TextOverObject', 'TextAndTwoObjects', 'TwoObjectsAndText', 'TwoObjectsOverText', 'FourObjects', 'VerticalText', 'ClipArtAndVerticalText', 'VerticalTitleAndText', 'VerticalTitleAndTextOverChart', 'TwoObjects', 'ObjectAndTwoObject', 'TwoObjectsAndObject', 'SectionHeader', 'TwoTextAndTwoObjects', 'TitleObjectAndCaption', 'PictureAndCaption', 'Custom'])
123
+ return false unless type_validator.valid?(@type)
124
+ true
125
+ end
126
+
127
+ # Custom attribute writer method checking allowed values (enum).
128
+ # @param [Object] type Object to be assigned
129
+ def type=(type)
130
+ validator = EnumAttributeValidator.new('String', ['Title', 'Text', 'TwoColumnText', 'Table', 'TextAndChart', 'ChartAndText', 'Diagram', 'Chart', 'TextAndClipArt', 'ClipArtAndText', 'TitleOnly', 'Blank', 'TextAndObject', 'ObjectAndText', 'Object', 'TitleAndObject', 'TextAndMedia', 'MediaAndText', 'ObjectOverText', 'TextOverObject', 'TextAndTwoObjects', 'TwoObjectsAndText', 'TwoObjectsOverText', 'FourObjects', 'VerticalText', 'ClipArtAndVerticalText', 'VerticalTitleAndText', 'VerticalTitleAndTextOverChart', 'TwoObjects', 'ObjectAndTwoObject', 'TwoObjectsAndObject', 'SectionHeader', 'TwoTextAndTwoObjects', 'TitleObjectAndCaption', 'PictureAndCaption', 'Custom'])
131
+ unless validator.valid?(type)
132
+ fail ArgumentError, 'invalid value for "type", must be one of #{validator.allowable_values}.'
133
+ end
134
+ @type = type
135
+ end
136
+
137
+ # Checks equality by comparing each attribute.
138
+ # @param [Object] Object to be compared
139
+ def ==(o)
140
+ return true if self.equal?(o)
141
+ self.class == o.class &&
142
+ self_uri == o.self_uri &&
143
+ alternate_links == o.alternate_links &&
144
+ name == o.name &&
145
+ type == o.type &&
146
+ master_slide == o.master_slide &&
147
+ depending_slides == o.depending_slides
148
+ end
149
+
150
+ # @see the `==` method
151
+ # @param [Object] Object to be compared
152
+ def eql?(o)
153
+ self == o
154
+ end
155
+
156
+ # Calculates hash code according to all attributes.
157
+ # @return [Fixnum] Hash code
158
+ def hash
159
+ [self_uri, alternate_links, name, type, master_slide, depending_slides].hash
160
+ end
161
+
162
+ # Builds the object from hash
163
+ # @param [Hash] attributes Model attributes in the form of hash
164
+ # @return [Object] Returns the model itself
165
+ def build_from_hash(attributes)
166
+ return nil unless attributes.is_a?(Hash)
167
+ self.class.swagger_types.each_pair do |key, type|
168
+ mapKey = self.class.attribute_map[key]
169
+ if !mapKey.nil?
170
+ val = attributes[mapKey]
171
+ if val.nil?
172
+ mapKeyString = mapKey.to_s
173
+ mapKeyString[0] = mapKeyString[0].downcase
174
+ mapKey = mapKeyString.to_sym
175
+ val = attributes[mapKey]
176
+ end
177
+ if !val.nil?
178
+ if type =~ /\AArray<(.*)>/i
179
+ # check to ensure the input is an array given that the the attribute
180
+ # is documented as an array but the input is not
181
+ if val.is_a?(Array)
182
+ self.send("#{key}=", val.map { |v| _deserialize($1, v) })
183
+ end
184
+ else
185
+ self.send("#{key}=", _deserialize(type, val))
186
+ end
187
+ end
188
+ end
189
+ end
190
+
191
+ self
192
+ end
193
+
194
+ # Deserializes the data based on type
195
+ # @param string type Data type
196
+ # @param string value Value to be deserialized
197
+ # @return [Object] Deserialized data
198
+ def _deserialize(type, value)
199
+ case type.to_sym
200
+ when :DateTime
201
+ DateTime.parse(value)
202
+ when :Date
203
+ Date.parse(value)
204
+ when :String
205
+ value.to_s
206
+ when :Integer
207
+ value.to_i
208
+ when :Float
209
+ value.to_f
210
+ when :BOOLEAN
211
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
212
+ true
213
+ else
214
+ false
215
+ end
216
+ when :Object
217
+ # generic object (usually a Hash), return directly
218
+ value
219
+ when /\AArray<(?<inner_type>.+)>\z/
220
+ inner_type = Regexp.last_match[:inner_type]
221
+ value.map { |v| _deserialize(inner_type, v) }
222
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
223
+ k_type = Regexp.last_match[:k_type]
224
+ v_type = Regexp.last_match[:v_type]
225
+ {}.tap do |hash|
226
+ value.each do |k, v|
227
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
228
+ end
229
+ end
230
+ else # model
231
+ temp_model = AsposeSlidesCloud.const_get(type).new
232
+ temp_model.build_from_hash(value)
233
+ end
234
+ end
235
+
236
+ # Returns the string representation of the object
237
+ # @return [String] String presentation of the object
238
+ def to_s
239
+ to_hash.to_s
240
+ end
241
+
242
+ # to_body is an alias to to_hash (backward compatibility)
243
+ # @return [Hash] Returns the object in the form of hash
244
+ def to_body
245
+ to_hash
246
+ end
247
+
248
+ # Returns the object in the form of hash
249
+ # @return [Hash] Returns the object in the form of hash
250
+ def to_hash
251
+ hash = {}
252
+ self.class.attribute_map.each_pair do |attr, param|
253
+ value = self.send(attr)
254
+ next if value.nil?
255
+ hash[param] = _to_hash(value)
256
+ end
257
+ hash
258
+ end
259
+
260
+ # Outputs non-array value in the form of hash
261
+ # For object, use to_hash. Otherwise, just return the value
262
+ # @param [Object] value Any valid value
263
+ # @return [Hash] Returns the value in the form of hash
264
+ def _to_hash(value)
265
+ if value.is_a?(Array)
266
+ value.compact.map { |v| _to_hash(v) }
267
+ elsif value.is_a?(Hash)
268
+ {}.tap do |hash|
269
+ value.each { |k, v| hash[k] = _to_hash(v) }
270
+ end
271
+ elsif value.respond_to? :to_hash
272
+ value.to_hash
273
+ else
274
+ value
275
+ end
276
+ end
277
+ end
278
+ end