mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-24 14:56:50 +00:00
Avoid work inside serializable_array
This commit is contained in:
parent
8006529e20
commit
86b9d5a226
@ -13,19 +13,20 @@ module ActiveModel
|
|||||||
end
|
end
|
||||||
|
|
||||||
def initialize(object, options={})
|
def initialize(object, options={})
|
||||||
@object = object
|
@object = object
|
||||||
@options = options
|
@root = options[:root]
|
||||||
@root = options[:root]
|
@root = self.class._root if @root.nil?
|
||||||
@root = self.class._root if @root.nil?
|
@meta_key = options[:meta_key] || :meta
|
||||||
@meta_key = options[:meta_key] || :meta
|
@meta = options[@meta_key]
|
||||||
@meta = options[@meta_key]
|
@each_serializer = options[:each_serializer]
|
||||||
|
@options = options.merge(root: nil)
|
||||||
end
|
end
|
||||||
attr_accessor :object, :root, :meta_key, :meta
|
attr_accessor :object, :root, :meta_key, :meta
|
||||||
|
|
||||||
def serializable_array
|
def serializable_array
|
||||||
@object.map do |item|
|
@object.map do |item|
|
||||||
serializer = @options[:each_serializer] || Serializer.serializer_for(item) || DefaultSerializer
|
serializer = @each_serializer || Serializer.serializer_for(item) || DefaultSerializer
|
||||||
serializer.new(item, @options.merge(root: nil)).serializable_object
|
serializer.new(item, @options).serializable_object
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
alias serializable_object serializable_array
|
alias serializable_object serializable_array
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user