From ee7e20706bdce4f00715ab320c2cc1cf6fbcda0c Mon Sep 17 00:00:00 2001
From: Alex <alex.tran1502@gmail.com>
Date: Mon, 6 May 2024 11:21:25 -0500
Subject: [PATCH] fix(mobile): fetch non-archive for partners

---
 mobile/lib/services/asset.service.dart | 21 ++++++++++++++++-----
 1 file changed, 16 insertions(+), 5 deletions(-)

diff --git a/mobile/lib/services/asset.service.dart b/mobile/lib/services/asset.service.dart
index 5610dc435d..e1d62748e3 100644
--- a/mobile/lib/services/asset.service.dart
+++ b/mobile/lib/services/asset.service.dart
@@ -39,7 +39,7 @@ class AssetService {
 
   /// Checks the server for updated assets and updates the local database if
   /// required. Returns `true` if there were any changes.
-  Future<bool> refreshRemoteAssets([User? user]) async {
+  Future<bool> refreshRemoteAssets({User? user, bool isArchive = true}) async {
     user ??= Store.get<User>(StoreKey.currentUser);
     final Stopwatch sw = Stopwatch()..start();
     final bool changes = await _syncService.syncRemoteAssetsToDb(
@@ -53,12 +53,19 @@ class AssetService {
 
   /// Returns `(null, null)` if changes are invalid -> requires full sync
   Future<(List<Asset>? toUpsert, List<String>? toDelete)>
-      _getRemoteAssetChanges(User user, DateTime since) async {
+      _getRemoteAssetChanges(
+    User user,
+    DateTime since, {
+    bool isArchive = true,
+  }) async {
     final deleted = await _apiService.auditApi
         .getAuditDeletes(since, EntityType.ASSET, userId: user.id);
     if (deleted == null || deleted.needsFullSync) return (null, null);
-    final assetDto = await _apiService.assetApi
-        .getAllAssets(userId: user.id, updatedAfter: since);
+    final assetDto = await _apiService.assetApi.getAllAssets(
+      userId: user.id,
+      updatedAfter: since,
+      isArchived: isArchive,
+    );
     if (assetDto == null) return (null, null);
     return (assetDto.map(Asset.remote).toList(), deleted.ids);
   }
@@ -85,7 +92,10 @@ class AssetService {
   }
 
   /// Returns `null` if the server state did not change, else list of assets
-  Future<List<Asset>?> _getRemoteAssets(User user) async {
+  Future<List<Asset>?> _getRemoteAssets(
+    User user, {
+    bool isArchive = true,
+  }) async {
     const int chunkSize = 10000;
     try {
       final DateTime now = DateTime.now().toUtc();
@@ -101,6 +111,7 @@ class AssetService {
           updatedBefore: now,
           skip: i,
           take: chunkSize,
+          isArchived: isArchive,
         );
         if (assets == null) {
           return null;