]> git.mxchange.org Git - quix0rs-gnu-social.git/commitdiff
trac494 email is now in recipient's language
authormillette <millette@controlyourself.ca>
Thu, 4 Dec 2008 20:34:33 +0000 (15:34 -0500)
committermillette <millette@controlyourself.ca>
Thu, 4 Dec 2008 20:34:33 +0000 (15:34 -0500)
darcs-hash:20081204203433-099f7-41be8f47b2a8e647414225f26318da005144006d.gz

lib/mail.php
lib/util.php

index 4c73a0b7bed39d0bda38ed687e68e2270363ddc5..b8d3236f6390378b90941bb60b253d74f0dbeca0 100644 (file)
@@ -115,6 +115,8 @@ function mail_subscribe_notify($listenee, $listener) {
 
 function mail_subscribe_notify_profile($listenee, $other) {
        if ($listenee->email && $listenee->emailnotifysub) {
+        // use the recipients localization
+        common_init_locale($listenee->language);
                $profile = $listenee->getProfile();
                $name = $profile->getBestName();
                $long_name = ($other->fullname) ? ($other->fullname . ' (' . $other->nickname . ')') : $other->nickname;
@@ -130,6 +132,9 @@ function mail_subscribe_notify_profile($listenee, $other) {
                                                 common_config('site', 'name'),
                                                 $other->profileurl,
                                                 common_config('site', 'name'));
+
+        // reset localization
+        common_init_locale();
                mail_send($recipients, $headers, $body);
        }
 }
index 204ad511ca85b96ab833c4b752b572ca7bda8ea2..077c9219a8889b9e279014c716f219060546c520 100644 (file)
@@ -131,17 +131,24 @@ function common_end_xml() {
        $xw->flush();
 }
 
+function common_init_locale($language=null) {
+    if(!$language) {
+        $language = common_language();
+    }
+    putenv('LANGUAGE='.$language);
+    putenv('LANG='.$language);
+    return setlocale(LC_ALL, $language . ".utf8",
+            $language . ".UTF8",
+            $language . ".utf-8",
+            $language . ".UTF-8",
+            $language);
+}
+
 function common_init_language() {
        mb_internal_encoding('UTF-8');
        $language = common_language();
        # So we don't have to make people install the gettext locales
-       putenv('LANGUAGE='.$language);
-       putenv('LANG='.$language);
-       $locale_set = setlocale(LC_ALL, $language . ".utf8",
-                                                       $language . ".UTF8",
-                                                       $language . ".utf-8",
-                                                       $language . ".UTF-8",
-                                                       $language);
+       $locale_set = common_init_locale($language);
        bindtextdomain("laconica", common_config('site','locale_path'));
        bind_textdomain_codeset("laconica", "UTF-8");
        textdomain("laconica");