Fix handlers to match decompiled production code

- ButtonHandler: Removed MapText/TextColor/Font (not in production), fixed namespace
- LabelHandler: Added CharacterSpacing/LayoutAlignment/FormattedText, ConnectHandler gesture logic
- EntryHandler: Added CharacterSpacing/ClearButtonVisibility/VerticalTextAlignment
- EditorHandler: Created from decompiled (was missing)
- SliderHandler: Fixed namespace, added ConnectHandler init calls
- SwitchHandler: Added OffTrackColor logic, fixed namespace
- CheckBoxHandler: Added VerticalLayoutAlignment/HorizontalLayoutAlignment
- ProgressBarHandler: Added ConnectHandler/DisconnectHandler IsVisible tracking
- PickerHandler: Created from decompiled with collection changed tracking
- ActivityIndicatorHandler: Removed IsEnabled/BackgroundColor (not in production)
- All handlers now use namespace Microsoft.Maui.Platform.Linux.Handlers
- All handlers have proper null checks on PlatformView
- Updated MERGE_TRACKING.md with accurate status

🤖 Generated with [Claude Code](https://claude.com/claude-code)

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
2026-01-01 13:51:12 -05:00
parent fd9043f749
commit 6f0d10935c
26 changed files with 2502 additions and 1594 deletions

View File

@@ -21,7 +21,7 @@ public class SkiaPicker : SkiaView
typeof(int),
typeof(SkiaPicker),
-1,
BindingMode.TwoWay,
BindingMode.OneWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).OnSelectedIndexChanged());
/// <summary>
@@ -33,6 +33,7 @@ public class SkiaPicker : SkiaView
typeof(string),
typeof(SkiaPicker),
"",
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).Invalidate());
/// <summary>
@@ -44,6 +45,7 @@ public class SkiaPicker : SkiaView
typeof(SKColor),
typeof(SkiaPicker),
SKColors.Black,
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).Invalidate());
/// <summary>
@@ -55,6 +57,7 @@ public class SkiaPicker : SkiaView
typeof(SKColor),
typeof(SkiaPicker),
new SKColor(0x80, 0x80, 0x80),
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).Invalidate());
/// <summary>
@@ -66,6 +69,7 @@ public class SkiaPicker : SkiaView
typeof(SKColor),
typeof(SkiaPicker),
new SKColor(0xBD, 0xBD, 0xBD),
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).Invalidate());
/// <summary>
@@ -77,6 +81,7 @@ public class SkiaPicker : SkiaView
typeof(SKColor),
typeof(SkiaPicker),
SKColors.White,
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).Invalidate());
/// <summary>
@@ -88,6 +93,7 @@ public class SkiaPicker : SkiaView
typeof(SKColor),
typeof(SkiaPicker),
new SKColor(0x21, 0x96, 0xF3, 0x30),
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).Invalidate());
/// <summary>
@@ -99,6 +105,7 @@ public class SkiaPicker : SkiaView
typeof(SKColor),
typeof(SkiaPicker),
new SKColor(0xE0, 0xE0, 0xE0),
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).Invalidate());
/// <summary>
@@ -110,6 +117,7 @@ public class SkiaPicker : SkiaView
typeof(string),
typeof(SkiaPicker),
"Sans",
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).InvalidateMeasure());
/// <summary>
@@ -121,6 +129,7 @@ public class SkiaPicker : SkiaView
typeof(float),
typeof(SkiaPicker),
14f,
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).InvalidateMeasure());
/// <summary>
@@ -132,6 +141,7 @@ public class SkiaPicker : SkiaView
typeof(float),
typeof(SkiaPicker),
40f,
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).Invalidate());
/// <summary>
@@ -143,6 +153,7 @@ public class SkiaPicker : SkiaView
typeof(float),
typeof(SkiaPicker),
4f,
BindingMode.TwoWay,
propertyChanged: (b, o, n) => ((SkiaPicker)b).Invalidate());
#endregion