diff options
author | Dominique Louis <dominique@MININT-Rock.fareast.corp.microsoft.com> | 2018-12-10 16:32:54 +0300 |
---|---|---|
committer | Dominique Louis <dominique@MININT-85NL3HC.europe.corp.microsoft.com> | 2019-01-10 18:02:51 +0300 |
commit | a4b2cb39a58f574a6d9e8a0cc7531e0d27d10dff (patch) | |
tree | 73ba68363bff8eeb4f4b32ee00d797199365236f /Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs | |
parent | cd248d8fa5306f3ab05fabc72d6e869dd616ba9a (diff) |
[Mac] Initial InputMode implementation.
Diffstat (limited to 'Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs')
-rw-r--r-- | Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs | 87 |
1 files changed, 74 insertions, 13 deletions
diff --git a/Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs b/Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs index 84a5206..ee6e826 100644 --- a/Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs +++ b/Xamarin.PropertyEditing.Mac/Controls/NumericEditorControl.cs @@ -1,5 +1,7 @@ using System; using System.Collections; +using System.Collections.Generic; +using System.Linq; using AppKit; using Foundation; using Xamarin.PropertyEditing.Mac.Resources; @@ -19,8 +21,8 @@ namespace Xamarin.PropertyEditing.Mac var t = typeof (T); if (t.Name == PropertyViewModel<T>.NullableName) { - underlyingType = Nullable.GetUnderlyingType (t); - t = underlyingType; + this.underlyingType = Nullable.GetUnderlyingType (t); + t = this.underlyingType; } TypeCode code = Type.GetTypeCode (t); switch (code) { @@ -38,25 +40,23 @@ namespace Xamarin.PropertyEditing.Mac AddSubview (NumericEditor); + this.numericEditorWidthConstraint = NSLayoutConstraint.Create (NumericEditor, NSLayoutAttribute.Width, NSLayoutRelation.Equal, this, NSLayoutAttribute.Width, 1f, -32f); + this.AddConstraints (new[] { NSLayoutConstraint.Create (NumericEditor, NSLayoutAttribute.Top, NSLayoutRelation.Equal, this, NSLayoutAttribute.Top, 1f, 1f), - NSLayoutConstraint.Create (NumericEditor, NSLayoutAttribute.Width, NSLayoutRelation.Equal, this, NSLayoutAttribute.Width, 1f, -32f), + this.numericEditorWidthConstraint, }); } protected NumericSpinEditor<T> NumericEditor { get; set; } protected NSNumberFormatter Formatter { - get { - return NumericEditor.Formatter; - } - set { - NumericEditor.Formatter = value; - } + get { return NumericEditor.Formatter; } + set { NumericEditor.Formatter = value; } } public override NSView FirstKeyView => NumericEditor; - public override NSView LastKeyView => NumericEditor.DecrementButton; + public override NSView LastKeyView => NumericEditor; protected NSNumberFormatterStyle NumberStyle { get { @@ -68,6 +68,11 @@ namespace Xamarin.PropertyEditing.Mac private Type underlyingType; + internal NSPopUpButton inputModePopup; + private IReadOnlyList<InputMode> viewModelInputModes; + + private NSLayoutConstraint numericEditorWidthConstraint; + protected override void UpdateErrorsDisplayed (IEnumerable errors) { if (ViewModel.HasErrors) { @@ -86,22 +91,31 @@ namespace Xamarin.PropertyEditing.Mac protected override void SetEnabled () { NumericEditor.Editable = ViewModel.Property.CanWrite; + if (this.inputModePopup != null) + this.inputModePopup.Enabled = ViewModel.Property.CanWrite; } protected virtual void OnValueChanged (object sender, EventArgs e) { var t = typeof (T); - if (underlyingType != null) - t = underlyingType; + if (this.underlyingType != null) + t = this.underlyingType; ViewModel.Value = (T)Convert.ChangeType (NumericEditor.Value, t); } protected override void UpdateValue() { - if (underlyingType != null) { + 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); + + if (this.inputModePopup != null) + this.inputModePopup.SelectItem ((ViewModel.InputMode == null) ? string.Empty : ViewModel.InputMode.Identifier); } else { NumericEditor.Value = (double)Convert.ChangeType (ViewModel.Value, typeof (double)); + + if (this.inputModePopup != null) + this.inputModePopup.SelectItem (-1); } } @@ -109,6 +123,53 @@ namespace Xamarin.PropertyEditing.Mac { NumericEditor.AccessibilityEnabled = NumericEditor.Enabled; NumericEditor.AccessibilityTitle = string.Format (LocalizationResources.AccessibilityNumeric, ViewModel.Property.Name); + + if (this.inputModePopup != null) { + this.inputModePopup.AccessibilityEnabled = NumericEditor.Enabled; + this.inputModePopup.AccessibilityTitle = string.Format (LocalizationResources.AccessibilityInpueModeEditor, ViewModel.Property.Name); + } + } + + protected override void OnViewModelChanged (PropertyViewModel oldModel) + { + if (ViewModel.HasInputModes) { + if (this.inputModePopup == null) { + this.inputModePopup = new NSPopUpButton { + Menu = new NSMenu (), + TranslatesAutoresizingMaskIntoConstraints = false, + }; + + this.inputModePopup.Activated += (o, e) => { + var popupButton = o as NSPopUpButton; + ViewModel.InputMode = this.viewModelInputModes.FirstOrDefault (im => im.Identifier == popupButton.Title); + }; + + AddSubview (this.inputModePopup); + + this.AddConstraints (new[] { + NSLayoutConstraint.Create (this.inputModePopup, NSLayoutAttribute.Top, NSLayoutRelation.Equal, this, NSLayoutAttribute.Top, 1f, 1f), + NSLayoutConstraint.Create (this.inputModePopup, NSLayoutAttribute.Right, NSLayoutRelation.Equal, this, NSLayoutAttribute.Right, 1f, -33f), + NSLayoutConstraint.Create (this.inputModePopup, NSLayoutAttribute.Width, NSLayoutRelation.Equal, 1f, 80f), + NSLayoutConstraint.Create (this.inputModePopup, NSLayoutAttribute.Height, NSLayoutRelation.Equal, 1f, DefaultControlHeight - 3 ), + }); + } + + this.inputModePopup.Menu.RemoveAllItems (); + this.viewModelInputModes = ViewModel.InputModes; + foreach (InputMode item in this.viewModelInputModes) { + this.inputModePopup.Menu.AddItem (new NSMenuItem (item.Identifier)); + } + + this.numericEditorWidthConstraint.Constant = -117f; // Shorten the stringEditor if we have Inputmodes Showing. + } else { + this.numericEditorWidthConstraint.Constant = -34f; // Lengthen the stringEditor if we have Inputmodes Hidden. + } + + // 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; + + base.OnViewModelChanged (oldModel); } } } |