diff options
author | Robert Jaros <rjaros@finn.pl> | 2017-08-16 01:58:43 +0200 |
---|---|---|
committer | Robert Jaros <rjaros@finn.pl> | 2017-08-16 01:58:43 +0200 |
commit | e1523ed62e16b6ecfde1a1d6dd69599910c7085a (patch) | |
tree | 60dd83080664e8fae218d68e488eb708bf121da3 /src/main/kotlin/pl/treksoft/kvision/main.kt | |
download | kvision-e1523ed62e16b6ecfde1a1d6dd69599910c7085a.tar.gz kvision-e1523ed62e16b6ecfde1a1d6dd69599910c7085a.tar.bz2 kvision-e1523ed62e16b6ecfde1a1d6dd69599910c7085a.zip |
Initial commit
Diffstat (limited to 'src/main/kotlin/pl/treksoft/kvision/main.kt')
-rw-r--r-- | src/main/kotlin/pl/treksoft/kvision/main.kt | 40 |
1 files changed, 40 insertions, 0 deletions
diff --git a/src/main/kotlin/pl/treksoft/kvision/main.kt b/src/main/kotlin/pl/treksoft/kvision/main.kt new file mode 100644 index 00000000..01ce118f --- /dev/null +++ b/src/main/kotlin/pl/treksoft/kvision/main.kt @@ -0,0 +1,40 @@ +package pl.treksoft.kvision + +import kotlin.browser.* +import kotlin.dom.* + +fun main(args: Array<String>) { + var application: ApplicationBase? = null + + val state: dynamic = module.hot?.let { hot -> + hot.accept() + + hot.dispose { data -> + data.appState = application?.dispose() + application = null + } + + hot.data + } + + if (document.body != null) { + application = start(state) + } else { + application = null + document.addEventListener("DOMContentLoaded", { application = start(state) }) + } +} + +fun start(state: dynamic): ApplicationBase? { + if (document.body?.hasClass("kvision") ?: false) { + val application = MainApplication() + + @Suppress("UnsafeCastFromDynamic") + application.start(state?.appState ?: emptyMap()) + + return application + } else { + return null + } +} + |