[Enhancement] Entry ReturnType (#2029)

* [Core] Add ReturnType to Entry

* [Controls] Add Entry ReturnType gallery

* [Android] Entry ReturnType implementation

* [iOS] Entry ReturnType implementation

* [Docs] Docs for ReturnType

* [UWP] Entry ReturnType implementation

* [Core] Make sure we respect command CanExecute fixes #1697

* [Docs] Fix docs

* [Tizen] Entry ReturnType implementation

* [Core] Add missing defaults to BP on entry

* [Tests]Add unit test to entry Returntype command

* [iOS,Android,Tizen,UWP] Better Exception for ReturnType

* [Android] Handle completed event with new return type

* [ControlGallery]Fix ReturnType example

* [UnitTests] Remove extra Test attribute
This commit is contained in:
Rui Marinho 2018-03-15 10:29:08 +00:00 коммит произвёл GitHub
Родитель dfeb9f7f91
Коммит 2f1f3e92e3
Не найден ключ, соответствующий данной подписи
Идентификатор ключа GPG: 4AEE18F83AFDEB23
16 изменённых файлов: 525 добавлений и 4 удалений

Просмотреть файл

@ -0,0 +1,90 @@
using System;
using System.Threading.Tasks;
namespace Xamarin.Forms.Controls
{
public class EntryReturnTypeGalleryPage: ContentPage
{
Picker picker;
Entry returnTypeEntry;
Label lblCompleted;
public EntryReturnTypeGalleryPage()
{
BackgroundColor = Color.LightBlue;
var layout = new StackLayout
{
VerticalOptions = LayoutOptions.StartAndExpand
};
lblCompleted = new Label
{
HorizontalOptions = LayoutOptions.FillAndExpand
};
picker = new Picker
{
HorizontalOptions = LayoutOptions.FillAndExpand
};
picker.Items.Add(ReturnType.Done.ToString());
picker.Items.Add(ReturnType.Go.ToString());
picker.Items.Add(ReturnType.Next.ToString());
picker.Items.Add(ReturnType.Search.ToString());
picker.Items.Add(ReturnType.Send.ToString());
picker.Items.Add(ReturnType.Default.ToString());
returnTypeEntry = new Entry
{
HorizontalOptions = LayoutOptions.Fill,
Placeholder = $"Entry with {ReturnType.Go}",
ReturnCommand = new Command<string>(obj =>
{
lblCompleted.Text = "Completed Fired";
}),
ReturnCommandParameter = "hello titles",
AutomationId = "returnTypeEntry"
};
returnTypeEntry.PropertyChanged += (s, e) =>
{
if (e.PropertyName == Entry.ReturnTypeProperty.PropertyName)
{
returnTypeEntry.Placeholder = $"Entry with {returnTypeEntry.ReturnType}";
}
};
picker.SelectedIndexChanged += (s, e) =>
{
if (picker.SelectedItem.ToString() == ReturnType.Done.ToString())
{
returnTypeEntry.ReturnType = ReturnType.Done;
}
if (picker.SelectedItem.ToString() == ReturnType.Go.ToString())
{
returnTypeEntry.ReturnType = ReturnType.Go;
}
if (picker.SelectedItem.ToString() == ReturnType.Next.ToString())
{
returnTypeEntry.ReturnType = ReturnType.Next;
}
if (picker.SelectedItem.ToString() == ReturnType.Search.ToString())
{
returnTypeEntry.ReturnType = ReturnType.Search;
}
if (picker.SelectedItem.ToString() == ReturnType.Send.ToString())
{
returnTypeEntry.ReturnType = ReturnType.Send;
}
if (picker.SelectedItem.ToString() == ReturnType.Default.ToString())
{
returnTypeEntry.ReturnType = ReturnType.Default;
}
};
layout.Children.Add(returnTypeEntry);
layout.Children.Add(picker);
layout.Children.Add(lblCompleted);
picker.SelectedIndex = 0;
Content = layout;
}
}
}

Просмотреть файл

@ -246,6 +246,7 @@ namespace Xamarin.Forms.Controls
List<GalleryPageFactory> _pages = new List<GalleryPageFactory> { List<GalleryPageFactory> _pages = new List<GalleryPageFactory> {
new GalleryPageFactory(() => new Issues.PerformanceGallery(), "Performance"), new GalleryPageFactory(() => new Issues.PerformanceGallery(), "Performance"),
new GalleryPageFactory(() => new EntryReturnTypeGalleryPage(), "Entry ReturnType "),
new GalleryPageFactory(() => new VisualStateManagerGallery(), "VisualStateManager Gallery"), new GalleryPageFactory(() => new VisualStateManagerGallery(), "VisualStateManager Gallery"),
new GalleryPageFactory(() => new FlowDirectionGalleryLandingPage(), "FlowDirection"), new GalleryPageFactory(() => new FlowDirectionGalleryLandingPage(), "FlowDirection"),
new GalleryPageFactory(() => new AutomationPropertiesGallery(), "Accessibility"), new GalleryPageFactory(() => new AutomationPropertiesGallery(), "Accessibility"),

Просмотреть файл

@ -51,5 +51,50 @@ namespace Xamarin.Forms.Core.UnitTests
Assert.AreEqual (initial, oldValue); Assert.AreEqual (initial, oldValue);
Assert.AreEqual (final, newValue); Assert.AreEqual (final, newValue);
} }
[TestCase(true)]
[TestCase(false)]
public void ReturnTypeCommand(bool isEnabled)
{
var entry = new Entry()
{
IsEnabled = isEnabled,
};
bool result = false;
var bindingContext = new
{
Command = new Command(() => { result = true; }, () => true)
};
entry.SetBinding(Entry.ReturnCommandProperty, "Command");
entry.BindingContext = bindingContext;
entry.SendCompleted();
Assert.True(result == isEnabled ? true : false);
}
[TestCase(true)]
[TestCase(false)]
public void ReturnTypeCommandNullTestIsEnabled(bool isEnabled)
{
var entry = new Entry()
{
IsEnabled = isEnabled,
};
bool result = false;
entry.SetBinding(Entry.ReturnCommandProperty, "Command");
entry.BindingContext = null;
entry.Completed += (s, e) => {
result = true;
};
entry.SendCompleted();
Assert.True(result == isEnabled ? true : false);
}
} }
} }

