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

Allow filtering by resource state and health status, and update the filters based on visible grid items #6925

Open
wants to merge 14 commits into
base: main
Choose a base branch
from

Conversation

adamint
Copy link
Member

@adamint adamint commented Dec 10, 2024

Description

Currently, you can filter resources by type, but it would also be useful to filter by health status or by resource state. I extracted the resource filter UI into its own component ResourceFilters and converted SelectResourceTypes into a component that was more generic and so could be reused for state and health status (SelectResourceOptions). This also meant other refactoring was necessary, such as creating reusable methods Get/SetFieldVisibility from the getter and setter logic previously in AreAllTypesVisible.

Fixes #1190

In a follow-up, we could persist these values in the URL (#3647)

image

(note that, for example, finished and no state have disappeared from available options because no resource with those values is in the grid anymore)
image

Checklist

  • Is this feature complete?
    • Yes. Ready to ship.
    • No. Follow-up changes expected.
  • Are you including unit tests for the changes and scenario tests if relevant?
    • Yes
    • No (largely just a refactor)
  • Did you add public API?
    • Yes
      • If yes, did you have an API Review for it?
        • Yes
        • No
      • Did you add <remarks /> and <code /> elements on your triple slash comments?
        • Yes
        • No
    • No
  • Does the change make any security assumptions or guarantees?
    • Yes
      • If yes, have you done a threat model and had a security review?
        • Yes
        • No
    • No
  • Does the change require an update in our Aspire docs?
Microsoft Reviewers: Open in CodeFlow

@JamesNK
Copy link
Member

JamesNK commented Dec 11, 2024

What happens if there are a lot of states, resources types and health states? The popup should probably have a maximum height and a scoll bar to handle that situation nicely.

@JamesNK
Copy link
Member

JamesNK commented Dec 11, 2024

Couple of examples of bugs.

Database type isn't in list because its resource is nested. Expanding the parent makes it display:

db-type-not-displayed

Problems with unselecting resource types:

resource-type-not-displayed

These are both caused by filtering available options based on visible resources.

@adamint
Copy link
Member Author

adamint commented Dec 12, 2024

Couple of examples of bugs.

Database type isn't in list because its resource is nested. Expanding the parent makes it display:

Problems with unselecting resource types:

These are both caused by filtering available options based on visible resources.

Reverted the change.

@adamint
Copy link
Member Author

adamint commented Dec 12, 2024

What happens if there are a lot of states, resources types and health states? The popup should probably have a maximum height and a scoll bar to handle that situation nicely.

Added a max height and scroll bar.
image

…lthstatus

# Conflicts:
#	src/Aspire.Dashboard/wwwroot/css/app.css
@adamint adamint requested a review from JamesNK December 12, 2024 18:23
@adamint
Copy link
Member Author

adamint commented Dec 18, 2024

@JamesNK

src/Aspire.Dashboard/Components/Pages/Resources.razor.cs Outdated Show resolved Hide resolved
src/Aspire.Dashboard/Components/Pages/Resources.razor Outdated Show resolved Hide resolved
src/Aspire.Dashboard/Components/Pages/Resources.razor Outdated Show resolved Hide resolved
src/Aspire.Dashboard/Components/Pages/Resources.razor.cs Outdated Show resolved Hide resolved
src/Aspire.Dashboard/wwwroot/css/app.css Outdated Show resolved Hide resolved
src/Aspire.Dashboard/wwwroot/css/app.css Outdated Show resolved Hide resolved
@dotnet-policy-service dotnet-policy-service bot added the needs-author-action An issue or pull request that requires more info or actions from the author. label Dec 30, 2024
@JamesNK
Copy link
Member

JamesNK commented Dec 30, 2024

I think you should add some component tests to test these changes. We don't tests for resources page yet so you'll need to add some setup code for registering required services and JS calls, but there a lot of other pages already setup that you can follow.

Copy link

This submission has been automatically marked as stale because it has been marked as requiring author action but has not had any activity for 14 days.
It will be closed if no further activity occurs within 7 days of this comment.

Adam Ratzman added 2 commits January 23, 2025 14:03
…lthstatus

# Conflicts:
#	src/Aspire.Dashboard/Components/Pages/Resources.razor.cs
#	src/Aspire.Dashboard/wwwroot/css/app.css
@dotnet-policy-service dotnet-policy-service bot removed the needs-author-action An issue or pull request that requires more info or actions from the author. label Jan 23, 2025
@JamesNK
Copy link
Member

JamesNK commented Jan 24, 2025

Do you intend to write component tests for this?

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Filter resources with errors on dashboard
4 participants