Show a confirmation message on successful Coupon redemption

Created on 29 October 2024, 5 months ago

Problem/Motivation

Currently, if a coupon is redeemed successfully, no success message is shown in the checkout, which I think is confusing and bad UX. It's even worse because if wrapper_element_open setting is FALSE, the wrapper will be collapsed, even if a coupon is present.

We should fix both! :)

Steps to reproduce

Add a coupon in checkout and see the results described above.

Proposed resolution

  1. Show a success message, if coupon was redeemed successfully
  2. If a coupon is present, keep the wrapper element open

Remaining tasks

User interface changes

Introduced terminology

API changes

Data model changes

Release notes snippet

Feature request
Status

Active

Version

3.0

Component

Promotions

Created by

🇩🇪Germany Anybody Porta Westfalica

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Merge Requests

Comments & Activities

  • Issue created by @Anybody
  • 🇩🇪Germany Anybody Porta Westfalica
  • 🇩🇪Germany Anybody Porta Westfalica
  • First commit to issue fork.
  • 🇩🇪Germany Grevil

    Alright, this works after the first form is submitted. Unfortunately, it doesn't work for any AJAX calls yet. Furthermore, I can't seem to get the message to display. I'll have a deeper look tommorow.

  • Pipeline finished with Success
    4 months ago
    Total: 531s
    #352147
  • 🇩🇪Germany Anybody Porta Westfalica

    Great, it already improves the situation once a coupon code has been entered.

  • 🇩🇪Germany Grevil

    Alright, works perfectly now! Including any ajax calls :)

    Please review!

  • Pipeline finished with Canceled
    4 months ago
    Total: 271s
    #360061
  • Pipeline finished with Canceled
    4 months ago
    Total: 531s
    #360068
  • 🇩🇪Germany Grevil

    Added a temporary patch for the time being.

  • Pipeline finished with Failed
    4 months ago
    #360078
  • 🇩🇪Germany Anybody Porta Westfalica

    Test needs to be fixed

  • 🇩🇪Germany Anybody Porta Westfalica

    Patch has a bug! Use statement for TranslatableMarkup is missing!

    I'll fix that now.

  • 🇩🇪Germany Anybody Porta Westfalica

    Ah I see it's not a bug in the patch, the patch is for 3.0.x and applies for 2.x but in 2.x there's no such use statement... -.-

    So I'll create a separate MR for that.

  • 🇩🇪Germany Anybody Porta Westfalica

    Patch for 8.x-2.x attached!

  • 🇩🇪Germany Anybody Porta Westfalica
  • Pipeline finished with Failed
    3 months ago
    Total: 995s
    #375785
  • Pipeline finished with Failed
    3 months ago
    Total: 700s
    #375786
  • Assigned to Grevil
  • Status changed to Needs review 2 months ago
  • 🇩🇪Germany Grevil

    grevil changed the visibility of the branch 3.0.x to hidden.

  • 🇩🇪Germany Grevil

    I don't think a separate branch and MR for 2.x isn't needed, as all of the work goes into 3.x now.

  • 🇩🇪Germany Grevil

    grevil changed the visibility of the branch 3484265-show-a-confirmation-2.x to hidden.

  • Pipeline finished with Failed
    2 months ago
    Total: 507s
    #410371
  • 🇩🇪Germany Grevil

    No idea, everything works as intended, but the test failures are definitely related to these issues changes, but I don't quite understand what's wrong...
    Everything works great and as expected, but inside the tests, the error "Unable to complete AJAX request" always appears. This is caused by the new "ajaxRefreshForm()" method. But, even if that method is ENTIRELY EMPTY and only calls the parent "ajaxRefreshForm()" method we get the exact same failure. I even tried to go back to the old [get_called_class(), 'ajaxRefreshForm'], but that breaks the ajax request outside the tests as well (and the test also fail with the same error message, even if it shouldn't).

    My first thought was, that we have to open the coupon code wrapper before we press the "ApplyCode" button, but inside the tests there is no wrapper. I also partially removed changes from this issue, to see what causes the failure, but it is definitely related to the new "ajaxRefreshForm" method.

  • Pipeline finished with Success
    2 months ago
    Total: 508s
    #410490
  • 🇩🇪Germany Grevil

    Missed a return statement....

  • 🇩🇪Germany Anybody Porta Westfalica

    Well tested and tests are green now. This is a nice improvement, so happy to RTBC :)

  • 🇩🇪Germany Anybody Porta Westfalica

    Static patch attached until this is merged!

  • 🇩🇪Germany Grevil

    Static patch for 3.0.x for the time being.

  • 🇮🇱Israel jsacksick

    I generally dislike fixes that make assumptions about pane IDS or pane placement... Additionally, this is not using dependency injection for the messenger and direct \Drupal calls() are generally not a good practice.

  • 🇩🇪Germany Grevil

    "applyCoupon()" is static, so I can't use the messenger service inside that method, unfortunately.

  • 🇩🇪Germany Grevil

    Ok, this should be it! Honestly, I have no idea, why I even added the "AjaxRefreshForm" method, the changes done in the CheckoutPane class already solves the issue.

    Maybe I had caching issues and didn't realize it. Still works as expected, and we don't check for a specific pane placement!

    Please review once again!

  • 🇮🇱Israel jsacksick

    Ok so we are still not injecting the messenger. We probably should remove the constructor and do the injection from the create() method. This would be considered as a BC for some people, but I don't like the alternative of conditionally setting the messenger if not injected.

    Also, I believe this is still a risk of showing a success message despite the coupon being removed on refresh. It's curious that we aren't doing like in the processor, i.e. validating the coupons reference... But this is probably out of scope for this issue:

    $constraints = $coupons_field_list->validate();.

  • Pipeline finished with Success
    about 2 months ago
    Total: 546s
    #414576
  • 🇩🇪Germany Anybody Porta Westfalica

    @jsacksick you saw that applyCoupon() is a static method? How would DI work there?

  • Pipeline finished with Skipped
    about 2 months ago
    #414701
  • 🇮🇱Israel jsacksick

    Apologies... This is what I see when reviewing the MR:

    As you can see, very little "context"... Merging this.

  • 🇩🇪Germany Anybody Porta Westfalica

    All good, so we're not total idiots, that's reassuring 😁

    Thank you!!

  • Automatically closed - issue fixed for 2 weeks with no activity.

Production build 0.71.5 2024