Просмотреть файл

@ -1,5 +1,6 @@
using System; using System;
using System.ComponentModel; using System.ComponentModel;
using System.Windows.Input;
using Xamarin.Forms.Internals; using Xamarin.Forms.Internals;
using Xamarin.Forms.Platform; using Xamarin.Forms.Platform;
@ -8,6 +9,12 @@ namespace Xamarin.Forms
[RenderWith(typeof(_EntryRenderer))] [RenderWith(typeof(_EntryRenderer))]
public class Entry : InputView, IFontElement, ITextElement, ITextAlignmentElement, IEntryController, IElementConfiguration<Entry> public class Entry : InputView, IFontElement, ITextElement, ITextAlignmentElement, IEntryController, IElementConfiguration<Entry>
{ {
public static readonly BindableProperty ReturnTypeProperty = BindableProperty.Create(nameof(ReturnType), typeof(ReturnType), typeof(Entry), ReturnType.Default);
public static readonly BindableProperty ReturnCommandProperty = BindableProperty.Create(nameof(ReturnCommand), typeof(ICommand), typeof(Entry), default(ICommand));
public static readonly BindableProperty ReturnCommandParameterProperty = BindableProperty.Create(nameof(ReturnCommandParameter), typeof(object), typeof(Entry), default(object));
public static readonly BindableProperty PlaceholderProperty = BindableProperty.Create("Placeholder", typeof(string), typeof(Entry), default(string)); public static readonly BindableProperty PlaceholderProperty = BindableProperty.Create("Placeholder", typeof(string), typeof(Entry), default(string));
public static readonly BindableProperty IsPasswordProperty = BindableProperty.Create("IsPassword", typeof(bool), typeof(Entry), default(bool)); public static readonly BindableProperty IsPasswordProperty = BindableProperty.Create("IsPassword", typeof(bool), typeof(Entry), default(bool));
@ -88,6 +95,24 @@ namespace Xamarin.Forms
set { SetValue(FontSizeProperty, value); } set { SetValue(FontSizeProperty, value); }
} }
public ReturnType ReturnType
{
get => (ReturnType)GetValue(ReturnTypeProperty);
set => SetValue(ReturnTypeProperty, value);
}
public ICommand ReturnCommand
{
get => (ICommand)GetValue(ReturnCommandProperty);
set => SetValue(ReturnCommandProperty, value);
}
public object ReturnCommandParameter
{
get => GetValue(ReturnCommandParameterProperty);
set => SetValue(ReturnCommandParameterProperty, value);
}
double IFontElement.FontSizeDefaultValueCreator() => double IFontElement.FontSizeDefaultValueCreator() =>
Device.GetNamedSize(NamedSize.Default, (Entry)this); Device.GetNamedSize(NamedSize.Default, (Entry)this);
@ -102,7 +127,7 @@ namespace Xamarin.Forms
void IFontElement.OnFontChanged(Font oldValue, Font newValue) => void IFontElement.OnFontChanged(Font oldValue, Font newValue) =>
InvalidateMeasureInternal(InvalidationTrigger.MeasureChanged); InvalidateMeasureInternal(InvalidationTrigger.MeasureChanged);
public event EventHandler Completed; public event EventHandler Completed;
public event EventHandler<TextChangedEventArgs> TextChanged; public event EventHandler<TextChangedEventArgs> TextChanged;
@ -110,7 +135,15 @@ namespace Xamarin.Forms
[EditorBrowsable(EditorBrowsableState.Never)] [EditorBrowsable(EditorBrowsableState.Never)]
public void SendCompleted() public void SendCompleted()
{ {
Completed?.Invoke(this, EventArgs.Empty); if (IsEnabled)
{
Completed?.Invoke(this, EventArgs.Empty);
if (ReturnCommand != null && ReturnCommand.CanExecute(ReturnCommandParameter))
{
ReturnCommand.Execute(ReturnCommandParameter);
}
}
} }
static void OnTextChanged(BindableObject bindable, object oldValue, object newValue) static void OnTextChanged(BindableObject bindable, object oldValue, object newValue)

