diff options
author | Rafael França <rafaelmfranca@gmail.com> | 2017-01-04 23:34:56 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-01-04 23:34:56 -0500 |
commit | 333283e79dc45c294f6928adf6dc2f0a7a7dedde (patch) | |
tree | 65f05c8e8cfa9ffeb6e576200cd138f9942895cb /actionview/lib/action_view/helpers | |
parent | 4f22406aae0221958eefaf5571cda4a68bc11a5d (diff) | |
parent | 13352f6972b4dbc9af33b0634a26184f1c4eb2c1 (diff) | |
download | rails-333283e79dc45c294f6928adf6dc2f0a7a7dedde.tar.gz rails-333283e79dc45c294f6928adf6dc2f0a7a7dedde.tar.bz2 rails-333283e79dc45c294f6928adf6dc2f0a7a7dedde.zip |
Merge pull request #27549 from mpugach/consider_params_in_current_page
Add "check_parameters" option to "current_page?"
Diffstat (limited to 'actionview/lib/action_view/helpers')
-rw-r--r-- | actionview/lib/action_view/helpers/url_helper.rb | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/actionview/lib/action_view/helpers/url_helper.rb b/actionview/lib/action_view/helpers/url_helper.rb index 58a4a04dcb..1f753bccd6 100644 --- a/actionview/lib/action_view/helpers/url_helper.rb +++ b/actionview/lib/action_view/helpers/url_helper.rb @@ -517,6 +517,9 @@ module ActionView # current_page?('http://www.example.com/shop/checkout') # # => true # + # current_page?('http://www.example.com/shop/checkout', check_parameters: true) + # # => false + # # current_page?('/shop/checkout') # # => true # @@ -530,7 +533,7 @@ module ActionView # # We can also pass in the symbol arguments instead of strings. # - def current_page?(options) + def current_page?(options, check_parameters: false) unless request raise "You cannot use helpers that need to determine the current " \ "page unless your view context provides a Request object " \ @@ -539,12 +542,14 @@ module ActionView return false unless request.get? || request.head? + check_parameters ||= !options.is_a?(String) && options.try(:delete, :check_parameters) url_string = URI.parser.unescape(url_for(options)).force_encoding(Encoding::BINARY) # We ignore any extra parameters in the request_uri if the # submitted url doesn't have any either. This lets the function # work with things like ?order=asc - request_uri = url_string.index("?") ? request.fullpath : request.path + # the behaviour can be disabled with check_parameters: true + request_uri = url_string.index("?") || check_parameters ? request.fullpath : request.path request_uri = URI.parser.unescape(request_uri).force_encoding(Encoding::BINARY) url_string.chomp!("/") if url_string.start_with?("/") && url_string != "/" |