From a52a73de879cbf4350b4d4631af2a5a71ce51375 Mon Sep 17 00:00:00 2001
From: Hamza417 <23103729+Hamza417@users.noreply.github.com>
Date: Thu, 2 Jan 2025 17:50:58 +0530
Subject: [PATCH] improve: predictable color patterns for installers
---
.idea/dictionaries/Hamza.xml | 3 ++
.../simple/inure/constants/InstallerColors.kt | 36 +++++++------------
.../viewmodels/panels/AnalyticsViewModel.kt | 4 ++-
3 files changed, 19 insertions(+), 24 deletions(-)
diff --git a/.idea/dictionaries/Hamza.xml b/.idea/dictionaries/Hamza.xml
index ab26f2853..a0b0b703f 100644
--- a/.idea/dictionaries/Hamza.xml
+++ b/.idea/dictionaries/Hamza.xml
@@ -161,6 +161,7 @@
fstrim
furiya
geolocstation
+ getjar
gles
gogh
gonçalves
@@ -357,6 +358,7 @@
shellscript
shizuku
sigsev
+ slideme
smsto
softprops
solarized
@@ -415,6 +417,7 @@
unmark
unshift
upto
+ uptodown
urbanist
usebackq
userdebug
diff --git a/app/src/main/java/app/simple/inure/constants/InstallerColors.kt b/app/src/main/java/app/simple/inure/constants/InstallerColors.kt
index 16f4ead7f..fd19433d4 100644
--- a/app/src/main/java/app/simple/inure/constants/InstallerColors.kt
+++ b/app/src/main/java/app/simple/inure/constants/InstallerColors.kt
@@ -1,33 +1,23 @@
package app.simple.inure.constants
+/**
+ * If you are developer who maintains apps that installs apps and acts as a
+ * source for them as well, you can add your signature colors here. Or open an
+ * issue for that.
+ */
object InstallerColors {
- const val UNKNOWN = 0xFF6D7291.toInt()
-
- private val colors: ArrayList by lazy {
- arrayListOf(
- 0xFFEA4335.toInt(), // Play Store
- 0xFFFFB401.toInt(), // Aurora Store
- 0xFF217AD3.toInt(), // F-Droid
- 0xFFFFA967.toInt(), // Inure
- 0xFF4CAF50.toInt(), // APKMirror
- 0xFF9E9E9E.toInt(), // System
- 0xFF673AB7.toInt(), // Aptoide
- 0xFF00C4F7.toInt(), // Amazon Appstore
- 0xFF2196F3.toInt(), // APKPure
- 0xFF3F51B5.toInt(), // Samsung Galaxy Store
- 0xFFF65C5B.toInt(), // Huawei AppGallery
- 0xFFE91E63.toInt(), // SlideME
- )
- }
-
private val colorMap = mapOf(
"com.android.vending" to 0xFFEA4335.toInt(),
"com.google.android.packageinstaller" to 0xFFEA4335.toInt(),
"com.aurora.store" to 0xFFFFB401.toInt(),
"org.fdroid.fdroid" to 0xFF217AD3.toInt(),
"app.simple.inure" to 0xFFFFA967.toInt(),
+ "app.simple.inure.debug" to 0xFFFFA967.toInt(),
+ "app.simple.inure.beta" to 0xFFFFA967.toInt(),
+ "app.simple.inure.play" to 0xFFFFA967.toInt(),
"com.apkmirror" to 0xFF4CAF50.toInt(),
+ "android" to 0xFF9E9E9E.toInt(),
"system" to 0xFF9E9E9E.toInt(),
"com.android.shell" to 0xFF9E9E9E.toInt(),
"com.aptoide.pt" to 0xFF673AB7.toInt(),
@@ -38,12 +28,12 @@ object InstallerColors {
"com.slideme.sam.manager" to 0xFFE91E63.toInt(),
"com.xiaomi.market" to 0xFFE173E5.toInt(),
"com.xiaomi.discover" to 0xFF3B56E5.toInt(),
+ "com.uptodown" to 0xFFE5E53B.toInt(),
+ "com.getjar.rewards" to 0xFF3BE5E5.toInt(),
+ "com.opera.app.discover" to 0xFF3BE53B.toInt(),
+ "com.opera.app.market" to 0xFFE53B3B.toInt(),
)
- fun getInstallerColors(): ArrayList {
- return colors
- }
-
fun getInstallerColorMap(): Map {
return colorMap
}
diff --git a/app/src/main/java/app/simple/inure/viewmodels/panels/AnalyticsViewModel.kt b/app/src/main/java/app/simple/inure/viewmodels/panels/AnalyticsViewModel.kt
index be398c3e6..669bf5f18 100644
--- a/app/src/main/java/app/simple/inure/viewmodels/panels/AnalyticsViewModel.kt
+++ b/app/src/main/java/app/simple/inure/viewmodels/panels/AnalyticsViewModel.kt
@@ -10,6 +10,7 @@ import androidx.lifecycle.viewModelScope
import app.simple.inure.R
import app.simple.inure.apk.utils.PackageUtils.getInstallerPackageName
import app.simple.inure.apk.utils.PackageUtils.safeApplicationInfo
+import app.simple.inure.constants.Colors
import app.simple.inure.constants.InstallerColors
import app.simple.inure.extensions.viewmodels.PackageUtilsViewModel
import app.simple.inure.preferences.AnalyticsPreferences
@@ -162,7 +163,8 @@ class AnalyticsViewModel(application: Application) : PackageUtilsViewModel(appli
}
installers.keys.distinct().forEach { packageName ->
- colors.add(InstallerColors.getInstallerColorMap()[packageName] ?: InstallerColors.UNKNOWN)
+ colors.add(InstallerColors.getInstallerColorMap()[packageName]
+ ?: Colors.getRetroColor()[installers.keys.distinct().indexOf(packageName)])
labels[packageName] = kotlin.runCatching {
packageManager.getApplicationLabel(packageManager.getApplicationInfo(packageName)!!).toString()
}.getOrElse {