Просмотреть файл

@ -0,0 +1,14 @@
using System;
namespace Xamarin.Forms
{
public enum ReturnType
{
Default,
Done,
Go,
Next,
Search,
Send,
}
}

Просмотреть файл

@ -4,6 +4,28 @@ namespace Xamarin.Forms.Platform.Android
{ {
internal static class EntryRendererExtensions internal static class EntryRendererExtensions
{ {
internal static ImeAction ToAndroidImeAction(this ReturnType returnType)
{
switch (returnType)
{
case ReturnType.Go:
return ImeAction.Go;
case ReturnType.Next:
return ImeAction.Next;
case ReturnType.Send:
return ImeAction.Send;
case ReturnType.Search:
return ImeAction.Search;
case ReturnType.Done:
return ImeAction.Done;
case ReturnType.Default:
return ImeAction.Done;
default:
throw new System.NotImplementedException($"ReturnType {returnType} not supported");
}
}
public static ImeAction ToAndroidImeOptions(this PlatformConfiguration.AndroidSpecific.ImeFlags flags) public static ImeAction ToAndroidImeOptions(this PlatformConfiguration.AndroidSpecific.ImeFlags flags)
{ {
switch (flags) switch (flags)

Просмотреть файл

@ -19,7 +19,6 @@ namespace Xamarin.Forms.Platform.Android
TextColorSwitcher _hintColorSwitcher; TextColorSwitcher _hintColorSwitcher;
TextColorSwitcher _textColorSwitcher; TextColorSwitcher _textColorSwitcher;
bool _disposed; bool _disposed;
//global::Android.Views.InputMethods.ImeFlags _defaultInputImeFlag;
ImeAction _currentInputImeFlag; ImeAction _currentInputImeFlag;
public EntryRenderer(Context context) : base(context) public EntryRenderer(Context context) : base(context)
@ -98,6 +97,7 @@ namespace Xamarin.Forms.Platform.Android
UpdatePlaceholderColor(); UpdatePlaceholderColor();
UpdateMaxLength(); UpdateMaxLength();
UpdateImeOptions(); UpdateImeOptions();
UpdateReturnType();
} }
protected override void Dispose(bool disposing) protected override void Dispose(bool disposing)
@ -160,6 +160,8 @@ namespace Xamarin.Forms.Platform.Android
UpdateMaxLength(); UpdateMaxLength();
else if (e.PropertyName == PlatformConfiguration.AndroidSpecific.Entry.ImeOptionsProperty.PropertyName) else if (e.PropertyName == PlatformConfiguration.AndroidSpecific.Entry.ImeOptionsProperty.PropertyName)
UpdateImeOptions(); UpdateImeOptions();
else if (e.PropertyName == Entry.ReturnTypeProperty.PropertyName)
UpdateReturnType();
base.OnElementPropertyChanged(sender, e); base.OnElementPropertyChanged(sender, e);
} }
@ -255,5 +257,14 @@ namespace Xamarin.Forms.Platform.Android
if (currentControlText.Length > Element.MaxLength) if (currentControlText.Length > Element.MaxLength)
Control.Text = currentControlText.Substring(0, Element.MaxLength); Control.Text = currentControlText.Substring(0, Element.MaxLength);
} }
void UpdateReturnType()
{
if (Control == null || Element == null)
return;
Control.ImeOptions = Element.ReturnType.ToAndroidImeAction();
_currentInputImeFlag = Control.ImeOptions;
}
} }
} }

Просмотреть файл

@ -0,0 +1,29 @@
using ElmSharp;
namespace Xamarin.Forms.Platform.Tizen
{
internal static class EntryExtensions
{
internal static InputPanelReturnKeyType ToInputPanelReturnKeyType(this ReturnType returnType)
{
switch (returnType)
{
case ReturnType.Go:
return InputPanelReturnKeyType.Go;
case ReturnType.Next:
return InputPanelReturnKeyType.Next;
case ReturnType.Send:
return InputPanelReturnKeyType.Send;
case ReturnType.Search:
return InputPanelReturnKeyType.Search;
case ReturnType.Done:
return InputPanelReturnKeyType.Done;
case ReturnType.Default:
return InputPanelReturnKeyType.Default;
default:
throw new System.NotImplementedException($"ReturnType {returnType} not supported");
}
}
}
}

Просмотреть файл

@ -1,5 +1,4 @@
using System; using System;
using ElmSharp;
using Specific = Xamarin.Forms.PlatformConfiguration.TizenSpecific.Entry; using Specific = Xamarin.Forms.PlatformConfiguration.TizenSpecific.Entry;
namespace Xamarin.Forms.Platform.Tizen namespace Xamarin.Forms.Platform.Tizen
@ -19,6 +18,7 @@ namespace Xamarin.Forms.Platform.Tizen
RegisterPropertyHandler(Entry.PlaceholderProperty, UpdatePlaceholder); RegisterPropertyHandler(Entry.PlaceholderProperty, UpdatePlaceholder);
RegisterPropertyHandler(Entry.PlaceholderColorProperty, UpdatePlaceholderColor); RegisterPropertyHandler(Entry.PlaceholderColorProperty, UpdatePlaceholderColor);
RegisterPropertyHandler(InputView.MaxLengthProperty, UpdateMaxLength); RegisterPropertyHandler(InputView.MaxLengthProperty, UpdateMaxLength);
RegisterPropertyHandler(Entry.ReturnTypeProperty, UpdateReturnType);
if (TizenPlatformServices.AppDomain.IsTizenSpecificAvailable) if (TizenPlatformServices.AppDomain.IsTizenSpecificAvailable)
{ {
RegisterPropertyHandler("FontWeight", UpdateFontWeight); RegisterPropertyHandler("FontWeight", UpdateFontWeight);
@ -146,5 +146,10 @@ namespace Xamarin.Forms.Platform.Tizen
return null; return null;
} }
void UpdateReturnType()
{
Control.SetInputPanelReturnKeyType(Element.ReturnType.ToInputPanelReturnKeyType());
}
} }
} }

