The DatePoint class
A datepoint is a position in time expressed as a DateTimeImmutable object.
The DatePoint class is used to ease DateTimeImmutable manipulation. This class decorates PHP’s DateTimeImmutable class.
It provides:
- named constructors to easily get a DateTimeImmutableobject.
- several factory methods to instantiate Periodclasses from aDateTimeImmutableobject.
- several methods to exposes the relation between a DateTimeImmutableobject and aLeague\Period\Periodinstance.
Named constructors
DatePoint::fromDate
public DatePoint::fromDate(DateTimeInterface $date): self;
Returns a DatePoint from a DateTimeInterface implementing object
example
use League\Period\DatePoint;
$datepoint1 = DatePoint::fromDate(new DateTime('2018-10-15'));
$datepoint2 = DatePoint::fromDate(new DateTimeImmutable('2018-10-15'));
$datepoint1 == $datepoint2; // returns true
DatePoint::fromDateString
public DatePoint::fromDateString(string $dateString, DateTimeZone|string $timezone = null): self;
Returns a DatePoint from a string parsable by the DateTimeImmutable constructor.
examples
use League\Period\DatePoint;
DatePoint::fromDateString('yesterday', 'Africa/Nairobi'); 
//is equivalent to
DatePoint::fromDate(new DateTimeImmutable('yesterday', new DateTimeZone('Africa/Nairobi'))); 
DatePoint::fromDateString('2018')
//is equivalent to
DatePoint::fromDate(new DateTimeImmutable('2018')); 
DatePoint::fromTimestamp
public DatePoint::fromTimestamp(int $timestamp): self;
Returns a DatePoint from an integer interpreted as a timestamp.
examples
Using the $datepoint argument
use League\Period\DatePoint;
DatePoint::fromTimestamp(2018); 
Accessing the inner Date object
public readonly DateTimeImmutable DatePoint::date;
At any given moment you can easily access the underlying DateTimeImmutable instance by
calling the public readonly property DatePoint::date.
examples
use League\Period\DatePoint;
DatePoint::fromTimestamp(2018)->date;
//returns an instance equivalent to `new DateTimeImmutable('@2018')`
Accessing calendar interval
Once you’ve got a DatePoint instantiated object, you can access a set of calendar type interval using the following method signature.
use League\Period\Bounds;
public function method(Bounds $boundaries = Bounds::IncludeStartExcludeEnd): Period;
where method is one of the following date time span:
- DatePoint::second
- DatePoint::minute
- DatePoint::hour
- DatePoint::day
- DatePoint::isoWeek
- DatePoint::month
- DatePoint::quarter
- DatePoint::semester
- DatePoint::year
- DatePoint::isoYear
For each a these methods a Period object is returned with:
- the Bounds::IncludeStartExcludeEndbounds type by default unless changed using the$boundsargument;
- the starting date endpoint represents the beginning of the current date endpoint calendar interval;
- the duration associated with the given calendar interval;
Examples
use League\Period\Bounds;
use League\Period\DatePoint;
$datepoint = Datepoint::fromDateString('2018-06-18 08:35:25');
$hour = $datepoint->hour();
// new Period('2018-06-18 08:00:00', '2018-06-18 09:00:00');
$month = $datepoint->month(Bounds::IncludeAll);
echo $month->toIso80000('Y-m-d');
// [2018-06-01, 2018-07-01 00:00:00];
$month->contains($datepoint); // true
$hour->contains($datepoint);  // true
$month->contains($hour);      // true
Relational method against interval
A datepoint can also be evaluated in relation to a given interval.
The following methods all share the same signature:
public function method(Period $interval): bool;
where method is one of the basic relation between a datepoint and an interval.
- DatePoint::isBefore
- DatePoint::bordersOnStart
- DatePoint::isStarting
- DatePoint::isDuring
- DatePoint::isEnding
- DatePoint::bordersOnEnd
- DatePoint::abuts
- DatePoint::isAfter
Examples
use League\Period\Bounds;
use League\Period\DatePoint;
use League\Period\Period;
$datepoint = DatePoint::fromDateString('2018-01-18 10:00:00');
$datepoint->bordersOnStart(
    Period::after($datepoint, new DateInterval('PT3M'), Bounds::ExcludeStartIncludeEnd)
); //  true
$datepoint->bordersOnStart(
    Period::after($datepoint, new DateInterval('PT3M'), Bounds::IncludeAll)
); // false
$datepoint->isAfter(
    Period::before(
        '2018-01-13 23:34:28', 
        '3 minutes', 
        Bounds::IncludeStartExcludeEnd
    )
);  // true