aspose_slides_cloud 20.10.0 → 20.12.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/TemplatingCVDataWithBase64.xml +22 -22
  4. data/lib/aspose_slides_cloud.rb +212 -212
  5. data/lib/aspose_slides_cloud/api/slides_api.rb +10979 -10979
  6. data/lib/aspose_slides_cloud/api/slides_api_requests.rb +4146 -4146
  7. data/lib/aspose_slides_cloud/api_client.rb +436 -432
  8. data/lib/aspose_slides_cloud/configuration.rb +7 -2
  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 -359
  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 -365
  24. data/lib/aspose_slides_cloud/models/chart_category.rb +271 -271
  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 -275
  30. data/lib/aspose_slides_cloud/models/custom_dash_pattern.rb +209 -209
  31. data/lib/aspose_slides_cloud/models/data_point.rb +197 -197
  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 -260
  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 -234
  58. data/lib/aspose_slides_cloud/models/group_shape.rb +234 -234
  59. data/lib/aspose_slides_cloud/models/header_footer.rb +247 -247
  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 -197
  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 -267
  83. data/lib/aspose_slides_cloud/models/object_exist.rb +227 -227
  84. data/lib/aspose_slides_cloud/models/ole_object_frame.rb +259 -259
  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 -245
  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 -234
  125. data/lib/aspose_slides_cloud/models/sections.rb +209 -209
  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 -255
  129. data/lib/aspose_slides_cloud/models/shape_base.rb +375 -375
  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 -342
  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 -235
  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 -350
  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 -329
  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 -206
  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 -320
  170. data/lib/aspose_slides_cloud/version.rb +25 -25
  171. data/spec/api/slides_api_spec.rb +35926 -35926
  172. data/spec/extra/extra_spec.rb +235 -235
  173. data/spec/spec_utils.rb +183 -183
  174. data/testConfig.json +7 -7
  175. data/testRules.json +441 -472
  176. metadata +2 -2
