Skip to content

Commit 572ff7d

Browse files
committed
Refactor add_links in JSONAPI adapter.
1 parent 7e2f3d1 commit 572ff7d

File tree

2 files changed

+12
-16
lines changed

2 files changed

+12
-16
lines changed

lib/active_model/serializer/adapter/json_api.rb

Lines changed: 6 additions & 16 deletions
Original file line numberDiff line numberDiff line change
@@ -29,7 +29,10 @@ def serializable_hash(options = nil)
2929
end
3030
end
3131

32-
add_links(options)
32+
if serializer.paginated?
33+
@hash[:links] ||= {}
34+
@hash[:links].update(links_for(serializer, options))
35+
end
3336
else
3437
primary_data = primary_data_for(serializer, options)
3538
relationships = relationships_for(serializer)
@@ -145,20 +148,7 @@ def _included_for(serializer, includes)
145148
end
146149
end
147150

148-
def add_links(options)
149-
links = @hash.fetch(:links) { {} }
150-
collection = serializer.object
151-
@hash[:links] = add_pagination_links(links, collection, options) if paginated?(collection)
152-
end
153-
154-
def add_pagination_links(links, resources, options)
155-
pagination_links = ActiveModel::Serializer::Adapter::JsonApi::PaginationLinks.new(resources, options[:context]).serializable_hash(options)
156-
links.update(pagination_links)
157-
end
158-
159-
def paginated?(collection)
160-
collection.respond_to?(:current_page) &&
161-
collection.respond_to?(:total_pages) &&
162-
collection.respond_to?(:size)
151+
def links_for(serializer, options)
152+
JsonApi::PaginationLinks.new(serializer.object, options[:context]).serializable_hash(options)
163153
end
164154
end

lib/active_model/serializer/array_serializer.rb

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -29,6 +29,12 @@ def json_key
2929
key = root || @serializers.first.try(:json_key) || object.try(:name).try(:underscore)
3030
key.try(:pluralize)
3131
end
32+
33+
def paginated?
34+
object.respond_to?(:current_page) &&
35+
object.respond_to?(:total_pages) &&
36+
object.respond_to?(:size)
37+
end
3238
end
3339
end
3440
end

0 commit comments

Comments
 (0)