mirror of
https://github.com/bitwarden/mobile.git
synced 2024-06-23 10:04:49 +02:00
2e8824ce05
* Account Switching (#1720) * Account switching * WIP * wip * wip * updates to send test logic * fixed Send tests * fixes for theme handling on account switching and re-adding existing account * switch fixes * fixes * fixes * cleanup * vault timeout fixes * account list status enhancements * logout fixes and token handling improvements * merge latest (#1727) * remove duplicate dependency * fix for initial login token storage paradox (#1730) * Fix avatar color update toolbar item issue on iOS for account switching (#1735) * Updated account switching menu UI (#1733) * updated account switching menu UI * additional changes * add key suffix to constant * GetFirstLetters method tweaks * Fix crash on account switching when logging out when having more than user at a time (#1740) * single account migration to multi-account on app update (#1741) * Account Switching Tap to dismiss (#1743) * Added tap to dismiss on the Account switching overlay and improved a bit the code * Fix account switching overlay background transparent on the proper place * Fixed transparent background and the shadow on the account switching overlay * Fix iOS top space on Account switching list overlay after modal (#1746) * Fix top space added to Account switching list overlay after closing modal * Fix top space added to Account switching list overlay after closing modal on lock, login and home views just in case we add modals in the future there as well * Usability: dismiss account list on certain events (#1748) * dismiss account list on certain events * use new FireAndForget method for back button logic * Create and use Account Switching overlay control (#1753) * Added Account switching overlay control and its own ViewModel and refactored accordingly * Fix account switching Accounts list binding update * Implemented dismiss account switching overlay when changing tabs and when selecting the same tab. Also updated the deprecated listener on CustomTabbedRenderer on Android (#1755) * Overriden Equals on AvatarImageSource so it doesn't get set multiple times when it's the same image thus producing blinking on tab chaged (#1756) * Usability improvements for logout on vault timeout (#1781) * accountswitching fixes (#1784) * Fix for invalid PIN lock state when switching accounts (#1792) * fix for pin lock flow * named tuple values and updated async * clear send service cache on account switch (#1796) * Global theme and account removal (#1793) * Global theme and account removal * remove redundant call to hide account list overlay * cleanup and additional tweaks * add try/catch to remove account dialog flow Co-authored-by: Federico Maccaroni <fedemkr@gmail.com>
178 lines
4.9 KiB
C#
178 lines
4.9 KiB
C#
using System;
|
|
using System.Threading.Tasks;
|
|
using Bit.App.Models;
|
|
using Bit.App.Resources;
|
|
using Bit.App.Utilities;
|
|
using Bit.Core.Utilities;
|
|
using Xamarin.Forms;
|
|
|
|
namespace Bit.App.Pages
|
|
{
|
|
public partial class LockPage : BaseContentPage
|
|
{
|
|
private readonly AppOptions _appOptions;
|
|
private readonly bool _autoPromptBiometric;
|
|
private readonly LockPageViewModel _vm;
|
|
|
|
private bool _promptedAfterResume;
|
|
private bool _appeared;
|
|
|
|
public LockPage(AppOptions appOptions = null, bool autoPromptBiometric = true)
|
|
{
|
|
_appOptions = appOptions;
|
|
_autoPromptBiometric = autoPromptBiometric;
|
|
InitializeComponent();
|
|
_vm = BindingContext as LockPageViewModel;
|
|
_vm.Page = this;
|
|
_vm.UnlockedAction = () => Device.BeginInvokeOnMainThread(async () => await UnlockedAsync());
|
|
MasterPasswordEntry = _masterPassword;
|
|
PinEntry = _pin;
|
|
|
|
if (Device.RuntimePlatform == Device.iOS)
|
|
{
|
|
ToolbarItems.Add(_moreItem);
|
|
}
|
|
else
|
|
{
|
|
ToolbarItems.Add(_logOut);
|
|
}
|
|
}
|
|
|
|
public Entry MasterPasswordEntry { get; set; }
|
|
public Entry PinEntry { get; set; }
|
|
|
|
public async Task PromptBiometricAfterResumeAsync()
|
|
{
|
|
if (_vm.BiometricLock)
|
|
{
|
|
await Task.Delay(500);
|
|
if (!_promptedAfterResume)
|
|
{
|
|
_promptedAfterResume = true;
|
|
await _vm?.PromptBiometricAsync();
|
|
}
|
|
}
|
|
}
|
|
|
|
protected override async void OnAppearing()
|
|
{
|
|
base.OnAppearing();
|
|
if (_appeared)
|
|
{
|
|
return;
|
|
}
|
|
|
|
_appeared = true;
|
|
_mainContent.Content = _mainLayout;
|
|
|
|
_accountAvatar?.OnAppearing();
|
|
|
|
_vm.AvatarImageSource = await GetAvatarImageSourceAsync();
|
|
|
|
await _vm.InitAsync();
|
|
if (!_vm.BiometricLock)
|
|
{
|
|
if (_vm.PinLock)
|
|
{
|
|
RequestFocus(PinEntry);
|
|
}
|
|
else
|
|
{
|
|
RequestFocus(MasterPasswordEntry);
|
|
}
|
|
}
|
|
else
|
|
{
|
|
if (_vm.UsingKeyConnector && !_vm.PinLock)
|
|
{
|
|
_passwordGrid.IsVisible = false;
|
|
_unlockButton.IsVisible = false;
|
|
}
|
|
if (_autoPromptBiometric)
|
|
{
|
|
var tasks = Task.Run(async () =>
|
|
{
|
|
await Task.Delay(500);
|
|
Device.BeginInvokeOnMainThread(async () => await _vm.PromptBiometricAsync());
|
|
});
|
|
}
|
|
}
|
|
}
|
|
|
|
protected override bool OnBackButtonPressed()
|
|
{
|
|
if (_accountListOverlay.IsVisible)
|
|
{
|
|
_accountListOverlay.HideAsync().FireAndForget();
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
protected override void OnDisappearing()
|
|
{
|
|
base.OnDisappearing();
|
|
|
|
_accountAvatar?.OnDisappearing();
|
|
}
|
|
|
|
private void Unlock_Clicked(object sender, EventArgs e)
|
|
{
|
|
if (DoOnce())
|
|
{
|
|
var tasks = Task.Run(async () =>
|
|
{
|
|
await Task.Delay(50);
|
|
Device.BeginInvokeOnMainThread(async () => await _vm.SubmitAsync());
|
|
});
|
|
}
|
|
}
|
|
|
|
private async void LogOut_Clicked(object sender, EventArgs e)
|
|
{
|
|
await _accountListOverlay.HideAsync();
|
|
if (DoOnce())
|
|
{
|
|
await _vm.LogOutAsync();
|
|
}
|
|
}
|
|
|
|
private async void Biometric_Clicked(object sender, EventArgs e)
|
|
{
|
|
if (DoOnce())
|
|
{
|
|
await _vm.PromptBiometricAsync();
|
|
}
|
|
}
|
|
|
|
private async void More_Clicked(object sender, System.EventArgs e)
|
|
{
|
|
await _accountListOverlay.HideAsync();
|
|
|
|
if (!DoOnce())
|
|
{
|
|
return;
|
|
}
|
|
|
|
var selection = await DisplayActionSheet(AppResources.Options,
|
|
AppResources.Cancel, null, AppResources.LogOut);
|
|
|
|
if (selection == AppResources.LogOut)
|
|
{
|
|
await _vm.LogOutAsync();
|
|
}
|
|
}
|
|
|
|
private async Task UnlockedAsync()
|
|
{
|
|
if (AppHelpers.SetAlternateMainPage(_appOptions))
|
|
{
|
|
return;
|
|
}
|
|
var previousPage = await AppHelpers.ClearPreviousPage();
|
|
|
|
Application.Current.MainPage = new TabsPage(_appOptions, previousPage);
|
|
}
|
|
}
|
|
}
|