Merge pull request #12553 from MrPetovan/bug/12552-getRelativeDate-60-minutes
Switch rounding to flooring in Temporal::getRelativeDate
This commit is contained in:
commit
96ae9a2ba8
3 changed files with 46 additions and 23 deletions
|
@ -137,7 +137,7 @@ abstract class BaseUsers extends BaseModeration
|
||||||
$user['account_type'] = ($user['page_flags_raw'] == 0) ? $account_types[$user['account-type']] : '';
|
$user['account_type'] = ($user['page_flags_raw'] == 0) ? $account_types[$user['account-type']] : '';
|
||||||
|
|
||||||
$user['register_date'] = Temporal::getRelativeDate($user['register_date']);
|
$user['register_date'] = Temporal::getRelativeDate($user['register_date']);
|
||||||
$user['login_date'] = Temporal::getRelativeDate($user['last-activity'], null, false);
|
$user['login_date'] = Temporal::getRelativeDate($user['last-activity'], false);
|
||||||
$user['lastitem_date'] = Temporal::getRelativeDate($user['last-item']);
|
$user['lastitem_date'] = Temporal::getRelativeDate($user['last-item']);
|
||||||
$user['is_admin'] = in_array($user['email'], $adminlist);
|
$user['is_admin'] = in_array($user['email'], $adminlist);
|
||||||
$user['is_deletable'] = !$user['account_removed'] && intval($user['uid']) != $this->session->getLocalUserId();
|
$user['is_deletable'] = !$user['account_removed'] && intval($user['uid']) != $this->session->getLocalUserId();
|
||||||
|
|
|
@ -26,6 +26,8 @@ use DateTimeZone;
|
||||||
use Friendica\Core\Renderer;
|
use Friendica\Core\Renderer;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
|
use Friendica\Util\Clock\SystemClock;
|
||||||
|
use Psr\Clock\ClockInterface;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Temporal class
|
* Temporal class
|
||||||
|
@ -305,19 +307,21 @@ class Temporal
|
||||||
* Results relative to current timezone.
|
* Results relative to current timezone.
|
||||||
* Limited to range of timestamps.
|
* Limited to range of timestamps.
|
||||||
*
|
*
|
||||||
* @param string $posted_date MySQL-formatted date string (YYYY-MM-DD HH:MM:SS)
|
* @param string|null $posted_date MySQL-formatted date string (YYYY-MM-DD HH:MM:SS)
|
||||||
* @param string $format (optional) Parsed with sprintf()
|
* @param bool $compare_time Compare date (false) or date and time (true). "true" is default.
|
||||||
* @param bool $compare_time Compare date (false) or date and time (true). "true" is default.
|
* @param ClockInterface|null $clock
|
||||||
* <tt>%1$d %2$s ago</tt>, e.g. 22 hours ago, 1 minute ago
|
* <tt>%1$d %2$s ago</tt>, e.g. 22 hours ago, 1 minute ago
|
||||||
*
|
*
|
||||||
* @return string with relative date
|
* @return string with relative date
|
||||||
*/
|
*/
|
||||||
public static function getRelativeDate(string $posted_date = null, string $format = null, bool $compare_time = true): string
|
public static function getRelativeDate(string $posted_date = null, bool $compare_time = true, ClockInterface $clock = null): string
|
||||||
{
|
{
|
||||||
if (empty($posted_date) || $posted_date <= DBA::NULL_DATETIME) {
|
if (empty($posted_date) || $posted_date <= DBA::NULL_DATETIME) {
|
||||||
return DI::l10n()->t('never');
|
return DI::l10n()->t('never');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$clock = $clock ?? new SystemClock();
|
||||||
|
|
||||||
$localtime = $posted_date . ' UTC';
|
$localtime = $posted_date . ' UTC';
|
||||||
$abs = strtotime($localtime);
|
$abs = strtotime($localtime);
|
||||||
|
|
||||||
|
@ -325,7 +329,7 @@ class Temporal
|
||||||
return DI::l10n()->t('never');
|
return DI::l10n()->t('never');
|
||||||
}
|
}
|
||||||
|
|
||||||
$now = time();
|
$now = $clock->now()->getTimestamp();
|
||||||
|
|
||||||
if (!$compare_time) {
|
if (!$compare_time) {
|
||||||
$now = mktime(0, 0, 0, date('m', $now), date('d', $now), date('Y', $now));
|
$now = mktime(0, 0, 0, date('m', $now), date('d', $now), date('Y', $now));
|
||||||
|
@ -335,7 +339,7 @@ class Temporal
|
||||||
$isfuture = false;
|
$isfuture = false;
|
||||||
$etime = $now - $abs;
|
$etime = $now - $abs;
|
||||||
|
|
||||||
if ($etime < 1 && $etime >= 0) {
|
if ($etime >= 0 && $etime < 1) {
|
||||||
return $compare_time ? DI::l10n()->t('less than a second ago') : DI::l10n()->t('today');
|
return $compare_time ? DI::l10n()->t('less than a second ago') : DI::l10n()->t('today');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -357,15 +361,13 @@ class Temporal
|
||||||
foreach ($a as $secs => $str) {
|
foreach ($a as $secs => $str) {
|
||||||
$d = $etime / $secs;
|
$d = $etime / $secs;
|
||||||
if ($d >= 1) {
|
if ($d >= 1) {
|
||||||
$r = round($d);
|
$r = floor($d);
|
||||||
// translators - e.g. 22 hours ago, 1 minute ago
|
// translators - e.g. 22 hours ago, 1 minute ago
|
||||||
if (!$format) {
|
if($isfuture){
|
||||||
if($isfuture){
|
$format = DI::l10n()->t('in %1$d %2$s');
|
||||||
$format = DI::l10n()->t('in %1$d %2$s');
|
}
|
||||||
}
|
else {
|
||||||
else {
|
$format = DI::l10n()->t('%1$d %2$s ago');
|
||||||
$format = DI::l10n()->t('%1$d %2$s ago');
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return sprintf($format, $r, (($r == 1) ? $str[0] : $str[1]));
|
return sprintf($format, $r, (($r == 1) ? $str[0] : $str[1]));
|
||||||
|
|
|
@ -22,6 +22,8 @@
|
||||||
namespace Friendica\Test\src\Util;
|
namespace Friendica\Test\src\Util;
|
||||||
|
|
||||||
use Friendica\DI;
|
use Friendica\DI;
|
||||||
|
use Friendica\Util\Clock\FrozenClock;
|
||||||
|
use Friendica\Util\DateTimeFormat;
|
||||||
use Friendica\Util\Temporal;
|
use Friendica\Util\Temporal;
|
||||||
use PHPUnit\Framework\TestCase;
|
use PHPUnit\Framework\TestCase;
|
||||||
|
|
||||||
|
@ -35,27 +37,46 @@ class TemporalTest extends TestCase
|
||||||
*/
|
*/
|
||||||
public function testGetRelativeDate()
|
public function testGetRelativeDate()
|
||||||
{
|
{
|
||||||
// "never" would should be returned
|
$clock = new FrozenClock();
|
||||||
|
|
||||||
|
// "never" should be returned
|
||||||
self::assertEquals(
|
self::assertEquals(
|
||||||
Temporal::getRelativeDate(''),
|
Temporal::getRelativeDate('', true, $clock),
|
||||||
DI::l10n()->t('never')
|
DI::l10n()->t('never')
|
||||||
);
|
);
|
||||||
|
|
||||||
// Format current date/time into "MySQL" format
|
// Format current date/time into "MySQL" format
|
||||||
$now = date('Y-m-d H:i:s');
|
|
||||||
self::assertEquals(
|
self::assertEquals(
|
||||||
Temporal::getRelativeDate($now),
|
Temporal::getRelativeDate($clock->now()->format(DateTimeFormat::MYSQL), true, $clock),
|
||||||
DI::l10n()->t('less than a second ago')
|
DI::l10n()->t('less than a second ago')
|
||||||
);
|
);
|
||||||
|
|
||||||
// Format current date/time - 1 minute into "MySQL" format
|
// Format current date/time - 1 minute into "MySQL" format
|
||||||
$minuteAgo = date('Y-m-d H:i:s', time() - 60);
|
$minuteAgo = date('Y-m-d H:i:s', $clock->now()->getTimestamp() - 60);
|
||||||
$format = DI::l10n()->t('%1$d %2$s ago');
|
$format = DI::l10n()->t('%1$d %2$s ago');
|
||||||
|
|
||||||
// Should be both equal
|
// Should be both equal
|
||||||
self::assertEquals(
|
self::assertEquals(
|
||||||
Temporal::getRelativeDate($minuteAgo),
|
Temporal::getRelativeDate($minuteAgo, true, $clock),
|
||||||
sprintf($format, 1, DI::l10n()->t('minute'))
|
sprintf($format, 1, DI::l10n()->t('minute'))
|
||||||
);
|
);
|
||||||
|
|
||||||
|
$almostAnHourAgoInterval = new \DateInterval('PT59M59S');
|
||||||
|
$almostAnHourAgoInterval->invert = 1;
|
||||||
|
$almostAnHourAgo = (clone $clock->now())->add($almostAnHourAgoInterval);
|
||||||
|
|
||||||
|
self::assertEquals(
|
||||||
|
Temporal::getRelativeDate($almostAnHourAgo->format(DateTimeFormat::MYSQL), true, $clock),
|
||||||
|
sprintf($format, 59, DI::l10n()->t('minutes'))
|
||||||
|
);
|
||||||
|
|
||||||
|
$anHourAgoInterval = new \DateInterval('PT1H');
|
||||||
|
$anHourAgoInterval->invert = 1;
|
||||||
|
$anHourAgo = (clone $clock->now())->add($anHourAgoInterval);
|
||||||
|
|
||||||
|
self::assertEquals(
|
||||||
|
Temporal::getRelativeDate($anHourAgo->format(DateTimeFormat::MYSQL), true, $clock),
|
||||||
|
sprintf($format, 1, DI::l10n()->t('hour'))
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue