diff options
-rw-r--r-- | kvision-modules/kvision-handlebars/build.gradle | 4 | ||||
-rw-r--r-- | src/main/kotlin/pl/treksoft/kvision/utils/JSON.kt | 9 |
2 files changed, 11 insertions, 2 deletions
diff --git a/kvision-modules/kvision-handlebars/build.gradle b/kvision-modules/kvision-handlebars/build.gradle index 918ed5a7..3a374298 100644 --- a/kvision-modules/kvision-handlebars/build.gradle +++ b/kvision-modules/kvision-handlebars/build.gradle @@ -3,8 +3,8 @@ apply from: "../shared.gradle" kotlinFrontend { npm { - dependency("handlebars", "4.0.11") - dependency("handlebars-loader", "1.7.0") + dependency("handlebars", "4.0.12") + dependency("handlebars-loader", "1.7.1") } } diff --git a/src/main/kotlin/pl/treksoft/kvision/utils/JSON.kt b/src/main/kotlin/pl/treksoft/kvision/utils/JSON.kt index e47351ac..a826d343 100644 --- a/src/main/kotlin/pl/treksoft/kvision/utils/JSON.kt +++ b/src/main/kotlin/pl/treksoft/kvision/utils/JSON.kt @@ -21,8 +21,10 @@ */ package pl.treksoft.kvision.utils +import kotlinx.serialization.ImplicitReflectionSerializer import kotlinx.serialization.context.SimpleModule import kotlinx.serialization.json.JSON +import kotlinx.serialization.serializer import pl.treksoft.kvision.types.DateSerializer import kotlin.js.Date @@ -36,4 +38,11 @@ object JSON { install(SimpleModule(Date::class, DateSerializer)) } + /** + * An extension function to convert Serializable object to JS dynamic object + */ + @UseExperimental(ImplicitReflectionSerializer::class) + inline fun <reified T : Any> T.toObj(): Any { + return kotlin.js.JSON.parse(plain.stringify(T::class.serializer(), this)) + } } |