Page Menu
Home
Phorge
Search
Configure Global Search
Log In
Files
F2348829
viewutils.php
No One
Temporary
Actions
Download File
Edit File
Delete File
View Transforms
Subscribe
Flag For Later
Award Token
Size
2 KB
Referenced Files
None
Subscribers
None
viewutils.php
View Options
<?php
function
phabricator_date
(
$epoch
,
PhabricatorUser
$user
)
{
return
phabricator_format_local_time
(
$epoch
,
$user
,
phutil_date_format
(
$epoch
));
}
function
phabricator_relative_date
(
$epoch
,
$user
,
$on
=
false
)
{
static
$today
;
static
$yesterday
;
if
(!
$today
||
!
$yesterday
)
{
$now
=
time
();
$today
=
phabricator_date
(
$now
,
$user
);
$yesterday
=
phabricator_date
(
$now
-
86400
,
$user
);
}
$date
=
phabricator_date
(
$epoch
,
$user
);
if
(
$date
===
$today
)
{
return
'today'
;
}
if
(
$date
===
$yesterday
)
{
return
'yesterday'
;
}
return
((
$on
?
'on '
:
''
).
$date
);
}
function
phabricator_time
(
$epoch
,
$user
)
{
$time_key
=
PhabricatorTimeFormatSetting
::
SETTINGKEY
;
return
phabricator_format_local_time
(
$epoch
,
$user
,
$user
->
getUserSetting
(
$time_key
));
}
function
phabricator_datetime
(
$epoch
,
$user
)
{
$time_key
=
PhabricatorTimeFormatSetting
::
SETTINGKEY
;
return
phabricator_format_local_time
(
$epoch
,
$user
,
pht
(
'%s, %s'
,
phutil_date_format
(
$epoch
),
$user
->
getUserSetting
(
$time_key
)));
}
/**
* This function does not usually need to be called directly. Instead, call
* @{function:phabricator_date}, @{function:phabricator_time}, or
* @{function:phabricator_datetime}.
*
* @param int Unix epoch timestamp.
* @param PhabricatorUser User viewing the timestamp.
* @param string Date format, as per DateTime class.
* @return string Formatted, local date/time.
*/
function
phabricator_format_local_time
(
$epoch
,
$user
,
$format
)
{
if
(!
$epoch
)
{
// If we're missing date information for something, the DateTime class will
// throw an exception when we try to construct an object. Since this is a
// display function, just return an empty string.
return
''
;
}
$user_zone
=
$user
->
getTimezoneIdentifier
();
static
$zones
=
array
();
if
(
empty
(
$zones
[
$user_zone
]))
{
$zones
[
$user_zone
]
=
new
DateTimeZone
(
$user_zone
);
}
$zone
=
$zones
[
$user_zone
];
// NOTE: Although DateTime takes a second DateTimeZone parameter to its
// constructor, it ignores it if the date string includes timezone
// information. Further, it treats epoch timestamps ("@946684800") as having
// a UTC timezone. Set the timezone explicitly after constructing the object.
try
{
$date
=
new
DateTime
(
'@'
.
$epoch
);
}
catch
(
Exception
$ex
)
{
// NOTE: DateTime throws an empty exception if the format is invalid,
// just replace it with a useful one.
throw
new
Exception
(
pht
(
"Construction of a DateTime() with epoch '%s' "
.
"raised an exception."
,
$epoch
));
}
$date
->
setTimezone
(
$zone
);
return
PhutilTranslator
::
getInstance
()->
translateDate
(
$format
,
$date
);
}
File Metadata
Details
Attached
Mime Type
text/x-php
Expires
Tue, Sep 16, 11:19 AM (1 d, 20 h)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
381145
Default Alt Text
viewutils.php (2 KB)
Attached To
Mode
rP Phorge
Attached
Detach File
Event Timeline
Log In to Comment