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

fix(plugin-chart-echarts): support forced categorical x-axis #26404

Merged
merged 20 commits into from
Jan 8, 2024

Conversation

villebro
Copy link
Member

@villebro villebro commented Jan 3, 2024

SUMMARY

This PR adds the option to force a chart with a numerical x-axis to categorical. This makes it possible to sort charts that have a numerical x-axis, while still retaining support for numerical x-axis functionality. This should clear up a compatibility issue between previous versions of Superset, where some versions always treated numerical x-axes as categorical, while others always treated them as numerical.

While working on this, I noticed that the Query based datasource was missing the generic data type information that's needed for charts to operate properly. I believe this should resolve some issues we've seen on charts that are using the SQL Lab query as the source.

Note, that I tried to add similar support for temporal x-axes, but that turned out to be very difficult due to how we handle timestamp formats. Therefore, the force option will only be available when the x-axis is numerical, but not for temporal ones. For use cases where similar sorting is needed for temporal charts, I recommend just casting and formatting them to a string based type first.

AFTER

Now there's a new control that makes it possible to force numerical x-axes to categorical (disabled by default):
image
Note, that if a sorting value had previously been defined, it will set this control to true by default. This is to ensure that charts that had been created on a previous version of Superset, where the x-axis was numeric but were treated as categorical, will work as they were originally intended.

Here we can see that we're able to sort by the metric value if the chart is forced to categorical style:
image

BEFORE

Previously the sorting control was visible, but didn't do anything if the x-axis was numeric:
image

TESTING INSTRUCTIONS

ADDITIONAL INFORMATION

  • Has associated issue: fixes Sorting control not working on numeric x axis #26323
  • Required feature flags:
  • Changes UI
  • Includes DB Migration (follow approval process in SIP-59)
    • Migration is atomic, supports rollback & is backwards-compatible
    • Confirm DB migration upgrade and downgrade tested
    • Runtime estimates and downtime expectations provided
  • Introduces new feature or API
  • Removes existing feature or API

Copy link

codecov bot commented Jan 4, 2024

Codecov Report

Attention: 13 lines in your changes are missing coverage. Please review.

Comparison is base (3a7d76c) 69.15% compared to head (7a61fdf) 66.98%.
Report is 2 commits behind head on master.

Files Patch % Lines
...rt-controls/src/shared-controls/customControls.tsx 7.69% 12 Missing ⚠️
...hart-echarts/src/MixedTimeseries/transformProps.ts 0.00% 1 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##           master   #26404      +/-   ##
==========================================
- Coverage   69.15%   66.98%   -2.18%     
==========================================
  Files        1947     1948       +1     
  Lines       76010    76043      +33     
  Branches     8481     8493      +12     
==========================================
- Hits        52565    50934    -1631     
- Misses      21264    22928    +1664     
  Partials     2181     2181              
Flag Coverage Δ
hive ?
javascript 56.50% <63.88%> (+0.01%) ⬆️
mysql 78.06% <100.00%> (-0.02%) ⬇️
postgres 78.18% <100.00%> (+<0.01%) ⬆️
presto ?
python 78.31% <100.00%> (-4.54%) ⬇️
sqlite 77.77% <100.00%> (+0.94%) ⬆️
unit ?

Flags with carried forward coverage won't be shown. Click here to find out more.

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@villebro villebro force-pushed the villebro/force-categorical branch from 6a0f529 to ce3ca2a Compare January 4, 2024 05:28
@villebro villebro force-pushed the villebro/force-categorical branch from 1dab26f to b60d84e Compare January 4, 2024 18:39
@villebro villebro force-pushed the villebro/force-categorical branch 2 times, most recently from badbcc9 to 9bfaf3f Compare January 4, 2024 21:17
@villebro villebro requested a review from kgabryje January 4, 2024 22:16
@villebro
Copy link
Member Author

villebro commented Jan 4, 2024

/testenv up

Copy link
Contributor

github-actions bot commented Jan 4, 2024

@villebro Ephemeral environment spinning up at http://34.220.253.149:8080. Credentials are admin/admin. Please allow several minutes for bootstrapping and startup.

@Vitor-Avila
Copy link
Contributor

This is amazing! thank you!

@villebro
Copy link
Member Author

villebro commented Jan 5, 2024

/testenv up

Copy link
Contributor

github-actions bot commented Jan 5, 2024

@villebro Ephemeral environment spinning up at http://34.217.31.67:8080. Credentials are admin/admin. Please allow several minutes for bootstrapping and startup.

Comment on lines -232 to +235
xAxisSortSeries === SortSeriesType.Name && typeof sortKey === 'string'
? sortKey.toLowerCase()
xAxisSortSeries === SortSeriesType.Name
? typeof sortKey === 'string'
? sortKey.toLowerCase()
: sortKey
Copy link
Member Author

Choose a reason for hiding this comment

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

Without this change, sorting by "category name" wouldn't work if the type is numeric

@villebro villebro requested a review from zhaoyongjie January 5, 2024 04:28
@villebro
Copy link
Member Author

