aboutsummaryrefslogtreecommitdiff
path: root/src/main/kotlin/pl/treksoft/kvision/i18n
diff options
context:
space:
mode:
authorRobert Jaros <rjaros@finn.pl>2018-10-08 13:40:04 +0200
committerRobert Jaros <rjaros@finn.pl>2018-10-08 13:40:04 +0200
commit0d3e7c87bf74948f83ce006a1d340b0f3f5e68b0 (patch)
treec86d5d0251da1fa3b208f53d1ca7d634a6cbcc8e /src/main/kotlin/pl/treksoft/kvision/i18n
parent91ae1d02de111f15608e84193c10ed17bea9fe41 (diff)
downloadkvision-0d3e7c87bf74948f83ce006a1d340b0f3f5e68b0.tar.gz
kvision-0d3e7c87bf74948f83ce006a1d340b0f3f5e68b0.tar.bz2
kvision-0d3e7c87bf74948f83ce006a1d340b0f3f5e68b0.zip
Refactoring to modules
Diffstat (limited to 'src/main/kotlin/pl/treksoft/kvision/i18n')
-rw-r--r--src/main/kotlin/pl/treksoft/kvision/i18n/I18n.kt123
-rw-r--r--src/main/kotlin/pl/treksoft/kvision/i18n/I18nManager.kt96
-rw-r--r--src/main/kotlin/pl/treksoft/kvision/i18n/SimpleI18nManager.kt34
3 files changed, 137 insertions, 116 deletions
diff --git a/src/main/kotlin/pl/treksoft/kvision/i18n/I18n.kt b/src/main/kotlin/pl/treksoft/kvision/i18n/I18n.kt
index 343c18ef..b61d6e40 100644
--- a/src/main/kotlin/pl/treksoft/kvision/i18n/I18n.kt
+++ b/src/main/kotlin/pl/treksoft/kvision/i18n/I18n.kt
@@ -21,24 +21,15 @@
*/
package pl.treksoft.kvision.i18n
-import org.w3c.xhr.XMLHttpRequest
import pl.treksoft.kvision.panel.Root
import kotlin.browser.window
-import kotlin.js.Promise
-
-external class Jed(json: dynamic) {
- fun gettext(key: String): String
- fun ngettext(singularKey: String, pluralKey: String, value: Int): String
- fun sprintf(format: String, value: Int): String
-}
-
-private const val I18N_SINGLE_DELIMITER = "###KvI18nS###"
-private const val I18N_PLURAL_DELIMITER = "###KvI18nP###"
/**
* A singleton object used for translations.
*/
-object I18n {
+object I18n : I18nManager {
+
+ var manager: I18nManager = SimpleI18nManager()
private val defaultLanguage = window.navigator.language.split("-")[0]
@@ -51,112 +42,12 @@ object I18n {
Root.roots.forEach { it.restart() }
}
- private val cache = mutableMapOf<String, Jed>()
-
- /**
- * I18n initialization function.
- * Should be called in the main function of the application.
- * @param languages a list of supported languages.
- * @param initCallback a code to run after the initialization process is complete.
- */
- fun init(vararg languages: String, initCallback: () -> Unit) {
- val promises = languages.map {
- I18n.readMessages(it)
- }.toTypedArray()
- Promise.all(promises).then { initCallback() }
+ override fun gettext(key: String): String {
+ return manager.gettext(key)
}
- @Suppress("MagicNumber")
- private fun readMessages(language: String): Promise<Jed> {
- return Promise { resolve, _ ->
- val xmlHttpRequest = XMLHttpRequest()
- xmlHttpRequest.overrideMimeType("application/json")
- xmlHttpRequest.open("GET", "js/messages-$language.json", true)
- xmlHttpRequest.onreadystatechange = {
- if (xmlHttpRequest.readyState.toInt() == 4 && (xmlHttpRequest.status.toInt() == 200 ||
- xmlHttpRequest.status.toInt() == 0)
- ) {
- val json = JSON.parse<dynamic>(xmlHttpRequest.responseText)
- val jed = Jed(json)
- cache[language] = jed
- resolve(jed)
- }
- }
- xmlHttpRequest.send()
- }
+ override fun ngettext(singularKey: String, pluralKey: String, value: Int): String {
+ return manager.ngettext(singularKey, pluralKey, value)
}
- /**
- * A static translation function for a singular form.
- * @param key a translation key.
- * @return translated text.
- */
- fun gettext(key: String): String {
- return cache[language]?.gettext(key) ?: key
- }
-
- /**
- * A static translation function for a plural form.
- * @param singularKey a translation key for a singular form.
- * @param pluralKey a translation key for a plural form.
- * @param value a count value.
- * @return translated text.
- */
- fun ngettext(singularKey: String, pluralKey: String, value: Int): String {
- return cache[language]?.run {
- sprintf(ngettext(singularKey, pluralKey, value), value)
- } ?: if (value == 1) singularKey else pluralKey
- }
-
- /**
- * A dynamic translation function for a singular form.
- * @param key a translation key.
- * @return text marked for a dynamic translation.
- */
- fun tr(key: String): String {
- return I18N_SINGLE_DELIMITER + key
- }
-
- /**
- * A dynamic translation function for a plural form.
- * @param singularKey a translation key for a singular form.
- * @param pluralKey a translation key for a plural form.
- * @param value a count value.
- * @return text marked for a dynamic translation.
- */
- fun ntr(singularKey: String, pluralKey: String, value: Int): String {
- return I18N_PLURAL_DELIMITER + singularKey + I18N_PLURAL_DELIMITER + pluralKey + I18N_PLURAL_DELIMITER + value
- }
-
- /**
- * A dynamic translation function.
- * @param text text marked for a dynamic translation.
- * @return translated text.
- */
- fun trans(text: String): String {
- return if (text.startsWith(I18N_SINGLE_DELIMITER)) {
- gettext(text.substring(I18N_SINGLE_DELIMITER.length))
- } else if (text.startsWith(I18N_PLURAL_DELIMITER)) {
- val tab = text.substring(I18N_PLURAL_DELIMITER.length).split(I18N_PLURAL_DELIMITER)
- @Suppress("MagicNumber")
- if (tab.size == 3) {
- ngettext(tab[0], tab[1], tab[2].toIntOrNull() ?: 1)
- } else {
- text
- }
- } else {
- text
- }
- }
-
- /**
- * A dynamic translation function.
- * @param text text marked for a dynamic translation.
- * @return translated text.
- */
- fun trans(text: String?): String? {
- return text?.let {
- trans(it)
- }
- }
}
diff --git a/src/main/kotlin/pl/treksoft/kvision/i18n/I18nManager.kt b/src/main/kotlin/pl/treksoft/kvision/i18n/I18nManager.kt
new file mode 100644
index 00000000..09890e6f
--- /dev/null
+++ b/src/main/kotlin/pl/treksoft/kvision/i18n/I18nManager.kt
@@ -0,0 +1,96 @@
+/*
+ * Copyright (c) 2017-present Robert Jaros
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ */
+package pl.treksoft.kvision.i18n
+
+private const val I18N_SINGLE_DELIMITER = "###KvI18nS###"
+private const val I18N_PLURAL_DELIMITER = "###KvI18nP###"
+
+interface I18nManager {
+ /**
+ * A static translation function for a singular form.
+ * @param key a translation key.
+ * @return translated text.
+ */
+ fun gettext(key: String): String
+
+ /**
+ * A static translation function for a plural form.
+ * @param singularKey a translation key for a singular form.
+ * @param pluralKey a translation key for a plural form.
+ * @param value a count value.
+ * @return translated text.
+ */
+ fun ngettext(singularKey: String, pluralKey: String, value: Int): String
+
+ /**
+ * A dynamic translation function for a singular form.
+ * @param key a translation key.
+ * @return text marked for a dynamic translation.
+ */
+ fun tr(key: String): String {
+ return I18N_SINGLE_DELIMITER + key
+ }
+
+ /**
+ * A dynamic translation function for a plural form.
+ * @param singularKey a translation key for a singular form.
+ * @param pluralKey a translation key for a plural form.
+ * @param value a count value.
+ * @return text marked for a dynamic translation.
+ */
+ fun ntr(singularKey: String, pluralKey: String, value: Int): String {
+ return I18N_PLURAL_DELIMITER + singularKey + I18N_PLURAL_DELIMITER + pluralKey + I18N_PLURAL_DELIMITER + value
+ }
+
+ /**
+ * A dynamic translation function.
+ * @param text text marked for a dynamic translation.
+ * @return translated text.
+ */
+ fun trans(text: String): String {
+ return if (text.startsWith(I18N_SINGLE_DELIMITER)) {
+ gettext(text.substring(I18N_SINGLE_DELIMITER.length))
+ } else if (text.startsWith(I18N_PLURAL_DELIMITER)) {
+ val tab = text.substring(I18N_PLURAL_DELIMITER.length).split(I18N_PLURAL_DELIMITER)
+ @Suppress("MagicNumber")
+ if (tab.size == 3) {
+ ngettext(tab[0], tab[1], tab[2].toIntOrNull() ?: 1)
+ } else {
+ text
+ }
+ } else {
+ text
+ }
+ }
+
+ /**
+ * A dynamic translation function.
+ * @param text text marked for a dynamic translation.
+ * @return translated text.
+ */
+ fun trans(text: String?): String? {
+ return text?.let {
+ trans(it)
+ }
+ }
+
+}
diff --git a/src/main/kotlin/pl/treksoft/kvision/i18n/SimpleI18nManager.kt b/src/main/kotlin/pl/treksoft/kvision/i18n/SimpleI18nManager.kt
new file mode 100644
index 00000000..d8d5897c
--- /dev/null
+++ b/src/main/kotlin/pl/treksoft/kvision/i18n/SimpleI18nManager.kt
@@ -0,0 +1,34 @@
+/*
+ * Copyright (c) 2017-present Robert Jaros
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a copy
+ * of this software and associated documentation files (the "Software"), to deal
+ * in the Software without restriction, including without limitation the rights
+ * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
+ * copies of the Software, and to permit persons to whom the Software is
+ * furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included in all
+ * copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
+ * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
+ * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
+ * SOFTWARE.
+ */
+package pl.treksoft.kvision.i18n
+
+class SimpleI18nManager : I18nManager {
+
+ override fun gettext(key: String): String {
+ return key
+ }
+
+ override fun ngettext(singularKey: String, pluralKey: String, value: Int): String {
+ return singularKey
+ }
+
+}