site-kit-wp
site-kit-wp copied to clipboard
Trigger the custom GA `view_notification` event only when the banner notifications are visible
Bug Description
Currently, some banner notifications trigger the custom GA view_notification
event using the useMount
hook. However, the view_notification
event will be triggered even if the banner notification is not displayed due to the respective component returning null
if the data is unavailable.
The above event should be triggered if the respective banner notification is displayed.
Steps to reproduce
- Go to the Site Kit dashboard.
- Ensure the Google Analytics Debugger is enabled.
- Open the dev tools->console and filter by
view_notification
. - Notice some GA events are triggered even though respective banner notifications aren't displayed. For example,
mainDashboard_wp52-version-notification
is triggered.
Do not alter or remove anything below. The following sections will be managed by moderators only.
Acceptance criteria
- All the banner notifications that trigger the custom GA
view_notification
event should be triggered if the respective banner notification is displayed. The following notification events should be checked to only send when the component actually renders and doesn'treturn null
- https://github.com/google/site-kit-wp/blob/a7a6f45123b24b9c767ac62ae4dcd2c6c5a1bd6a/assets/js/components/activation/activation-app.js#L62
- https://github.com/google/site-kit-wp/blob/a7a6f45123b24b9c767ac62ae4dcd2c6c5a1bd6a/assets/js/components/notifications/SetupSuccessBannerNotification.js#L99-L102
- https://github.com/google/site-kit-wp/blob/a7a6f45123b24b9c767ac62ae4dcd2c6c5a1bd6a/assets/js/components/notifications/WPVersionBumpNotification.js#L53
Implementation Brief
- We should trigger the
trackEvent
call within auseEffect
instead of theuseMount
hook, conditionally on the same code path that causes the component to actually render. An example of how we have done this is in theThankWithGoogleSupporterWallNotification
component.
Test Coverage
QA Brief
Changelog entry
ACs here are largely good, but I wanted to call out which components were actually affected. I'll move this to IB, and I can work on that myself 👍🏻
Thanks, @tofumatt. Could you please add more information to IB? I think that each components have different circumstances when we can consider them as rendered, right? Let's write them down in IB.
Thanks, @tofumatt. IB ✔️
QA Update: ⚠️
@hussain-t I have a query based on this section of the QAB.
Install Site Kit via the plugin directory and activate it. Ensure the view_notification GA event for the mainDashboard event category is triggered only when the ActivationApp notification is displayed. (This notification will have the Congratulations, the Site Kit plugin is now activated. title).
When viewing the log the mainDashboard
event is not showing and I am wondering if this is expected, since the Congratulations, the Site Kit plugin is now activated. title
takes place on the plugins page. Please could you confirm this. This is what I see.
data:image/s3,"s3://crabby-images/94259/94259151c9b21f6f56cf7f4494c441db118fca78" alt="events-1"
@wpdarren, you're correct mainDashboard
won't be available on the plugins page rather, it should be the activation
category for the view_notification
event.
QA Update: ✅
Verified:
- The
view_notification
GA event for the activation category is triggered only when the ActivationApp notification is displayed. - The
view_notification
GA event for the mainDashboard_wp52-version-notification event category is triggered only when the WPVersionBumpNotification is displayed. The following events are triggered only when theSetupSuccessBannerNotification
is displayed:view_notification
- mainDashboard_authentication-success-notification-
complete_user_setup
- mainDashboard_authentication-success-notification -
complete_site_setup
- mainDashboard_authentication-success-notification
-
Screenshots
⚠️ Approval
Not sure if this is a regression, but I still see the main authentication success view_notification
event even when has been dismissed.
data:image/s3,"s3://crabby-images/3473a/3473ae7cdfe35a2d187a88bf78e52e7f22a76f4a" alt="image"
Also, it seems that view_notification
events are triggered even when it isn't visible (i.e. hidden by CSS) due to the limit of only one shown at a time.
This can be seen by meeting the conditions for seeing the WPVersionBumpNotification
, not dismissing it, and then visiting /wp-admin/admin.php?page=googlesitekit-dashboard¬ification=authentication_success&slug=analytics
to trigger the SetupSuccessBannerNotification
. view_notification
events are triggered for both right away even though only the success banner notification is visible.
cc: @hussain-t @tofumatt
It may be that this fulfills the AC as-is but we probably want to open a follow-up here so that view events are truly triggered when in-view (maybe using IntersectionObserver?)
Good spot there @aaemnnosttv. I have looked into this and it's not a regression as I can see the same behaviour in the previous release. I've created a followup issue to address this: https://github.com/google/site-kit-wp/issues/6109