mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-23 06:16:50 +00:00
Merge branch 'create-default-serializer' into HEAD
Conflicts: lib/active_model/array_serializer.rb
This commit is contained in:
commit
da26ebd26f
@ -31,7 +31,8 @@ module ActiveModel
|
|||||||
serializer = item.active_model_serializer
|
serializer = item.active_model_serializer
|
||||||
end
|
end
|
||||||
|
|
||||||
serializable = serializer ? serializer.new(item, @options) : item
|
serializable = serializer ? serializer.new(item, @options)
|
||||||
|
: DefaultSerializer.new(item)
|
||||||
|
|
||||||
if serializable.respond_to?(:serializable_hash)
|
if serializable.respond_to?(:serializable_hash)
|
||||||
serializable.serializable_hash
|
serializable.serializable_hash
|
||||||
|
|||||||
@ -395,4 +395,20 @@ module ActiveModel
|
|||||||
ActiveSupport::Notifications.instrument(event_name, payload, &block)
|
ActiveSupport::Notifications.instrument(event_name, payload, &block)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
# DefaultSerializer
|
||||||
|
#
|
||||||
|
# Provides a constant interface for all items, particularly
|
||||||
|
# for ArraySerializer.
|
||||||
|
class DefaultSerializer
|
||||||
|
attr_reader :object, :options
|
||||||
|
|
||||||
|
def initialize(object, options={})
|
||||||
|
@object, @options = object, options
|
||||||
|
end
|
||||||
|
|
||||||
|
def serializable_hash
|
||||||
|
@object.as_json
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -51,5 +51,4 @@ class ArraySerializerTest < ActiveModel::TestCase
|
|||||||
{ :title => "Post2" }
|
{ :title => "Post2" }
|
||||||
], serializer.as_json)
|
], serializer.as_json)
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user