mirror of
https://github.com/InsanusMokrassar/MicroUtils.git
synced 2025-09-17 14:29:24 +00:00
Compare commits
15 Commits
Author | SHA1 | Date | |
---|---|---|---|
22541f2d5e | |||
e235c52b6c | |||
e89b8c72dd | |||
a374e53a3a | |||
afb066c4ee | |||
f05761d4a5 | |||
76adc9ea33 | |||
99dd291413 | |||
f904eb27e1 | |||
eeb8214812 | |||
f7215b039e | |||
c07fe5a0f9 | |||
0d28cb6e20 | |||
a1a17bfd1f | |||
f386f09592 |
25
CHANGELOG.md
25
CHANGELOG.md
@@ -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`:
|
||||
|
@@ -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
|
||||
|
@@ -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"
|
||||
|
2
gradle/wrapper/gradle-wrapper.properties
vendored
2
gradle/wrapper/gradle-wrapper.properties
vendored
@@ -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
|
||||
|
@@ -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()
|
||||
}
|
||||
|
Reference in New Issue
Block a user