-
Notifications
You must be signed in to change notification settings - Fork 1.5k
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
feat(retention): graph UX updates #29270
base: master
Are you sure you want to change the base?
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
PR Summary
This PR enhances the retention graph UX with multiple visualization and display options for better dashboard integration.
- Added
RetentionOptions
component that separates retention calculation settings from display controls - Created
RetentionChartPicker
allowing users to switch between line and bar chart visualizations - Implemented
RetentionDashboardDisplayPicker
with options to show table-only, graph-only, or both in dashboards - Replaced checkbox with
RetentionCumulativeButton
using segmented controls with improved tooltips - Modified
RetentionContainer
to conditionally render components based on dashboard display preferences
20 file(s) reviewed, 7 comment(s)
Edit PR Review Bot Settings | Greptile
frontend/src/scenes/insights/filters/RetentionCumulativeButton.tsx
Outdated
Show resolved
Hide resolved
frontend/src/scenes/insights/filters/RetentionCumulativeButton.tsx
Outdated
Show resolved
Hide resolved
const showLineGraph = | ||
!vizSpecificOptions?.hideLineGraph && | ||
(!inCardView || | ||
(!!retentionFilter?.dashboardDisplay && // for backwards compatibility as we were hiding the graph on dashboards before adding this property | ||
retentionFilter?.dashboardDisplay !== RetentionDashboardDisplayType.TableOnly)) | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
logic: The showLineGraph logic has a potential issue with the double negative (!vizSpecificOptions?.hideLineGraph). When inCardView is true but retentionFilter.dashboardDisplay is undefined (for existing dashboards), the graph will be hidden. This matches the comment about backwards compatibility, but might be confusing for users upgrading.
Size Change: +813 B (+0.01%) Total Size: 9.73 MB ℹ️ View Unchanged
|
📸 UI snapshots have been updated22 snapshot changes in total. 0 added, 22 modified, 0 deleted:
Triggered by this commit. |
…into feat/retention-graph-ux
Co-authored-by: greptile-apps[bot] <165735046+greptile-apps[bot]@users.noreply.github.com>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Cool thing!
Some remarks:
- Please add frontend only settings to https://github.com/PostHog/posthog/blob/master/frontend/src/scenes/insights/utils/queryUtils.ts#L132-L151 and https://github.com/PostHog/posthog/blob/master/posthog/schema_helpers.py#L58-L81.
- I accepted a couple of greptile's suggestions regarding grammar spelling.
- It looks like the numbers change in visual regression tests. Is the code in
retentionTableLogic
correct? - Schema changes are backwards compatible, so no issue there.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Seems odd to me that the numbers would change in visual regression tests.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Updating retention reference updates the table as well now (previously only changed the line graph). This would mean some numbers changed, but is there a way to tell if this snapshot was created with a different retention reference?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The snapshots come from storybook and the query for that is mocked in https://github.com/PostHog/posthog/tree/master/frontend/src/mocks/fixtures/api/projects/team_id/insights.
Mocks still have filters in them, could that cause an issue as well? - Happy to pair on this, if easier.
📸 UI snapshots have been updated1 snapshot changes in total. 0 added, 1 modified, 0 deleted:
Triggered by this commit. |
📸 UI snapshots have been updated1 snapshot changes in total. 0 added, 1 modified, 0 deleted:
Triggered by this commit. |
…into feat/retention-graph-ux
📸 UI snapshots have been updated2 snapshot changes in total. 0 added, 2 modified, 0 deleted:
Triggered by this commit. |
📸 UI snapshots have been updated12 snapshot changes in total. 0 added, 12 modified, 0 deleted:
Triggered by this commit. |
Problem
Closes #23911
Lot of UX changes highlighted below
Changes
Option to show retention graph in dashboards
data:image/s3,"s3://crabby-images/5b9ae/5b9aea662f4e3418c8f00e7a54820b0fa8c2237e" alt="image"
Option for bar chart instead of line graph (will add more enhancements to bar chart in future PRs)
data:image/s3,"s3://crabby-images/031f0/031f08434596dafd7068e2ed67528d91cb40fba8" alt="image"
New section for 'Retention calculation options', buttons around chart only control display configs (eventually will move mean to the side as well, once Sri's changes are merged in)
data:image/s3,"s3://crabby-images/d6dc6/d6dc631cf8ca355ff94ce4f1ed3fa7b5a522a68c" alt="image"
Selecting retention reference actually updates the table now (previously only changed the line graph)
data:image/s3,"s3://crabby-images/c2ed0/c2ed0ac6f013380b2ac8e244dc8b01f14db96d87" alt="image"
Added tooltips for cumulative retention
data:image/s3,"s3://crabby-images/c8c8a/c8c8a1b0bcd684e9219e9555e93a05c061f6d49d" alt="image"
👉 Stay up-to-date with PostHog coding conventions for a smoother review.
Does this work well for both Cloud and self-hosted?
How did you test this code?