diff options
Diffstat (limited to 'actionpack')
-rw-r--r-- | actionpack/lib/action_dispatch/routing/polymorphic_routes.rb | 29 |
1 files changed, 19 insertions, 10 deletions
diff --git a/actionpack/lib/action_dispatch/routing/polymorphic_routes.rb b/actionpack/lib/action_dispatch/routing/polymorphic_routes.rb index 36db278eab..074eb8a59c 100644 --- a/actionpack/lib/action_dispatch/routing/polymorphic_routes.rb +++ b/actionpack/lib/action_dispatch/routing/polymorphic_routes.rb @@ -117,6 +117,8 @@ module ActionDispatch record = extract_record(record_or_hash_or_array) record = convert_to_model(record) + record_list = extract_record_list(record_or_hash_or_array) + args = Array === record_or_hash_or_array ? record_or_hash_or_array.dup : [ record_or_hash_or_array ] @@ -130,12 +132,15 @@ module ActionDispatch elsif record.is_a?(Class) args.pop :plural + elsif record.is_a?(Hash) + record_list = [] + :singular else :singular end args.delete_if {|arg| arg.is_a?(Symbol) || arg.is_a?(String)} - named_route = build_named_route_call(record_or_hash_or_array, record, inflection, options) + named_route = build_named_route_call(record_list, record, inflection, options) url_options = options.except(:action, :routing_type) unless url_options.empty? @@ -193,12 +198,8 @@ module ActionDispatch end def build_named_route_call(records, record, inflection, options) - if records.is_a?(Array) - records.pop - route = records.map { |parent| build_route_part parent, :singular } - else - route = [] - end + records.pop + route = records.map { |parent| build_route_part parent, :singular } route << build_route_part(record, inflection) route << routing_type(options) @@ -208,9 +209,17 @@ module ActionDispatch def extract_record(record_or_hash_or_array) case record_or_hash_or_array - when Array; record_or_hash_or_array.last - when Hash; record_or_hash_or_array[:id] - else record_or_hash_or_array + when Array; record_or_hash_or_array.last + when Hash; record_or_hash_or_array[:id] + else record_or_hash_or_array + end + end + + def extract_record_list(record_or_hash_or_array) + case record_or_hash_or_array + when Array; record_or_hash_or_array + when Hash; [record_or_hash_or_array[:id]].compact + else [record_or_hash_or_array] end end end |