diff options
Diffstat (limited to 'vendor/gipfl/format')
-rw-r--r-- | vendor/gipfl/format/composer.json | 28 | ||||
-rw-r--r-- | vendor/gipfl/format/src/LocalDateFormat.php | 41 | ||||
-rw-r--r-- | vendor/gipfl/format/src/LocalTimeFormat.php | 184 | ||||
-rw-r--r-- | vendor/gipfl/format/src/LocaleAwareness.php | 94 |
4 files changed, 347 insertions, 0 deletions
diff --git a/vendor/gipfl/format/composer.json b/vendor/gipfl/format/composer.json new file mode 100644 index 0000000..10c3b90 --- /dev/null +++ b/vendor/gipfl/format/composer.json @@ -0,0 +1,28 @@ +{ + "name": "gipfl/format", + "description": "Arbitrary collection of Format helpers", + "type": "library", + "license": "MIT", + "authors": [ + { + "name": "Thomas Gelf", + "email": "thomas@gelf.net" + } + ], + "config": { + "sort-packages": true + }, + "autoload": { + "psr-4": { + "gipfl\\Format\\": "src" + } + }, + "require": { + "php": ">=5.6.0", + "ext-intl": "*" + }, + "require-dev": { + "phpunit/phpunit": "^9.3 || ^7.5 || ^6.5 || ^5.7", + "squizlabs/php_codesniffer": "^3.6" + } +} diff --git a/vendor/gipfl/format/src/LocalDateFormat.php b/vendor/gipfl/format/src/LocalDateFormat.php new file mode 100644 index 0000000..60a29e4 --- /dev/null +++ b/vendor/gipfl/format/src/LocalDateFormat.php @@ -0,0 +1,41 @@ +<?php + +namespace gipfl\Format; + +use IntlDateFormatter; + +class LocalDateFormat +{ + use LocaleAwareness; + + /** @var IntlDateFormatter */ + protected $formatter; + + /** + * @param $time + * @return string + */ + public function getFullDay($time) + { + return $this->formatter()->format($time); + } + + protected function formatter() + { + if ($this->formatter === null) { + $this->formatter = new IntlDateFormatter( + $this->getLocale(), + IntlDateFormatter::FULL, + IntlDateFormatter::NONE + ); + $this->formatter->setTimeZone($this->getTimezone()); + } + + return $this->formatter; + } + + protected function reset() + { + $this->formatter = null; + } +} diff --git a/vendor/gipfl/format/src/LocalTimeFormat.php b/vendor/gipfl/format/src/LocalTimeFormat.php new file mode 100644 index 0000000..1ea3ce7 --- /dev/null +++ b/vendor/gipfl/format/src/LocalTimeFormat.php @@ -0,0 +1,184 @@ +<?php + +namespace gipfl\Format; + +use IntlDateFormatter; +use RuntimeException; + +class LocalTimeFormat +{ + use LocaleAwareness; + + /** @var IntlDateFormatter */ + protected $formatter; + + /** + * For available symbols please see: + * https://unicode-org.github.io/icu/userguide/format_parse/datetime/#date-field-symbol-table + * + * @param int|float $time Hint: also supports DateTime, DateTimeInterface since 7.1.5 + * @return string + */ + public function format($time, $pattern) + { + $result = $this->formatter($pattern)->format($time); + if ($result === false) { + throw new RuntimeException(sprintf( + 'Failed to format %s as "%s": %s (%d)', + $time, + $pattern, + $this->formatter->getErrorMessage(), + $this->formatter->getErrorCode() + )); + } + + return $result; + } + + /** + * @param $time + * @return string + */ + public function getWeekOfYear($time) + { + return $this->format($time, 'ww'); + } + + /** + * @param $time + * @return int + */ + public function getNumericWeekOfYear($time) + { + return (int) $this->format($time, 'w'); + } + + /** + * @param $time + * @return string + */ + public function getDayInMonth($time) + { + return $this->format($time, 'dd'); + } + + /** + * @param $time + * @return int + */ + public function getNumericDayInMonth($time) + { + return (int) $this->format($time, 'd'); + } + + /** + * @param $time + * @return string + */ + public function getWeekdayName($time) + { + return $this->format($time, 'cccc'); + } + + /** + * @param $time + * @return string + */ + public function getShortWeekdayName($time) + { + return $this->format($time, 'ccc'); + } + + /** + * e.g. September + * + * @param $time + * @return string + */ + public function getMonthName($time) + { + return $this->format($time, 'LLLL'); + } + + /** + * e.g. Sep + * + * @param $time + * @return string + */ + public function getShortMonthName($time) + { + return $this->format($time, 'LLL'); + } + + /** + * e.g. 2021 + * @param $time + * @return string + */ + public function getYear($time) + { + return $this->format($time, 'y'); + } + + /** + * e.g. 21 + * + * @param $time + * @return string + */ + public function getShortYear($time) + { + return $this->format($time, 'yy'); + } + + /** + * e.g. 21:50:12 + * + * @param $time + * @return string + */ + public function getTime($time) + { + if ($this->wantsAmPm()) { + return $this->format($time, 'h:mm:ss a'); + } + + return $this->format($time, 'H:mm:ss'); + } + + /** + * e.g. 21:50 + * + * @param $time + * @return string + */ + public function getShortTime($time) + { + if ($this->wantsAmPm()) { + return $this->format($time, 'K:mm a'); + } + + return $this->format($time, 'H:mm'); + } + + protected function formatter($pattern) + { + if ($this->formatter === null) { + $this->formatter = new IntlDateFormatter( + $this->getLocale(), + IntlDateFormatter::GREGORIAN, + IntlDateFormatter::GREGORIAN + ); + $this->formatter->setTimeZone($this->getTimezone()); + } + $this->formatter->setPattern($pattern); + + return $this->formatter; + } + + protected function reset() + { + $this->formatter = null; + } +} diff --git a/vendor/gipfl/format/src/LocaleAwareness.php b/vendor/gipfl/format/src/LocaleAwareness.php new file mode 100644 index 0000000..cb1a417 --- /dev/null +++ b/vendor/gipfl/format/src/LocaleAwareness.php @@ -0,0 +1,94 @@ +<?php + +namespace gipfl\Format; + +use DateTimeZone; +use IntlTimeZone; +use RuntimeException; + +trait LocaleAwareness +{ + /** @var string */ + protected $locale; + + /** @var DateTimeZone|IntlTimeZone */ + protected $timezone; + + /** + * @param string $locale + * @return void + */ + public function setLocale($locale) + { + if ($this->locale !== $locale) { + $this->locale = (string) $locale; + $this->reset(); + } + } + + /** + * @param DateTimeZone|IntlTimeZone $timezone + * @return void + */ + public function setTimezone($timezone) + { + // Hint: type checking is delegated to timeZonesAreEqual + if (self::timeZonesAreEqual($this->timezone, $timezone)) { + return; + } + + $this->timezone = $timezone; + $this->reset(); + } + + protected function wantsAmPm() + { + // TODO: complete this list + return in_array($this->getLocale(), ['en_US', 'en_US.UTF-8']); + } + + protected function isUsEnglish() + { + return in_array($this->getLocale(), ['en_US', 'en_US.UTF-8']); + } + + protected function getLocale() + { + if ($this->locale === null) { + $this->locale = setlocale(LC_TIME, 0) ?: 'C'; + } + + return $this->locale; + } + + protected function getTimezone() + { + if ($this->timezone === null) { + $this->timezone = new DateTimeZone(date_default_timezone_get()); + } + + return $this->timezone; + } + + protected static function timeZonesAreEqual($left, $right) + { + if ($left === null && $right !== null) { + return false; + } + if ($left !== null && $right === null) { + return false; + } + if ($left instanceof DateTimeZone) { + return $right instanceof DateTimeZone && $left->getName() === $right->getName(); + } + if ($left instanceof IntlTimeZone) { + return $right instanceof IntlTimeZone && $left->getID() === $right->getID(); + } + + throw new RuntimeException(sprintf( + 'Valid timezone expected, got left=%s, right=%s', + is_object($left) ? get_class($left) : gettype($left), + is_object($right) ? get_class($right) : gettype($right) + )); + } +} |