Period class
A period of time between two DateTimes.
- Implemented types
- Implementers
- Annotations
-
- @immutable
Constructors
Properties
- duration → Duration
-
The difference between the start and end plus one microsecond.
If start and end are equal, returns
Duration(microseconds: 1)
.no setter - end → DateTime
-
The end of the period. It is included in the period.
final
- hashCode → int
-
The hash code for this object.
no setterinherited
- isEmpty → bool
-
If start and end are equal.
no setter
- isNotEmpty → bool
-
If start and end are different.
no setter
-
props
→ List<
Object?> -
The list of properties that will be used to determine whether
two instances are equal.
no setter
- runtimeType → Type
-
A representation of the runtime type of the object.
no setterinherited
- start → DateTime
-
The start of the period. It is included in the period.
final
- stringify → bool?
-
If set to
true
, the toString method will be overridden to output this instance's props.no setterinherited
Methods
-
compareTo(
Period other) → int -
Compares this object to another object.
override
-
containedFullyBy(
Period other) → bool -
Returns
true
if this is contained fully byother
. -
containedPartiallyBy(
Period other) → bool -
Returns
true
if this is contained partially byother
. -
contains(
DateTime date) → bool -
Returns
true
if this contains the givendate
. If thedate
is equal to the start or end or is between the two dates, it will returntrue
. -
containsFully(
Period other) → bool -
Returns
true
if this fully containsother
. -
containsPartially(
Period other) → bool -
Returns
true
if this contains partiallyother
. -
copyWith(
{DateTime? start, DateTime? end}) → Period -
Returns a new Period with the given
start
andend
values. Ifstart
orend
are not provided, the corresponding value of this is used. -
differenceBetween(
Period other) → List< Period> -
Returns a list of Periods that are the difference between this and
other
. -
doesNotOverlapWith(
Period other) → bool -
Returns
true
if this does not overlap withother
. -
endsAfter(
DateTime date) → bool -
Returns
true
if this ends after the givendate
. -
endsBefore(
DateTime date) → bool -
Returns
true
if this ends before the givendate
. -
getDateTimeValues(
DateTime? next(DateTime last)) → List< DateTime> -
Returns a list of DateTime values that are contained in this Period.
The
next
function is used to calculate the DateTime values for the returned list. Thenext
function is called with the last DateTime value, or start. Thenext
function must return a DateTime value that is contained in this Period. Thenext
function must return a DateTime value that is not after the end value of this Period. When thenext
function returnsnull
, the iteration stops. -
getIntersection(
Period other) → Period? -
Returns a Period that is the intersection of this and
other
. -
getNext<
T extends Period> (PeriodGeneratorMixin< T> generator) → T -
Returns a new Period that starts after this using
generator
. -
getPrevious<
T extends Period> (PeriodGeneratorMixin< T> generator) → T -
Returns a new Period that starts before this using
generator
. -
mergeWith(
Period other) → Period? -
Returns a Period that is the union of this and
other
. -
noSuchMethod(
Invocation invocation) → dynamic -
Invoked when a nonexistent method or property is accessed.
inherited
-
occursAfter(
Period other) → bool -
Returns
true
if this occurs afterother
. -
occursBefore(
Period other) → bool -
Returns
true
if this occurs beforeother
. -
overlapsWith(
Period other) → bool -
Returns
true
if this overlaps withother
. -
shift(
Duration duration) → Period -
Returns a new Period that is shifted by the given
duration
. -
splitAt(
Set< DateTime> dates, {Duration periodBetween = Duration.zero}) → List<Period> -
Splits the period in multiple periods at the given
dates
. TheperiodBetween
is the duration between each period. Thedates
not included in the period are ignored. Thedates
will be sorted before splitting. -
splitIn(
int times, {Duration periodBetween = Duration.zero}) → List< Period> -
Split the period in multiple periods. The
times
is the number of periods to split the period in. -
startsAfter(
DateTime date) → bool -
Returns
true
if this starts after the givendate
. -
startsBefore(
DateTime date) → bool -
Returns
true
if this starts before the givendate
. -
subtract(
List< Period> periods) → List<Period> -
Returns a list of Periods that are the difference between this Period
and the
periods
passed as argument. -
toString(
{String dateFormat(DateTime date)?}) → String -
A string representation of this object.
override
-
trim(
List< Period> periods) → List<Period> - Removes periods that do not overlap with this period and trims the ones that do overlap and are not fully contained by this period.
Operators
-
operator &(
Period other) → Period? -
Returns a Period that is the intersection of this and
other
. -
operator <<(
Duration duration) → Period -
Returns a new Period that is shifted by the given
duration
backwards. -
operator ==(
Object other) → bool -
The equality operator.
override
-
operator >>(
Duration duration) → Period -
Returns a new Period that is shifted by the given
duration
forwards. -
operator |(
Period other) → List< Period> - Returns a list of Periods.
Static Methods
-
calculateEndDifference(
Period first, Period second) → Period? -
Returns the period between the end of the
first
period and the end of thesecond
period. -
calculateStartDifference(
Period first, Period second) → Period? -
Returns the period between the start of the
first
period and the start of thesecond
period. -
inBetween(
Period first, Period second) → Period? -
Returns the period between
first
andsecond
. -
intersections(
List< Period> periods, {bool sort = true}) → List<Period> - Returns a list of periods that are the intersection of the given periods.
-
mergeOverlappingPeriods(
List< Period> periods, {bool sort = true}) → List<Period> - Returns a list of periods that are the union of the given periods.