summaryrefslogtreecommitdiffstats
path: root/vendor/simshaun/recurr/src/Recurr/Transformer/Translator.php
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 11:30:08 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-13 11:30:08 +0000
commit4ce65d59ca91871cfd126497158200a818720bce (patch)
treee277def01fc7eba7dbc21c4a4ae5576e8aa2cf1f /vendor/simshaun/recurr/src/Recurr/Transformer/Translator.php
parentInitial commit. (diff)
downloadicinga-php-library-4ce65d59ca91871cfd126497158200a818720bce.tar.xz
icinga-php-library-4ce65d59ca91871cfd126497158200a818720bce.zip
Adding upstream version 0.13.1.upstream/0.13.1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'vendor/simshaun/recurr/src/Recurr/Transformer/Translator.php')
-rw-r--r--vendor/simshaun/recurr/src/Recurr/Transformer/Translator.php42
1 files changed, 42 insertions, 0 deletions
diff --git a/vendor/simshaun/recurr/src/Recurr/Transformer/Translator.php b/vendor/simshaun/recurr/src/Recurr/Transformer/Translator.php
new file mode 100644
index 0000000..cf3cb2a
--- /dev/null
+++ b/vendor/simshaun/recurr/src/Recurr/Transformer/Translator.php
@@ -0,0 +1,42 @@
+<?php
+
+namespace Recurr\Transformer;
+
+class Translator implements TranslatorInterface
+{
+ protected $data = array();
+
+ public function __construct($locale = 'en', $fallbackLocale = 'en')
+ {
+ $this->loadLocale($fallbackLocale);
+ if ($locale !== $fallbackLocale) {
+ $this->loadLocale($locale);
+ }
+ }
+
+ public function loadLocale($locale, $path = null)
+ {
+ if (!$path) {
+ $path = __DIR__ . '/../../../translations/' . $locale . '.php';
+ }
+ if (!file_exists($path)) {
+ throw new \InvalidArgumentException('Locale '.$locale.' could not be found in '.$path);
+ }
+
+ $this->data = array_merge($this->data, include $path);
+ }
+
+ public function trans($string, array $params = array())
+ {
+ $res = $this->data[$string];
+ if (is_object($res) && is_callable($res)) {
+ $res = $res($string, $params);
+ }
+
+ foreach ($params as $key => $val) {
+ $res = str_replace('%' . $key . '%', $val, $res);
+ }
+
+ return $res;
+ }
+}