Просмотреть файл

@ -49,6 +49,7 @@ namespace Xamarin.Forms.Platform.UWP
UpdatePlaceholderColor(); UpdatePlaceholderColor();
UpdateMaxLength(); UpdateMaxLength();
UpdateDetectReadingOrderFromContent(); UpdateDetectReadingOrderFromContent();
UpdateReturnType();
} }
} }
@ -95,6 +96,8 @@ namespace Xamarin.Forms.Platform.UWP
UpdateMaxLength(); UpdateMaxLength();
else if (e.PropertyName == Specifics.DetectReadingOrderFromContentProperty.PropertyName) else if (e.PropertyName == Specifics.DetectReadingOrderFromContentProperty.PropertyName)
UpdateDetectReadingOrderFromContent(); UpdateDetectReadingOrderFromContent();
else if (e.PropertyName == Entry.ReturnTypeProperty.PropertyName)
UpdateReturnType();
} }
protected override void UpdateBackgroundColor() protected override void UpdateBackgroundColor()
@ -249,5 +252,13 @@ namespace Xamarin.Forms.Platform.UWP
} }
} }
} }
void UpdateReturnType()
{
if (Control == null || Element == null)
return;
Control.InputScope = Element.ReturnType.ToInputScope();
}
} }
} }

Просмотреть файл

@ -2,6 +2,7 @@
using System.Runtime.CompilerServices; using System.Runtime.CompilerServices;
using Windows.Foundation; using Windows.Foundation;
using Windows.UI.Xaml; using Windows.UI.Xaml;
using Windows.UI.Xaml.Input;
namespace Xamarin.Forms.Platform.UWP namespace Xamarin.Forms.Platform.UWP
{ {
@ -26,5 +27,37 @@ namespace Xamarin.Forms.Platform.UWP
{ {
self.SetBinding(property, new Windows.UI.Xaml.Data.Binding { Path = new PropertyPath(path), Converter = converter }); self.SetBinding(property, new Windows.UI.Xaml.Data.Binding { Path = new PropertyPath(path), Converter = converter });
} }
internal static InputScopeNameValue GetKeyboardButtonType(this ReturnType returnType)
{
switch (returnType)
{
case ReturnType.Default:
case ReturnType.Done:
case ReturnType.Go:
case ReturnType.Next:
case ReturnType.Send:
return InputScopeNameValue.Default;
case ReturnType.Search:
return InputScopeNameValue.Search;
default:
throw new System.NotImplementedException($"ReturnType {returnType} not supported");
}
}
internal static InputScope ToInputScope(this ReturnType returnType)
{
var scopeName = new InputScopeName()
{
NameValue = GetKeyboardButtonType(returnType)
};
var inputScope = new InputScope
{
Names = { scopeName }
};
return inputScope;
}
} }
} }

Просмотреть файл

