mirror of
https://github.com/ditkrg/active_model_serializers.git
synced 2026-01-22 22:06:50 +00:00
Add type when association name is different than objects type
This commit is contained in:
parent
462efc0ea5
commit
2d21a8e83f
@ -34,8 +34,18 @@ module ActiveModel
|
|||||||
end
|
end
|
||||||
|
|
||||||
def add_links(name, serializers, options)
|
def add_links(name, serializers, options)
|
||||||
@hash[@root][:links][name] ||= []
|
if serializers.first
|
||||||
@hash[@root][:links][name] += serializers.map{|serializer| serializer.id.to_s }
|
type = serializers.first.object.class.to_s.underscore.pluralize
|
||||||
|
end
|
||||||
|
if name.to_s == type || !type
|
||||||
|
@hash[@root][:links][name] ||= []
|
||||||
|
@hash[@root][:links][name] += serializers.map{|serializer| serializer.id.to_s }
|
||||||
|
else
|
||||||
|
@hash[@root][:links][name] ||= {}
|
||||||
|
@hash[@root][:links][name][:type] = type
|
||||||
|
@hash[@root][:links][name][:ids] ||= []
|
||||||
|
@hash[@root][:links][name][:ids] += serializers.map{|serializer| serializer.id.to_s }
|
||||||
|
end
|
||||||
|
|
||||||
unless options[:embed] == :ids
|
unless options[:embed] == :ids
|
||||||
@hash[:linked][name] ||= []
|
@hash[:linked][name] ||= []
|
||||||
@ -45,7 +55,14 @@ module ActiveModel
|
|||||||
|
|
||||||
def add_link(name, serializer, options)
|
def add_link(name, serializer, options)
|
||||||
if serializer
|
if serializer
|
||||||
@hash[@root][:links][name] = serializer.id.to_s
|
type = serializer.object.class.to_s.underscore
|
||||||
|
if name.to_s == type || !type
|
||||||
|
@hash[@root][:links][name] = serializer.id.to_s
|
||||||
|
else
|
||||||
|
@hash[@root][:links][name] ||= {}
|
||||||
|
@hash[@root][:links][name][:type] = type
|
||||||
|
@hash[@root][:links][name][:id] = serializer.id.to_s
|
||||||
|
end
|
||||||
|
|
||||||
unless options[:embed] == :ids
|
unless options[:embed] == :ids
|
||||||
plural_name = name.to_s.pluralize.to_sym
|
plural_name = name.to_s.pluralize.to_sym
|
||||||
|
|||||||
@ -15,6 +15,9 @@ module ActiveModel
|
|||||||
@comment.post = @post
|
@comment.post = @post
|
||||||
@post.author = @author
|
@post.author = @author
|
||||||
@anonymous_post.author = nil
|
@anonymous_post.author = nil
|
||||||
|
@blog = Blog.new(id: 1, name: "My Blog!!")
|
||||||
|
@blog.writer = @author
|
||||||
|
@blog.articles = [@post, @anonymous_post]
|
||||||
|
|
||||||
@serializer = CommentSerializer.new(@comment)
|
@serializer = CommentSerializer.new(@comment)
|
||||||
@adapter = ActiveModel::Serializer::Adapter::JsonApi.new(@serializer)
|
@adapter = ActiveModel::Serializer::Adapter::JsonApi.new(@serializer)
|
||||||
@ -34,6 +37,12 @@ module ActiveModel
|
|||||||
|
|
||||||
assert_equal({comments: [], author: nil}, adapter.serializable_hash[:posts][:links])
|
assert_equal({comments: [], author: nil}, adapter.serializable_hash[:posts][:links])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_include_type_for_association_when_is_different_than_name
|
||||||
|
serializer = BlogSerializer.new(@blog)
|
||||||
|
adapter = ActiveModel::Serializer::Adapter::JsonApi.new(serializer)
|
||||||
|
assert_equal({type: "author", id: "1"}, adapter.serializable_hash[:blogs][:links][:writer])
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
@ -7,13 +7,16 @@ module ActiveModel
|
|||||||
class HasManyTest < Minitest::Test
|
class HasManyTest < Minitest::Test
|
||||||
def setup
|
def setup
|
||||||
@author = Author.new(id: 1, name: 'Steve K.')
|
@author = Author.new(id: 1, name: 'Steve K.')
|
||||||
@post = Post.new(title: 'New Post', body: 'Body')
|
@post = Post.new(id: 1, title: 'New Post', body: 'Body')
|
||||||
@first_comment = Comment.new(id: 1, body: 'ZOMG A COMMENT')
|
@first_comment = Comment.new(id: 1, body: 'ZOMG A COMMENT')
|
||||||
@second_comment = Comment.new(id: 2, body: 'ZOMG ANOTHER COMMENT')
|
@second_comment = Comment.new(id: 2, body: 'ZOMG ANOTHER COMMENT')
|
||||||
@post.comments = [@first_comment, @second_comment]
|
@post.comments = [@first_comment, @second_comment]
|
||||||
@first_comment.post = @post
|
@first_comment.post = @post
|
||||||
@second_comment.post = @post
|
@second_comment.post = @post
|
||||||
@post.author = @author
|
@post.author = @author
|
||||||
|
@blog = Blog.new(id: 1, name: "My Blog!!")
|
||||||
|
@blog.writer = @author
|
||||||
|
@blog.articles = [@post]
|
||||||
|
|
||||||
@serializer = PostSerializer.new(@post)
|
@serializer = PostSerializer.new(@post)
|
||||||
@adapter = ActiveModel::Serializer::Adapter::JsonApi.new(@serializer)
|
@adapter = ActiveModel::Serializer::Adapter::JsonApi.new(@serializer)
|
||||||
@ -29,6 +32,12 @@ module ActiveModel
|
|||||||
{id: "2", body: 'ZOMG ANOTHER COMMENT'}
|
{id: "2", body: 'ZOMG ANOTHER COMMENT'}
|
||||||
], @adapter.serializable_hash[:linked][:comments])
|
], @adapter.serializable_hash[:linked][:comments])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_include_type_for_association_when_is_different_than_name
|
||||||
|
serializer = BlogSerializer.new(@blog)
|
||||||
|
adapter = ActiveModel::Serializer::Adapter::JsonApi.new(serializer)
|
||||||
|
assert_equal({type: "posts", ids: ["1"]}, adapter.serializable_hash[:blogs][:links][:articles])
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|||||||
8
test/fixtures/poro.rb
vendored
8
test/fixtures/poro.rb
vendored
@ -38,6 +38,7 @@ end
|
|||||||
Post = Class.new(Model)
|
Post = Class.new(Model)
|
||||||
Comment = Class.new(Model)
|
Comment = Class.new(Model)
|
||||||
Author = Class.new(Model)
|
Author = Class.new(Model)
|
||||||
|
Blog = Class.new(Model)
|
||||||
|
|
||||||
PostSerializer = Class.new(ActiveModel::Serializer) do
|
PostSerializer = Class.new(ActiveModel::Serializer) do
|
||||||
attributes :title, :body, :id
|
attributes :title, :body, :id
|
||||||
@ -58,3 +59,10 @@ AuthorSerializer = Class.new(ActiveModel::Serializer) do
|
|||||||
|
|
||||||
has_many :posts, embed: :ids
|
has_many :posts, embed: :ids
|
||||||
end
|
end
|
||||||
|
|
||||||
|
BlogSerializer = Class.new(ActiveModel::Serializer) do
|
||||||
|
attributes :id, :name
|
||||||
|
|
||||||
|
belongs_to :writer
|
||||||
|
has_many :articles
|
||||||
|
end
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user