mirror of
https://github.com/bitwarden/android.git
synced 2024-12-25 18:38:27 +03:00
custom toast for ios
This commit is contained in:
parent
f897193f79
commit
839df123ff
5 changed files with 167 additions and 14 deletions
33
src/Android/Resources/Resource.Designer.cs
generated
33
src/Android/Resources/Resource.Designer.cs
generated
|
@ -4375,17 +4375,17 @@ namespace Bit.Android
|
||||||
// aapt resource value: 0x7f090051
|
// aapt resource value: 0x7f090051
|
||||||
public const int ApplicationName = 2131296337;
|
public const int ApplicationName = 2131296337;
|
||||||
|
|
||||||
// aapt resource value: 0x7f0900ab
|
// aapt resource value: 0x7f0900b2
|
||||||
public const int AutoFillServiceDescription = 2131296427;
|
public const int AutoFillServiceDescription = 2131296434;
|
||||||
|
|
||||||
// aapt resource value: 0x7f0900aa
|
// aapt resource value: 0x7f0900b1
|
||||||
public const int AutoFillServiceSummary = 2131296426;
|
public const int AutoFillServiceSummary = 2131296433;
|
||||||
|
|
||||||
// aapt resource value: 0x7f090050
|
// aapt resource value: 0x7f090050
|
||||||
public const int Hello = 2131296336;
|
public const int Hello = 2131296336;
|
||||||
|
|
||||||
// aapt resource value: 0x7f0900ac
|
// aapt resource value: 0x7f0900b3
|
||||||
public const int MyVault = 2131296428;
|
public const int MyVault = 2131296435;
|
||||||
|
|
||||||
// aapt resource value: 0x7f090027
|
// aapt resource value: 0x7f090027
|
||||||
public const int abc_action_bar_home_description = 2131296295;
|
public const int abc_action_bar_home_description = 2131296295;
|
||||||
|
@ -4540,6 +4540,27 @@ namespace Bit.Android
|
||||||
// aapt resource value: 0x7f09000f
|
// aapt resource value: 0x7f09000f
|
||||||
public const int common_signin_button_text_long = 2131296271;
|
public const int common_signin_button_text_long = 2131296271;
|
||||||
|
|
||||||
|
// aapt resource value: 0x7f0900ac
|
||||||
|
public const int default_web_client_id = 2131296428;
|
||||||
|
|
||||||
|
// aapt resource value: 0x7f0900ad
|
||||||
|
public const int firebase_database_url = 2131296429;
|
||||||
|
|
||||||
|
// aapt resource value: 0x7f0900aa
|
||||||
|
public const int gcm_defaultSenderId = 2131296426;
|
||||||
|
|
||||||
|
// aapt resource value: 0x7f0900ae
|
||||||
|
public const int google_api_key = 2131296430;
|
||||||
|
|
||||||
|
// aapt resource value: 0x7f0900ab
|
||||||
|
public const int google_app_id = 2131296427;
|
||||||
|
|
||||||
|
// aapt resource value: 0x7f0900af
|
||||||
|
public const int google_crash_reporting_api_key = 2131296431;
|
||||||
|
|
||||||
|
// aapt resource value: 0x7f0900b0
|
||||||
|
public const int google_storage_bucket = 2131296432;
|
||||||
|
|
||||||
// aapt resource value: 0x7f090052
|
// aapt resource value: 0x7f090052
|
||||||
public const int hockeyapp_crash_dialog_app_name_fallback = 2131296338;
|
public const int hockeyapp_crash_dialog_app_name_fallback = 2131296338;
|
||||||
|
|
||||||
|
|
135
src/iOS.Core/Views/Toast.cs
Normal file
135
src/iOS.Core/Views/Toast.cs
Normal file
|
@ -0,0 +1,135 @@
|
||||||
|
using Foundation;
|
||||||
|
using System;
|
||||||
|
using UIKit;
|
||||||
|
|
||||||
|
namespace Bit.iOS.Core.Views
|
||||||
|
{
|
||||||
|
public class Toast : UIView
|
||||||
|
{
|
||||||
|
// Timer to dismiss the snack bar.
|
||||||
|
private NSTimer _dismissTimer;
|
||||||
|
|
||||||
|
// Constraints.
|
||||||
|
private NSLayoutConstraint _heightConstraint;
|
||||||
|
private NSLayoutConstraint _leftMarginConstraint;
|
||||||
|
private NSLayoutConstraint _rightMarginConstraint;
|
||||||
|
private NSLayoutConstraint _topMarginConstraint;
|
||||||
|
private NSLayoutConstraint _bottomMarginConstraint;
|
||||||
|
|
||||||
|
public Toast(string text) : base(CoreGraphics.CGRect.FromLTRB(0, 0, 320, 44))
|
||||||
|
{
|
||||||
|
TranslatesAutoresizingMaskIntoConstraints = false;
|
||||||
|
BackgroundColor = UIColor.DarkGray;
|
||||||
|
Layer.CornerRadius = 4;
|
||||||
|
Layer.MasksToBounds = true;
|
||||||
|
|
||||||
|
MessageLabel = new UILabel
|
||||||
|
{
|
||||||
|
TranslatesAutoresizingMaskIntoConstraints = false,
|
||||||
|
TextColor = UIColor.White,
|
||||||
|
Font = UIFont.SystemFontOfSize(14),
|
||||||
|
BackgroundColor = UIColor.Clear,
|
||||||
|
LineBreakMode = UILineBreakMode.WordWrap,
|
||||||
|
TextAlignment = UITextAlignment.Center,
|
||||||
|
Lines = 0
|
||||||
|
};
|
||||||
|
|
||||||
|
var hConstraints = NSLayoutConstraint.FromVisualFormat("H:|-5-[messageLabel]-5-|", 0, new NSDictionary(),
|
||||||
|
NSDictionary.FromObjectsAndKeys(new NSObject[] { MessageLabel },
|
||||||
|
new NSObject[] { new NSString("messageLabel") })
|
||||||
|
);
|
||||||
|
|
||||||
|
var vMessageConstraints = NSLayoutConstraint.FromVisualFormat("V:|-0-[messageLabel]-0-|", 0, new NSDictionary(),
|
||||||
|
NSDictionary.FromObjectsAndKeys(new NSObject[] { MessageLabel },
|
||||||
|
new NSObject[] { new NSString("messageLabel") })
|
||||||
|
);
|
||||||
|
|
||||||
|
AddConstraints(hConstraints);
|
||||||
|
AddConstraints(vMessageConstraints);
|
||||||
|
AddSubview(MessageLabel);
|
||||||
|
}
|
||||||
|
|
||||||
|
public TimeSpan Duration { get; set; } = TimeSpan.FromSeconds(3);
|
||||||
|
public UILabel MessageLabel { get; set; }
|
||||||
|
public nfloat LeftMargin { get; set; } = 4;
|
||||||
|
public nfloat RightMargin { get; set; } = 4;
|
||||||
|
public nfloat BottomMargin { get; set; } = 4;
|
||||||
|
public nfloat Height { get; set; } = 44;
|
||||||
|
public nfloat TopMargin { get; set; } = 8;
|
||||||
|
|
||||||
|
public void Show()
|
||||||
|
{
|
||||||
|
if(Superview != null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
_dismissTimer = NSTimer.CreateScheduledTimer(Duration, x => Dismiss());
|
||||||
|
LayoutIfNeeded();
|
||||||
|
|
||||||
|
var localSuperView = UIApplication.SharedApplication.KeyWindow;
|
||||||
|
if(localSuperView != null)
|
||||||
|
{
|
||||||
|
localSuperView.AddSubview(this);
|
||||||
|
|
||||||
|
_heightConstraint = NSLayoutConstraint.Create(this, NSLayoutAttribute.Height,
|
||||||
|
NSLayoutRelation.GreaterThanOrEqual, null, NSLayoutAttribute.NoAttribute, 1, Height);
|
||||||
|
|
||||||
|
_leftMarginConstraint = NSLayoutConstraint.Create(this, NSLayoutAttribute.Left, NSLayoutRelation.Equal,
|
||||||
|
localSuperView, NSLayoutAttribute.Left, 1, LeftMargin);
|
||||||
|
|
||||||
|
_rightMarginConstraint = NSLayoutConstraint.Create(this, NSLayoutAttribute.Right, NSLayoutRelation.Equal,
|
||||||
|
localSuperView, NSLayoutAttribute.Right, 1, -RightMargin);
|
||||||
|
|
||||||
|
_bottomMarginConstraint = NSLayoutConstraint.Create(this, NSLayoutAttribute.Bottom, NSLayoutRelation.Equal,
|
||||||
|
localSuperView, NSLayoutAttribute.Bottom, 1, -BottomMargin);
|
||||||
|
|
||||||
|
// Avoid the "UIView-Encapsulated-Layout-Height" constraint conflicts
|
||||||
|
// http://stackoverflow.com/questions/25059443/what-is-nslayoutconstraint-uiview-encapsulated-layout-height-and-how-should-i
|
||||||
|
_leftMarginConstraint.Priority = 999;
|
||||||
|
_rightMarginConstraint.Priority = 999;
|
||||||
|
|
||||||
|
AddConstraint(_heightConstraint);
|
||||||
|
localSuperView.AddConstraint(_leftMarginConstraint);
|
||||||
|
localSuperView.AddConstraint(_rightMarginConstraint);
|
||||||
|
localSuperView.AddConstraint(_bottomMarginConstraint);
|
||||||
|
|
||||||
|
// Show
|
||||||
|
ShowWithAnimation();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
Console.WriteLine("Toast needs a keyWindows to display.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Dismiss(bool animated = true)
|
||||||
|
{
|
||||||
|
_dismissTimer?.Invalidate();
|
||||||
|
_dismissTimer = null;
|
||||||
|
nfloat superViewWidth = 0;
|
||||||
|
|
||||||
|
if(Superview != null)
|
||||||
|
{
|
||||||
|
superViewWidth = Superview.Frame.Width;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(!animated)
|
||||||
|
{
|
||||||
|
RemoveFromSuperview();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
SetNeedsLayout();
|
||||||
|
Animate(0.3f, 0, UIViewAnimationOptions.CurveEaseIn, () => { Alpha = 0; }, RemoveFromSuperview);
|
||||||
|
}
|
||||||
|
|
||||||
|
private void ShowWithAnimation()
|
||||||
|
{
|
||||||
|
_bottomMarginConstraint.Constant = -BottomMargin;
|
||||||
|
_leftMarginConstraint.Constant = LeftMargin;
|
||||||
|
_rightMarginConstraint.Constant = -RightMargin;
|
||||||
|
AnimateNotify(0.3f, 0, 0.7f, 5f, UIViewAnimationOptions.CurveEaseInOut, () => { Alpha = 0; }, null);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -63,6 +63,7 @@
|
||||||
<Compile Include="Views\SliderTableViewCell.cs" />
|
<Compile Include="Views\SliderTableViewCell.cs" />
|
||||||
<Compile Include="Views\SwitchTableViewCell.cs" />
|
<Compile Include="Views\SwitchTableViewCell.cs" />
|
||||||
<Compile Include="Views\FormEntryTableViewCell.cs" />
|
<Compile Include="Views\FormEntryTableViewCell.cs" />
|
||||||
|
<Compile Include="Views\Toast.cs" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<ProjectReference Include="..\App\App.csproj">
|
<ProjectReference Include="..\App\App.csproj">
|
||||||
|
|
|
@ -10,6 +10,7 @@ using Photos;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
using System.Threading.Tasks;
|
using System.Threading.Tasks;
|
||||||
using Bit.App.Models.Page;
|
using Bit.App.Models.Page;
|
||||||
|
using Bit.iOS.Core.Views;
|
||||||
|
|
||||||
namespace Bit.iOS.Services
|
namespace Bit.iOS.Services
|
||||||
{
|
{
|
||||||
|
@ -28,12 +29,10 @@ namespace Bit.iOS.Services
|
||||||
|
|
||||||
public void Toast(string text, bool longDuration = false)
|
public void Toast(string text, bool longDuration = false)
|
||||||
{
|
{
|
||||||
var snackbar = new TTGSnackBar.TTGSnackbar(text)
|
new Toast(text)
|
||||||
{
|
{
|
||||||
Duration = TimeSpan.FromSeconds(longDuration ? 5 : 2),
|
Duration = TimeSpan.FromSeconds(longDuration ? 5 : 3)
|
||||||
AnimationType = TTGSnackBar.TTGSnackbarAnimationType.FadeInFadeOut
|
}.Show();
|
||||||
};
|
|
||||||
snackbar.Show();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void CopyToClipboard(string text)
|
public void CopyToClipboard(string text)
|
||||||
|
|
|
@ -704,9 +704,6 @@
|
||||||
<PackageReference Include="SimpleInjector">
|
<PackageReference Include="SimpleInjector">
|
||||||
<Version>4.0.12</Version>
|
<Version>4.0.12</Version>
|
||||||
</PackageReference>
|
</PackageReference>
|
||||||
<PackageReference Include="TTGSnackbar">
|
|
||||||
<Version>1.3.4</Version>
|
|
||||||
</PackageReference>
|
|
||||||
<PackageReference Include="Xamarin.Google.iOS.Analytics">
|
<PackageReference Include="Xamarin.Google.iOS.Analytics">
|
||||||
<Version>3.17.0.1</Version>
|
<Version>3.17.0.1</Version>
|
||||||
</PackageReference>
|
</PackageReference>
|
||||||
|
|
Loading…
Reference in a new issue