@ -68,6 +68,27 @@ namespace Xamarin.Forms.Platform.iOS
} }
} }
internal static UIReturnKeyType ToUIReturnKeyType(this ReturnType returnType)
{
switch (returnType)
{
case ReturnType.Go:
return UIReturnKeyType.Go;
case ReturnType.Next:
return UIReturnKeyType.Next;
case ReturnType.Send:
return UIReturnKeyType.Send;
case ReturnType.Search:
return UIReturnKeyType.Search;
case ReturnType.Done:
return UIReturnKeyType.Done;
case ReturnType.Default:
return UIReturnKeyType.Default;
default:
throw new System.NotImplementedException($"ReturnType {returnType} not supported");
}
}
internal static DeviceOrientation ToDeviceOrientation(this UIDeviceOrientation orientation) internal static DeviceOrientation ToDeviceOrientation(this UIDeviceOrientation orientation)
{ {
switch (orientation) switch (orientation)

Просмотреть файл

@ -108,6 +108,7 @@ namespace Xamarin.Forms.Platform.iOS
UpdateAlignment(); UpdateAlignment();
UpdateAdjustsFontSizeToFitWidth(); UpdateAdjustsFontSizeToFitWidth();
UpdateMaxLength(); UpdateMaxLength();
UpdateReturnType();
} }
protected override void OnElementPropertyChanged(object sender, PropertyChangedEventArgs e) protected override void OnElementPropertyChanged(object sender, PropertyChangedEventArgs e)
@ -143,6 +144,8 @@ namespace Xamarin.Forms.Platform.iOS
UpdateAlignment(); UpdateAlignment();
else if (e.PropertyName == Xamarin.Forms.InputView.MaxLengthProperty.PropertyName) else if (e.PropertyName == Xamarin.Forms.InputView.MaxLengthProperty.PropertyName)
UpdateMaxLength(); UpdateMaxLength();
else if (e.PropertyName == Entry.ReturnTypeProperty.PropertyName)
UpdateReturnType();
base.OnElementPropertyChanged(sender, e); base.OnElementPropertyChanged(sender, e);
} }
@ -278,5 +281,13 @@ namespace Xamarin.Forms.Platform.iOS
var newLength = textField?.Text?.Length + replacementString.Length - range.Length; var newLength = textField?.Text?.Length + replacementString.Length - range.Length;
return newLength <= Element?.MaxLength; return newLength <= Element?.MaxLength;
} }
void UpdateReturnType()
{
if (Control == null || Element == null)
return;
Control.ReturnKeyType = Element.ReturnType.ToUIReturnKeyType();
}
} }
} }

Просмотреть файл

@ -417,6 +417,99 @@ View CreateLoginForm ()
</remarks> </remarks>
</Docs> </Docs>
</Member> </Member>
<Member MemberName="ReturnCommand">
<MemberSignature Language="C#" Value="public System.Windows.Input.ICommand ReturnCommand { get; set; }" />
<MemberSignature Language="ILAsm" Value=".property instance class System.Windows.Input.ICommand ReturnCommand" />
<MemberType>Property</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>System.Windows.Input.ICommand</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
<value>To be added.</value>
<remarks>To be added.</remarks>
</Docs>
</Member>
<Member MemberName="ReturnCommandParameter">
<MemberSignature Language="C#" Value="public object ReturnCommandParameter { get; set; }" />
<MemberSignature Language="ILAsm" Value=".property instance object ReturnCommandParameter" />
<MemberType>Property</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>System.Object</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
<value>To be added.</value>
<remarks>To be added.</remarks>
</Docs>
</Member>
<Member MemberName="ReturnCommandParameterProperty">
<MemberSignature Language="C#" Value="public static readonly Xamarin.Forms.BindableProperty ReturnCommandParameterProperty;" />
<MemberSignature Language="ILAsm" Value=".field public static initonly class Xamarin.Forms.BindableProperty ReturnCommandParameterProperty" />
<MemberType>Field</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.BindableProperty</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
<remarks>To be added.</remarks>
</Docs>
</Member>
<Member MemberName="ReturnCommandProperty">
<MemberSignature Language="C#" Value="public static readonly Xamarin.Forms.BindableProperty ReturnCommandProperty;" />
<MemberSignature Language="ILAsm" Value=".field public static initonly class Xamarin.Forms.BindableProperty ReturnCommandProperty" />
<MemberType>Field</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.BindableProperty</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
<remarks>To be added.</remarks>
</Docs>
</Member>
<Member MemberName="ReturnType">
<MemberSignature Language="C#" Value="public Xamarin.Forms.ReturnType ReturnType { get; set; }" />
<MemberSignature Language="ILAsm" Value=".property instance valuetype Xamarin.Forms.ReturnType ReturnType" />
<MemberType>Property</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.ReturnType</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
<value>To be added.</value>
<remarks>To be added.</remarks>
</Docs>
</Member>
<Member MemberName="ReturnTypeProperty">
<MemberSignature Language="C#" Value="public static readonly Xamarin.Forms.BindableProperty ReturnTypeProperty;" />
<MemberSignature Language="ILAsm" Value=".field public static initonly class Xamarin.Forms.BindableProperty ReturnTypeProperty" />
<MemberType>Field</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.BindableProperty</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
<remarks>To be added.</remarks>
</Docs>
</Member>
<Member MemberName="SendCompleted"> <Member MemberName="SendCompleted">
<MemberSignature Language="C#" Value="public void SendCompleted ();" /> <MemberSignature Language="C#" Value="public void SendCompleted ();" />
<MemberSignature Language="ILAsm" Value=".method public hidebysig newslot virtual instance void SendCompleted() cil managed" /> <MemberSignature Language="ILAsm" Value=".method public hidebysig newslot virtual instance void SendCompleted() cil managed" />

