-
Notifications
You must be signed in to change notification settings - Fork 409
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 Windows Media Element in MultiWindow Mode on exit Crash #2259
base: main
Are you sure you want to change the base?
Fix Windows Media Element in MultiWindow Mode on exit Crash #2259
Conversation
Added a static `NumberOfWindows` property to the `Options` class to track the number of windows. Updated `SetShouldEnableSnackbarOnWindows` to increment/decrement `NumberOfWindows` on window creation/closure. Conditional registration/unregistration of `AppNotificationManager` for snackbar notifications based on `NumberOfWindows` count.
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.
This changed fixed #2279
Hoping it will be released soon
src/CommunityToolkit.Maui/Options.cs
Outdated
@@ -66,13 +66,25 @@ public void SetShouldEnableSnackbarOnWindows(bool value) | |||
builder.ConfigureLifecycleEvents(events => | |||
{ | |||
events.AddWindows(windows => windows | |||
.OnWindowCreated((_) => | |||
{ | |||
NumberOfWindows++; |
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.
I'm not sure if just the UIThread can create an window or if can be done by another thread. I believe that's the second, so the Window1.UIThread != Window2.UIThread, and that can cause concurrency issues.
I would suggest to use the Interlocked.Increment
and Interlocked.Decrement
to control this counter
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.
Good catch! Interlocked.Increment
and Interlocked.Decrement
are perfect for this scenario.
In this implementation, I think we should actually remove internal static int NumberOfWindows { get; private set; }
and use Application.Current.Windows.Count
to avoid creating a duplicate property forcing CommunityToolkit.Maui
to increment/decrement properly.
I don't see a problem removing internal static in Options.NumberOfWindows { get; }
since it is not being used anywhere else in the code.
I'll update the code to remove this property 👍
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.
Are we going to go ahead and use else if (Application.Current.Windows.Count is 1)
and not switch to Interlocked.Increment
and Interlocked.Decrement
. I am happy either way but it would be nice to resolve this.
Can some please resolve this merge conflict? |
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.
Copilot reviewed 1 out of 1 changed files in this pull request and generated no suggestions.
I am new to this process, and don't understand who needs to do what to get this done, but I would appreciate any help to get the mission accomplished. |
Description of Change
Track window count and manage snackbar notifications
Added a static
NumberOfWindows
property to theOptions
class to track the number of windows. UpdatedSetShouldEnableSnackbarOnWindows
to increment/decrementNumberOfWindows
on window creation/closure. Conditional registration/unregistration ofAppNotificationManager
for snackbar notifications based onNumberOfWindows
count.Linked Issues
PR Checklist
approved
(bug) orChampioned
(feature/proposal)main
at time of PRAdditional information
This PR uses a simple counter to track the number of windows that exist and only when one is remaining will it unregister Snackview