data-values / time
Time value objects, parsers and formatters
Installs: 310 373
Dependents: 16
Suggesters: 2
Security: 0
Stars: 11
Watchers: 20
Forks: 6
Open Issues: 4
pkg:composer/data-values/time
Requires
- php: >=7.4.0
- data-values/common: ~1.0|~0.4.0|~0.3.0
- data-values/data-values: ~3.0|~2.0|~1.0|~0.1
- data-values/interfaces: ~1.0|~0.2.0
Requires (Dev)
- 1.2.0
- 1.1.2
- 1.1.1
- 1.1.0
- dev-master / 1.0.x-dev
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- 0.8.x-dev
- 0.8.6
- 0.8.5
- 0.8.4
- 0.8.3
- 0.8.2
- 0.8.1
- 0.8.0
- 0.7.0
- 0.6.1
- 0.6
- 0.5.2
- 0.5.1
- 0.5
- 0.4
- 0.3
- 0.2
- 0.1
- dev-combo-github-actions-cs-update
- dev-MonthNameUnlocalizer
- dev-ymdMonthNames
- dev-timeFormatterCal2
- dev-REL_0.7.1
- dev-addParseAndFormat
- dev-sinceEpoch
This package is auto-updated.
Last update: 2025-10-12 14:10:41 UTC
README
Library containing value objects to represent temporal information, parsers to turn user input into such value objects, and formatters to turn them back into user consumable representations.
It is part of the DataValues set of libraries.
On Packagist:
Installation
The recommended way to use this library is via Composer.
Composer
To add this package as a local, per-project dependency to your project, simply add a
dependency on data-values/time to your project's composer.json file.
Here is a minimal example of a composer.json file that just defines a dependency on
version 1.x of this package:
{ "require": { "data-values/time": "~1.2" } }
Manual
Get the code of this package, either via git, or some other means. Also get all dependencies. You can find a list of the dependencies in the "require" section of the composer.json file. Then take care of autoloading the classes defined in the src directory.
Tests
This library comes with a set up PHPUnit tests that cover all non-trivial code. You can run these tests using the PHPUnit configuration file found in the root directory. The tests can also be run via TravisCI, as a TravisCI configuration file is also provided in the root directory.
Authors
DataValues Time has been written by the Wikidata team, as Wikimedia Germany employees for the Wikidata project.
Release notes
1.2.0 (2024-12-12)
- Drop support for PHP 7.2, 7.3
- Upgrade codesniffer rules to current
mediawiki/mediawiki-codesnifferversion (45.0.0) - Make nullable type parameter declarations explicit for compatibility with PHP 8.4
1.1.2 (2022-10-24)
- Allow installation together with data-values/common 1.1.0 and data-values/interfaces 1.x
1.1.1 (2022-10-21)
- Allow installation together with DataValues 3.1
1.1.0 (2022-10-21)
- Improved compatibility with PHP 8.1;
in particular, the new
__serialize/__unserializemethods are implemented now (in addition to the still supportedSerializableinterface). Make sure to also usedata-values/data-valuesversion 3.1.0 (or later) to keep hashes stable. - Added support for the YYYY-DDD format (DDDth day of the year) added in PHP 8.1.7. (Not supported in earlier PHP versions.)
1.0.4 (2021-07-15)
- Support month+year dates with era
1.0.3 (2021-03-18)
- Update major
data-values/*versions
1.0.2 (2020-08-20)
- Fixed parsing unicode month names
1.0.1 (2018-09-18)
- Parse and refuse invalid calendar option
1.0.0 (2018-08-02)
- Removed
DATAVALUES_TIME_VERSIONconstant - Allow installation together with DataValues 2.x
0.8.6 (2017-09-06)
- Added whitespace trimming to
YearTimeParser. - Fixed
IsoTimestampParserandTimeValueaccepting a time of day with no day. - Fixed
MonthNameUnlocalizeraccidentally replacing already unlocalized numeric months. - Fixed
PhpDateTimeParsermisinterpreting inputs with only one or two numbers. - Deprecated
TimeValue::newFromArray. - Raised required PHP version from 5.3 to 5.5.
0.8.5 (2017-08-09)
- Removed MediaWiki integration
- Bump data-values/common dependency
0.8.4 (2016-04-20)
- Added
MonthNameProviderinterface. - Added
MonolingualMonthNameProvider. - Added
YearMonthTimeParser. - Added
YearTimeParser.
0.8.3 (2016-03-16)
- Added optional
ParserOptionsparameter to theYearMonthDayTimeParserconstructor. - Fixed
YearMonthDayTimeParsernot accepting calendar model and precision options. - Fixed
IsoTimestampParsernot accepting string precisions. - Fixed
IsoTimestampParsernot always throwing an exception on invalid precisions. - Fixed
FORMAT_NAMEconstants in parsers.
0.8.2 (2015-09-15)
- Fixed
IsoTimestampParserandTimeValueaccepting days with no month. - Fixed
YearMonthDayTimeParserrejecting YDM dates. YearMonthDayTimeParseraccepts some more dates where month and day are the same anyway.
0.8.1 (2015-08-14)
Additions
- Added
YearMonthDayTimeParser. PhpDateTimeParsernow accepts space-separated dates in YMD order.
Other changes
- The component can now be installed together with DataValues Interfaces 0.2.x.
- The component can now be installed together with DataValues Common 0.3.x.
0.8.0 (2015-06-26)
Breaking changes
IsoTimestampParserauto-detects the calendar model and does not default to Gregorian any more- Removed
IsoTimestampParser::PRECISION_NONE, usenullinstead TimeValues leap second range changed from [0..62] to [0..61]
Additions
- Added
EraParser - Added
TimeValue::CALENDAR_GREGORIANandTimeValue::CALENDAR_JULIAN - Renamed all
TimeValue::PRECISION_...constants with lower case letters, e.g.PRECISION_10atoPRECISION_YEAR10, leaving backwards compatible aliases IsoTimestampParsernow accepts time values with optional colons, per ISOPhpDateTimeParsernow accepts comma separated dates
Other changes
- Fixed
IsoTimestampParsernot being able to set precision to hour, minute or second on midnight - Deprecated
IsoTimestampParser::CALENDAR_GREGORIANandIsoTimestampParser::CALENDAR_JULIAN - Deprecated
TimeFormatter::CALENDAR_GREGORIANandTimeFormatter::CALENDAR_JULIAN
0.7.0 (2015-04-20)
Breaking changes
- Renamed
TimeParsertoIsoTimestampParser - Empty strings are now detected as invalid calendar models in the
TimeValueconstructor
Additions
- Added
MonthNameUnlocalizer - Added
PhpDateTimeParser IsoTimestampParsercan now parse various YMD ordered timestamp strings resembling ISO 8601CalendarModelParsernow accepts URIs and localized calendar names given via options
Other changes
- The year in
TimeValues is now padded to 4 digits, and additional leading zeros are trimmed - Major update of the
TimeValuedocumentation - Constructor arguments in
IsoTimestampParserandTimeFormatterare optional now - Fixed
TimeFormatterdelegating to an ISO timestamp formatter given via option TimeFormatterdoes not output the calendar model any more
0.6.1 (2014-10-09)
- Made component installable with DataValues 1.x
0.6.0 (2014-06-05)
- Added TimeValueCalculator
- Removed TimeIsoFormatter interface
- Introduced FORMAT_NAME class constants on ValueParsers in order to use them as expectedFormat
- Changed ValueParsers to pass rawValue and expectedFormat arguments when constructing a ParseException
0.5.2 (2014-04-28)
- Fix parsing of years ending in zero, defaulting precision to year when year is <= 4000 and >= 4000 BC.
0.5.1 (2014-03-24)
- Fix composer version of DataValues/Common
0.5.0 (2014-03-21)
- Removed TimeParser::SIGN_PATTERN constant
- Removed TimeParser::TIME_PATTERN constant
- Fixed bug 62730. The TimeParser now returns the correct precision when only month and year or year is given
0.4.0 (2014-03-14)
- Corrected spelling errors calender/calander -> calendar
0.3.0 (2014-03-13)
- Renamed CalenderModelParser to CalendarModelParser
- Added Calandar and Precision options to TimeParser
0.2.0 (2014-02-11)
Added features:
- TimeParser
- CalenderModelParser
0.1.0 (2013-11-17)
Initial release with these features:
- TimeValue
- TimeFormatter
- TimeIsoFormatter