villebro commented Jan 5, 2024

/testenv up

Copy link
Contributor

github-actions bot commented Jan 5, 2024

@villebro Ephemeral environment spinning up at http://34.216.59.17:8080. Credentials are admin/admin. Please allow several minutes for bootstrapping and startup.

@michael-s-molina
Copy link
Member

Thank you for the PR @villebro and for nice tests!

I noticed that a numerical chart is rendering as categorical when you navigate from the dashboard to Explore.

Screen.Recording.2024-01-05.at.09.56.26.mov

I also noticed it's not possible to drill by when the chart is not categorical. I'm not sure if this is a restriction or if numerical bars could be selected too.

Screen.Recording.2024-01-05.at.09.57.54.mov

@michael-s-molina
Copy link
Member

michael-s-molina commented Jan 5, 2024

@yousoph @Vitor-Avila @sfirke Could you help testing this too?

@villebro
Copy link
Member Author

villebro commented Jan 5, 2024

I noticed that a numerical chart is rendering as categorical when you navigate from the dashboard to Explore.

Good catch, there must be something in the initialValue hook. I'll look into that now

@sfirke
Copy link
Member

sfirke commented Jan 5, 2024

I will test this but out sick this afternoon so probably not until Monday.

@michael-s-molina
Copy link
Member

I will test this but out sick this afternoon so probably not until Monday.

I hope you get well soon!

@villebro
Copy link
Member Author

villebro commented Jan 5, 2024

/testenv up

Copy link
Contributor

github-actions bot commented Jan 5, 2024

@villebro Ephemeral environment spinning up at http://35.91.107.86:8080. Credentials are admin/admin. Please allow several minutes for bootstrapping and startup.

@villebro
Copy link
Member Author

villebro commented Jan 5, 2024

@michael-s-molina the initial value issue should now be fixed. Please check out my new test dashboard: http://35.91.107.86:8080/superset/dashboard/p/qkWeveYvMXr/

@villebro
Copy link
Member Author

villebro commented Jan 5, 2024

I also noticed it's not possible to drill by when the chart is not categorical. I'm not sure if this is a restriction or if numerical bars could be selected too.

@michael-s-molina I believe this is by design - @kgabryje can probably add more context on this. Maybe something we can consider working in the near future?

@zhaoyongjie
Copy link
Member

zhaoyongjie commented Jan 6, 2024

@villebro Thanks for tackling the sorting issue. If I didn't forget that the x-axis sorting is using a sorting operator, so the data from backend was sorting ready, I tested this use case in Superset 3.0.2 release, but I can't reproduce it.

BTW, theoretically, if we treated a dimension as a categorical, the dimension should be converted to TEXT type in database, but it might be another topic.

Screen.Recording.2024-01-06.at.10.25.45.mov

@michael-s-molina
Copy link
Member

@michael-s-molina I believe this is by design - @kgabryje can probably add more context on this. Maybe something we can consider working in the near future?

Got it. Thanks for checking.

@villebro villebro force-pushed the villebro/force-categorical branch from a9e67a7 to f20e5de Compare January 8, 2024 17:22
This reverts commit c615cb5.
@villebro villebro merged commit 219c4a1 into apache:master Jan 8, 2024
33 checks passed
@villebro villebro deleted the villebro/force-categorical branch January 8, 2024 20:04
Copy link
Contributor

github-actions bot commented Jan 8, 2024

Ephemeral environment shutdown and build artifacts deleted.

@Vitor-Avila
Copy link
Contributor

Vitor-Avila commented Jan 8, 2024

@michael-s-molina thanks for tagging me and apologies for the late response. I just tested creating a chart before this fix and tested the upgrade which successfully fixed the chart!

Thanks @villebro for working on this change! 🎉

@michael-s-molina michael-s-molina added v3.0 Label added by the release manager to track PRs to be included in the 3.0 branch v3.1 Label added by the release manager to track PRs to be included in the 3.1 branch labels Jan 9, 2024
michael-s-molina pushed a commit that referenced this pull request Jan 9, 2024
josedev-union pushed a commit to Ortege-xyz/studio that referenced this pull request Jan 22, 2024
@mistercrunch mistercrunch added 🍒 3.0.3 🍒 3.0.4 🍒 3.1.0 🍒 3.1.1 🏷️ bot A label used by `supersetbot` to keep track of which PR where auto-tagged with release labels labels Mar 8, 2024
sfirke pushed a commit to sfirke/superset that referenced this pull request Mar 22, 2024
vinothkumar66 pushed a commit to vinothkumar66/superset that referenced this pull request Nov 11, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
🏷️ bot A label used by `supersetbot` to keep track of which PR where auto-tagged with release labels size/L v3.0 Label added by the release manager to track PRs to be included in the 3.0 branch v3.1 Label added by the release manager to track PRs to be included in the 3.1 branch 🍒 3.0.3 🍒 3.0.4 🍒 3.1.0 🍒 3.1.1 🍒 3.1.2 🍒 3.1.3 🚢 4.0.0
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Sorting control not working on numeric x axis
7 participants