mirror of
https://github.com/bitwarden/android.git
synced 2025-01-12 11:17:30 +03:00
support "no folder" short list on vault page
This commit is contained in:
parent
7d8dfb997e
commit
9ae08932c2
1 changed files with 44 additions and 35 deletions
|
@ -3,7 +3,6 @@ using Bit.App.Resources;
|
||||||
using Bit.App.Utilities;
|
using Bit.App.Utilities;
|
||||||
using Bit.Core.Abstractions;
|
using Bit.Core.Abstractions;
|
||||||
using Bit.Core.Enums;
|
using Bit.Core.Enums;
|
||||||
using Bit.Core.Exceptions;
|
|
||||||
using Bit.Core.Models.Domain;
|
using Bit.Core.Models.Domain;
|
||||||
using Bit.Core.Models.View;
|
using Bit.Core.Models.View;
|
||||||
using Bit.Core.Utilities;
|
using Bit.Core.Utilities;
|
||||||
|
@ -17,6 +16,8 @@ namespace Bit.App.Pages
|
||||||
{
|
{
|
||||||
public class GroupingsPageViewModel : BaseViewModel
|
public class GroupingsPageViewModel : BaseViewModel
|
||||||
{
|
{
|
||||||
|
private const int NoFolderListSize = 100;
|
||||||
|
|
||||||
private bool _refreshing;
|
private bool _refreshing;
|
||||||
private bool _doingLoad;
|
private bool _doingLoad;
|
||||||
private bool _loading;
|
private bool _loading;
|
||||||
|
@ -68,6 +69,8 @@ namespace Bit.App.Pages
|
||||||
public bool HasCiphers { get; set; }
|
public bool HasCiphers { get; set; }
|
||||||
public bool HasFolders { get; set; }
|
public bool HasFolders { get; set; }
|
||||||
public bool HasCollections { get; set; }
|
public bool HasCollections { get; set; }
|
||||||
|
public bool ShowNoFolderCiphers => (NoFolderCiphers?.Count ?? int.MaxValue) < NoFolderListSize &&
|
||||||
|
(!Collections?.Any() ?? true);
|
||||||
public List<CipherView> Ciphers { get; set; }
|
public List<CipherView> Ciphers { get; set; }
|
||||||
public List<CipherView> FavoriteCiphers { get; set; }
|
public List<CipherView> FavoriteCiphers { get; set; }
|
||||||
public List<CipherView> NoFolderCiphers { get; set; }
|
public List<CipherView> NoFolderCiphers { get; set; }
|
||||||
|
@ -132,35 +135,24 @@ namespace Bit.App.Pages
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
await LoadDataAsync();
|
await LoadDataAsync();
|
||||||
|
if(ShowNoFolderCiphers && (NestedFolders?.Any() ?? false))
|
||||||
|
{
|
||||||
|
// Remove "No Folder" from folder listing
|
||||||
|
NestedFolders = NestedFolders.GetRange(0, NestedFolders.Count - 1);
|
||||||
|
}
|
||||||
|
|
||||||
var favListItems = FavoriteCiphers?.Select(c => new GroupingsPageListItem { Cipher = c }).ToList();
|
var uppercaseGroupNames = _deviceActionService.DeviceType == DeviceType.iOS;
|
||||||
var ciphersListItems = Ciphers?.Select(c => new GroupingsPageListItem { Cipher = c }).ToList();
|
var hasFavorites = FavoriteCiphers?.Any() ?? false;
|
||||||
var folderListItems = NestedFolders?.Select(f =>
|
if(hasFavorites)
|
||||||
{
|
|
||||||
var fId = f.Node.Id ?? "none";
|
|
||||||
return new GroupingsPageListItem
|
|
||||||
{
|
|
||||||
Folder = f.Node,
|
|
||||||
ItemCount = (_folderCounts.ContainsKey(fId) ? _folderCounts[fId] : 0).ToString("N0")
|
|
||||||
};
|
|
||||||
}).ToList();
|
|
||||||
var collectionListItems = NestedCollections?.Select(c => new GroupingsPageListItem
|
|
||||||
{
|
|
||||||
Collection = c.Node,
|
|
||||||
ItemCount = (_collectionCounts.ContainsKey(c.Node.Id) ?
|
|
||||||
_collectionCounts[c.Node.Id] : 0).ToString("N0")
|
|
||||||
}).ToList();
|
|
||||||
|
|
||||||
var hasFavorites = favListItems?.Any() ?? false;
|
|
||||||
if(favListItems?.Any() ?? false)
|
|
||||||
{
|
{
|
||||||
|
var favListItems = FavoriteCiphers.Select(c => new GroupingsPageListItem { Cipher = c }).ToList();
|
||||||
groupedItems.Add(new GroupingsPageListGroup(favListItems, AppResources.Favorites,
|
groupedItems.Add(new GroupingsPageListGroup(favListItems, AppResources.Favorites,
|
||||||
favListItems.Count, Device.RuntimePlatform == Device.iOS, true));
|
favListItems.Count, uppercaseGroupNames, true));
|
||||||
}
|
}
|
||||||
if(MainPage)
|
if(MainPage)
|
||||||
{
|
{
|
||||||
groupedItems.Add(new GroupingsPageListGroup(
|
groupedItems.Add(new GroupingsPageListGroup(
|
||||||
AppResources.Types, 4, Device.RuntimePlatform == Device.iOS, !hasFavorites)
|
AppResources.Types, 4, uppercaseGroupNames, !hasFavorites)
|
||||||
{
|
{
|
||||||
new GroupingsPageListItem
|
new GroupingsPageListItem
|
||||||
{
|
{
|
||||||
|
@ -188,28 +180,45 @@ namespace Bit.App.Pages
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
if(folderListItems?.Any() ?? false)
|
if(NestedFolders?.Any() ?? false)
|
||||||
{
|
{
|
||||||
|
var folderListItems = NestedFolders.Select(f =>
|
||||||
|
{
|
||||||
|
var fId = f.Node.Id ?? "none";
|
||||||
|
return new GroupingsPageListItem
|
||||||
|
{
|
||||||
|
Folder = f.Node,
|
||||||
|
ItemCount = (_folderCounts.ContainsKey(fId) ? _folderCounts[fId] : 0).ToString("N0")
|
||||||
|
};
|
||||||
|
}).ToList();
|
||||||
groupedItems.Add(new GroupingsPageListGroup(folderListItems, AppResources.Folders,
|
groupedItems.Add(new GroupingsPageListGroup(folderListItems, AppResources.Folders,
|
||||||
folderListItems.Count, Device.RuntimePlatform == Device.iOS, !MainPage));
|
folderListItems.Count, uppercaseGroupNames, !MainPage));
|
||||||
}
|
}
|
||||||
if(collectionListItems?.Any() ?? false)
|
if(NestedCollections?.Any() ?? false)
|
||||||
{
|
{
|
||||||
|
var collectionListItems = NestedCollections.Select(c => new GroupingsPageListItem
|
||||||
|
{
|
||||||
|
Collection = c.Node,
|
||||||
|
ItemCount = (_collectionCounts.ContainsKey(c.Node.Id) ?
|
||||||
|
_collectionCounts[c.Node.Id] : 0).ToString("N0")
|
||||||
|
}).ToList();
|
||||||
groupedItems.Add(new GroupingsPageListGroup(collectionListItems, AppResources.Collections,
|
groupedItems.Add(new GroupingsPageListGroup(collectionListItems, AppResources.Collections,
|
||||||
collectionListItems.Count, Device.RuntimePlatform == Device.iOS, !MainPage));
|
collectionListItems.Count, uppercaseGroupNames, !MainPage));
|
||||||
}
|
}
|
||||||
if(ciphersListItems?.Any() ?? false)
|
if(Ciphers?.Any() ?? false)
|
||||||
{
|
{
|
||||||
|
var ciphersListItems = Ciphers.Select(c => new GroupingsPageListItem { Cipher = c }).ToList();
|
||||||
groupedItems.Add(new GroupingsPageListGroup(ciphersListItems, AppResources.Items,
|
groupedItems.Add(new GroupingsPageListGroup(ciphersListItems, AppResources.Items,
|
||||||
ciphersListItems.Count, Device.RuntimePlatform == Device.iOS,
|
ciphersListItems.Count, uppercaseGroupNames, !MainPage && !groupedItems.Any()));
|
||||||
!MainPage && !groupedItems.Any()));
|
}
|
||||||
|
if(ShowNoFolderCiphers)
|
||||||
|
{
|
||||||
|
var noFolderCiphersListItems = NoFolderCiphers.Select(
|
||||||
|
c => new GroupingsPageListItem { Cipher = c }).ToList();
|
||||||
|
groupedItems.Add(new GroupingsPageListGroup(noFolderCiphersListItems, AppResources.FolderNone,
|
||||||
|
noFolderCiphersListItems.Count, uppercaseGroupNames, false));
|
||||||
}
|
}
|
||||||
// Workaround for https://stackoverflow.com/a/49992132/1090359
|
|
||||||
page.ListView.HasUnevenRows = false;
|
|
||||||
page.ListView.IsGroupingEnabled = false;
|
|
||||||
GroupedItems.ResetWithRange(groupedItems);
|
GroupedItems.ResetWithRange(groupedItems);
|
||||||
page.ListView.HasUnevenRows = true;
|
|
||||||
page.ListView.IsGroupingEnabled = true;
|
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue