- Issue created by @Anybody
- First commit to issue fork.
- Merge request !378Issue #3484265: Show a confirmation message on successful Coupon redemption & expand wrapper → (Merged) created by Grevil
- 🇩🇪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.
- 🇩🇪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!
- 🇩🇪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.
- Assigned to Grevil
- Status changed to Needs review
2 months ago 1:18pm 30 January 2025 - 🇩🇪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
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.
- 🇩🇪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!
- 🇮🇱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();
. - 🇩🇪Germany Anybody Porta Westfalica
@jsacksick you saw that
applyCoupon()
is a static method? How would DI work there? - 🇮🇱Israel jsacksick
Apologies... This is what I see when reviewing the MR:
As you can see, very little "context"... Merging this.
-
jsacksick →
committed d1bd2465 on 3.0.x authored by
grevil →
Issue #3484265 by grevil, anybody, jsacksick: Show a confirmation...
-
jsacksick →
committed d1bd2465 on 3.0.x authored by
grevil →
- 🇩🇪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.