superset
superset copied to clipboard
feat(native-filters): Adhoc dashboard native filters
SUMMARY
Our users really like the functionality of the adhoc filters in the explore view and were interested in something similar for for dashboard filtering. Anything that can be done with an adhoc filter native filter can be done with the other filter types and vice versa, but in order to filter by any given column the user has to either:
- create a new filter (which can be a hassle to do on an adhoc basis),
- or have a value filter for every column in the dashboard which is not feasible in every dashboard.
In this PR we added a new native filter type that reuses the adhoc filter component from the explore view to allow for more complex filtering to easily be done in a dashboard.
This solution provides the user with a lot of power and flexibility in dashboards, which is why it is behind a feature flag for now.
BEFORE/AFTER SCREENSHOTS OR ANIMATED GIF
https://user-images.githubusercontent.com/102618419/202734225-c44cfa32-40e5-4edd-8cab-83dafe94bb2a.mp4
https://user-images.githubusercontent.com/102618419/202734246-d650a4e7-c964-4f07-8a31-ea6e0e907270.mp4
TESTING INSTRUCTIONS
- Enable Feature Flag: ADHOC_DASHBOARD_NATIVE_FILTERS
- Navigate to dashboard
- Add/Edit Filters on the sidebar
- A new filter type should appear called "Adhoc"
ADDITIONAL INFORMATION
- [ ] Has associated issue:
- [x] Required feature flags: ADHOC_DASHBOARD_NATIVE_FILTERS
- [x] 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
- [x] Introduces new feature or API
- [ ] Removes existing feature or API
Codecov Report
Attention: Patch coverage is 6.45161%
with 87 lines
in your changes missing coverage. Please review.
Project coverage is 70.35%. Comparing base (
76d897e
) to head (3c8c73c
). Report is 305 commits behind head on master.
Additional details and impacted files
@@ Coverage Diff @@
## master #22168 +/- ##
==========================================
+ Coverage 60.48% 70.35% +9.86%
==========================================
Files 1931 1958 +27
Lines 76236 78450 +2214
Branches 8568 8783 +215
==========================================
+ Hits 46114 55192 +9078
+ Misses 28017 21126 -6891
- Partials 2105 2132 +27
Flag | Coverage Δ | |
---|---|---|
hive | 48.62% <ø> (-0.54%) |
:arrow_down: |
javascript | 57.67% <6.45%> (-0.04%) |
:arrow_down: |
mysql | 77.31% <ø> (?) |
|
postgres | 77.43% <ø> (?) |
|
presto | 53.67% <ø> (-0.13%) |
:arrow_down: |
python | 83.70% <ø> (+20.21%) |
:arrow_up: |
sqlite | 76.87% <ø> (?) |
|
unit | 59.22% <ø> (+1.59%) |
:arrow_up: |
Flags with carried forward coverage won't be shown. Click here to find out more.
:umbrella: View full report in Codecov by Sentry.
:loudspeaker: Have feedback on the report? Share it here.
looking forward to it being released.
Pinging @kasiazjc @yousoph to make sure we're ok with the popover approach and other components being recycled in the filters area.
Cool! Thanks for this feature! Two comments:
- The + button feels out of place, I think we can hide it like it's hidden from the chart builder:
- I don't think we use the terminology "ad hoc filters" in any user facing copy right now, are there any other names that might make it clear to the user about what the filter does? I'm having trouble naming it, would love any ideas!
Thank you for the PR @cccs-RyanK!
How will this filter behave considering inter filter features such as Values depend on other filters
and Filter scopes
? Specially in the case where we have a SQL value and it's hard to determine the referenced column/dataset.
Is the popup arrow pointing to the correct direction when the filter bar is horizontal? We need to consider the scenario where the filter is displayed in the bar in which case the arrow should point up and the case where the filter is displayed in the dropdown in which case the arrow should point to the right.
I agree with @yousoph's points.
Cool! Thanks for this feature! Two comments:
1. The + button feels out of place, I think we can hide it like it's hidden from the chart builder: data:image/s3,"s3://crabby-images/e86d7/e86d701adb659436caf430e2adef0458156cbaaf" alt="image" 2. I don't think we use the terminology "ad hoc filters" in any user facing copy right now, are there any other names that might make it clear to the user about what the filter does? I'm having trouble naming it, would love any ideas!
Thank you for the feedback @yousoph! I agree with the first point I can remove the plus button for sure. For the name maybe "advanced", "extra", or "custom" filters? Not sure if any of those fit.
How will this filter behave considering inter filter features such as Values depend on other filters and Filter scopes? Specially in the case where we have a SQL value and it's hard to determine the referenced column/dataset.
@cccs-RyanK Just to be more clear about the above point. There's a feature called Values depend on other filters (check this PR's video) which allows you to establish an hierarchy between filters. One example is when you have a State and City filters and you want to change the City's values depending on the selected value in State. This all works because there's a clear definition of the dataset and column when creating a filter. When you introduce a SQL filter, we don't know what's the column (or even if the SQL returns a column), so I'm wondering how all the features that depend on this definition will work. I think we need to at least disable these features when working with a SQL filter. If I defined the State filter as a SQL filter, then it shouldn't appear as one of the options in Values depend on other filters when configuring the City filter.
How will this filter behave considering inter filter features such as Values depend on other filters and Filter scopes? Specially in the case where we have a SQL value and it's hard to determine the referenced column/dataset.
@cccs-RyanK Just to be more clear about the above point. There's a feature called Values depend on other filters (check this PR's video) which allows you to establish an hierarchy between filters. One example is when you have a State and City filters and you want to change the City's values depending on the selected value in State. This all works because there's a clear definition of the dataset and column when creating a filter. When you introduce a SQL filter, we don't know what's the column (or even if the SQL returns a column), so I'm wondering how all the features that depend on this definition will work. I think we need to at least disable these features when working with a SQL filter. If I defined the State filter as a SQL filter, then it shouldn't appear as one of the options in Values depend on other filters when configuring the City filter.
@michael-s-molina thank you for the clarification! Yes I think that feature will need to be disabled on the SQL filter based on the reasons you mentioned. As for scoping, the SQL filter should work the same as other filters such as Time column filter which only specifies the dataset and not a specific column.
Lastly, I also agree about the horizontal filter bar I will test and adjust the popover so that it pops below instead of to the right in that case. Aiming to work on this soon.
@cccs-RyanK , @michael-s-molina Is there a permission to control this. I would want this available to Gamma roles and admins will have the normal add/edit filter.
@cccs-RyanK , @michael-s-molina Is there a permission to control this. I would want this available to Gamma roles and admins will have the normal add/edit filter.
Hey @michaelkovatt! I am not sure I understand all your question. For the first part no there was no permissions in place for this type of filter as of the last update, but for the second part what exactly is the behaviour you were thinking? You would like to configure it so that only certain roles have access to this type of filter?
@cccs-RyanK , @michael-s-molina Is there a permission to control this. I would want this available to Gamma roles and admins will have the normal add/edit filter.
Hey @michaelkovatt! I am not sure I understand all your question. For the first part no there was no permissions in place for this type of filter as of the last update, but for the second part what exactly is the behaviour you were thinking? You would like to configure it so that only certain roles have access to this type of filter?
@cccs-RyanK , @michael-s-molina Is there a permission to control this. I would want this available to Gamma roles and admins will have the normal add/edit filter.
Hey @michaelkovatt! I am not sure I understand all your question. For the first part no there was no permissions in place for this type of filter as of the last update, but for the second part what exactly is the behaviour you were thinking? You would like to configure it so that only certain roles have access to this type of filter?
@cccs-RyanK , yes you are right. Only need to enable this for some roles. Also, wanted to know if there is any timeline for the feature to go as part of next release?
@cccs-RyanK , yes you are right. Only need to enable this for some roles. Also, wanted to know if there is any timeline for the feature to go as part of next release?
I have no timeline on finishing it at the moment since I have been using this feature in my fork of superset for quite a while. Your comment the other day brought my attention back to this and I would like to finally push to include it in a future release. One major wall that I ran into was the design of the component when in horizontal view. In the screenshot I have included below you can see that adding a few filters expands the height too much. If you added enough filters you could eventually expand the filterbar to take up the whole screen. I am looking for input/ideas on adjusting it
Setting this to draft, but please make it ready for review when it's... ready for review. :)
@cccs-RyanK is CCCS still interested in reopening this PR? This request comes up from time to time, and this would cover a bunch of use cases that are impossible with the current set of filters..