Просмотреть файл

@ -0,0 +1,101 @@
<Type Name="ReturnType" FullName="Xamarin.Forms.ReturnType">
<TypeSignature Language="C#" Value="public enum ReturnType" />
<TypeSignature Language="ILAsm" Value=".class public auto ansi sealed ReturnType extends System.Enum" />
<AssemblyInfo>
<AssemblyName>Xamarin.Forms.Core</AssemblyName>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<Base>
<BaseTypeName>System.Enum</BaseTypeName>
</Base>
<Docs>
<summary>To be added.</summary>
<remarks>To be added.</remarks>
</Docs>
<Members>
<Member MemberName="Default">
<MemberSignature Language="C#" Value="Default" />
<MemberSignature Language="ILAsm" Value=".field public static literal valuetype Xamarin.Forms.ReturnType Default = int32(0)" />
<MemberType>Field</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.ReturnType</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
</Docs>
</Member>
<Member MemberName="Done">
<MemberSignature Language="C#" Value="Done" />
<MemberSignature Language="ILAsm" Value=".field public static literal valuetype Xamarin.Forms.ReturnType Done = int32(1)" />
<MemberType>Field</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.ReturnType</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
</Docs>
</Member>
<Member MemberName="Go">
<MemberSignature Language="C#" Value="Go" />
<MemberSignature Language="ILAsm" Value=".field public static literal valuetype Xamarin.Forms.ReturnType Go = int32(2)" />
<MemberType>Field</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.ReturnType</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
</Docs>
</Member>
<Member MemberName="Next">
<MemberSignature Language="C#" Value="Next" />
<MemberSignature Language="ILAsm" Value=".field public static literal valuetype Xamarin.Forms.ReturnType Next = int32(3)" />
<MemberType>Field</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.ReturnType</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
</Docs>
</Member>
<Member MemberName="Search">
<MemberSignature Language="C#" Value="Search" />
<MemberSignature Language="ILAsm" Value=".field public static literal valuetype Xamarin.Forms.ReturnType Search = int32(4)" />
<MemberType>Field</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.ReturnType</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
</Docs>
</Member>
<Member MemberName="Send">
<MemberSignature Language="C#" Value="Send" />
<MemberSignature Language="ILAsm" Value=".field public static literal valuetype Xamarin.Forms.ReturnType Send = int32(5)" />
<MemberType>Field</MemberType>
<AssemblyInfo>
<AssemblyVersion>2.0.0.0</AssemblyVersion>
</AssemblyInfo>
<ReturnValue>
<ReturnType>Xamarin.Forms.ReturnType</ReturnType>
</ReturnValue>
<Docs>
<summary>To be added.</summary>
</Docs>
</Member>
</Members>
</Type>

Просмотреть файл

@ -369,6 +369,7 @@
<Type Name="ResolutionGroupNameAttribute" Kind="Class" /> <Type Name="ResolutionGroupNameAttribute" Kind="Class" />
<Type Name="ResourceDictionary" Kind="Class" /> <Type Name="ResourceDictionary" Kind="Class" />
<Type Name="ResourceDictionary+RDSourceTypeConverter" Kind="Class" /> <Type Name="ResourceDictionary+RDSourceTypeConverter" Kind="Class" />
<Type Name="ReturnType" Kind="Enumeration" />
<Type Name="RoutingEffect" Kind="Class" /> <Type Name="RoutingEffect" Kind="Class" />
<Type Name="RowDefinition" Kind="Class" /> <Type Name="RowDefinition" Kind="Class" />
<Type Name="RowDefinitionCollection" Kind="Class" /> <Type Name="RowDefinitionCollection" Kind="Class" />