mirror of
https://github.com/InsanusMokrassar/MicroUtils.git
synced 2025-09-17 22:39:25 +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
|
# 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
|
## 0.20.28
|
||||||
|
|
||||||
* `Versions`:
|
* `Versions`:
|
||||||
|
@@ -15,5 +15,5 @@ crypto_js_version=4.1.1
|
|||||||
# Project data
|
# Project data
|
||||||
|
|
||||||
group=dev.inmo
|
group=dev.inmo
|
||||||
version=0.20.28
|
version=0.20.32
|
||||||
android_code_version=234
|
android_code_version=238
|
||||||
|
@@ -1,32 +1,32 @@
|
|||||||
[versions]
|
[versions]
|
||||||
|
|
||||||
kt = "1.9.21"
|
kt = "1.9.22"
|
||||||
kt-serialization = "1.6.2"
|
kt-serialization = "1.6.2"
|
||||||
kt-coroutines = "1.7.3"
|
kt-coroutines = "1.7.3"
|
||||||
|
|
||||||
kslog = "1.3.1"
|
kslog = "1.3.2"
|
||||||
|
|
||||||
jb-compose = "1.5.11"
|
jb-compose = "1.5.12"
|
||||||
jb-exposed = "0.46.0"
|
jb-exposed = "0.47.0"
|
||||||
jb-dokka = "1.9.10"
|
jb-dokka = "1.9.10"
|
||||||
|
|
||||||
korlibs = "5.3.0"
|
korlibs = "5.3.1"
|
||||||
uuid = "0.8.2"
|
uuid = "0.8.2"
|
||||||
|
|
||||||
ktor = "2.3.7"
|
ktor = "2.3.8"
|
||||||
|
|
||||||
gh-release = "2.5.2"
|
gh-release = "2.5.2"
|
||||||
|
|
||||||
koin = "3.5.3"
|
koin = "3.5.3"
|
||||||
|
|
||||||
okio = "3.7.0"
|
okio = "3.8.0"
|
||||||
|
|
||||||
ksp = "1.9.22-1.0.16"
|
ksp = "1.9.22-1.0.17"
|
||||||
kotlin-poet = "1.15.3"
|
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"
|
dexcount = "4.0.0"
|
||||||
|
|
||||||
android-coreKtx = "1.12.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
|
distributionBase=GRADLE_USER_HOME
|
||||||
distributionPath=wrapper/dists
|
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
|
zipStoreBase=GRADLE_USER_HOME
|
||||||
zipStorePath=wrapper/dists
|
zipStorePath=wrapper/dists
|
||||||
|
@@ -1,6 +1,11 @@
|
|||||||
package dev.inmo.micro_utils.strings
|
package dev.inmo.micro_utils.strings
|
||||||
|
|
||||||
import dev.inmo.micro_utils.language_codes.IetfLang
|
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:
|
* 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
|
* @see buildStringResource
|
||||||
*/
|
*/
|
||||||
class StringResource(
|
@Serializable(StringResource.Companion::class)
|
||||||
|
data class StringResource(
|
||||||
val default: String,
|
val default: String,
|
||||||
val map: Map<IetfLang, Lazy<String>>
|
val translations: Map<IetfLang, Lazy<String>>
|
||||||
) {
|
) {
|
||||||
class Builder(
|
class Builder(
|
||||||
var default: String
|
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 lazy(value)
|
||||||
infix fun IetfLang.variant(value: String) = this variant lazyOf(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: Lazy<String>) = IetfLang(this) variant value
|
||||||
infix fun String.variant(value: () -> String) = IetfLang(this) variant lazy(value)
|
infix fun String.variant(value: () -> String) = IetfLang(this) variant lazy(value)
|
||||||
infix fun String.variant(value: String) = this variant lazyOf(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())
|
fun build() = StringResource(default, map.toMap())
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -43,17 +56,48 @@ class StringResource(
|
|||||||
if (languageCode == null) {
|
if (languageCode == null) {
|
||||||
return default
|
return default
|
||||||
}
|
}
|
||||||
map[languageCode] ?.let { return it.value }
|
translations[languageCode] ?.let { return it.value }
|
||||||
|
|
||||||
return languageCode.parentLang ?.let {
|
return languageCode.parentLang ?.let {
|
||||||
map[it] ?.value
|
translations[it] ?.value
|
||||||
} ?: default
|
} ?: 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(
|
inline fun buildStringResource(
|
||||||
default: String,
|
default: String,
|
||||||
builder: StringResource.Builder.() -> Unit
|
builder: StringResource.Builder.() -> Unit = {}
|
||||||
): StringResource {
|
): StringResource {
|
||||||
return StringResource.Builder(default).apply(builder).build()
|
return StringResource.Builder(default).apply(builder).build()
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user