@@ -1,222 +1,222 @@
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 chart title
27
- class ChartTitle
28
- # Get or sets the text.
29
- attr_accessor :text
30
-
31
- # Get or sets value determines visibility of title
32
- attr_accessor :has_title
33
-
34
- # Attribute mapping from ruby-style variable name to JSON key.
35
- def self.attribute_map
36
- {
37
- :'text' => :'Text',
38
- :'has_title' => :'HasTitle',
39
- }
40
- end
41
-
42
- # Attribute type mapping.
43
- def self.swagger_types
44
- {
45
- :'text' => :'String',
46
- :'has_title' => :'BOOLEAN',
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?(:'Text')
59
- self.text = attributes[:'Text']
60
- end
61
-
62
- if attributes.has_key?(:'HasTitle')
63
- self.has_title = attributes[:'HasTitle']
64
- end
65
- end
66
-
67
- # Show invalid properties with the reasons. Usually used together with valid?
68
- # @return Array for valid properties with the reasons
69
- def list_invalid_properties
70
- invalid_properties = Array.new
71
- if @has_title.nil?
72
- invalid_properties.push('invalid value for "has_title", has_title cannot be nil.')
73
- end
74
-
75
- invalid_properties
76
- end
77
-
78
- # Check to see if the all the properties in the model are valid
79
- # @return true if the model is valid
80
- def valid?
81
- return false if @has_title.nil?
82
- true
83
- end
84
-
85
- # Checks equality by comparing each attribute.
86
- # @param [Object] Object to be compared
87
- def ==(o)
88
- return true if self.equal?(o)
89
- self.class == o.class &&
90
- text == o.text &&
91
- has_title == o.has_title
92
- end
93
-
94
- # @see the `==` method
95
- # @param [Object] Object to be compared
96
- def eql?(o)
97
- self == o
98
- end
99
-
100
- # Calculates hash code according to all attributes.
101
- # @return [Fixnum] Hash code
102
- def hash
103
- [text, has_title].hash
104
- end
105
-
106
- # Builds the object from hash
107
- # @param [Hash] attributes Model attributes in the form of hash
108
- # @return [Object] Returns the model itself
109
- def build_from_hash(attributes)
110
- return nil unless attributes.is_a?(Hash)
111
- self.class.swagger_types.each_pair do |key, type|
112
- mapKey = self.class.attribute_map[key]
113
- if !mapKey.nil?
114
- val = attributes[mapKey]
115
- if val.nil?
116
- mapKeyString = mapKey.to_s
117
- mapKeyString[0] = mapKeyString[0].downcase
118
- mapKey = mapKeyString.to_sym
119
- val = attributes[mapKey]
120
- end
121
- if !val.nil?
122
- if type =~ /\AArray<(.*)>/i
123
- # check to ensure the input is an array given that the the attribute
124
- # is documented as an array but the input is not
125
- if val.is_a?(Array)
126
- self.send("#{key}=", val.map { |v| _deserialize($1, v) })
127
- end
128
- else
129
- self.send("#{key}=", _deserialize(type, val))
130
- end
131
- end
132
- end
133
- end
134
-
135
- self
136
- end
137
-
138
- # Deserializes the data based on type
139
- # @param string type Data type
140
- # @param string value Value to be deserialized
141
- # @return [Object] Deserialized data
142
- def _deserialize(type, value)
143
- case type.to_sym
144
- when :DateTime
145
- DateTime.parse(value)
146
- when :Date
147
- Date.parse(value)
148
- when :String
149
- value.to_s
150
- when :Integer
151
- value.to_i
152
- when :Float
153
- value.to_f
154
- when :BOOLEAN
155
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
156
- true
157
- else
158
- false
159
- end
160
- when :Object
161
- # generic object (usually a Hash), return directly
162
- value
163
- when /\AArray<(?<inner_type>.+)>\z/
164
- inner_type = Regexp.last_match[:inner_type]
165
- value.map { |v| _deserialize(inner_type, v) }
166
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
167
- k_type = Regexp.last_match[:k_type]
168
- v_type = Regexp.last_match[:v_type]
169
- {}.tap do |hash|
170
- value.each do |k, v|
171
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
172
- end
173
- end
174
- else # model
175
- temp_model = AsposeSlidesCloud.const_get(type).new
176
- temp_model.build_from_hash(value)
177
- end
178
- end
179
-
180
- # Returns the string representation of the object
181
- # @return [String] String presentation of the object
182
- def to_s
183
- to_hash.to_s
184
- end
185
-
186
- # to_body is an alias to to_hash (backward compatibility)
187
- # @return [Hash] Returns the object in the form of hash
188
- def to_body
189
- to_hash
190
- end
191
-
192
- # Returns the object in the form of hash
193
- # @return [Hash] Returns the object in the form of hash
194
- def to_hash
195
- hash = {}
196
- self.class.attribute_map.each_pair do |attr, param|
197
- value = self.send(attr)
198
- next if value.nil?
199
- hash[param] = _to_hash(value)
200
- end
201
- hash
202
- end
203
-
204
- # Outputs non-array value in the form of hash
205
- # For object, use to_hash. Otherwise, just return the value
206
- # @param [Object] value Any valid value
207
- # @return [Hash] Returns the value in the form of hash
208
- def _to_hash(value)
209
- if value.is_a?(Array)
210
- value.compact.map { |v| _to_hash(v) }
211
- elsif value.is_a?(Hash)
212
- {}.tap do |hash|
213
- value.each { |k, v| hash[k] = _to_hash(v) }
214
- end
215
- elsif value.respond_to? :to_hash
216
- value.to_hash
217
- else
218
- value
219
- end
220
- end
221
- end
222
- 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 chart title
27
+ class ChartTitle
28
+ # Get or sets the text.
29
+ attr_accessor :text
30
+
31
+ # Get or sets value determines visibility of title
32
+ attr_accessor :has_title
33
+
34
+ # Attribute mapping from ruby-style variable name to JSON key.
35
+ def self.attribute_map
36
+ {
37
+ :'text' => :'Text',
38
+ :'has_title' => :'HasTitle',
39
+ }
40
+ end
41
+
42
+ # Attribute type mapping.
43
+ def self.swagger_types
44
+ {
45
+ :'text' => :'String',
46
+ :'has_title' => :'BOOLEAN',
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?(:'Text')
59
+ self.text = attributes[:'Text']
60
+ end
61
+
62
+ if attributes.has_key?(:'HasTitle')
63
+ self.has_title = attributes[:'HasTitle']
64
+ end
65
+ end
66
+
67
+ # Show invalid properties with the reasons. Usually used together with valid?
68
+ # @return Array for valid properties with the reasons
69
+ def list_invalid_properties
70
+ invalid_properties = Array.new
71
+ if @has_title.nil?
72
+ invalid_properties.push('invalid value for "has_title", has_title cannot be nil.')
73
+ end
74
+
75
+ invalid_properties
76
+ end
77
+
78
+ # Check to see if the all the properties in the model are valid
79
+ # @return true if the model is valid
80
+ def valid?
81
+ return false if @has_title.nil?
82
+ true
83
+ end
84
+
85
+ # Checks equality by comparing each attribute.
86
+ # @param [Object] Object to be compared
87
+ def ==(o)
88
+ return true if self.equal?(o)
89
+ self.class == o.class &&
90
+ text == o.text &&
91
+ has_title == o.has_title
92
+ end
93
+
94
+ # @see the `==` method
95
+ # @param [Object] Object to be compared
96
+ def eql?(o)
97
+ self == o
98
+ end
99
+
100
+ # Calculates hash code according to all attributes.
101
+ # @return [Fixnum] Hash code
102
+ def hash
103
+ [text, has_title].hash
104
+ end
105
+
106
+ # Builds the object from hash
107
+ # @param [Hash] attributes Model attributes in the form of hash
108
+ # @return [Object] Returns the model itself
109
+ def build_from_hash(attributes)
110
+ return nil unless attributes.is_a?(Hash)
111
+ self.class.swagger_types.each_pair do |key, type|
112
+ mapKey = self.class.attribute_map[key]
113
+ if !mapKey.nil?
114
+ val = attributes[mapKey]
115
+ if val.nil?
116
+ mapKeyString = mapKey.to_s
117
+ mapKeyString[0] = mapKeyString[0].downcase
118
+ mapKey = mapKeyString.to_sym
119
+ val = attributes[mapKey]
120
+ end
121
+ if !val.nil?
122
+ if type =~ /\AArray<(.*)>/i
123
+ # check to ensure the input is an array given that the the attribute
124
+ # is documented as an array but the input is not
125
+ if val.is_a?(Array)
126
+ self.send("#{key}=", val.map { |v| _deserialize($1, v) })
127
+ end
128
+ else
129
+ self.send("#{key}=", _deserialize(type, val))
130
+ end
131
+ end
132
+ end
133
+ end
134
+
135
+ self
136
+ end
137
+
138
+ # Deserializes the data based on type
139
+ # @param string type Data type
140
+ # @param string value Value to be deserialized
141
+ # @return [Object] Deserialized data
142
+ def _deserialize(type, value)
143
+ case type.to_sym
144
+ when :DateTime
145
+ DateTime.parse(value)
146
+ when :Date
147
+ Date.parse(value)
148
+ when :String
149
+ value.to_s
150
+ when :Integer
151
+ value.to_i
152
+ when :Float
153
+ value.to_f
154
+ when :BOOLEAN
155
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
156
+ true
157
+ else
158
+ false
159
+ end
160
+ when :Object
161
+ # generic object (usually a Hash), return directly
162
+ value
163
+ when /\AArray<(?<inner_type>.+)>\z/
164
+ inner_type = Regexp.last_match[:inner_type]
165
+ value.map { |v| _deserialize(inner_type, v) }
166
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
167
+ k_type = Regexp.last_match[:k_type]
168
+ v_type = Regexp.last_match[:v_type]
169
+ {}.tap do |hash|
170
+ value.each do |k, v|
171
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
172
+ end
173
+ end
174
+ else # model
175
+ temp_model = AsposeSlidesCloud.const_get(type).new
176
+ temp_model.build_from_hash(value)
177
+ end
178
+ end
179
+
180
+ # Returns the string representation of the object
181
+ # @return [String] String presentation of the object
182
+ def to_s
183
+ to_hash.to_s
184
+ end
185
+
186
+ # to_body is an alias to to_hash (backward compatibility)
187
+ # @return [Hash] Returns the object in the form of hash
188
+ def to_body
189
+ to_hash
190
+ end
191
+
192
+ # Returns the object in the form of hash
193
+ # @return [Hash] Returns the object in the form of hash
194
+ def to_hash
195
+ hash = {}
196
+ self.class.attribute_map.each_pair do |attr, param|
197
+ value = self.send(attr)
198
+ next if value.nil?
199
+ hash[param] = _to_hash(value)
200
+ end
201
+ hash
202
+ end
203
+
204
+ # Outputs non-array value in the form of hash
205
+ # For object, use to_hash. Otherwise, just return the value
206
+ # @param [Object] value Any valid value
207
+ # @return [Hash] Returns the value in the form of hash
208
+ def _to_hash(value)
209
+ if value.is_a?(Array)
210
+ value.compact.map { |v| _to_hash(v) }
211
+ elsif value.is_a?(Hash)
212
+ {}.tap do |hash|
213
+ value.each { |k, v| hash[k] = _to_hash(v) }
214
+ end
215
+ elsif value.respond_to? :to_hash
216
+ value.to_hash
217
+ else
218
+ value
219
+ end
220
+ end
221
+ end
222
+ end
@@ -1,281 +1,281 @@
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 wall
27
- class ChartWall
28
- # Get or sets the fill format.
29
- attr_accessor :fill_format
30
-
31
- # Get or sets the effect format.
32
- attr_accessor :effect_format
33
-
34
- # Get or sets the line format.
35
- attr_accessor :line_format
36
-
37
- # Get or sets wall thickness as a percentage of the largest dimension of the plot volume.
38
- attr_accessor :thickness
39
-
40
- # Get or sets mode of bar picture filling.
41
- attr_accessor :picture_type
42
-
43
- class EnumAttributeValidator
44
- attr_reader :datatype
45
- attr_reader :allowable_values
46
-
47
- def initialize(datatype, allowable_values)
48
- @allowable_values = allowable_values.map do |value|
49
- case datatype.to_s
50
- when /Integer/i
51
- value.to_i
52
- when /Float/i
53
- value.to_f
54
- else
55
- value
56
- end
57
- end
58
- end
59
-
60
- def valid?(value)
61
- !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
62
- end
63
- end
64
-
65
- # Attribute mapping from ruby-style variable name to JSON key.
66
- def self.attribute_map
67
- {
68
- :'fill_format' => :'FillFormat',
69
- :'effect_format' => :'EffectFormat',
70
- :'line_format' => :'LineFormat',
71
- :'thickness' => :'Thickness',
72
- :'picture_type' => :'PictureType',
73
- }
74
- end
75
-
76
- # Attribute type mapping.
77
- def self.swagger_types
78
- {
79
- :'fill_format' => :'FillFormat',
80
- :'effect_format' => :'EffectFormat',
81
- :'line_format' => :'LineFormat',
82
- :'thickness' => :'Integer',
83
- :'picture_type' => :'String',
84
- }
85
- end
86
-
87
- # Initializes the object
88
- # @param [Hash] attributes Model attributes in the form of hash
89
- def initialize(attributes = {})
90
- return unless attributes.is_a?(Hash)
91
-
92
- # convert string to symbol for hash key
93
- attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
94
-
95
- if attributes.has_key?(:'FillFormat')
96
- self.fill_format = attributes[:'FillFormat']
97
- end
98
-
99
- if attributes.has_key?(:'EffectFormat')
100
- self.effect_format = attributes[:'EffectFormat']
101
- end
102
-
103
- if attributes.has_key?(:'LineFormat')
104
- self.line_format = attributes[:'LineFormat']
105
- end
106
-
107
- if attributes.has_key?(:'Thickness')
108
- self.thickness = attributes[:'Thickness']
109
- end
110
-
111
- if attributes.has_key?(:'PictureType')
112
- self.picture_type = attributes[:'PictureType']
113
- end
114
- end
115
-
116
- # Show invalid properties with the reasons. Usually used together with valid?
117
- # @return Array for valid properties with the reasons
118
- def list_invalid_properties
119
- invalid_properties = Array.new
120
- invalid_properties
121
- end
122
-
123
- # Check to see if the all the properties in the model are valid
124
- # @return true if the model is valid
125
- def valid?
126
- picture_type_validator = EnumAttributeValidator.new('String', ['Stack', 'StackScale', 'Stretch', 'NotDefined'])
127
- return false unless picture_type_validator.valid?(@picture_type)
128
- true
129
- end
130
-
131
- # Custom attribute writer method checking allowed values (enum).
132
- # @param [Object] picture_type Object to be assigned
133
- def picture_type=(picture_type)
134
- validator = EnumAttributeValidator.new('String', ['Stack', 'StackScale', 'Stretch', 'NotDefined'])
135
- unless validator.valid?(picture_type)
136
- fail ArgumentError, 'invalid value for "picture_type", must be one of #{validator.allowable_values}.'
137
- end
138
- @picture_type = picture_type
139
- end
140
-
141
- # Checks equality by comparing each attribute.
142
- # @param [Object] Object to be compared
143
- def ==(o)
144
- return true if self.equal?(o)
145
- self.class == o.class &&
146
- fill_format == o.fill_format &&
147
- effect_format == o.effect_format &&
148
- line_format == o.line_format &&
149
- thickness == o.thickness &&
150
- picture_type == o.picture_type
151
- end
152
-
153
- # @see the `==` method
154
- # @param [Object] Object to be compared
155
- def eql?(o)
156
- self == o
157
- end
158
-
159
- # Calculates hash code according to all attributes.
160
- # @return [Fixnum] Hash code
161
- def hash
162
- [fill_format, effect_format, line_format, thickness, picture_type].hash
163
- end
164
-
165
- # Builds the object from hash
166
- # @param [Hash] attributes Model attributes in the form of hash
167
- # @return [Object] Returns the model itself
168
- def build_from_hash(attributes)
169
- return nil unless attributes.is_a?(Hash)
170
- self.class.swagger_types.each_pair do |key, type|
171
- mapKey = self.class.attribute_map[key]
172
- if !mapKey.nil?
173
- val = attributes[mapKey]
174
- if val.nil?
175
- mapKeyString = mapKey.to_s
176
- mapKeyString[0] = mapKeyString[0].downcase
177
- mapKey = mapKeyString.to_sym
178
- val = attributes[mapKey]
179
- end
180
- if !val.nil?
181
- if type =~ /\AArray<(.*)>/i
182
- # check to ensure the input is an array given that the the attribute
183
- # is documented as an array but the input is not
184
- if val.is_a?(Array)
185
- self.send("#{key}=", val.map { |v| _deserialize($1, v) })
186
- end
187
- else
188
- self.send("#{key}=", _deserialize(type, val))
189
- end
190
- end
191
- end
192
- end
193
-
194
- self
195
- end
196
-
197
- # Deserializes the data based on type
198
- # @param string type Data type
199
- # @param string value Value to be deserialized
200
- # @return [Object] Deserialized data
201
- def _deserialize(type, value)
202
- case type.to_sym
203
- when :DateTime
204
- DateTime.parse(value)
205
- when :Date
206
- Date.parse(value)
207
- when :String
208
- value.to_s
209
- when :Integer
210
- value.to_i
211
- when :Float
212
- value.to_f
213
- when :BOOLEAN
214
- if value.to_s =~ /\A(true|t|yes|y|1)\z/i
215
- true
216
- else
217
- false
218
- end
219
- when :Object
220
- # generic object (usually a Hash), return directly
221
- value
222
- when /\AArray<(?<inner_type>.+)>\z/
223
- inner_type = Regexp.last_match[:inner_type]
224
- value.map { |v| _deserialize(inner_type, v) }
225
- when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
226
- k_type = Regexp.last_match[:k_type]
227
- v_type = Regexp.last_match[:v_type]
228
- {}.tap do |hash|
229
- value.each do |k, v|
230
- hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
231
- end
232
- end
233
- else # model
234
- temp_model = AsposeSlidesCloud.const_get(type).new
235
- temp_model.build_from_hash(value)
236
- end
237
- end
238
-
239
- # Returns the string representation of the object
240
- # @return [String] String presentation of the object
241
- def to_s
242
- to_hash.to_s
243
- end
244
-
245
- # to_body is an alias to to_hash (backward compatibility)
246
- # @return [Hash] Returns the object in the form of hash
247
- def to_body
248
- to_hash
249
- end
250
-
251
- # Returns the object in the form of hash
252
- # @return [Hash] Returns the object in the form of hash
253
- def to_hash
254
- hash = {}
255
- self.class.attribute_map.each_pair do |attr, param|
256
- value = self.send(attr)
257
- next if value.nil?
258
- hash[param] = _to_hash(value)
259
- end
260
- hash
261
- end
262
-
263
- # Outputs non-array value in the form of hash
264
- # For object, use to_hash. Otherwise, just return the value
265
- # @param [Object] value Any valid value
266
- # @return [Hash] Returns the value in the form of hash
267
- def _to_hash(value)
268
- if value.is_a?(Array)
269
- value.compact.map { |v| _to_hash(v) }
270
- elsif value.is_a?(Hash)
271
- {}.tap do |hash|
272
- value.each { |k, v| hash[k] = _to_hash(v) }
273
- end
274
- elsif value.respond_to? :to_hash
275
- value.to_hash
276
- else
277
- value
278
- end
279
- end
280
- end
281
- 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 wall
27
+ class ChartWall
28
+ # Get or sets the fill format.
29
+ attr_accessor :fill_format
30
+
31
+ # Get or sets the effect format.
32
+ attr_accessor :effect_format
33
+
34
+ # Get or sets the line format.
35
+ attr_accessor :line_format
36
+
37
+ # Get or sets wall thickness as a percentage of the largest dimension of the plot volume.
38
+ attr_accessor :thickness
39
+
40
+ # Get or sets mode of bar picture filling.
41
+ attr_accessor :picture_type
42
+
43
+ class EnumAttributeValidator
44
+ attr_reader :datatype
45
+ attr_reader :allowable_values
46
+
47
+ def initialize(datatype, allowable_values)
48
+ @allowable_values = allowable_values.map do |value|
49
+ case datatype.to_s
50
+ when /Integer/i
51
+ value.to_i
52
+ when /Float/i
53
+ value.to_f
54
+ else
55
+ value
56
+ end
57
+ end
58
+ end
59
+
60
+ def valid?(value)
61
+ !value || allowable_values.any?{ |s| s.casecmp(value) == 0 }
62
+ end
63
+ end
64
+
65
+ # Attribute mapping from ruby-style variable name to JSON key.
66
+ def self.attribute_map
67
+ {
68
+ :'fill_format' => :'FillFormat',
69
+ :'effect_format' => :'EffectFormat',
70
+ :'line_format' => :'LineFormat',
71
+ :'thickness' => :'Thickness',
72
+ :'picture_type' => :'PictureType',
73
+ }
74
+ end
75
+
76
+ # Attribute type mapping.
77
+ def self.swagger_types
78
+ {
79
+ :'fill_format' => :'FillFormat',
80
+ :'effect_format' => :'EffectFormat',
81
+ :'line_format' => :'LineFormat',
82
+ :'thickness' => :'Integer',
83
+ :'picture_type' => :'String',
84
+ }
85
+ end
86
+
87
+ # Initializes the object
88
+ # @param [Hash] attributes Model attributes in the form of hash
89
+ def initialize(attributes = {})
90
+ return unless attributes.is_a?(Hash)
91
+
92
+ # convert string to symbol for hash key
93
+ attributes = attributes.each_with_object({}) { |(k, v), h| h[k.to_sym] = v }
94
+
95
+ if attributes.has_key?(:'FillFormat')
96
+ self.fill_format = attributes[:'FillFormat']
97
+ end
98
+
99
+ if attributes.has_key?(:'EffectFormat')
100
+ self.effect_format = attributes[:'EffectFormat']
101
+ end
102
+
103
+ if attributes.has_key?(:'LineFormat')
104
+ self.line_format = attributes[:'LineFormat']
105
+ end
106
+
107
+ if attributes.has_key?(:'Thickness')
108
+ self.thickness = attributes[:'Thickness']
109
+ end
110
+
111
+ if attributes.has_key?(:'PictureType')
112
+ self.picture_type = attributes[:'PictureType']
113
+ end
114
+ end
115
+
116
+ # Show invalid properties with the reasons. Usually used together with valid?
117
+ # @return Array for valid properties with the reasons
118
+ def list_invalid_properties
119
+ invalid_properties = Array.new
120
+ invalid_properties
121
+ end
122
+
123
+ # Check to see if the all the properties in the model are valid
124
+ # @return true if the model is valid
125
+ def valid?
126
+ picture_type_validator = EnumAttributeValidator.new('String', ['Stack', 'StackScale', 'Stretch', 'NotDefined'])
127
+ return false unless picture_type_validator.valid?(@picture_type)
128
+ true
129
+ end
130
+
131
+ # Custom attribute writer method checking allowed values (enum).
132
+ # @param [Object] picture_type Object to be assigned
133
+ def picture_type=(picture_type)
134
+ validator = EnumAttributeValidator.new('String', ['Stack', 'StackScale', 'Stretch', 'NotDefined'])
135
+ unless validator.valid?(picture_type)
136
+ fail ArgumentError, 'invalid value for "picture_type", must be one of #{validator.allowable_values}.'
137
+ end
138
+ @picture_type = picture_type
139
+ end
140
+
141
+ # Checks equality by comparing each attribute.
142
+ # @param [Object] Object to be compared
143
+ def ==(o)
144
+ return true if self.equal?(o)
145
+ self.class == o.class &&
146
+ fill_format == o.fill_format &&
147
+ effect_format == o.effect_format &&
148
+ line_format == o.line_format &&
149
+ thickness == o.thickness &&
150
+ picture_type == o.picture_type
151
+ end
152
+
153
+ # @see the `==` method
154
+ # @param [Object] Object to be compared
155
+ def eql?(o)
156
+ self == o
157
+ end
158
+
159
+ # Calculates hash code according to all attributes.
160
+ # @return [Fixnum] Hash code
161
+ def hash
162
+ [fill_format, effect_format, line_format, thickness, picture_type].hash
163
+ end
164
+
165
+ # Builds the object from hash
166
+ # @param [Hash] attributes Model attributes in the form of hash
167
+ # @return [Object] Returns the model itself
168
+ def build_from_hash(attributes)
169
+ return nil unless attributes.is_a?(Hash)
170
+ self.class.swagger_types.each_pair do |key, type|
171
+ mapKey = self.class.attribute_map[key]
172
+ if !mapKey.nil?
173
+ val = attributes[mapKey]
174
+ if val.nil?
175
+ mapKeyString = mapKey.to_s
176
+ mapKeyString[0] = mapKeyString[0].downcase
177
+ mapKey = mapKeyString.to_sym
178
+ val = attributes[mapKey]
179
+ end
180
+ if !val.nil?
181
+ if type =~ /\AArray<(.*)>/i
182
+ # check to ensure the input is an array given that the the attribute
183
+ # is documented as an array but the input is not
184
+ if val.is_a?(Array)
185
+ self.send("#{key}=", val.map { |v| _deserialize($1, v) })
186
+ end
187
+ else
188
+ self.send("#{key}=", _deserialize(type, val))
189
+ end
190
+ end
191
+ end
192
+ end
193
+
194
+ self
195
+ end
196
+
197
+ # Deserializes the data based on type
198
+ # @param string type Data type
199
+ # @param string value Value to be deserialized
200
+ # @return [Object] Deserialized data
201
+ def _deserialize(type, value)
202
+ case type.to_sym
203
+ when :DateTime
204
+ DateTime.parse(value)
205
+ when :Date
206
+ Date.parse(value)
207
+ when :String
208
+ value.to_s
209
+ when :Integer
210
+ value.to_i
211
+ when :Float
212
+ value.to_f
213
+ when :BOOLEAN
214
+ if value.to_s =~ /\A(true|t|yes|y|1)\z/i
215
+ true
216
+ else
217
+ false
218
+ end
219
+ when :Object
220
+ # generic object (usually a Hash), return directly
221
+ value
222
+ when /\AArray<(?<inner_type>.+)>\z/
223
+ inner_type = Regexp.last_match[:inner_type]
224
+ value.map { |v| _deserialize(inner_type, v) }
225
+ when /\AHash<(?<k_type>.+?), (?<v_type>.+)>\z/
226
+ k_type = Regexp.last_match[:k_type]
227
+ v_type = Regexp.last_match[:v_type]
228
+ {}.tap do |hash|
229
+ value.each do |k, v|
230
+ hash[_deserialize(k_type, k)] = _deserialize(v_type, v)
231
+ end
232
+ end
233
+ else # model
234
+ temp_model = AsposeSlidesCloud.const_get(type).new
235
+ temp_model.build_from_hash(value)
236
+ end
237
+ end
238
+
239
+ # Returns the string representation of the object
240
+ # @return [String] String presentation of the object
241
+ def to_s
242
+ to_hash.to_s
243
+ end
244
+
245
+ # to_body is an alias to to_hash (backward compatibility)
246
+ # @return [Hash] Returns the object in the form of hash
247
+ def to_body
248
+ to_hash
249
+ end
250
+
251
+ # Returns the object in the form of hash
252
+ # @return [Hash] Returns the object in the form of hash
253
+ def to_hash
254
+ hash = {}
255
+ self.class.attribute_map.each_pair do |attr, param|
256
+ value = self.send(attr)
257
+ next if value.nil?
258
+ hash[param] = _to_hash(value)
259
+ end
260
+ hash
261
+ end
262
+
263
+ # Outputs non-array value in the form of hash
264
+ # For object, use to_hash. Otherwise, just return the value
265
+ # @param [Object] value Any valid value
266
+ # @return [Hash] Returns the value in the form of hash
267
+ def _to_hash(value)
268
+ if value.is_a?(Array)
269
+ value.compact.map { |v| _to_hash(v) }
270
+ elsif value.is_a?(Hash)
271
+ {}.tap do |hash|
272
+ value.each { |k, v| hash[k] = _to_hash(v) }
273
+ end
274
+ elsif value.respond_to? :to_hash
275
+ value.to_hash
276
+ else
277
+ value
278
+ end
279
+ end
280
+ end
281
+ end