-
Notifications
You must be signed in to change notification settings - Fork 1.9k
[macOS] Fix RadioButton activated behaviour #14139
Conversation
Wow nice job we really needed this! ❤ i hope this will be merged soon. |
Hi @jsuarezruiz. This change is rather small and solves clear usability issues. Any chance the Xamarin team could take a look? |
i've used your renderer and works nicely but |
Hi. Thanks for letting me know. |
yeah sure! |
Try this slight adjustment: protected override void OnElementChanged(ElementChangedEventArgs<RadioButton> e)
{
base.OnElementChanged(e);
if (Control != null)
{
Control.Activated += HandleActivated;
if (e.NewElement.IsChecked)
Control.State = NSCellStateValue.On;
}
} |
Thanks @chucker it worked!!! It's fully working now. |
@JunielKatarn could you add this to your PR? |
(To expand on this a little: I've found that to help when a radio button is supposed to be initially checked, before the renderer comes into play. In that case, the renderer never receives the appropriate property changed event. However, I'm not sure this fixes all issues. I'm also simultaneously running into #13752, which isn't macOS-specific. It might also be that, once #13752 is fixed, my above adjustment isn't actually necessary.) |
Right away! :) Thanks for the contribution, @chucker. |
@jsuarezruiz The fix for initial state (i.e. when loading from Xamarin Essentials settings) has been applied. Is there any pending requirement for this change to be merged? |
This reverts commit 1bd1238.
Shouldn't this have been merged by now? @rmarinho |
* Fix 4143: improved Span region calculation (#13348) fixes #4143 fixes #6992 fixes #11650 fixes #7655 fixes #11657 fixes #10520 fixes #4829 * improved span region calculation on android * Remove unused code * Nit: clean up comments * Wrap in ScrollView for small screen compatibility Co-authored-by: Tim Dittmar <[email protected]> Co-authored-by: Rachel Kang <[email protected]> Co-authored-by: Rachel Kang <[email protected]> * Only check for netfx when not in a wapproj (#14402) fixes #13957 * [macOS] Update Switch renderer (#14334) fixes #14313 * [macOS] Update Switch renderer #14313 * [macOS] Update Switch renderer #14313 * [Android] Fix to Issue Java.Lang.IndexOutOfBoundsException: setSpan (#12764) Fix to Issue #12762 * Update EntryRenderer.cs Fix to Issue #12762 Java.Lang.IndexOutOfBoundsException: setSpan (nn ... nn) ends beyond length n-1 * Fix to EntryRenderer.cs * Update EntryRenderer.cs * Update EntryRenderer.cs Co-authored-by: Rui Marinho <[email protected]> * [Android] Fix ClearButton not working when changing the ClearButtonVisibility while the Entry field is focused (#13820) Fixes #13819 Co-authored-by: Javier Suárez <[email protected]> * Automated dotnet-format update (#14404) Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Automated dotnet-format update (#14405) Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * fix memory leak (and some crashes) in ItemsViewController (iOS) (#14111) * add unit test * fix memory leak (and some crashes) in ItemsViewController (iOS) * Update ItemsViewController.cs Co-authored-by: Rui Marinho <[email protected]> * Enable ScrollTo tests for Android, UWP; implement ScrollTo with group index for Android (#13007) * Remove inaccurate category * Enable ScrollTo tests for Android/UWP; Implement grouped ScrollTo for Android * Implement missing ScrollTo grouped item by index * Exempt 3788 test from UWP * Ignore test on UWP Co-authored-by: Rui Marinho <[email protected]> * Fix type for case blueviolet (#14434) The 'v' in this case was uppercase causing this typeconverter to reject BlueViolet as a valid color value. Fixes #AB1286706 [XVS]XLS0431: Invalid value for property 'BackgroundColor': 'BlueViolet' * [iOS] Fix: CollectionView was not updating when it was invisible (#14384) * [iOS] Fix: CollectionView was not updating when it was invisible * [iOS] Fix: NSInternalInconsistencyException Reason: request for number of items in section X when there are only X sections in the collection view when NumberOfItemsInSection is invoked * Revert "[iOS] Fix: NSInternalInconsistencyException Reason: request for number of items in section X when there are only X sections in the collection view when NumberOfItemsInSection is invoked" This reverts commit 2343f15. * [iOS] Fix: Prevent NumberOfItemsInSection invoking if CollectionView is hidded to avoid "NSInternalInconsistencyException Reason: request for number of items in section X when there are only X sections" * [iOS] Scroll locked issue using SwipeView (#12758) * Fixed issue re-enabling the scroll * Added repro sample * Fixed also the swipe sensitive issue on iOS Co-authored-by: Gerald Versluis <[email protected]> * Fix removed shadow in Thumb setting a custom color (#13166) * [iOS] Fix crash/closing wrong modal with FormSheet and tap outside (#14527) * Add repro + fix * Update Issue12300.cs * [Core] SwipeItem Parent using SwipeView in DataTemplate (#13385) * Added repro sample * Fix the issue Co-authored-by: Gerald Versluis <[email protected]> * Fix Frame Background issue with transparent color (#14565) * Fix broken disabled Button visual state in UWP (#14567) Co-authored-by: Gerald Versluis <[email protected]> * Update Device.Idiom when flipping tablet mode state (#13150) * [Android] Fix occasional wrong touch interception in SwipeView Content (#13732) * Fix wrong touch interception in SwipeView Content on Android * Updated swipe delta * Fix Entry issue using TextColor and ClearButton in iOS < 13 (#14566) Co-authored-by: Gerald Versluis <[email protected]> * Fix issue using FormattedString and LineBreakMode on iOS (#14572) Co-authored-by: Gerald Versluis <[email protected]> * Align BarBackground behavior between Android and iOS. (#13503) * Automated dotnet-format update (#14570) Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * [Android] Update gradients based on offset changes in Frame and BoxView (#11812) * Update gradients based on offset changes in Frame and BoxView on Android * Updated the sample to test also the BoxView Brush offsets * Fix NRE in ListView Command validation (#14580) * [iOS] Fix inability to check an initially disabled RadioButton after enabling it (#14545) * Listen for updates to IsEnabled on RadioButton to ensure that the tap gesture recogniser is added when the control is enabled * Update Issue14544.cs * Update test case Co-authored-by: Gerald Versluis <[email protected]> * Fix crash navigating in Shell (#14577) * Androidx bumps (#14506) * Update to Latest Android X Libraries * - fix android forwarders * Moar updates Co-authored-by: Gerald Versluis <[email protected]> * Validate issue 14433 (#14576) * Added repro sample * Updated sample Co-authored-by: Gerald Versluis <[email protected]> * [iOS] Remove usage of System.Drawing types (#14571) * Run nightly also for 5.0.0 branch * Automated dotnet-format update (#14581) Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * Ordering children while adding (#8231) * Ordering children while adding * Abstract OrderElement * Re-order on runtime child addition and Tests * Runtime addition ensures Z Index * Stop performance measurement on return * Update VisualElementPackager.cs Co-authored-by: Gerald Versluis <[email protected]> Co-authored-by: Javier Suárez <[email protected]> * If stroke is null avoid render a shape stroke (#14587) * Fix broken Android platform tests (#14590) * Automated dotnet-format update (#14595) Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * [macOS] Fix RadioButton activated behaviour (#14139) * Respond to Activated event * Set initial control state based on element state * Revert "Set initial control state based on element state" This reverts commit 1bd1238. * CollectionView RemainingItemsThreshold implementation for UWP (#14202) * [Android] Fix building with Android stable bits (#14608) * Set java sdk path * Use class-parse Co-authored-by: Braini01 <[email protected]> Co-authored-by: Tim Dittmar <[email protected]> Co-authored-by: Rachel Kang <[email protected]> Co-authored-by: Rachel Kang <[email protected]> Co-authored-by: Matthew Leibowitz <[email protected]> Co-authored-by: MH Rastegari <[email protected]> Co-authored-by: Felipe Silveira <[email protected]> Co-authored-by: Rui Marinho <[email protected]> Co-authored-by: Jonathan Goyvaerts <[email protected]> Co-authored-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: Thomas Mijieux <[email protected]> Co-authored-by: E.Z. Hart <[email protected]> Co-authored-by: Marco Goertz <[email protected]> Co-authored-by: Kirill <[email protected]> Co-authored-by: Gerald Versluis <[email protected]> Co-authored-by: Lee Millward <[email protected]> Co-authored-by: Gerald Versluis <[email protected]> Co-authored-by: Shane Neuville <[email protected]> Co-authored-by: Filip Navara <[email protected]> Co-authored-by: Shanmukha Ranganath <[email protected]> Co-authored-by: Julio César Rocha <[email protected]> Co-authored-by: nk221 <[email protected]>
Description of Change
Allows RadioButton in macOS to respond to the Activated event, thus propagating the necessary property changes.
Issues Resolved
API Changes
None
Platforms Affected
Behavioral/Visual Changes
Radio buttons within a group get exclusively activated, as intended.
Before/After Screenshots
Before:
After:
Testing Procedure
PR Checklist