mirror of
https://codeberg.org/Freeyourgadget/Gadgetbridge
synced 2025-01-01 13:35:49 +01:00
App Manager: Fill out missing app info from cache
This commit is contained in:
parent
9b7d5eee42
commit
5957f71110
@ -41,6 +41,7 @@ import android.widget.Toast;
|
||||
|
||||
import com.google.android.material.floatingactionbutton.FloatingActionButton;
|
||||
|
||||
import org.apache.commons.lang3.StringUtils;
|
||||
import org.json.JSONObject;
|
||||
import org.slf4j.Logger;
|
||||
import org.slf4j.LoggerFactory;
|
||||
@ -134,6 +135,8 @@ public abstract class AbstractAppManagerFragment extends Fragment {
|
||||
}
|
||||
|
||||
private void refreshListFromDevice(Intent intent) {
|
||||
final Map<UUID, GBDeviceApp> cachedAppsMap = getCachedAppsMap(null);
|
||||
|
||||
appList.clear();
|
||||
int appCount = intent.getIntExtra("app_count", 0);
|
||||
for (int i = 0; i < appCount; i++) {
|
||||
@ -144,6 +147,22 @@ public abstract class AbstractAppManagerFragment extends Fragment {
|
||||
GBDeviceApp.Type appType = GBDeviceApp.Type.values()[intent.getIntExtra("app_type" + i, 0)];
|
||||
Bitmap previewImage = getAppPreviewImage(uuid.toString());
|
||||
|
||||
// Fill out information from the cached app if missing
|
||||
final GBDeviceApp cachedApp = cachedAppsMap.get(uuid);
|
||||
if (cachedApp != null) {
|
||||
if (StringUtils.isBlank(appName)) {
|
||||
appName = cachedApp.getName();
|
||||
}
|
||||
if (StringUtils.isBlank(appCreator)) {
|
||||
appCreator = cachedApp.getCreator();
|
||||
}
|
||||
} else {
|
||||
if (StringUtils.isBlank(appName)) {
|
||||
// If the app does not have a name, fallback to uuid
|
||||
appName = uuid.toString();
|
||||
}
|
||||
}
|
||||
|
||||
GBDeviceApp app = new GBDeviceApp(uuid, appName, appCreator, appVersion, appType, previewImage);
|
||||
app.setOnDevice(true);
|
||||
if (mGBDevice.getType() == DeviceType.FOSSILQHYBRID) {
|
||||
@ -243,6 +262,15 @@ public abstract class AbstractAppManagerFragment extends Fragment {
|
||||
}
|
||||
};
|
||||
|
||||
protected Map<UUID, GBDeviceApp> getCachedAppsMap(final List<UUID> uuids) {
|
||||
final List<GBDeviceApp> cachedApps = getCachedApps(uuids);
|
||||
final Map<UUID, GBDeviceApp> cachedAppsMap = new HashMap<>();
|
||||
for (GBDeviceApp cachedApp : cachedApps) {
|
||||
cachedAppsMap.put(cachedApp.getUUID(), cachedApp);
|
||||
}
|
||||
return cachedAppsMap;
|
||||
}
|
||||
|
||||
protected List<GBDeviceApp> getCachedApps(List<UUID> uuids) {
|
||||
List<GBDeviceApp> cachedAppList = new ArrayList<>();
|
||||
File cachePath;
|
||||
|
Loading…
Reference in New Issue
Block a user