Include unthemed icon variant in icon picker for icon packs that support themed icons
This commit is contained in:
parent
6353b38a70
commit
8ae3d74512
@ -82,13 +82,15 @@ sealed class CustomIcon : CustomAttribute {
|
||||
CustomIconPackIcon(
|
||||
iconPackageName = legacyComponentName.packageName,
|
||||
iconActivityName = legacyComponentName.className,
|
||||
iconPackPackage = payload.getString("icon_pack")
|
||||
iconPackPackage = payload.getString("icon_pack"),
|
||||
allowThemed = payload.optBoolean("allow_themed", true),
|
||||
)
|
||||
} else {
|
||||
CustomIconPackIcon(
|
||||
iconPackageName = payload.optString("package").takeIf { it.isNotEmpty() } ?: return null,
|
||||
iconActivityName = payload.optString("activity").takeIf { it.isNotEmpty() },
|
||||
iconPackPackage = payload.getString("icon_pack")
|
||||
iconPackPackage = payload.getString("icon_pack"),
|
||||
allowThemed = payload.optBoolean("allow_themed", true),
|
||||
)
|
||||
}
|
||||
}
|
||||
@ -118,6 +120,7 @@ data class CustomIconPackIcon(
|
||||
val iconPackPackage: String,
|
||||
val iconPackageName: String,
|
||||
val iconActivityName: String?,
|
||||
val allowThemed: Boolean = true,
|
||||
) : CustomIcon() {
|
||||
override fun toDatabaseValue(): String {
|
||||
return jsonObjectOf(
|
||||
@ -125,6 +128,7 @@ data class CustomIconPackIcon(
|
||||
"package" to iconPackageName,
|
||||
"activity" to iconActivityName,
|
||||
"icon_pack" to iconPackPackage,
|
||||
"allow_themed" to allowThemed,
|
||||
).toString()
|
||||
}
|
||||
}
|
||||
|
||||
@ -359,16 +359,38 @@ class IconRepository(
|
||||
|
||||
suspend fun searchCustomIcons(query: String, iconPack: IconPack?): List<CustomIconWithPreview> {
|
||||
val transformations = this.transformations.first()
|
||||
val iconPackIcons = iconPackManager.searchIconPackIcon(query, iconPack).mapNotNull {
|
||||
CustomIconWithPreview(
|
||||
customIcon = CustomIconPackIcon(
|
||||
iconPackPackage = it.iconPack,
|
||||
iconActivityName = it.activityName,
|
||||
iconPackageName = it.packageName,
|
||||
),
|
||||
preview = iconPackManager.getIcon(it.iconPack, it.packageName, it.activityName)
|
||||
?.transform(transformations) ?: return@mapNotNull null
|
||||
)
|
||||
val iconPackIcons = iconPackManager.searchIconPackIcon(query, iconPack).flatMap {
|
||||
val unthemedIcon = if (it.themed) {
|
||||
iconPackManager.getIcon(it.iconPack, it.packageName, it.activityName, false)
|
||||
?.transform(transformations)
|
||||
} else null
|
||||
val icon = iconPackManager.getIcon(it.iconPack, it.packageName, it.activityName, true)
|
||||
?.transform(transformations)
|
||||
|
||||
buildList<CustomIconWithPreview> {
|
||||
if (icon != null) {
|
||||
add(CustomIconWithPreview(
|
||||
customIcon = CustomIconPackIcon(
|
||||
iconPackPackage = it.iconPack,
|
||||
iconActivityName = it.activityName,
|
||||
iconPackageName = it.packageName,
|
||||
allowThemed = true
|
||||
),
|
||||
preview = icon
|
||||
))
|
||||
}
|
||||
if (unthemedIcon != null) {
|
||||
add(CustomIconWithPreview(
|
||||
customIcon = CustomIconPackIcon(
|
||||
iconPackPackage = it.iconPack,
|
||||
iconActivityName = it.activityName,
|
||||
iconPackageName = it.packageName,
|
||||
allowThemed = false
|
||||
),
|
||||
preview = unthemedIcon
|
||||
))
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
return iconPackIcons
|
||||
|
||||
@ -15,6 +15,7 @@ class CustomIconPackIconProvider(
|
||||
customIcon.iconPackPackage,
|
||||
customIcon.iconPackageName,
|
||||
customIcon.iconActivityName,
|
||||
customIcon.allowThemed,
|
||||
)
|
||||
}
|
||||
}
|
||||
Loading…
x
Reference in New Issue
Block a user