mirror of
https://github.com/bitwarden/mobile.git
synced 2025-01-04 18:28:15 +01:00
Adjusted button and entry to handle font upadte on property changes
This commit is contained in:
parent
98335c6acb
commit
596a74b394
@ -3,6 +3,7 @@ using Bit.iOS.Controls;
|
|||||||
using UIKit;
|
using UIKit;
|
||||||
using Xamarin.Forms;
|
using Xamarin.Forms;
|
||||||
using Xamarin.Forms.Platform.iOS;
|
using Xamarin.Forms.Platform.iOS;
|
||||||
|
using System.ComponentModel;
|
||||||
|
|
||||||
[assembly: ExportRenderer(typeof(Button), typeof(CustomButtonRenderer))]
|
[assembly: ExportRenderer(typeof(Button), typeof(CustomButtonRenderer))]
|
||||||
namespace Bit.iOS.Controls
|
namespace Bit.iOS.Controls
|
||||||
@ -16,10 +17,25 @@ namespace Bit.iOS.Controls
|
|||||||
var view = e.NewElement as Button;
|
var view = e.NewElement as Button;
|
||||||
if(Control != null && view != null)
|
if(Control != null && view != null)
|
||||||
{
|
{
|
||||||
var descriptor = UIFontDescriptor.PreferredBody;
|
UpdateFont();
|
||||||
var pointSize = descriptor.PointSize;
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var size = view.FontSize;
|
protected override void OnElementPropertyChanged(object sender, PropertyChangedEventArgs e)
|
||||||
|
{
|
||||||
|
base.OnElementPropertyChanged(sender, e);
|
||||||
|
|
||||||
|
if(e.PropertyName == Button.FontProperty.PropertyName)
|
||||||
|
{
|
||||||
|
UpdateFont();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void UpdateFont()
|
||||||
|
{
|
||||||
|
var pointSize = UIFontDescriptor.PreferredBody.PointSize;
|
||||||
|
|
||||||
|
var size = Element.FontSize;
|
||||||
if(size == Device.GetNamedSize(NamedSize.Large, typeof(Button)))
|
if(size == Device.GetNamedSize(NamedSize.Large, typeof(Button)))
|
||||||
{
|
{
|
||||||
pointSize *= 1.3f;
|
pointSize *= 1.3f;
|
||||||
@ -33,8 +49,7 @@ namespace Bit.iOS.Controls
|
|||||||
pointSize *= .6f;
|
pointSize *= .6f;
|
||||||
}
|
}
|
||||||
|
|
||||||
Control.Font = UIFont.FromDescriptor(descriptor, pointSize);
|
Control.Font = UIFont.FromDescriptor(Element.Font.ToUIFont().FontDescriptor, pointSize);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -21,12 +21,10 @@ namespace Bit.iOS.Controls
|
|||||||
var view = e.NewElement as ExtendedEntry;
|
var view = e.NewElement as ExtendedEntry;
|
||||||
if(view != null)
|
if(view != null)
|
||||||
{
|
{
|
||||||
var descriptor = UIFontDescriptor.PreferredBody;
|
|
||||||
Control.Font = UIFont.FromDescriptor( descriptor, descriptor.PointSize );
|
|
||||||
|
|
||||||
SetBorder(view);
|
SetBorder(view);
|
||||||
SetMaxLength(view);
|
SetMaxLength(view);
|
||||||
UpdateKeyboard();
|
UpdateKeyboard();
|
||||||
|
UpdateFont();
|
||||||
|
|
||||||
if(view.AllowClear)
|
if(view.AllowClear)
|
||||||
{
|
{
|
||||||
@ -92,6 +90,39 @@ namespace Bit.iOS.Controls
|
|||||||
{
|
{
|
||||||
UpdateKeyboard();
|
UpdateKeyboard();
|
||||||
}
|
}
|
||||||
|
else if(e.PropertyName == Entry.FontAttributesProperty.PropertyName)
|
||||||
|
{
|
||||||
|
UpdateFont();
|
||||||
|
}
|
||||||
|
else if(e.PropertyName == Entry.FontFamilyProperty.PropertyName)
|
||||||
|
{
|
||||||
|
UpdateFont();
|
||||||
|
}
|
||||||
|
else if(e.PropertyName == Entry.FontSizeProperty.PropertyName)
|
||||||
|
{
|
||||||
|
UpdateFont();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void UpdateFont()
|
||||||
|
{
|
||||||
|
var pointSize = UIFontDescriptor.PreferredBody.PointSize;
|
||||||
|
|
||||||
|
var size = Element.FontSize;
|
||||||
|
if(size == Device.GetNamedSize(NamedSize.Large, typeof(ExtendedEntry)))
|
||||||
|
{
|
||||||
|
pointSize *= 1.3f;
|
||||||
|
}
|
||||||
|
else if(size == Device.GetNamedSize(NamedSize.Small, typeof(ExtendedEntry)))
|
||||||
|
{
|
||||||
|
pointSize *= .8f;
|
||||||
|
}
|
||||||
|
else if(size == Device.GetNamedSize(NamedSize.Micro, typeof(ExtendedEntry)))
|
||||||
|
{
|
||||||
|
pointSize *= .6f;
|
||||||
|
}
|
||||||
|
|
||||||
|
Control.Font = UIFont.FromName(Element.FontFamily, pointSize);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void SetBorder(ExtendedEntry view)
|
private void SetBorder(ExtendedEntry view)
|
||||||
|
Loading…
Reference in New Issue
Block a user