Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[Woo POS] Coupons: Show error when coupons are disabled in core #15468

Merged

Conversation

iamgabrielma
Copy link
Contributor

@iamgabrielma iamgabrielma commented Apr 2, 2025

Partially closes: #15348

Description:

This PR takes a first go to handling coupons being enabled or disabled in core. When coupons are disabled, we show an error screen prompting the user to enable them. Once done, we can refresh and coupons will load.

Screen.Recording.2025-04-02.at.09.56.30.mov

Next steps:

I think we have two options to move forward:

  1. Current approach: The error message just tell the merchant "Please enable coupons in WooCommerce Settings, and retry", then wait until they do so in the web and retry.
  2. A continuation is the CTA showing "Retry" and which would call enableStoreCouponSettings at some point, which enables this setting and refreshes the view automatically. This would need some refactor around how we retry errors in the dashboard view, or perhaps add a secondary action that we can use for coupons only.

In both cases we'd still need a way for the user to switch between products and coupons, this should not be an issue with the latest designs, as both are in the navigation bar, so there's no need for dismissal/close button.

Testing information

  • Load POS, go to coupons, see how they load
  • In WooCommerce Settings > General > Disable "Enable the use of coupon codes" and save changes
  • Reload the view in POS, observe how the error is displayed
  • Re-enable coupons, reload the view in POS, observe how coupons are loaded.

  • I have considered if this change warrants user-facing release notes and have added them to RELEASE-NOTES.txt if necessary.

Reviewer (or Author, in the case of optional code reviews):

Please make sure these conditions are met before approving the PR, or request changes if the PR needs improvement:

  • The PR is small and has a clear, single focus, or a valid explanation is provided in the description. If needed, please request to split it into smaller PRs.
  • Ensure Adequate Unit Test Coverage: The changes are reasonably covered by unit tests or an explanation is provided in the PR description.
  • Manual Testing: The author listed all the tests they ran, including smoke tests when needed (e.g., for refactorings). The reviewer confirmed that the PR works as expected on all devices (phone/tablet) and no regressions are added.

@iamgabrielma iamgabrielma added type: task An internally driven task. feature: coupons Related to basic fulfillment such as order tracking. feature: POS labels Apr 2, 2025
@iamgabrielma iamgabrielma added this to the 22.1 milestone Apr 2, 2025
}
}

private func enableStoreCouponSettings() async -> Bool {
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is not used at the moment, happy to remove it or keep it if you prefer that we handle the enable action via CTA on this same PR 👍

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we're not handling enabling on this PR, then let's remove it. 👍

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Done! d2619de

@iamgabrielma iamgabrielma requested a review from staskus April 2, 2025 03:13
@wpmobilebot
Copy link
Collaborator

wpmobilebot commented Apr 2, 2025

App Icon📲 You can test the changes from this Pull Request in WooCommerce iOS Prototype by scanning the QR code below to install the corresponding build.

App NameWooCommerce iOS Prototype
Build Number29133
VersionPR #15468
Bundle IDcom.automattic.alpha.woocommerce
Commitd2619de
Installation URL49mim6k5ccff8
Automatticians: You can use our internal self-serve MC tool to give yourself access to those builds if needed.

@staskus
Copy link
Contributor

staskus commented Apr 2, 2025

Thanks for starting to tackle this.

According to the requirements (pdfdoF-6BG-p2), the expectation is:

Coupons disabled (WooCommerce > Settings > General > Enable coupons):
Show a message and CTA to enable coupon functionality. Reload the list once the setting is enabled.

This is what we have in IPP right now, and that would be an expectation:

Simulator.Screen.Recording.-.iPad.Air.11-inch.M2.-.2025-04-02.at.09.57.07.mp4

This would need some refactor around how we retry errors in the dashboard view, or perhaps add a secondary action that we can use for coupons only.

Yes. It will probably require some refactoring:

  • Products / Coupons switch should be visible when error appears
  • Coupon disabled error should have a specific handler for enabling a setting and only then refreshing the view

Copy link
Contributor

@staskus staskus left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks!

Since the title of PR is "Show error when coupons are disabled", the goal is fulfilled.

On the next PR, the rest of the things can be handled as I mentioned in the previous comment.

}
}

private func enableStoreCouponSettings() async -> Bool {
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

If we're not handling enabling on this PR, then let's remove it. 👍

@dangermattic
Copy link
Collaborator

1 Warning
⚠️ This PR is assigned to the milestone 22.1. This milestone is due in less than 2 days.
Please make sure to get it merged by then or assign it to a milestone with a later deadline.

Generated by 🚫 Danger

@iamgabrielma
Copy link
Contributor Author

Thanks for the review!

Yes. It will probably require some refactoring:

- Products / Coupons switch should be visible when error appears
- Coupon disabled error should have a specific handler for enabling a setting and only then refreshing the view

Perfect, I'll merge this for the moment and log/handle the "enable coupons" action separately 👍

@iamgabrielma iamgabrielma enabled auto-merge April 2, 2025 09:36
@iamgabrielma iamgabrielma merged commit c5d8155 into trunk Apr 2, 2025
13 checks passed
@iamgabrielma iamgabrielma deleted the issue/15348-pos-coupons-enabled-disabled-in-core branch April 2, 2025 09:54
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
feature: coupons Related to basic fulfillment such as order tracking. feature: POS type: task An internally driven task.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

[Woo POS] Coupons: Handle coupons enabled/disabled in core
4 participants