2015-04-10 09:44:38 +02:00
|
|
|
<?php
|
2016-02-08 15:41:00 +01:00
|
|
|
/* Icinga Web 2 | (c) 2015 Icinga Development Team | GPLv2+ */
|
2015-04-10 09:44:38 +02:00
|
|
|
|
|
|
|
namespace Icinga\Date;
|
|
|
|
|
|
|
|
/**
|
2015-05-19 13:26:46 +02:00
|
|
|
* Date formatting
|
2015-04-10 09:44:38 +02:00
|
|
|
*/
|
|
|
|
class DateFormatter
|
|
|
|
{
|
|
|
|
/**
|
2015-05-19 09:55:21 +02:00
|
|
|
* Format relative
|
2015-04-10 09:44:38 +02:00
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
2015-05-19 09:55:21 +02:00
|
|
|
const RELATIVE = 0;
|
2015-04-10 09:44:38 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Format time
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
const TIME = 1;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format date
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
const DATE = 2;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format date and time
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
const DATETIME = 4;
|
|
|
|
|
|
|
|
/**
|
2015-05-19 09:55:21 +02:00
|
|
|
* Get the diff between the given time and the current time
|
2015-04-10 09:44:38 +02:00
|
|
|
*
|
2015-05-19 09:55:21 +02:00
|
|
|
* @param int|float $time
|
2019-07-11 13:03:04 +02:00
|
|
|
* @param bool $requireTime
|
2015-04-10 09:44:38 +02:00
|
|
|
*
|
2015-05-19 09:55:21 +02:00
|
|
|
* @return array
|
2015-04-10 09:44:38 +02:00
|
|
|
*/
|
2019-07-11 13:03:04 +02:00
|
|
|
protected static function diff($time, $requireTime = false)
|
2015-04-10 09:44:38 +02:00
|
|
|
{
|
|
|
|
$invert = false;
|
2015-05-19 09:55:21 +02:00
|
|
|
$now = time();
|
2022-01-19 12:08:28 +01:00
|
|
|
$time = (int) $time;
|
2015-04-10 09:44:38 +02:00
|
|
|
$diff = $time - $now;
|
|
|
|
if ($diff < 0) {
|
|
|
|
$diff = abs($diff);
|
|
|
|
$invert = true;
|
|
|
|
}
|
|
|
|
if ($diff > 3600 * 24 * 3) {
|
2015-04-15 15:26:25 +02:00
|
|
|
$type = static::DATE;
|
2015-05-19 13:26:46 +02:00
|
|
|
if (date('Y') === date('Y', $time)) {
|
2019-07-11 13:03:04 +02:00
|
|
|
$formatted = date($requireTime ? 'M j H:i' : 'M j', $time);
|
2015-05-19 13:26:46 +02:00
|
|
|
} else {
|
2019-07-11 13:03:04 +02:00
|
|
|
$formatted = date($requireTime ? 'Y-m-d H:i' : 'Y-m', $time);
|
2015-05-19 13:26:46 +02:00
|
|
|
}
|
2015-04-10 09:44:38 +02:00
|
|
|
} else {
|
|
|
|
$minutes = floor($diff / 60);
|
|
|
|
if ($minutes < 60) {
|
2015-05-19 09:55:21 +02:00
|
|
|
$type = static::RELATIVE;
|
2015-04-10 09:44:38 +02:00
|
|
|
$formatted = sprintf('%dm %ds', $minutes, $diff % 60);
|
|
|
|
} else {
|
|
|
|
$hours = floor($minutes / 60);
|
|
|
|
if ($hours < 24) {
|
2015-05-19 13:26:46 +02:00
|
|
|
if (date('d') === date('d', $time)) {
|
|
|
|
$type = static::TIME;
|
|
|
|
$formatted = date('H:i', $time);
|
|
|
|
} else {
|
|
|
|
$type = static::DATE;
|
|
|
|
$formatted = date('M j H:i', $time);
|
|
|
|
}
|
2015-04-10 09:44:38 +02:00
|
|
|
} else {
|
2015-05-19 09:55:21 +02:00
|
|
|
$type = static::RELATIVE;
|
2015-04-10 09:44:38 +02:00
|
|
|
$formatted = sprintf('%dd %dh', floor($hours / 24), $hours % 24);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-05-19 09:55:21 +02:00
|
|
|
return array($type, $formatted, $invert);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format date
|
|
|
|
*
|
2015-05-19 11:25:54 +02:00
|
|
|
* @param int|float $date
|
2015-05-19 09:55:21 +02:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2015-05-19 11:25:54 +02:00
|
|
|
public static function formatDate($date)
|
2015-05-19 09:55:21 +02:00
|
|
|
{
|
2022-01-19 12:08:28 +01:00
|
|
|
return date('Y-m-d', (int) $date);
|
2015-05-19 09:55:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format date and time
|
|
|
|
*
|
2015-05-19 11:25:54 +02:00
|
|
|
* @param int|float $dateTime
|
2015-05-19 09:55:21 +02:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2015-05-19 11:25:54 +02:00
|
|
|
public static function formatDateTime($dateTime)
|
2015-05-19 09:55:21 +02:00
|
|
|
{
|
2022-01-19 10:56:19 +01:00
|
|
|
return date('Y-m-d H:i:s', (int) $dateTime);
|
2015-05-19 09:55:21 +02:00
|
|
|
}
|
|
|
|
|
2015-05-22 09:49:06 +02:00
|
|
|
/**
|
|
|
|
* Format a duration
|
|
|
|
*
|
|
|
|
* @param int|float $seconds Duration in seconds
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function formatDuration($seconds)
|
|
|
|
{
|
|
|
|
$minutes = floor((float) $seconds / 60);
|
|
|
|
if ($minutes < 60) {
|
|
|
|
$formatted = sprintf('%dm %ds', $minutes, $seconds % 60);
|
|
|
|
} else {
|
|
|
|
$hours = floor($minutes / 60);
|
|
|
|
if ($hours < 24) {
|
|
|
|
$formatted = sprintf('%dh %dm', $hours, $minutes % 60);
|
|
|
|
} else {
|
|
|
|
$formatted = sprintf('%dd %dh', floor($hours / 24), $hours % 24);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return $formatted;
|
|
|
|
}
|
|
|
|
|
2015-05-19 09:55:21 +02:00
|
|
|
/**
|
|
|
|
* Format time
|
|
|
|
*
|
2015-05-19 11:25:54 +02:00
|
|
|
* @param int|float $time
|
2015-05-19 09:55:21 +02:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public static function formatTime($time)
|
|
|
|
{
|
2022-01-19 12:08:28 +01:00
|
|
|
return date('H:i:s', (int) $time);
|
2015-05-19 09:55:21 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format time as time ago
|
|
|
|
*
|
|
|
|
* @param int|float $time
|
|
|
|
* @param bool $timeOnly
|
2019-07-11 14:28:50 +02:00
|
|
|
* @param bool $requireTime
|
2015-05-19 09:55:21 +02:00
|
|
|
*
|
2023-08-16 11:30:23 +02:00
|
|
|
* @return ?string
|
2015-05-19 09:55:21 +02:00
|
|
|
*/
|
2019-07-11 14:28:50 +02:00
|
|
|
public static function timeAgo($time, $timeOnly = false, $requireTime = false)
|
2015-05-19 09:55:21 +02:00
|
|
|
{
|
2019-07-11 14:28:50 +02:00
|
|
|
list($type, $ago, $invert) = static::diff($time, $requireTime);
|
2015-05-19 09:55:21 +02:00
|
|
|
if ($timeOnly) {
|
|
|
|
return $ago;
|
|
|
|
}
|
2023-08-16 09:26:41 +02:00
|
|
|
|
|
|
|
$formatted = null;
|
2015-05-19 09:55:21 +02:00
|
|
|
switch ($type) {
|
|
|
|
case static::DATE:
|
|
|
|
// Move to next case
|
|
|
|
case static::DATETIME:
|
|
|
|
$formatted = sprintf(
|
|
|
|
t('on %s', 'An event happened on the given date or date and time'),
|
|
|
|
$ago
|
|
|
|
);
|
2015-04-10 09:44:38 +02:00
|
|
|
break;
|
2015-05-19 09:55:21 +02:00
|
|
|
case static::RELATIVE:
|
|
|
|
$formatted = sprintf(
|
|
|
|
t('%s ago', 'An event that happened the given time interval ago'),
|
|
|
|
$ago
|
|
|
|
);
|
2015-04-10 09:44:38 +02:00
|
|
|
break;
|
2015-05-19 09:55:21 +02:00
|
|
|
case static::TIME:
|
|
|
|
$formatted = sprintf(t('at %s', 'An event happened at the given time'), $ago);
|
2015-04-10 09:44:38 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
return $formatted;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-05-19 09:55:21 +02:00
|
|
|
* Format time as time since
|
2015-04-10 09:44:38 +02:00
|
|
|
*
|
2015-05-19 09:55:21 +02:00
|
|
|
* @param int|float $time
|
|
|
|
* @param bool $timeOnly
|
2019-07-11 14:28:50 +02:00
|
|
|
* @param bool $requireTime
|
2015-04-10 09:44:38 +02:00
|
|
|
*
|
2023-08-16 11:30:23 +02:00
|
|
|
* @return ?string
|
2015-04-10 09:44:38 +02:00
|
|
|
*/
|
2019-07-11 14:28:50 +02:00
|
|
|
public static function timeSince($time, $timeOnly = false, $requireTime = false)
|
2015-04-10 09:44:38 +02:00
|
|
|
{
|
2019-07-11 14:28:50 +02:00
|
|
|
list($type, $since, $invert) = static::diff($time, $requireTime);
|
2015-05-19 09:55:21 +02:00
|
|
|
if ($timeOnly) {
|
|
|
|
return $since;
|
|
|
|
}
|
2023-08-16 09:26:41 +02:00
|
|
|
|
|
|
|
$formatted = null;
|
2015-05-19 09:55:21 +02:00
|
|
|
switch ($type) {
|
|
|
|
case static::RELATIVE:
|
|
|
|
$formatted = sprintf(
|
|
|
|
t('for %s', 'A status is lasting for the given time interval'),
|
|
|
|
$since
|
|
|
|
);
|
|
|
|
break;
|
|
|
|
case static::DATE:
|
|
|
|
// Move to next case
|
|
|
|
case static::DATETIME:
|
|
|
|
// Move to next case
|
2015-04-10 09:44:38 +02:00
|
|
|
case static::TIME:
|
2015-05-19 09:55:21 +02:00
|
|
|
$formatted = sprintf(
|
|
|
|
t('since %s', 'A status is lasting since the given time, date or date and time'),
|
|
|
|
$since
|
|
|
|
);
|
2015-04-10 09:44:38 +02:00
|
|
|
break;
|
2015-05-19 09:55:21 +02:00
|
|
|
}
|
|
|
|
return $formatted;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Format time as time until
|
|
|
|
*
|
|
|
|
* @param int|float $time
|
|
|
|
* @param bool $timeOnly
|
2019-07-11 13:03:04 +02:00
|
|
|
* @param bool $requireTime
|
2015-05-19 09:55:21 +02:00
|
|
|
*
|
2023-08-16 11:30:23 +02:00
|
|
|
* @return ?string
|
2015-05-19 09:55:21 +02:00
|
|
|
*/
|
2019-07-11 13:03:04 +02:00
|
|
|
public static function timeUntil($time, $timeOnly = false, $requireTime = false)
|
2015-05-19 09:55:21 +02:00
|
|
|
{
|
2019-07-11 13:03:04 +02:00
|
|
|
list($type, $until, $invert) = static::diff($time, $requireTime);
|
2015-05-22 09:33:51 +02:00
|
|
|
if ($invert && $type === static::RELATIVE) {
|
2015-05-21 10:19:07 +02:00
|
|
|
$until = '-' . $until;
|
|
|
|
}
|
2015-05-19 09:55:21 +02:00
|
|
|
if ($timeOnly) {
|
|
|
|
return $until;
|
|
|
|
}
|
2023-08-16 09:26:41 +02:00
|
|
|
|
|
|
|
$formatted = null;
|
2015-05-19 09:55:21 +02:00
|
|
|
switch ($type) {
|
|
|
|
case static::DATE:
|
|
|
|
// Move to next case
|
|
|
|
case static::DATETIME:
|
|
|
|
$formatted = sprintf(
|
|
|
|
t('on %s', 'An event will happen on the given date or date and time'),
|
|
|
|
$until
|
|
|
|
);
|
2015-04-10 09:44:38 +02:00
|
|
|
break;
|
2015-05-19 09:55:21 +02:00
|
|
|
case static::RELATIVE:
|
|
|
|
$formatted = sprintf(
|
|
|
|
t('in %s', 'An event will happen after the given time interval has elapsed'),
|
2015-05-21 10:19:07 +02:00
|
|
|
$until
|
2015-05-19 09:55:21 +02:00
|
|
|
);
|
2015-04-10 09:44:38 +02:00
|
|
|
break;
|
2015-05-19 09:55:21 +02:00
|
|
|
case static::TIME:
|
|
|
|
$formatted = sprintf(t('at %s', 'An event will happen at the given time'), $until);
|
2015-04-10 09:44:38 +02:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
return $formatted;
|
|
|
|
}
|
|
|
|
}
|