Skip to content

Create and use Account Switching overlay control#1753

Merged
mpbw2 merged 3 commits intoaccountswitchingfrom
accountswitching-overlaycontrol
Feb 7, 2022
Merged

Create and use Account Switching overlay control#1753
mpbw2 merged 3 commits intoaccountswitchingfrom
accountswitching-overlaycontrol

Conversation

@fedemkr
Copy link
Copy Markdown
Member

@fedemkr fedemkr commented Feb 4, 2022

Type of change

  • Bug fix
  • New feature development
  • Tech debt (refactoring, code cleanup, dependency upgrades, etc)
  • Build/deploy pipeline (DevOps)
  • Other

Objective

Add an account switching overlay control to be reused on all the views. Also add its own ViewModel to handle the logic and configuration.

Code changes

  • AccountSwitchingOverlayView: This is the new control for the overlay
  • AccountSwitchingOverlayViewModel: This is the overlay's viewmodel to handle logic and configuration
  • ...Page.xaml: Changed to use the new overlay control
  • ...Page.xaml.cs: Changed to use the new overlay control and removed old code
  • ...PageViewModel.cs: Added and created new AccountSwitchingOverlayViewModel on each to offer the binding context for the new overlay control and configuration
  • BaseContentPage.cs: Moved Account switching overlay logic to the new control
  • StateService: Change the AccountViews to be a List instead of an ExtendedObservableCollection given that we don't change items while the view is open; it only changes when adding/removing accounts and that happens on pages transition so it doesn't make sense to use all the notifying events of the ExtendedObservableCollection. And also the List is replaced completely when refreshing the accounts so a simple List makes more sense for this case given that there are just a few items.

Testing requirements

Everything should work as before.

Before you submit

  • I have added unit tests where it makes sense to do so (encouraged but not required)
  • This change requires a documentation update (notify the documentation team)
  • This change has particular deployment requirements (notify the DevOps team)

@fedemkr fedemkr marked this pull request as draft February 4, 2022 21:48
* accountswitching:
  Autosync the updated translations (#1752)
  Fix delete account SSO with CME that the OTP parameter was being sent incorrectly to the server (#1751)
@fedemkr fedemkr marked this pull request as ready for review February 7, 2022 15:54
@fedemkr fedemkr requested a review from mpbw2 February 7, 2022 15:54
@fedemkr fedemkr self-assigned this Feb 7, 2022
@fedemkr fedemkr changed the title Add and use Account Switching overlay control Create and use Account Switching overlay control Feb 7, 2022
@mpbw2 mpbw2 merged commit c8698cf into accountswitching Feb 7, 2022
@mpbw2 mpbw2 deleted the accountswitching-overlaycontrol branch February 7, 2022 22:14
Copy link
Copy Markdown
Contributor

@mpbw2 mpbw2 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

oops, meant to approve but merged instead. Guess the coffee wore off.

fedemkr added a commit that referenced this pull request Feb 7, 2022
…miss

* accountswitching:
  Create and use Account Switching overlay control (#1753)

# Conflicts:
#	src/App/Pages/Vault/GroupingsPage/GroupingsPage.xaml.cs
mpbw2 added a commit that referenced this pull request Feb 23, 2022
* 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>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

2 participants