diff options
author | Dominique Louis <dominique@cnlilyzhou.fareast.corp.microsoft.com> | 2019-02-22 13:03:19 +0300 |
---|---|---|
committer | Dominique Louis <dominique@satoshy-sb1.fareast.corp.microsoft.com> | 2019-03-02 15:45:48 +0300 |
commit | 6b2b898b76a4ab942d8cdc415a84205805c750ba (patch) | |
tree | 9c8319d18b843b5db00f4ef224bf751c0c4a301c /Xamarin.PropertyEditing.Mac | |
parent | 1b4da57c501b14b295a90f0a57aea526ba637dc5 (diff) |
Enabled must be set for ReadOnly to look right. Also fixes InputMode enablement.
Diffstat (limited to 'Xamarin.PropertyEditing.Mac')
9 files changed, 33 insertions, 17 deletions
diff --git a/Xamarin.PropertyEditing.Mac/Controls/BasePointEditorControl.cs b/Xamarin.PropertyEditing.Mac/Controls/BasePointEditorControl.cs index 1306f1b..1b6b0e4 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/BasePointEditorControl.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/BasePointEditorControl.cs @@ -94,8 +94,8 @@ namespace Xamarin.PropertyEditing.Mac protected override void SetEnabled () { - XEditor.Editable = ViewModel.Property.CanWrite; - YEditor.Editable = ViewModel.Property.CanWrite; + XEditor.Enabled = ViewModel.Property.CanWrite; + YEditor.Enabled = ViewModel.Property.CanWrite; } protected override void UpdateAccessibilityValues () diff --git a/Xamarin.PropertyEditing.Mac/Controls/BaseRectangleEditorControl.cs b/Xamarin.PropertyEditing.Mac/Controls/BaseRectangleEditorControl.cs index bab77ed..b9f3152 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/BaseRectangleEditorControl.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/BaseRectangleEditorControl.cs @@ -150,10 +150,10 @@ namespace Xamarin.PropertyEditing.Mac protected override void SetEnabled () { - XEditor.Editable = ViewModel.Property.CanWrite; - YEditor.Editable = ViewModel.Property.CanWrite; - WidthEditor.Editable = ViewModel.Property.CanWrite; - HeightEditor.Editable = ViewModel.Property.CanWrite; + XEditor.Enabled = ViewModel.Property.CanWrite; + YEditor.Enabled = ViewModel.Property.CanWrite; + WidthEditor.Enabled = ViewModel.Property.CanWrite; + HeightEditor.Enabled = ViewModel.Property.CanWrite; } protected override void UpdateAccessibilityValues () diff --git a/Xamarin.PropertyEditing.Mac/Controls/CombinablePropertyEditor.cs b/Xamarin.PropertyEditing.Mac/Controls/CombinablePropertyEditor.cs index 311be05..61c2de9 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/CombinablePropertyEditor.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/CombinablePropertyEditor.cs @@ -102,6 +102,8 @@ namespace Xamarin.PropertyEditing.Mac // Set our tabable order this.firstKeyView = this.combinableList.KeyAt (0); this.lastKeyView = this.combinableList.KeyAt (this.combinableList.Count - 1); + + SetEnabled (); } protected override void UpdateValue () diff --git a/Xamarin.PropertyEditing.Mac/Controls/Custom/SpinnerButton.cs b/Xamarin.PropertyEditing.Mac/Controls/Custom/SpinnerButton.cs index bec2871..fcefa67 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/Custom/SpinnerButton.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/Custom/SpinnerButton.cs @@ -47,7 +47,7 @@ namespace Xamarin.PropertyEditing.Mac private void UpdateImage () { - Image = (this.isMouseOver) ? this.mouseOverImage : this.image; + Image = Enabled ? (this.isMouseOver) ? this.mouseOverImage : this.image : this.image; } } } diff --git a/Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs b/Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs index 05b2463..7af5487 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs @@ -59,6 +59,8 @@ namespace Xamarin.PropertyEditing.Mac public override NSView FirstKeyView => NumericEditor; public override NSView LastKeyView => NumericEditor.DecrementButton; + private bool CanEnable => ViewModel.Property.CanWrite && (((ViewModel.InputMode != null) && !ViewModel.InputMode.IsSingleValue) || (this.inputModePopup == null)); + protected NSNumberFormatterStyle NumberStyle { get { return NumericEditor.NumberStyle; } @@ -91,7 +93,7 @@ namespace Xamarin.PropertyEditing.Mac protected override void SetEnabled () { - NumericEditor.Editable = ViewModel.Property.CanWrite; + NumericEditor.Enabled = CanEnable; if (this.inputModePopup != null) this.inputModePopup.Enabled = ViewModel.Property.CanWrite; } @@ -108,7 +110,7 @@ namespace Xamarin.PropertyEditing.Mac { if (this.underlyingType != null) { NumericEditor.StringValue = ViewModel.Value == null ? string.Empty : ViewModel.Value.ToString (); - NumericEditor.Enabled = ((ViewModel.InputMode != null) && !ViewModel.InputMode.IsSingleValue) || (this.inputModePopup == null); + NumericEditor.Enabled = CanEnable; if (this.inputModePopup != null) this.inputModePopup.SelectItem ((ViewModel.InputMode == null) ? string.Empty : ViewModel.InputMode.Identifier); @@ -126,7 +128,7 @@ namespace Xamarin.PropertyEditing.Mac NumericEditor.AccessibilityTitle = string.Format (LocalizationResources.AccessibilityNumeric, ViewModel.Property.Name); if (this.inputModePopup != null) { - this.inputModePopup.AccessibilityEnabled = NumericEditor.Enabled; + this.inputModePopup.AccessibilityEnabled = this.inputModePopup.Enabled; this.inputModePopup.AccessibilityTitle = string.Format (LocalizationResources.AccessibilityInpueModeEditor, ViewModel.Property.Name); } } @@ -174,6 +176,8 @@ namespace Xamarin.PropertyEditing.Mac // If we are reusing the control we'll have to hid the inputMode if this doesn't have InputMode. if (this.inputModePopup != null) this.inputModePopup.Hidden = !ViewModel.HasInputModes; + + SetEnabled (); } } } diff --git a/Xamarin.PropertyEditing.Mac/Controls/PanelHeaderEditorControl.cs b/Xamarin.PropertyEditing.Mac/Controls/PanelHeaderEditorControl.cs index 13ecdaf..f733fb6 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/PanelHeaderEditorControl.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/PanelHeaderEditorControl.cs @@ -100,7 +100,7 @@ namespace Xamarin.PropertyEditing.Mac this.typeDisplay.StringValue = value?.TypeName ?? String.Empty; UpdateValue (); UpdateIcon (); - this.propertyObjectName.Editable = !this.viewModel.IsObjectNameReadOnly; + this.propertyObjectName.Enabled = !this.viewModel.IsObjectNameReadOnly; } } @@ -133,7 +133,7 @@ namespace Xamarin.PropertyEditing.Mac { this.propertyObjectName.StringValue = this.viewModel.ObjectName ?? string.Empty; this.propertyObjectName.AccessibilityTitle = string.Format (LocalizationResources.AccessibilityObjectName, nameof (viewModel.ObjectName)); - this.propertyObjectName.Editable = !this.viewModel.IsObjectNameReadOnly; + this.propertyObjectName.Enabled = !this.viewModel.IsObjectNameReadOnly; } private void OnObjectNameEdited (object sender, EventArgs e) diff --git a/Xamarin.PropertyEditing.Mac/Controls/PredefinedValuesEditor.cs b/Xamarin.PropertyEditing.Mac/Controls/PredefinedValuesEditor.cs index 6da0661..65d92cb 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/PredefinedValuesEditor.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/PredefinedValuesEditor.cs @@ -94,6 +94,11 @@ namespace Xamarin.PropertyEditing.Mac protected override void OnViewModelChanged (PropertyViewModel oldModel) { + base.OnViewModelChanged (oldModel); + + if (ViewModel == null) + return; + if (!this.dataPopulated) { if (ViewModel.IsConstrainedToPredefined) { this.popupButtonList.RemoveAllItems (); @@ -136,7 +141,7 @@ namespace Xamarin.PropertyEditing.Mac this.dataPopulated = true; } - base.OnViewModelChanged (oldModel); + SetEnabled (); } protected override void UpdateValue () diff --git a/Xamarin.PropertyEditing.Mac/Controls/RatioEditorControl.cs b/Xamarin.PropertyEditing.Mac/Controls/RatioEditorControl.cs index 22c218a..9f76079 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/RatioEditorControl.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/RatioEditorControl.cs @@ -49,7 +49,7 @@ namespace Xamarin.PropertyEditing.Mac protected override void SetEnabled () { - this.ratioEditor.Editable = ViewModel.Property.CanWrite; + this.ratioEditor.Enabled = ViewModel.Property.CanWrite; } protected override void UpdateAccessibilityValues () diff --git a/Xamarin.PropertyEditing.Mac/Controls/StringEditorControl.cs b/Xamarin.PropertyEditing.Mac/Controls/StringEditorControl.cs index fa7badb..f715576 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/StringEditorControl.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/StringEditorControl.cs @@ -25,6 +25,8 @@ namespace Xamarin.PropertyEditing.Mac internal NSPopUpButton inputModePopup; private IReadOnlyList<InputMode> viewModelInputModes; + private bool CanEnable => ViewModel.Property.CanWrite && (((ViewModel.InputMode != null) && !ViewModel.InputMode.IsSingleValue) || (this.inputModePopup == null)); + public StringEditorControl (IHostResourceProvider hostResource) : base (hostResource) { @@ -56,7 +58,7 @@ namespace Xamarin.PropertyEditing.Mac protected override void UpdateValue () { this.stringEditor.StringValue = ViewModel.Value ?? string.Empty; - this.stringEditor.Enabled = ((ViewModel.InputMode != null) && !ViewModel.InputMode.IsSingleValue) || (this.inputModePopup == null); + this.stringEditor.Enabled = CanEnable; if (this.inputModePopup != null) this.inputModePopup.SelectItem ((ViewModel.InputMode == null) ? string.Empty : ViewModel.InputMode.Identifier); } @@ -111,6 +113,8 @@ namespace Xamarin.PropertyEditing.Mac // If we are reusing the control we'll have to hid the inputMode if this doesn't have InputMode. if (this.inputModePopup != null) this.inputModePopup.Hidden = !ViewModel.HasInputModes; + + SetEnabled (); } protected override void UpdateErrorsDisplayed (IEnumerable errors) @@ -125,16 +129,17 @@ namespace Xamarin.PropertyEditing.Mac protected override void SetEnabled () { - this.stringEditor.Editable = ViewModel.Property.CanWrite; + this.stringEditor.Enabled = CanEnable; if (this.inputModePopup != null) this.inputModePopup.Enabled = ViewModel.Property.CanWrite; } protected override void UpdateAccessibilityValues () { - this.stringEditor.AccessibilityEnabled = this.stringEditor.Editable; + this.stringEditor.AccessibilityEnabled = this.stringEditor.Enabled; this.stringEditor.AccessibilityTitle = string.Format (LocalizationResources.AccessibilityString, ViewModel.Property.Name); if (this.inputModePopup != null) { + this.inputModePopup.AccessibilityEnabled = this.inputModePopup.Enabled; this.inputModePopup.AccessibilityTitle = string.Format (LocalizationResources.AccessibilityInpueModeEditor, ViewModel.Property.Name); } } |