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

SettingsCard does not render content #17311

Closed
MartinZikmund opened this issue Jun 26, 2024 · 8 comments · Fixed by CommunityToolkit/Windows#452
Closed

SettingsCard does not render content #17311

MartinZikmund opened this issue Jun 26, 2024 · 8 comments · Fixed by CommunityToolkit/Windows#452
Assignees
Labels
difficulty/tbd Categorizes an issue for which the difficulty level needs to be defined. kind/bug Something isn't working triage/untriaged Indicates an issue requires triaging or verification

Comments

@MartinZikmund
Copy link
Member

MartinZikmund commented Jun 26, 2024

Current behavior

In latest version of Uno, SettingsCard content no longer renders:

image

Expected behavior

Should render

image

How to reproduce it (as minimally and precisely as possible)

  1. Check out https://github.com/MartinZikmund/uno-bug-repros/tree/bug/settings-no-content
  2. Run the app on any Skia target (with Uno.WinUI 5.4.0-dev.121)

Workaround

No response

Works on UWP/WinUI

None

Environment

No response

NuGet package version(s)

No response

Affected platforms

No response

IDE

No response

IDE version

No response

Relevant plugins

No response

Anything else we need to know?

No response

@MartinZikmund MartinZikmund added kind/bug Something isn't working triage/untriaged Indicates an issue requires triaging or verification difficulty/tbd Categorizes an issue for which the difficulty level needs to be defined. labels Jun 26, 2024
MartinZikmund added a commit to MartinZikmund/uno-bug-repros that referenced this issue Jun 26, 2024
@morning4coffe-dev
Copy link
Member

I can replicate this issue only on Skia (I updated the description for it) and very interestingly only when there is only one Control placed in the content:
image

When I put a StackPanel with more items, I can no longer reproduce the issue:
image

@agneszitte
Copy link
Contributor

agneszitte commented Jul 3, 2024

@jeromelaban, @MartinZikmund just a note that SettingsCard is used as an example for the WCT documentation
https://platform.uno/docs/articles/uno-community-toolkit-v8.html?tabs=singleproj
So best if we could prioritize fixing this issue I think

@morning4coffe-dev morning4coffe-dev self-assigned this Jul 8, 2024
@morning4coffe-dev
Copy link
Member

morning4coffe-dev commented Jul 8, 2024

@MartinZikmund @agneszitte The issue is a regression caused by changes in #16834 image I also validated this with #17223, but the issue still persists. I checked with @Youssef1313 on this, and there will need to be more investigation to properly fix this. For now, we could implement a workaround or add a note to the documentation (#17374) for users to add a Grid/StackPanel before adding content to the SettingsCard.

@agneszitte
Copy link
Contributor

agneszitte commented Jul 8, 2024

@MartinZikmund @agneszitte The issue is a regression caused by changes in #16834 I also validated this with #17223, but the issue still persists. I checked with @Youssef1313 on this, and there will need to be more investigation to properly fix this. For now, we could implement a workaround or add a note to the documentation (#17374) for users to add a Grid/StackPanel before adding content to the SettingsCard.

Thank you a lot @morning4coffe-dev for all the details, appreciated.
I synced with @jeromelaban and @Youssef1313 will be able to investigate this issue as a priority since it is a regression.
@Youssef1313 if you have additional comments/details please let us know

@Youssef1313
Copy link
Member

The root cause here is that FrameworkElement is IEnumerable.

https://github.com/CommunityToolkit/Windows/blob/0bab2c0359ab33b7ef9868496a2fe5175c5afe6b/components/Triggers/src/IsNullOrEmptyStateTrigger.cs#L120

When Content is ComboBox, IsNullOrEmpty should simply return false. But in our case because FrameworkElements are IEnumerables, it could end up returning true incorrectly.

I don't see any way to fix this without a breaking change, other than opening a PR for CommunityToolkit/Windows to adjust the logic for Uno specifically.

@Youssef1313
Copy link
Member

CommunityToolkit/Windows#452 is now merged

@agneszitte
Copy link
Contributor

@jeromelaban, @MartinZikmund, @Youssef1313 I think we need to keep that issue opened (with maybe a little lower priority for now) as it still needs to be properly fixed at some point.

@Arlodotexe left a comment here in the Windows Community Toolkit code to track this issue for cleanup later on.
https://github.com/CommunityToolkit/Windows/pull/452/files

@Youssef1313
Copy link
Member

The fix will be a breaking change to make FrameworkElement not IEnumerable which is tracked bt #8339

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
difficulty/tbd Categorizes an issue for which the difficulty level needs to be defined. kind/bug Something isn't working triage/untriaged Indicates an issue requires triaging or verification
Projects
None yet
Development

Successfully merging a pull request may close this issue.

4 participants