blob: 92226fc9d94d5f8e682b4332f965d40d9ee74dbe (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
<?php
/**
* Piwik - free/libre analytics platform
*
* @link http://piwik.org
* @license http://www.gnu.org/licenses/gpl-3.0.html GPL v3 or later
*/
namespace Piwik\Plugins\Intl;
use Piwik\Container\StaticContainer;
use Piwik\Plugins\LanguagesManager\LanguagesManager;
/**
* Provides date and time formats.
*/
class DateTimeFormatProvider extends \Piwik\Intl\Data\Provider\DateTimeFormatProvider
{
protected $use12HourClock;
/**
* Returns the format pattern for the given format type
*
* @param int $format one of the format constants
*
* @return string
*/
public function getFormatPattern($format)
{
$translator = StaticContainer::get('Piwik\Translation\Translator');
switch ($format) {
case self::DATETIME_FORMAT_LONG:
$pattern = $translator->translate('Intl_Format_DateTime_Long');
break;
case self::DATETIME_FORMAT_SHORT:
$pattern = $translator->translate('Intl_Format_DateTime_Short');
break;
case self::DATE_FORMAT_LONG:
$pattern = $translator->translate('Intl_Format_Date_Long');
break;
case self::DATE_FORMAT_DAY_MONTH:
$pattern = $translator->translate('Intl_Format_Date_Day_Month');
break;
case self::DATE_FORMAT_SHORT:
$pattern = $translator->translate('Intl_Format_Date_Short');
break;
case self::DATE_FORMAT_MONTH_SHORT:
$pattern = $translator->translate('Intl_Format_Month_Short');
break;
case self::DATE_FORMAT_MONTH_LONG:
$pattern = $translator->translate('Intl_Format_Month_Long');
break;
case self::DATE_FORMAT_YEAR:
$pattern = $translator->translate('Intl_Format_Year');
break;
case self::TIME_FORMAT:
$pattern = $translator->translate('Intl_Format_Time');
break;
default:
$pattern = $format;
}
if (strpos($pattern, '{time}') !== false) {
$pattern = str_replace('{time}', $this->getTimeFormat(), $pattern);
}
return $pattern;
}
/**
* Returns interval format pattern for the given format type
*
* @param bool $short whether to return short or long format pattern
* @param string $maxDifference maximal difference in interval dates (Y, M or D)
*
* @return string
*/
public function getRangeFormatPattern($short=false, $maxDifference='Y')
{
return StaticContainer::get('Piwik\Translation\Translator')->translate(
sprintf(
'Intl_Format_Interval_%s_%s',
$short ? 'Short' : 'Long',
$maxDifference
));
}
protected function getTimeFormat()
{
if (is_null($this->use12HourClock)) {
$this->use12HourClock = LanguagesManager::uses12HourClockForCurrentUser();
}
$timeFormat = 'Intl_Format_Time_24';
if ($this->use12HourClock) {
$timeFormat = 'Intl_Format_Time_12';
}
$translator = StaticContainer::get('Piwik\Translation\Translator');
$template = $translator->translate($timeFormat);
return $template;
}
/**
* For testing purpose only: Overwrites time format
*
* @param bool $use12HourClock
*/
public function forceTimeFormat($use12HourClock = false)
{
$this->use12HourClock = $use12HourClock;
}
}
|