Compare commits

...

15 Commits

5 changed files with 88 additions and 19 deletions

View File

@@ -1,5 +1,30 @@
# Changelog
## 0.20.32
* `Versions`:
* `Okio`: `3.7.0` -> `3.8.0`
* `Resources`:
* Make `StringResource` serializable
* Add several variants of builder usages
## 0.20.31
* `Versions`:
* `Ktor`: `2.3.7` -> `2.3.8`
## 0.20.30
* `Versions`:
* `Exposed`: `0.46.0` -> `0.47.0`
## 0.20.29
* `Versions`:
* `Kotlin`: `1.9.21` -> `1.9.22`
* `Compose`: `1.5.11` -> `1.5.12`
* `Korlibs`: `5.3.0` -> `5.3.1`
## 0.20.28
* `Versions`:

View File

@@ -15,5 +15,5 @@ crypto_js_version=4.1.1
# Project data
group=dev.inmo
version=0.20.28
android_code_version=234
version=0.20.32
android_code_version=238

View File

@@ -1,32 +1,32 @@
[versions]
kt = "1.9.21"
kt = "1.9.22"
kt-serialization = "1.6.2"
kt-coroutines = "1.7.3"
kslog = "1.3.1"
kslog = "1.3.2"
jb-compose = "1.5.11"
jb-exposed = "0.46.0"
jb-compose = "1.5.12"
jb-exposed = "0.47.0"
jb-dokka = "1.9.10"
korlibs = "5.3.0"
korlibs = "5.3.1"
uuid = "0.8.2"
ktor = "2.3.7"
ktor = "2.3.8"
gh-release = "2.5.2"
koin = "3.5.3"
okio = "3.7.0"
okio = "3.8.0"
ksp = "1.9.22-1.0.16"
kotlin-poet = "1.15.3"
ksp = "1.9.22-1.0.17"
kotlin-poet = "1.16.0"
versions = "0.50.0"
versions = "0.51.0"
android-gradle = "8.2.1"
android-gradle = "8.2.2"
dexcount = "4.0.0"
android-coreKtx = "1.12.0"

View File

@@ -1,5 +1,5 @@
distributionBase=GRADLE_USER_HOME
distributionPath=wrapper/dists
distributionUrl=https\://services.gradle.org/distributions/gradle-8.5-bin.zip
distributionUrl=https\://services.gradle.org/distributions/gradle-8.6-bin.zip
zipStoreBase=GRADLE_USER_HOME
zipStorePath=wrapper/dists

View File

@@ -1,6 +1,11 @@
package dev.inmo.micro_utils.strings
import dev.inmo.micro_utils.language_codes.IetfLang
import kotlinx.serialization.KSerializer
import kotlinx.serialization.Serializable
import kotlinx.serialization.descriptors.SerialDescriptor
import kotlinx.serialization.encoding.Decoder
import kotlinx.serialization.encoding.Encoder
/**
* Use this class as a type of your strings object fields. For example:
@@ -15,9 +20,10 @@ import dev.inmo.micro_utils.language_codes.IetfLang
*
* @see buildStringResource
*/
class StringResource(
@Serializable(StringResource.Companion::class)
data class StringResource(
val default: String,
val map: Map<IetfLang, Lazy<String>>
val translations: Map<IetfLang, Lazy<String>>
) {
class Builder(
var default: String
@@ -31,11 +37,18 @@ class StringResource(
infix fun IetfLang.variant(value: () -> String) = this variant lazy(value)
infix fun IetfLang.variant(value: String) = this variant lazyOf(value)
operator fun IetfLang.invoke(value: () -> String) = this variant value
operator fun IetfLang.invoke(value: String) = this variant value
infix fun String.variant(value: Lazy<String>) = IetfLang(this) variant value
infix fun String.variant(value: () -> String) = IetfLang(this) variant lazy(value)
infix fun String.variant(value: String) = this variant lazyOf(value)
operator fun String.invoke(value: () -> String) = this variant value
operator fun String.invoke(value: String) = this variant value
fun build() = StringResource(default, map.toMap())
}
@@ -43,17 +56,48 @@ class StringResource(
if (languageCode == null) {
return default
}
map[languageCode] ?.let { return it.value }
translations[languageCode] ?.let { return it.value }
return languageCode.parentLang ?.let {
map[it] ?.value
translations[it] ?.value
} ?: default
}
companion object : KSerializer<StringResource> {
@Serializable
private class Surrogate(
val default: String,
val translations: Map<String, String>
)
override val descriptor: SerialDescriptor
get() = Surrogate.serializer().descriptor
override fun deserialize(decoder: Decoder): StringResource {
val surrogate = Surrogate.serializer().deserialize(decoder)
return StringResource(
surrogate.default,
surrogate.translations.map { IetfLang(it.key) to lazyOf(it.value) }.toMap()
)
}
override fun serialize(encoder: Encoder, value: StringResource) {
Surrogate.serializer().serialize(
encoder,
Surrogate(
value.default,
value.translations.map {
it.key.code to it.value.value
}.toMap()
)
)
}
}
}
inline fun buildStringResource(
default: String,
builder: StringResource.Builder.() -> Unit
builder: StringResource.Builder.() -> Unit = {}
): StringResource {
return StringResource.Builder(default).apply(builder).build()
}