Query string parameters token replacement broken when configured param is empty

Created on 5 June 2019, over 5 years ago
Updated 7 February 2023, almost 2 years ago

Problem/Motivation

#1442960: Query string parameters token replacements added the ability to use query string parameters from the current request to replace tokens in fields using the "render as link" feature. The original patch made sure that query string parameters were removed from the generated URL when the corresponding parameters in the current request URL where missing or empty. This no longer happens in D8, so the /node/[nid]?page={{ arguments.page }} pattern is translated to /node/1?page= on when the current URL is /node/1. This among the rest breaks active URL handling.

Proposed resolution

Restore the original behavior and remove configured parameters when they are empty.

Remaining tasks

  • Validate the proposed solution
  • Add test coverage
  • Reviews

User interface changes

None

API changes

None

Data model changes

None

Release notes snippet

None

🐛 Bug report
Status

Postponed: needs info

Version

10.1

Component
Views 

Last updated about 3 hours ago

Created by

🇮🇹Italy plach Venezia

Live updates comments and jobs are added and updated live.
  • Needs tests

    The change is currently missing an automated test that fails when run with the original code, and succeeds when the bug has been fixed.

Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇺🇸United States smustgrave

    This issue is being reviewed by the kind folks in Slack, #needs-review-queue-initiative. We are working to keep the size of Needs Review queue [2700+ issues] to around 400 (1 month or less), following Review a patch or merge request as a guide.

    Moving to PNMI for steps to reproduce per #8

  • Status changed to Needs work 9 months ago
  • 🇳🇱Netherlands Lendude Amsterdam

    Steps to reproduce:
    * Create a View of nodes
    * Show fields
    * Show the nid and title field
    * Add a contextual filter 'Content: Has taxonomy term ID' and set default value to ' Display all results for the specified field'
    * For the title field set rewrite results: Output this field as a custom link to /node/{{ nid }}?term_id={{ arguments.tid }}
    * Create a page display
    * Go to the page and see that 'term_id' is added to the link URL on the title, bt with no value

    Didn't try the patch yet

  • First commit to issue fork.
  • 🇪🇸Spain vidorado Pamplona (Navarra)

    I’ve created an MR but wasn’t able to figure out how to write the tests. The existing tests in core/modules/views/tests/src/Unit/Plugin/field/FieldPluginBaseTest.php are a bit complex for me to follow. Additionally, I’m unsure whether this can be unit tested or if it requires functional tests due to its dependency on view arguments.

    I’ve also updated the steps to reproduce, as the view argument name (tid) must match the query parameter name set in the rewrite field (which was mistakenly set to term_id).

Production build 0.71.5 2024