mirror of
https://github.com/KevinMidboe/immich.git
synced 2025-10-29 17:40:28 +00:00
feat(mobile): Various minor performance improvements (#1176)
* Improve scroll performance by introducing repaint boundaries and moving more calculations to providers. * Add error handing for malformed dates. * Remove unused method * Use compute in different places to improve app performance during heavy tasks * Fix test * Refactor `List<RenderAssetGridElement>` to separate `RenderList` class and make `fromAssetGroups` a static method of this class. * Fix loading indicator bug * Use provider directly * `RenderList` refactoring * `AssetNotifier` refactoring * Move `combine` to static private method * Extract compute methods in cache services to static private methods. * Use `tryParse` instead of `parse` with try/catch for dates. * Fix bug in caching mechanism. * Fixed state not being used to trigger conditional rendering * styling * Corrected state Co-authored-by: Alex Tran <alex.tran1502@gmail.com>
This commit is contained in:
@@ -54,55 +54,9 @@ void main() {
|
||||
}).toList()
|
||||
};
|
||||
|
||||
group('Asset only list', () {
|
||||
test('items < itemsPerRow', () {
|
||||
final assets = testAssets.sublist(0, 2);
|
||||
final renderList = assetsToRenderList(assets, 3);
|
||||
|
||||
expect(renderList.length, 1);
|
||||
expect(renderList[0].assetRow!.assets.length, 2);
|
||||
});
|
||||
|
||||
test('items = itemsPerRow', () {
|
||||
final assets = testAssets.sublist(0, 3);
|
||||
final renderList = assetsToRenderList(assets, 3);
|
||||
|
||||
expect(renderList.length, 1);
|
||||
expect(renderList[0].assetRow!.assets.length, 3);
|
||||
});
|
||||
|
||||
test('items > itemsPerRow', () {
|
||||
final assets = testAssets.sublist(0, 20);
|
||||
final renderList = assetsToRenderList(assets, 3);
|
||||
|
||||
expect(renderList.length, 7);
|
||||
expect(renderList[6].assetRow!.assets.length, 2);
|
||||
});
|
||||
|
||||
test('items > itemsPerRow partition 4', () {
|
||||
final assets = testAssets.sublist(0, 21);
|
||||
final renderList = assetsToRenderList(assets, 4);
|
||||
|
||||
expect(renderList.length, 6);
|
||||
expect(renderList[5].assetRow!.assets.length, 1);
|
||||
});
|
||||
|
||||
test('items > itemsPerRow check ids', () {
|
||||
final assets = testAssets.sublist(0, 21);
|
||||
final renderList = assetsToRenderList(assets, 3);
|
||||
|
||||
expect(renderList.length, 7);
|
||||
expect(renderList[6].assetRow!.assets.length, 3);
|
||||
expect(renderList[0].assetRow!.assets[0].id, '0');
|
||||
expect(renderList[1].assetRow!.assets[1].id, '4');
|
||||
expect(renderList[3].assetRow!.assets[2].id, '11');
|
||||
expect(renderList[6].assetRow!.assets[2].id, '20');
|
||||
});
|
||||
});
|
||||
|
||||
group('Test grouped', () {
|
||||
test('test grouped check months', () {
|
||||
final renderList = assetGroupsToRenderList(groups, 3);
|
||||
test('test grouped check months', () async {
|
||||
final renderList = await RenderList.fromAssetGroups(groups, 3);
|
||||
|
||||
// Jan
|
||||
// Day 1
|
||||
@@ -115,17 +69,17 @@ void main() {
|
||||
// Oct
|
||||
// Day 1
|
||||
// 15 Assets => 5 Rows
|
||||
expect(renderList.length, 18);
|
||||
expect(renderList[0].type, RenderAssetGridElementType.monthTitle);
|
||||
expect(renderList[0].date.month, 1);
|
||||
expect(renderList[7].type, RenderAssetGridElementType.monthTitle);
|
||||
expect(renderList[7].date.month, 2);
|
||||
expect(renderList[11].type, RenderAssetGridElementType.monthTitle);
|
||||
expect(renderList[11].date.month, 10);
|
||||
expect(renderList.elements.length, 18);
|
||||
expect(renderList.elements[0].type, RenderAssetGridElementType.monthTitle);
|
||||
expect(renderList.elements[0].date.month, 1);
|
||||
expect(renderList.elements[7].type, RenderAssetGridElementType.monthTitle);
|
||||
expect(renderList.elements[7].date.month, 2);
|
||||
expect(renderList.elements[11].type, RenderAssetGridElementType.monthTitle);
|
||||
expect(renderList.elements[11].date.month, 10);
|
||||
});
|
||||
|
||||
test('test grouped check types', () {
|
||||
final renderList = assetGroupsToRenderList(groups, 5);
|
||||
test('test grouped check types', () async {
|
||||
final renderList = await RenderList.fromAssetGroups(groups, 5);
|
||||
|
||||
// Jan
|
||||
// Day 1
|
||||
@@ -155,10 +109,10 @@ void main() {
|
||||
RenderAssetGridElementType.assetRow
|
||||
];
|
||||
|
||||
expect(renderList.length, types.length);
|
||||
expect(renderList.elements.length, types.length);
|
||||
|
||||
for (int i = 0; i < renderList.length; i++) {
|
||||
expect(renderList[i].type, types[i]);
|
||||
for (int i = 0; i < renderList.elements.length; i++) {
|
||||
expect(renderList.elements[i].type, types[i]);
|
||||
}
|
||||
});
|
||||
});
|
||||
|
||||
Reference in New Issue
Block a user