diff --git a/program/include/rcmail.php b/program/include/rcmail.php index 8a8cb323296..38b94d8312c 100644 --- a/program/include/rcmail.php +++ b/program/include/rcmail.php @@ -212,6 +212,7 @@ public function set_user($user) // set localization setlocale(LC_ALL, $lang . '.utf8', $lang . '.UTF-8', 'en_US.utf8', 'en_US.UTF-8'); + ini_set('intl.default_locale', $lang); // Workaround for http://bugs.php.net/bug.php?id=18556 // Also strtoupper/strtolower and other methods are locale-aware @@ -1698,7 +1699,7 @@ public function format_date($date, $format = null, $convert = true) $out .= $this->gettext('long'.strtolower(date('M', $timestamp))); } else if ($format[$i] == 'x') { - $formatter = new IntlDateFormatter(setlocale(LC_ALL, '0'), IntlDateFormatter::SHORT, IntlDateFormatter::SHORT); + $formatter = new IntlDateFormatter(null, IntlDateFormatter::SHORT, IntlDateFormatter::SHORT); $out .= $formatter->format($timestamp); } else { diff --git a/tests/Rcmail/Rcmail.php b/tests/Rcmail/Rcmail.php index 4a16b38d40c..e6b1dc861d6 100644 --- a/tests/Rcmail/Rcmail.php +++ b/tests/Rcmail/Rcmail.php @@ -272,6 +272,7 @@ function test_format_date() // Test various formats setlocale(LC_ALL, 'en_US'); + ini_set('intl.default_locale', 'en_US'); $date = new DateTime('2020-06-01 12:20:30', new DateTimeZone('UTC')); $this->assertSame('2020-06-01 12:20', $rcmail->format_date($date));