summaryrefslogtreecommitdiffstats
path: root/inc
diff options
context:
space:
mode:
authorSimon Rettberg2014-08-07 19:20:39 +0200
committerSimon Rettberg2014-08-07 19:20:39 +0200
commit5472fd01bdb5640f58579fc06b0777e4f52975d7 (patch)
tree325b21b71f7e74eb19404271f81c9f03cada13ee /inc
parentMerge branch 'i18n' of https://gitlab.c3sl.ufpr.br/cdn/slx-admin into i18n (diff)
downloadslx-admin-5472fd01bdb5640f58579fc06b0777e4f52975d7.tar.gz
slx-admin-5472fd01bdb5640f58579fc06b0777e4f52975d7.tar.xz
slx-admin-5472fd01bdb5640f58579fc06b0777e4f52975d7.zip
Some sanity checks; start making detection of available languages dynamic; put dictionary class in inc/; make redirection on language change work if browser doesn't send referer information
Diffstat (limited to 'inc')
-rw-r--r--inc/dictionary.inc.php82
1 files changed, 82 insertions, 0 deletions
diff --git a/inc/dictionary.inc.php b/inc/dictionary.inc.php
new file mode 100644
index 00000000..58127c18
--- /dev/null
+++ b/inc/dictionary.inc.php
@@ -0,0 +1,82 @@
+<?php
+
+class Dictionary
+{
+
+ private static $messageArray;
+ private static $languages;
+
+ public static function init()
+ {
+ self::$languages = array();
+ foreach (glob('lang/??', GLOB_ONLYDIR) as $lang) {
+ $lang = basename($lang);
+ if ($lang === '..')
+ continue;
+ self::$languages[] = $lang;
+ }
+
+ //Changes the language in case there is a request to
+ $lang = Request::get('lang');
+ if ($lang !== false && in_array($lang, self::$languages)) {
+ setcookie('lang', $lang, time() + 60 * 60 * 24 * 30 * 12);
+ $url = Request::get('url');
+ if ($url === false && isset($_SERVER['HTTP_REFERER']))
+ $url = $_SERVER['HTTP_REFERER'];
+ if ($url === false)
+ $url = '?do=Main';
+ Util::redirect($url);
+ }
+
+ //Default language
+ $language = 'en';
+
+ if (isset($_COOKIE['lang']) && in_array($_COOKIE['lang'], self::$languages)) {
+ // Did user override language?
+ $language = $_COOKIE['lang'];
+ } else if (isset($_SERVER['HTTP_ACCEPT_LANGUAGE'])) {
+ $langs = preg_split('/[,\s]+/', $_SERVER['HTTP_ACCEPT_LANGUAGE']);
+ foreach ($langs as $lang) {
+ $lang = substr($lang, 0, 2);
+ if (in_array($lang, self::$languages)) {
+ $language = $lang;
+ break;
+ }
+ }
+ }
+
+ define('LANG', $language);
+ self::$messageArray = json_decode(file_get_contents("lang/" . LANG . "/messages.json"), true);
+ }
+
+ public static function getArrayTemplate($template, $lang = false)
+ {
+ if ($lang === false)
+ $lang = LANG;
+ $file = "lang/" . $lang . "/" . $template . ".json";
+ $content = @file_get_contents($file);
+ if ($content === false)
+ Util::traceError("Could not find language file $template for language $lang");
+ $language = array('lang' => $lang);
+ return array_merge($language, json_decode($content, true));
+ }
+
+ public static function translate($string)
+ {
+ $hardcoded = json_decode(file_get_contents("lang/" . LANG . "/messages-hardcoded.json"), true);
+ return $hardcoded[$string];
+ }
+
+ public static function getMessages()
+ {
+ return self::$messageArray;
+ }
+
+ public static function getLanguages()
+ {
+ return self::$languages;
+ }
+
+}
+
+Dictionary::init();