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

Implement the “no audiences” banner error state #8190

Closed
3 of 4 tasks
techanvil opened this issue Jan 29, 2024 · 10 comments
Closed
3 of 4 tasks

Implement the “no audiences” banner error state #8190

techanvil opened this issue Jan 29, 2024 · 10 comments
Labels
Module: Analytics Google Analytics module related issues P1 Medium priority Team M Issues for Squad 2 Type: Enhancement Improvement of an existing feature

Comments

@techanvil
Copy link
Collaborator

techanvil commented Jan 29, 2024

Feature Description

Implement the error handling for the "no audiences" banner, showing the Full Width Error Banner when there is an error.

See no audiences banner > error state in the design doc.


Do not alter or remove anything below. The following sections will be managed by moderators only.

Acceptance criteria

  • Given that the Audience Segmentation feature has already been set up:
    • If an error occurs when syncing the list of available audiences (which should occur for an authenticated user, either when viewing the Audience Widget Area and an hour or more has passed since the last sync, or when opening the Audience Selection Panel the first time for a given page load):
      • The Full Width Error Banner should be displayed in the appropriate variant.
        • If a permission error is returned by the API call, the "insufficient permissions" variant of the error banner will be shown (see the AC for Add the Full Width Error Banner (Storybook) #8230).
        • Otherwise, the catch-all variant will be shown. Clicking the Retry button will retry syncing the list of available audiences.
      • The Audience Tiles and Info Notice should not be displayed.

Implementation Brief

Note that we should ensure this IB is drafted after that of its dependency, #8147.

  • Within AudienceTilesWidget, retrieve the syncAvailableAudiences error via getErrorForAction().
    • If the error is set:
      • Render AudienceSegmentationErrorWidget, passing the error via the errors prop.
      • If the error is not an insufficient permission error:
        • Pass the showRetryButton and onRetry() props.
        • In the onRetry() callback, clear the syncAvailableAudiences error and dispatch the syncAvailableAudiences() action.
  • Refer to AudienceSelectionPanel/ErrorNotice for similar logic regarding the syncAvailableAudiences error.

Test Coverage

  • Add JS test coverage for the changes to AudienceTilesWidget.

QA Brief

  1. Enable audience segmentation and enable audience groups so that audiences are visible in audience tile area.

  2. Install Time Travel extension in chrome.

  3. Using the Tweak Chrome extension, create a rule as follows.

  • URL: .*/wp-json/google-site-kit/v1/modules/analytics-4/data/sync-audiences.*
  • Enable the use of regular expressions (.*)
  • HTTP Method: POST
  • Status code: 400
  • Response payload.
{
    "code": 400,
    "message": "Some Error",
    "data": {
        "status": 400,
        "reason": "Some Reason"
    }
}
  1. Set the time in Time travel extension to couple of hours later in the future. Reload the page.

  2. There should be a the error banner visible in audience tile area with retry button.

  3. Change the payload in tweak to following and refresh the page. This time, there should be no retry button, but banner should be visible.

{
  "code": 400,
  "message": "Some Error",
  "data": {
    "status": 400,
    "reason": "insufficientPermissions"
  }
}

Changelog entry

  • Add handling for audience sync errors in the audiences widget area.
@techanvil techanvil added Module: Analytics Google Analytics module related issues P1 Medium priority Type: Enhancement Improvement of an existing feature labels Jan 29, 2024
@ivonac4
Copy link
Collaborator

ivonac4 commented Feb 2, 2024

@techanvil it looks like this should be added to the design doc, right?

@techanvil
Copy link
Collaborator Author

@ivonac4 yup this has been added to the design doc, I've created an additional issue in for the component and added that as a dependency here. This issue is now ready for AC.

@jimmymadon jimmymadon self-assigned this Feb 6, 2024
@techanvil
Copy link
Collaborator Author

I've moved this back to Backlog as the final in-progress changes to the design doc, relating to audience caching, will probably affect the AC for this one.

I've also unassigned @jimmymadon from this one due to his break.

@techanvil
Copy link
Collaborator Author

The audience caching aspect of the design doc has been sufficiently finalised, and I've moved this back to AC.

@ivonac4 ivonac4 added the Team M Issues for Squad 2 label Apr 9, 2024
@kuasha420 kuasha420 self-assigned this Jul 10, 2024
@techanvil techanvil assigned techanvil and unassigned kuasha420 Jul 25, 2024
@techanvil
Copy link
Collaborator Author

Hey @kuasha420, just letting you know I've picked this one up to add the AC.

@techanvil techanvil removed their assignment Jul 25, 2024
@techanvil techanvil assigned techanvil and unassigned techanvil Aug 6, 2024
@techanvil techanvil assigned techanvil and unassigned techanvil Aug 15, 2024
@kuasha420 kuasha420 self-assigned this Aug 27, 2024
@kuasha420
Copy link
Contributor

Hi @techanvil, the IB looks good overall.

However, in #8130 (related PR #9219) we added a onRetry prop to AudienceSegmentationErrorWidget here. Maybe we can use that instead of creating the new errorActions prop. What do you think?

Cheers.

@kuasha420 kuasha420 assigned techanvil and unassigned kuasha420 Aug 28, 2024
@ivonac4 ivonac4 added Next Up Issues to prioritize for definition and removed Next Up Issues to prioritize for definition labels Aug 29, 2024
@techanvil
Copy link
Collaborator Author

Thanks @kuasha420, that's a good point. #8130 has some related feedback, so I'll hold off until it's been merged and update the IB for this issue accordingly.

@techanvil
Copy link
Collaborator Author

With 8130 merged, I've updated the IB for this issue. Back to you for another pass, @kuasha420.

@techanvil techanvil removed their assignment Sep 10, 2024
@kuasha420
Copy link
Contributor

Thanks @techanvil! That simplifies a lot 😄

IB ✔️

@kuasha420 kuasha420 removed their assignment Sep 11, 2024
@ankitrox ankitrox self-assigned this Sep 19, 2024
@ankitrox ankitrox removed their assignment Sep 25, 2024
@benbowler benbowler assigned benbowler and unassigned benbowler Sep 25, 2024
@nfmohit nfmohit assigned nfmohit and unassigned nfmohit Sep 25, 2024
@mohitwp mohitwp self-assigned this Sep 26, 2024
@mohitwp
Copy link
Collaborator

mohitwp commented Sep 27, 2024

QA Update ✅

  • Tested on dev environment.
  • Tested using Tweak and Time Travel extension.
  • Verified that -
  • If a permission error is returned by the API call, the "insufficient permissions" variant of the error banner appear.
  • Otherwise, the catch-all variant appears. Clicking the Retry button retry syncing the list of available audiences.
  • The Audience Tiles and Info Notice not display.

Insufficient Permission error banner

Recording.1436.mp4

Error banner with Retry Button

Recording.1435.mp4

@mohitwp mohitwp removed their assignment Sep 27, 2024
@tofumatt tofumatt closed this as completed Oct 4, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Module: Analytics Google Analytics module related issues P1 Medium priority Team M Issues for Squad 2 Type: Enhancement Improvement of an existing feature
Projects
None yet
Development

No branches or pull requests

9 participants