engelsystem/src/Helpers/Carbon.php

59 lines
1.6 KiB
PHP
Raw Normal View History

2022-04-13 01:02:37 +02:00
<?php
declare(strict_types=1);
namespace Engelsystem\Helpers;
class Carbon extends \Carbon\Carbon
{
public const DATETIME_LOCAL = '!Y-m-d\TH:i';
public const DATETIME_FALLBACK = '!Y-m-d H:i';
public const DATETIME_FORMATS = [
self::DATETIME_LOCAL,
self::DATETIME_FALLBACK,
];
/**
* Parses HTML datetime-local and ISO date/time strings.
*
2023-08-27 19:40:33 +02:00
* @return self|null Carbon if parseable, else null
2022-04-13 01:02:37 +02:00
* @see self::DATETIME_FORMATS
*/
public static function createFromDatetime(string $value): ?\Carbon\Carbon
{
foreach (self::DATETIME_FORMATS as $datetimeFormat) {
if (self::canBeCreatedFromFormat($value, $datetimeFormat)) {
return self::createFromFormat($datetimeFormat, $value);
}
}
return null;
}
/**
* Parses HTML datetime-local and ISO date/time strings.
*
* @return int|null Timestamp if parseable, else null
* @see self::DATETIME_FORMATS
*/
public static function createTimestampFromDatetime(string $value): ?int
{
$carbon = self::createFromDateTime($value);
return $carbon === null ? null : $carbon->timestamp;
}
2023-08-27 19:40:33 +02:00
/**
* Check if the instance is at the start of an hour.
*
* @param bool $checkMicroseconds check time at microseconds precision
*/
public function isStartOfHour(bool $checkMicroseconds = false): bool
{
return $checkMicroseconds
? $this->rawFormat('i:s.u') === '00:00.000000'
: $this->rawFormat('i:s') === '00:00';
}
2022-04-13 01:02:37 +02:00
}