@elderbyte/ngx-starter 13.5.0 → 13.5.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1,5 +1,4 @@
1
- import { DateUtil } from './date-util';
2
- import { Duration, Instant, LocalDate, Period } from '@js-joda/core';
1
+ import { Duration, Instant, LocalDate, nativeJs, Period, ZoneId } from '@js-joda/core';
3
2
  import { TimeUtil } from './time-util';
4
3
  import { PeriodDuration } from './period-duration';
5
4
  export class Interval {
@@ -49,16 +48,17 @@ export class Interval {
49
48
  }
50
49
  /**
51
50
  * Creates a Interval from a Date by spreading it to the begin and end of its day.
52
- *
53
- * @param localDate Date to spread
51
+ * @param date Date to spread
54
52
  */
55
- static ofDayDate(localDate) {
56
- const start = TimeUtil.instant(DateUtil.startOfDay(localDate));
57
- return Interval.ofStartAndOffset(start, Period.ofDays(1));
53
+ static ofDayDate(date) {
54
+ const localDate = LocalDate.from(nativeJs(date));
55
+ return Interval.ofDay(localDate, ZoneId.systemDefault());
58
56
  }
59
57
  static ofDay(day, zoneId) {
60
- const todayStart = day.atStartOfDay(zoneId).toInstant();
61
- return Interval.ofStartAndOffset(todayStart, Period.ofDays(1));
58
+ return Interval.betweenDays(day, day.plusDays(1), zoneId);
59
+ }
60
+ static betweenDays(startDayInclusive, endDayExclusive, zoneId) {
61
+ return Interval.of(startDayInclusive.atStartOfDay(zoneId).toInstant(), endDayExclusive.atStartOfDay(zoneId).toInstant());
62
62
  }
63
63
  /**
64
64
  * Creates a new interval with the given start time point
@@ -416,4 +416,4 @@ export class Interval {
416
416
  return this.start.compareTo(other.start);
417
417
  }
418
418
  }
419
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interval.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/time/interval.ts"],"names":[],"mappings":"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","sourcesContent":["import {DateUtil} from './date-util';\nimport {Duration, Instant, LocalDate, Period, TemporalAmount, ZoneId} from '@js-joda/core';\nimport {TimeUtil} from './time-util';\nimport {PeriodDuration} from './period-duration';\n\n/**\n * Represents an ISO-8601 interval string.\n * https://en.wikipedia.org/wiki/ISO_8601#Time_intervals\n */\nexport type IsoIntervalStr = string;\n\nexport class Interval {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly start: Instant,\n    public readonly end: Instant\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Static Builders                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Parses an ISO-8601 interval string.\n   * https://en.wikipedia.org/wiki/ISO_8601#Time_intervals\n   * @param iso\n   */\n  public static parse(\n    iso: IsoIntervalStr\n  ): Interval {\n    const parts = iso.split('/');\n\n    if (parts.length !== 2) {\n      throw new Error('The given string is not a valid iso interval: ' + iso);\n    }\n\n    const start = Instant.parse(parts[0]);\n\n    const endStr = parts[1];\n\n    // The 'end' part can either be an instant or a duration in iso format\n\n    if (endStr.startsWith('P') || endStr.startsWith('-P')) {\n\n      const duration = Duration.parse(endStr);\n\n      return Interval.ofStartAndOffset(\n        start,\n        duration\n      );\n    } else {\n      return Interval.of(\n        start,\n        Instant.parse(endStr)\n      );\n    }\n  }\n\n  public static yesterday(zoneId: ZoneId): Interval {\n    return Interval.ofDay(\n      LocalDate.now().minusDays(1),\n      zoneId\n    );\n  }\n\n  public static  tomorrow(zoneId: ZoneId): Interval {\n    return Interval.ofDay(\n      LocalDate.now().plusDays(1),\n      zoneId\n    );\n  }\n\n  public static today(zoneId: ZoneId): Interval {\n    return Interval.ofDay(\n      LocalDate.now(),\n      zoneId\n    );\n  }\n\n  /**\n   * Creates a Interval from a Date by spreading it to the begin and end of its day.\n   *\n   * @param localDate Date to spread\n   */\n  public static ofDayDate(localDate: Date): Interval {\n    const start = TimeUtil.instant(DateUtil.startOfDay(localDate));\n    return Interval.ofStartAndOffset(\n      start,\n      Period.ofDays(1)\n    );\n  }\n\n\n  public static ofDay(day: LocalDate, zoneId: ZoneId): Interval {\n    const todayStart = day.atStartOfDay(zoneId).toInstant();\n    return Interval.ofStartAndOffset(\n      todayStart,\n      Period.ofDays(1)\n    );\n  }\n\n\n  /**\n   * Creates a new interval with the given start time point\n   * and a offset from the start.\n   *\n   * Note that you should use Period for days to account for zone specific\n   * things like daylight saving.\n   *\n   * @param startInclusive\n   * @param offsetExclusive A Period or Duration offset.\n   */\n  public static ofStartAndOffset(startInclusive: Instant, offsetExclusive: TemporalAmount): Interval {\n    return Interval.of(\n      startInclusive,\n      startInclusive.plus(offsetExclusive)\n    );\n  }\n\n  public static of(\n    startInclusive: Instant,\n    endExclusive: Instant\n  ): Interval {\n    return new Interval(\n      startInclusive,\n      endExclusive\n    );\n  }\n\n  public static ofDate(\n    startInclusive: Date | string,\n    endExclusive: Date | string\n  ): Interval {\n    return new Interval(\n      TimeUtil.instant(startInclusive),\n      TimeUtil.instant(endExclusive)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Checks if the range is empty.\n   * <p>\n   * An empty range occurs when the start date equals the inclusive end date.\n   *\n   * @return true if the range is empty\n   */\n  public isEmpty(): boolean {\n    return this.start.equals(this.end);\n  }\n\n  /**\n   * Checks if the start of the interval is unbounded.\n   *\n   * @return true if start is unbounded\n   */\n  public isUnboundedStart(): boolean {\n    return this.start.equals(Instant.MIN);\n  }\n\n  /**\n   * Checks if the end of the interval is unbounded.\n   *\n   * @return true if end is unbounded\n   */\n  public isUnboundedEnd(): boolean {\n    return this.end.equals(Instant.MAX);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public toDuration(): Duration {\n    return Duration.between(this.start, this.end);\n  }\n\n  public toPeriodDuration(zone: ZoneId): PeriodDuration {\n    return PeriodDuration.between(\n      this.start.atZone(zone),\n      this.end.atZone(zone)\n    );\n  }\n\n  public toString(): IsoIntervalStr {\n    return this.toDurationString();\n  }\n\n  public toInstantString(): IsoIntervalStr {\n    return this.start.toString() + '/' + this.end.toString();\n  }\n\n  public toDurationString(): IsoIntervalStr {\n    return this.start.toString() + '/' + this.toDuration().toString();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public Modification API                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Returns a copy of this range with the specified start instant.\n   *\n   * @param start  the start instant for the new interval, not null\n   * @return an interval with the end from this interval and the specified start\n   * @throws DateTimeException if the resulting interval has end before start\n   */\n  public withStart(start: Instant): Interval {\n    return Interval.of(start, this.end);\n  }\n\n  /**\n   * Returns a copy of this range with the specified end instant.\n   *\n   * @param end  the end instant for the new interval, not null\n   * @return an interval with the start from this interval and the specified end\n   * @throws DateTimeException if the resulting interval has end before start\n   */\n  public withEnd(end: Instant): Interval {\n    return Interval.of(this.start, end);\n  }\n\n  /**\n   * Calculates the interval that is the intersection of this interval and the specified interval.\n   * <p>\n   * This finds the intersection of two intervals.\n   * This throws an exception if the two intervals are not {@linkplain #isConnected(Interval) connected}.\n   *\n   * @param other  the other interval to check for, not null\n   * @return the interval that is the intersection of the two intervals\n   * @throws DateTimeException if the intervals do not connect\n   */\n  public intersection(other: Interval): Interval {\n    if (this.isConnected(other) === false) {\n      throw new Error('Intervals do not connect: ' + this + ' and ' + other);\n    }\n    const cmpStart = this.start.compareTo(other.start);\n    const cmpEnd = this.end.compareTo(other.end);\n    if (cmpStart >= 0 && cmpEnd <= 0) {\n      return this;\n    } else if (cmpStart <= 0 && cmpEnd >= 0) {\n      return other;\n    } else {\n      const newStart = (cmpStart >= 0 ? this.start : other.start);\n      const newEnd = (cmpEnd <= 0 ? this.end : other.end);\n      return Interval.of(newStart, newEnd);\n    }\n  }\n\n  /**\n   * Calculates the interval that is the union of this interval and the specified interval.\n   * <p>\n   * This finds the union of two intervals.\n   * This throws an exception if the two intervals are not {@linkplain #isConnected(Interval) connected}.\n   *\n   * @param other  the other interval to check for, not null\n   * @return the interval that is the union of the two intervals\n   * @throws DateTimeException if the intervals do not connect\n   */\n  public union(other: Interval): Interval {\n    if (this.isConnected(other) === false) {\n      throw new Error('Intervals do not connect: ' + this + ' and ' + other);\n    }\n    const cmpStart = this.start.compareTo(other.start);\n    const cmpEnd = this.end.compareTo(other.end);\n    if (cmpStart >= 0 && cmpEnd <= 0) {\n      return other;\n    } else if (cmpStart <= 0 && cmpEnd >= 0) {\n      return this;\n    } else {\n      const newStart = (cmpStart >= 0 ? other.start : this.start);\n      const newEnd = (cmpEnd <= 0 ? other.end : this.end);\n      return Interval.of(newStart, newEnd);\n    }\n  }\n\n  /**\n   * Calculates the smallest interval that encloses this interval and the specified interval.\n   * <p>\n   * The result of this method will {@linkplain #encloses(Interval) enclose}\n   * this interval and the specified interval.\n   *\n   * @param other  the other interval to check for, not null\n   * @return the interval that spans the two intervals\n   */\n  public span(other: Interval): Interval {\n    const cmpStart = this.start.compareTo(other.start);\n    const cmpEnd = this.end.compareTo(other.end);\n    const newStart = (cmpStart >= 0 ? other.start : this.start);\n    const newEnd = (cmpEnd <= 0 ? other.end : this.end);\n    return Interval.of(newStart, newEnd);\n  }\n\n\n  /**\n   * Shift the whole interval by the given days period.\n   * @param days\n   */\n  public shiftDays(days: number): Interval {\n    return this.shift(Period.ofDays(days));\n  }\n\n  /**\n   * Shift the whole interval by the given temporal amount.\n   * Note that only Period will account for zone specific things such as daylight savings.\n   * Use Duration only if you are below days.\n   * @param offset\n   */\n  public shift(offset: TemporalAmount): Interval {\n    return Interval.of(\n      this.start.plus(offset),\n      this.end.plus(offset)\n    );\n  }\n\n  public moveStart(offset: TemporalAmount): Interval {\n    return Interval.of(\n      this.start.plus(offset),\n      this.end\n    );\n  }\n\n  public moveEnd(offset: TemporalAmount): Interval {\n    return Interval.of(\n      this.start,\n      this.end.plus(offset)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Interval Query API                                                      *\n   *                                                                         *\n   **************************************************************************/\n\n\n  /**\n   * Checks if the given TimeFrame overlaps with this one.\n   *\n   * @param other TimeFrame to check against\n   * @return Returns {@code true} if the two candidates overlap, false otherwise\n   */\n  public overlaps(other: Interval): boolean {\n    return other.equals(this) || (this.start.compareTo(other.end) < 0 && other.start.compareTo(this.end) < 0);\n  }\n\n  /**\n   * Checks it the given localDate overlaps with the given TimeFrame.\n   *\n   * @param timeFrame TimeFrame to check against\n   * @param localDate LocalDate to check\n   */\n  public overlapsWithLocalDate(\n    localDate: Date\n  ): boolean {\n    return this.overlaps(Interval.ofDayDate(localDate));\n  }\n\n  /**\n   * Checks if this interval contains the specified instant.\n   * <p>\n   * This checks if the specified instant is within the bounds of this interval.\n   * If this range has an unbounded start then {@code contains(Instant#MIN)} returns true.\n   * If this range has an unbounded end then {@code contains(Instant#MAX)} returns true.\n   * If this range is empty then this method always returns false.\n   *\n   * @param instant  the instant, not null\n   * @return true if this interval contains the instant\n   */\n  public  contains(instant: Instant): boolean {\n    return this.start.compareTo(instant) <= 0 && (instant.compareTo(this.end) < 0 || this.isUnboundedEnd());\n  }\n\n  /**\n   * Checks if this interval encloses the specified interval.\n   * <p>\n   * This checks if the bounds of the specified interval are within the bounds of this interval.\n   * An empty interval encloses itself.\n   *\n   * @param other  the other interval, not null\n   * @return true if this interval contains the other interval\n   */\n  public encloses(other: Interval): boolean {\n    return this.start.compareTo(other.start) <= 0 && other.end.compareTo(this.end) <= 0;\n  }\n\n  /**\n   * Checks if this interval abuts (is next to or has a common boundary with) the specified interval.\n   * <p>\n   * The result is true if the end of this interval is the start of the other, or vice versa.\n   * An empty interval does not abut itself.\n   *\n   * @param other  the other interval, not null\n   * @return true if this interval abuts the other interval\n   */\n  public abuts(other: Interval): boolean {\n    return this.end.equals(other.start) !== this.start.equals(other.end); // !== means XOR\n  }\n\n  /**\n   * Checks if this interval is connected to the specified interval.\n   * <p>\n   * The result is true if the two intervals have an enclosed interval in common, even if that interval is empty.\n   * An empty interval is connected to itself.\n   * <p>\n   * This is equivalent to {@code (overlaps(other) || abuts(other))}.\n   *\n   * @param other  the other interval, not null\n   * @return true if this interval is connected to the other interval\n   */\n  public isConnected(other: Interval): boolean {\n    return this.equals(other) || (this.start.compareTo(other.end) <= 0 && other.start.compareTo(this.end) <= 0);\n  }\n\n  // ---\n\n  /**\n   * Checks if this interval is after the specified instant.\n   * <p>\n   * The result is true if this instant starts after the specified instant.\n   * An empty interval behaves as though it is an instant for comparison purposes.\n   *\n   * @param instant  the other instant to compare to, not null\n   * @return true if the start of this interval is after the specified instant\n   */\n  public isAfterInstant(instant: Instant): boolean {\n    return this.start.compareTo(instant) > 0;\n  }\n\n  /**\n   * Checks if this interval is before the specified instant.\n   * <p>\n   * The result is true if this instant ends before the specified instant.\n   * Since intervals do not include their end points, this will return true if the\n   * instant equals the end of the interval.\n   * An empty interval behaves as though it is an instant for comparison purposes.\n   *\n   * @param instant  the other instant to compare to, not null\n   * @return true if the start of this interval is before the specified instant\n   */\n  public isBeforeInstant(instant: Instant): boolean {\n    return this.end.compareTo(instant) <= 0 && this.start.compareTo(instant) < 0;\n  }\n\n  /**\n   * Checks if this interval is after the specified interval.\n   * <p>\n   * The result is true if this instant starts after the end of the specified interval.\n   * Since intervals do not include their end points, this will return true if the\n   * instant equals the end of the interval.\n   * An empty interval behaves as though it is an instant for comparison purposes.\n   *\n   * @param interval  the other interval to compare to, not null\n   * @return true if this instant is after the specified instant\n   */\n  public isAfter(interval: Interval): boolean {\n    return this.start.compareTo(interval.end) >= 0 && !interval.equals(this);\n  }\n\n  /**\n   * Checks if this interval is before the specified interval.\n   * <p>\n   * The result is true if this instant ends before the start of the specified interval.\n   * Since intervals do not include their end points, this will return true if the\n   * two intervals abut.\n   * An empty interval behaves as though it is an instant for comparison purposes.\n   *\n   * @param interval  the other interval to compare to, not null\n   * @return true if this instant is before the specified instant\n   */\n  public isBefore(interval: Interval): boolean {\n    return this.end.compareTo(interval.start) <= 0 && !interval.equals(this);\n  }\n\n\n\n/***************************************************************************\n   *                                                                         *\n   * Equality & Hashcode                                                     *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Checks if this interval is equal to another interval.\n   * <p>\n   * Compares this {@code Interval} with another ensuring that the two instants are the same.\n   * Only objects of type {@code Interval} are compared, other types return false.\n   *\n   * @param obj  the object to check, null returns false\n   * @return true if this is equal to the other interval\n   */\n  public equals(obj: any): boolean {\n    if (this === obj) {\n      return true;\n    }\n    if (obj instanceof Interval) {\n      const other = <Interval> obj;\n      return this.start.equals(other.start) && this.end.equals(other.end);\n    }\n    return false;\n  }\n\n  /**\n   * Compares this Interval to the given Interval.\n   * <p>\n   * The comparison is based on the time-line position of the lower bound instants (Interval start).\n   *\n   * @param other the other Interval to compare to, not null\n   * @return the comparator value, negative if less, positive if greater\n   * @throws NullPointerException if other is null\n   */\n  public compareTo(other: Interval): number {\n    return this.start.compareTo(other.start);\n  }\n\n\n}\n"]}
419
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interval.js","sourceRoot":"","sources":["../../../../../../../projects/elderbyte/ngx-starter/src/lib/common/time/interval.ts"],"names":[],"mappings":"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","sourcesContent":["import {DateUtil} from './date-util';\nimport {Duration, Instant, LocalDate, nativeJs, Period, TemporalAmount, ZoneId} from '@js-joda/core';\nimport {TimeUtil} from './time-util';\nimport {PeriodDuration} from './period-duration';\n\n/**\n * Represents an ISO-8601 interval string.\n * https://en.wikipedia.org/wiki/ISO_8601#Time_intervals\n */\nexport type IsoIntervalStr = string;\n\nexport class Interval {\n\n\n  /***************************************************************************\n   *                                                                         *\n   * Constructor                                                             *\n   *                                                                         *\n   **************************************************************************/\n\n  constructor(\n    public readonly start: Instant,\n    public readonly end: Instant\n  ) { }\n\n  /***************************************************************************\n   *                                                                         *\n   * Static Builders                                                         *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Parses an ISO-8601 interval string.\n   * https://en.wikipedia.org/wiki/ISO_8601#Time_intervals\n   * @param iso\n   */\n  public static parse(\n    iso: IsoIntervalStr\n  ): Interval {\n    const parts = iso.split('/');\n\n    if (parts.length !== 2) {\n      throw new Error('The given string is not a valid iso interval: ' + iso);\n    }\n\n    const start = Instant.parse(parts[0]);\n\n    const endStr = parts[1];\n\n    // The 'end' part can either be an instant or a duration in iso format\n\n    if (endStr.startsWith('P') || endStr.startsWith('-P')) {\n\n      const duration = Duration.parse(endStr);\n\n      return Interval.ofStartAndOffset(\n        start,\n        duration\n      );\n    } else {\n      return Interval.of(\n        start,\n        Instant.parse(endStr)\n      );\n    }\n  }\n\n  public static yesterday(zoneId: ZoneId): Interval {\n    return Interval.ofDay(\n      LocalDate.now().minusDays(1),\n      zoneId\n    );\n  }\n\n  public static  tomorrow(zoneId: ZoneId): Interval {\n    return Interval.ofDay(\n      LocalDate.now().plusDays(1),\n      zoneId\n    );\n  }\n\n  public static today(zoneId: ZoneId): Interval {\n    return Interval.ofDay(LocalDate.now(), zoneId);\n  }\n\n  /**\n   * Creates a Interval from a Date by spreading it to the begin and end of its day.\n   * @param date Date to spread\n   */\n  public static ofDayDate(date: Date): Interval {\n    const localDate = LocalDate.from(nativeJs(date));\n    return Interval.ofDay(localDate, ZoneId.systemDefault());\n  }\n\n  public static ofDay(day: LocalDate, zoneId: ZoneId): Interval {\n    return Interval.betweenDays(\n      day,\n      day.plusDays(1),\n      zoneId\n    );\n  }\n\n  public static betweenDays(\n    startDayInclusive: LocalDate,\n    endDayExclusive: LocalDate,\n    zoneId: ZoneId\n  ) {\n    return Interval.of(\n      startDayInclusive.atStartOfDay(zoneId).toInstant(),\n      endDayExclusive.atStartOfDay(zoneId).toInstant()\n    );\n  }\n\n\n\n  /**\n   * Creates a new interval with the given start time point\n   * and a offset from the start.\n   *\n   * Note that you should use Period for days to account for zone specific\n   * things like daylight saving.\n   *\n   * @param startInclusive\n   * @param offsetExclusive A Period or Duration offset.\n   */\n  public static ofStartAndOffset(startInclusive: Instant, offsetExclusive: TemporalAmount): Interval {\n    return Interval.of(\n      startInclusive,\n      startInclusive.plus(offsetExclusive)\n    );\n  }\n\n  public static of(\n    startInclusive: Instant,\n    endExclusive: Instant\n  ): Interval {\n    return new Interval(\n      startInclusive,\n      endExclusive\n    );\n  }\n\n  public static ofDate(\n    startInclusive: Date | string,\n    endExclusive: Date | string\n  ): Interval {\n    return new Interval(\n      TimeUtil.instant(startInclusive),\n      TimeUtil.instant(endExclusive)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Properties                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Checks if the range is empty.\n   * <p>\n   * An empty range occurs when the start date equals the inclusive end date.\n   *\n   * @return true if the range is empty\n   */\n  public isEmpty(): boolean {\n    return this.start.equals(this.end);\n  }\n\n  /**\n   * Checks if the start of the interval is unbounded.\n   *\n   * @return true if start is unbounded\n   */\n  public isUnboundedStart(): boolean {\n    return this.start.equals(Instant.MIN);\n  }\n\n  /**\n   * Checks if the end of the interval is unbounded.\n   *\n   * @return true if end is unbounded\n   */\n  public isUnboundedEnd(): boolean {\n    return this.end.equals(Instant.MAX);\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public API                                                              *\n   *                                                                         *\n   **************************************************************************/\n\n  public toDuration(): Duration {\n    return Duration.between(this.start, this.end);\n  }\n\n  public toPeriodDuration(zone: ZoneId): PeriodDuration {\n    return PeriodDuration.between(\n      this.start.atZone(zone),\n      this.end.atZone(zone)\n    );\n  }\n\n  public toString(): IsoIntervalStr {\n    return this.toDurationString();\n  }\n\n  public toInstantString(): IsoIntervalStr {\n    return this.start.toString() + '/' + this.end.toString();\n  }\n\n  public toDurationString(): IsoIntervalStr {\n    return this.start.toString() + '/' + this.toDuration().toString();\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Public Modification API                                                 *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Returns a copy of this range with the specified start instant.\n   *\n   * @param start  the start instant for the new interval, not null\n   * @return an interval with the end from this interval and the specified start\n   * @throws DateTimeException if the resulting interval has end before start\n   */\n  public withStart(start: Instant): Interval {\n    return Interval.of(start, this.end);\n  }\n\n  /**\n   * Returns a copy of this range with the specified end instant.\n   *\n   * @param end  the end instant for the new interval, not null\n   * @return an interval with the start from this interval and the specified end\n   * @throws DateTimeException if the resulting interval has end before start\n   */\n  public withEnd(end: Instant): Interval {\n    return Interval.of(this.start, end);\n  }\n\n  /**\n   * Calculates the interval that is the intersection of this interval and the specified interval.\n   * <p>\n   * This finds the intersection of two intervals.\n   * This throws an exception if the two intervals are not {@linkplain #isConnected(Interval) connected}.\n   *\n   * @param other  the other interval to check for, not null\n   * @return the interval that is the intersection of the two intervals\n   * @throws DateTimeException if the intervals do not connect\n   */\n  public intersection(other: Interval): Interval {\n    if (this.isConnected(other) === false) {\n      throw new Error('Intervals do not connect: ' + this + ' and ' + other);\n    }\n    const cmpStart = this.start.compareTo(other.start);\n    const cmpEnd = this.end.compareTo(other.end);\n    if (cmpStart >= 0 && cmpEnd <= 0) {\n      return this;\n    } else if (cmpStart <= 0 && cmpEnd >= 0) {\n      return other;\n    } else {\n      const newStart = (cmpStart >= 0 ? this.start : other.start);\n      const newEnd = (cmpEnd <= 0 ? this.end : other.end);\n      return Interval.of(newStart, newEnd);\n    }\n  }\n\n  /**\n   * Calculates the interval that is the union of this interval and the specified interval.\n   * <p>\n   * This finds the union of two intervals.\n   * This throws an exception if the two intervals are not {@linkplain #isConnected(Interval) connected}.\n   *\n   * @param other  the other interval to check for, not null\n   * @return the interval that is the union of the two intervals\n   * @throws DateTimeException if the intervals do not connect\n   */\n  public union(other: Interval): Interval {\n    if (this.isConnected(other) === false) {\n      throw new Error('Intervals do not connect: ' + this + ' and ' + other);\n    }\n    const cmpStart = this.start.compareTo(other.start);\n    const cmpEnd = this.end.compareTo(other.end);\n    if (cmpStart >= 0 && cmpEnd <= 0) {\n      return other;\n    } else if (cmpStart <= 0 && cmpEnd >= 0) {\n      return this;\n    } else {\n      const newStart = (cmpStart >= 0 ? other.start : this.start);\n      const newEnd = (cmpEnd <= 0 ? other.end : this.end);\n      return Interval.of(newStart, newEnd);\n    }\n  }\n\n  /**\n   * Calculates the smallest interval that encloses this interval and the specified interval.\n   * <p>\n   * The result of this method will {@linkplain #encloses(Interval) enclose}\n   * this interval and the specified interval.\n   *\n   * @param other  the other interval to check for, not null\n   * @return the interval that spans the two intervals\n   */\n  public span(other: Interval): Interval {\n    const cmpStart = this.start.compareTo(other.start);\n    const cmpEnd = this.end.compareTo(other.end);\n    const newStart = (cmpStart >= 0 ? other.start : this.start);\n    const newEnd = (cmpEnd <= 0 ? other.end : this.end);\n    return Interval.of(newStart, newEnd);\n  }\n\n\n  /**\n   * Shift the whole interval by the given days period.\n   * @param days\n   */\n  public shiftDays(days: number): Interval {\n    return this.shift(Period.ofDays(days));\n  }\n\n  /**\n   * Shift the whole interval by the given temporal amount.\n   * Note that only Period will account for zone specific things such as daylight savings.\n   * Use Duration only if you are below days.\n   * @param offset\n   */\n  public shift(offset: TemporalAmount): Interval {\n    return Interval.of(\n      this.start.plus(offset),\n      this.end.plus(offset)\n    );\n  }\n\n  public moveStart(offset: TemporalAmount): Interval {\n    return Interval.of(\n      this.start.plus(offset),\n      this.end\n    );\n  }\n\n  public moveEnd(offset: TemporalAmount): Interval {\n    return Interval.of(\n      this.start,\n      this.end.plus(offset)\n    );\n  }\n\n  /***************************************************************************\n   *                                                                         *\n   * Interval Query API                                                      *\n   *                                                                         *\n   **************************************************************************/\n\n\n  /**\n   * Checks if the given TimeFrame overlaps with this one.\n   *\n   * @param other TimeFrame to check against\n   * @return Returns {@code true} if the two candidates overlap, false otherwise\n   */\n  public overlaps(other: Interval): boolean {\n    return other.equals(this) || (this.start.compareTo(other.end) < 0 && other.start.compareTo(this.end) < 0);\n  }\n\n  /**\n   * Checks it the given localDate overlaps with the given TimeFrame.\n   *\n   * @param timeFrame TimeFrame to check against\n   * @param localDate LocalDate to check\n   */\n  public overlapsWithLocalDate(\n    localDate: Date\n  ): boolean {\n    return this.overlaps(Interval.ofDayDate(localDate));\n  }\n\n  /**\n   * Checks if this interval contains the specified instant.\n   * <p>\n   * This checks if the specified instant is within the bounds of this interval.\n   * If this range has an unbounded start then {@code contains(Instant#MIN)} returns true.\n   * If this range has an unbounded end then {@code contains(Instant#MAX)} returns true.\n   * If this range is empty then this method always returns false.\n   *\n   * @param instant  the instant, not null\n   * @return true if this interval contains the instant\n   */\n  public  contains(instant: Instant): boolean {\n    return this.start.compareTo(instant) <= 0 && (instant.compareTo(this.end) < 0 || this.isUnboundedEnd());\n  }\n\n  /**\n   * Checks if this interval encloses the specified interval.\n   * <p>\n   * This checks if the bounds of the specified interval are within the bounds of this interval.\n   * An empty interval encloses itself.\n   *\n   * @param other  the other interval, not null\n   * @return true if this interval contains the other interval\n   */\n  public encloses(other: Interval): boolean {\n    return this.start.compareTo(other.start) <= 0 && other.end.compareTo(this.end) <= 0;\n  }\n\n  /**\n   * Checks if this interval abuts (is next to or has a common boundary with) the specified interval.\n   * <p>\n   * The result is true if the end of this interval is the start of the other, or vice versa.\n   * An empty interval does not abut itself.\n   *\n   * @param other  the other interval, not null\n   * @return true if this interval abuts the other interval\n   */\n  public abuts(other: Interval): boolean {\n    return this.end.equals(other.start) !== this.start.equals(other.end); // !== means XOR\n  }\n\n  /**\n   * Checks if this interval is connected to the specified interval.\n   * <p>\n   * The result is true if the two intervals have an enclosed interval in common, even if that interval is empty.\n   * An empty interval is connected to itself.\n   * <p>\n   * This is equivalent to {@code (overlaps(other) || abuts(other))}.\n   *\n   * @param other  the other interval, not null\n   * @return true if this interval is connected to the other interval\n   */\n  public isConnected(other: Interval): boolean {\n    return this.equals(other) || (this.start.compareTo(other.end) <= 0 && other.start.compareTo(this.end) <= 0);\n  }\n\n  // ---\n\n  /**\n   * Checks if this interval is after the specified instant.\n   * <p>\n   * The result is true if this instant starts after the specified instant.\n   * An empty interval behaves as though it is an instant for comparison purposes.\n   *\n   * @param instant  the other instant to compare to, not null\n   * @return true if the start of this interval is after the specified instant\n   */\n  public isAfterInstant(instant: Instant): boolean {\n    return this.start.compareTo(instant) > 0;\n  }\n\n  /**\n   * Checks if this interval is before the specified instant.\n   * <p>\n   * The result is true if this instant ends before the specified instant.\n   * Since intervals do not include their end points, this will return true if the\n   * instant equals the end of the interval.\n   * An empty interval behaves as though it is an instant for comparison purposes.\n   *\n   * @param instant  the other instant to compare to, not null\n   * @return true if the start of this interval is before the specified instant\n   */\n  public isBeforeInstant(instant: Instant): boolean {\n    return this.end.compareTo(instant) <= 0 && this.start.compareTo(instant) < 0;\n  }\n\n  /**\n   * Checks if this interval is after the specified interval.\n   * <p>\n   * The result is true if this instant starts after the end of the specified interval.\n   * Since intervals do not include their end points, this will return true if the\n   * instant equals the end of the interval.\n   * An empty interval behaves as though it is an instant for comparison purposes.\n   *\n   * @param interval  the other interval to compare to, not null\n   * @return true if this instant is after the specified instant\n   */\n  public isAfter(interval: Interval): boolean {\n    return this.start.compareTo(interval.end) >= 0 && !interval.equals(this);\n  }\n\n  /**\n   * Checks if this interval is before the specified interval.\n   * <p>\n   * The result is true if this instant ends before the start of the specified interval.\n   * Since intervals do not include their end points, this will return true if the\n   * two intervals abut.\n   * An empty interval behaves as though it is an instant for comparison purposes.\n   *\n   * @param interval  the other interval to compare to, not null\n   * @return true if this instant is before the specified instant\n   */\n  public isBefore(interval: Interval): boolean {\n    return this.end.compareTo(interval.start) <= 0 && !interval.equals(this);\n  }\n\n\n\n/***************************************************************************\n   *                                                                         *\n   * Equality & Hashcode                                                     *\n   *                                                                         *\n   **************************************************************************/\n\n  /**\n   * Checks if this interval is equal to another interval.\n   * <p>\n   * Compares this {@code Interval} with another ensuring that the two instants are the same.\n   * Only objects of type {@code Interval} are compared, other types return false.\n   *\n   * @param obj  the object to check, null returns false\n   * @return true if this is equal to the other interval\n   */\n  public equals(obj: any): boolean {\n    if (this === obj) {\n      return true;\n    }\n    if (obj instanceof Interval) {\n      const other = <Interval> obj;\n      return this.start.equals(other.start) && this.end.equals(other.end);\n    }\n    return false;\n  }\n\n  /**\n   * Compares this Interval to the given Interval.\n   * <p>\n   * The comparison is based on the time-line position of the lower bound instants (Interval start).\n   *\n   * @param other the other Interval to compare to, not null\n   * @return the comparator value, negative if less, positive if greater\n   * @throws NullPointerException if other is null\n   */\n  public compareTo(other: Interval): number {\n    return this.start.compareTo(other.start);\n  }\n\n\n}\n"]}
@@ -1,4 +1,4 @@
1
- import { Instant, LocalDate, ZoneId } from '@js-joda/core';
1
+ import { Instant, LocalDate, nativeJs, ZoneId } from '@js-joda/core';
2
2
  export class TimeUtil {
3
3
  /**
4
4
  * Returns an instant for a javascript date / iso date string.
@@ -6,20 +6,23 @@ export class TimeUtil {
6
6
  */
7
7
  static instant(date) {
8
8
  if (date instanceof Date) {
9
- return Instant.ofEpochMilli(date.getTime());
9
+ return Instant.from(TimeUtil.temporalAccessor(date));
10
10
  }
11
11
  else {
12
12
  return Instant.parse(date);
13
13
  }
14
14
  }
15
+ static dateToLocalDate(date) {
16
+ return LocalDate.from(TimeUtil.temporalAccessor(date));
17
+ }
18
+ static temporalAccessor(date) {
19
+ return nativeJs(date);
20
+ }
15
21
  static date(instant) {
16
22
  const d = new Date(0); // The 0 there is the key, which sets the date to the epoch
17
23
  d.setUTCMilliseconds(instant.toEpochMilli());
18
24
  return d;
19
25
  }
20
- static dateToLocalDate(date) {
21
- return LocalDate.of(date.getFullYear(), date.getMonth() + 1, date.getDate());
22
- }
23
26
  static localDateToDate(localDate, zone = ZoneId.systemDefault()) {
24
27
  return new Date(localDate.year(), localDate.monthValue() - 1, localDate.dayOfMonth(), 0, 0, 0, 0);
25
28
  }
@@ -35,4 +38,4 @@ export class TimeUtil {
35
38
  }
36
39
  }
37
40
  TimeUtil.SECONDS_PER_DAY = 86400;
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS11dGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tbW9uL3RpbWUvdGltZS11dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBVyxPQUFPLEVBQUUsU0FBUyxFQUFpQixNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFbEYsTUFBTSxPQUFPLFFBQVE7SUFJbkI7OztPQUdHO0lBQ0ksTUFBTSxDQUFDLE9BQU8sQ0FBQyxJQUFtQjtRQUN2QyxJQUFJLElBQUksWUFBWSxJQUFJLEVBQUU7WUFDeEIsT0FBTyxPQUFPLENBQUMsWUFBWSxDQUFDLElBQUksQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1NBQzdDO2FBQU07WUFDTCxPQUFPLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLENBQUM7U0FDNUI7SUFDSCxDQUFDO0lBRU0sTUFBTSxDQUFDLElBQUksQ0FBQyxPQUFnQjtRQUNqQyxNQUFNLENBQUMsR0FBRyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLDJEQUEyRDtRQUNsRixDQUFDLENBQUMsa0JBQWtCLENBQUMsT0FBTyxDQUFDLFlBQVksRUFBRSxDQUFDLENBQUM7UUFDN0MsT0FBTyxDQUFDLENBQUM7SUFDWCxDQUFDO0lBRU0sTUFBTSxDQUFDLGVBQWUsQ0FBQyxJQUFVO1FBQ3RDLE9BQU8sU0FBUyxDQUFDLEVBQUUsQ0FDakIsSUFBSSxDQUFDLFdBQVcsRUFBRSxFQUNsQixJQUFJLENBQUMsUUFBUSxFQUFFLEdBQUcsQ0FBQyxFQUNuQixJQUFJLENBQUMsT0FBTyxFQUFFLENBQ2YsQ0FBQztJQUNKLENBQUM7SUFFTSxNQUFNLENBQUMsZUFBZSxDQUFDLFNBQW9CLEVBQUUsSUFBSSxHQUFHLE1BQU0sQ0FBQyxhQUFhLEVBQUU7UUFDL0UsT0FBTyxJQUFJLElBQUksQ0FDYixTQUFTLENBQUMsSUFBSSxFQUFFLEVBQ2hCLFNBQVMsQ0FBQyxVQUFVLEVBQUUsR0FBRyxDQUFDLEVBQzFCLFNBQVMsQ0FBQyxVQUFVLEVBQUUsRUFDdEIsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUNYLENBQUM7SUFDSixDQUFDO0lBRU0sTUFBTSxDQUFDLFVBQVUsQ0FBQyxRQUFrQjtRQUN6QyxNQUFNLENBQUMsR0FBRyxRQUFRLENBQUMsT0FBTyxFQUFFLEdBQUcsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUN4RCxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakIsQ0FBQztJQUVNLE1BQU0sQ0FBQyxZQUFZLENBQUMsSUFBbUI7UUFDNUMsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQztlQUNyQixJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQztlQUNuQixJQUFJLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQztlQUNqQixJQUFJLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUNuQjtJQUNMLENBQUM7O0FBaERzQix3QkFBZSxHQUFHLEtBQUssQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RHVyYXRpb24sIEluc3RhbnQsIExvY2FsRGF0ZSwgWm9uZWREYXRlVGltZSwgWm9uZUlkfSBmcm9tICdAanMtam9kYS9jb3JlJztcblxuZXhwb3J0IGNsYXNzIFRpbWVVdGlsIHtcblxuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IFNFQ09ORFNfUEVSX0RBWSA9IDg2NDAwO1xuXG4gIC8qKlxuICAgKiBSZXR1cm5zIGFuIGluc3RhbnQgZm9yIGEgamF2YXNjcmlwdCBkYXRlIC8gaXNvIGRhdGUgc3RyaW5nLlxuICAgKiBAcGFyYW0gZGF0ZVxuICAgKi9cbiAgcHVibGljIHN0YXRpYyBpbnN0YW50KGRhdGU6IERhdGUgfCBzdHJpbmcpOiBJbnN0YW50IHtcbiAgICBpZiAoZGF0ZSBpbnN0YW5jZW9mIERhdGUpIHtcbiAgICAgIHJldHVybiBJbnN0YW50Lm9mRXBvY2hNaWxsaShkYXRlLmdldFRpbWUoKSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBJbnN0YW50LnBhcnNlKGRhdGUpO1xuICAgIH1cbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgZGF0ZShpbnN0YW50OiBJbnN0YW50KTogRGF0ZSB7XG4gICAgY29uc3QgZCA9IG5ldyBEYXRlKDApOyAvLyBUaGUgMCB0aGVyZSBpcyB0aGUga2V5LCB3aGljaCBzZXRzIHRoZSBkYXRlIHRvIHRoZSBlcG9jaFxuICAgIGQuc2V0VVRDTWlsbGlzZWNvbmRzKGluc3RhbnQudG9FcG9jaE1pbGxpKCkpO1xuICAgIHJldHVybiBkO1xuICB9XG5cbiAgcHVibGljIHN0YXRpYyBkYXRlVG9Mb2NhbERhdGUoZGF0ZTogRGF0ZSk6IExvY2FsRGF0ZSB7XG4gICAgcmV0dXJuIExvY2FsRGF0ZS5vZihcbiAgICAgIGRhdGUuZ2V0RnVsbFllYXIoKSxcbiAgICAgIGRhdGUuZ2V0TW9udGgoKSArIDEsXG4gICAgICBkYXRlLmdldERhdGUoKVxuICAgICk7XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIGxvY2FsRGF0ZVRvRGF0ZShsb2NhbERhdGU6IExvY2FsRGF0ZSwgem9uZSA9IFpvbmVJZC5zeXN0ZW1EZWZhdWx0KCkpOiBEYXRlIHtcbiAgICByZXR1cm4gbmV3IERhdGUoXG4gICAgICBsb2NhbERhdGUueWVhcigpLFxuICAgICAgbG9jYWxEYXRlLm1vbnRoVmFsdWUoKSAtIDEsXG4gICAgICBsb2NhbERhdGUuZGF5T2ZNb250aCgpLFxuICAgICAgMCwgMCwgMCwgMFxuICAgICk7XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIGlzRnVsbERheXMoZHVyYXRpb246IER1cmF0aW9uKTogYm9vbGVhbiB7XG4gICAgY29uc3QgciA9IGR1cmF0aW9uLnNlY29uZHMoKSAlIFRpbWVVdGlsLlNFQ09ORFNfUEVSX0RBWTtcbiAgICByZXR1cm4gciA9PT0gMDtcbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgaXNTdGFydE9mRGF5KGRhdGU6IFpvbmVkRGF0ZVRpbWUpOiBib29sZWFuIHtcbiAgICByZXR1cm4gZGF0ZS5zZWNvbmQoKSA9PT0gMFxuICAgICAgJiYgZGF0ZS5taW51dGUoKSA9PT0gMFxuICAgICAgJiYgZGF0ZS5ob3VyKCkgPT09IDBcbiAgICAgICYmIGRhdGUubmFubygpID09PSAwXG4gICAgICA7XG4gIH1cbn1cbiJdfQ==
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS11dGlsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZWxkZXJieXRlL25neC1zdGFydGVyL3NyYy9saWIvY29tbW9uL3RpbWUvdGltZS11dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBVyxPQUFPLEVBQUUsU0FBUyxFQUFFLFFBQVEsRUFBbUMsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRTlHLE1BQU0sT0FBTyxRQUFRO0lBSW5COzs7T0FHRztJQUNJLE1BQU0sQ0FBQyxPQUFPLENBQUMsSUFBbUI7UUFDdkMsSUFBSSxJQUFJLFlBQVksSUFBSSxFQUFFO1lBQ3hCLE9BQU8sT0FBTyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsZ0JBQWdCLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztTQUN0RDthQUFNO1lBQ0wsT0FBTyxPQUFPLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQzVCO0lBQ0gsQ0FBQztJQUVNLE1BQU0sQ0FBQyxlQUFlLENBQUMsSUFBVTtRQUN0QyxPQUFPLFNBQVMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLGdCQUFnQixDQUFDLElBQUksQ0FBQyxDQUFDLENBQUM7SUFDekQsQ0FBQztJQUVNLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxJQUFVO1FBQ3ZDLE9BQU8sUUFBUSxDQUFDLElBQUksQ0FBQyxDQUFDO0lBQ3hCLENBQUM7SUFFTSxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQWdCO1FBQ2pDLE1BQU0sQ0FBQyxHQUFHLElBQUksSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsMkRBQTJEO1FBQ2xGLENBQUMsQ0FBQyxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQztRQUM3QyxPQUFPLENBQUMsQ0FBQztJQUNYLENBQUM7SUFFTSxNQUFNLENBQUMsZUFBZSxDQUFDLFNBQW9CLEVBQUUsSUFBSSxHQUFHLE1BQU0sQ0FBQyxhQUFhLEVBQUU7UUFDL0UsT0FBTyxJQUFJLElBQUksQ0FDYixTQUFTLENBQUMsSUFBSSxFQUFFLEVBQ2hCLFNBQVMsQ0FBQyxVQUFVLEVBQUUsR0FBRyxDQUFDLEVBQzFCLFNBQVMsQ0FBQyxVQUFVLEVBQUUsRUFDdEIsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUNYLENBQUM7SUFDSixDQUFDO0lBRU0sTUFBTSxDQUFDLFVBQVUsQ0FBQyxRQUFrQjtRQUN6QyxNQUFNLENBQUMsR0FBRyxRQUFRLENBQUMsT0FBTyxFQUFFLEdBQUcsUUFBUSxDQUFDLGVBQWUsQ0FBQztRQUN4RCxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDakIsQ0FBQztJQUVNLE1BQU0sQ0FBQyxZQUFZLENBQUMsSUFBbUI7UUFDNUMsT0FBTyxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQztlQUNyQixJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQztlQUNuQixJQUFJLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQztlQUNqQixJQUFJLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUNuQjtJQUNMLENBQUM7O0FBaERzQix3QkFBZSxHQUFHLEtBQUssQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7RHVyYXRpb24sIEluc3RhbnQsIExvY2FsRGF0ZSwgbmF0aXZlSnMsIFRlbXBvcmFsQWNjZXNzb3IsIFpvbmVkRGF0ZVRpbWUsIFpvbmVJZH0gZnJvbSAnQGpzLWpvZGEvY29yZSc7XG5cbmV4cG9ydCBjbGFzcyBUaW1lVXRpbCB7XG5cbiAgcHVibGljIHN0YXRpYyByZWFkb25seSBTRUNPTkRTX1BFUl9EQVkgPSA4NjQwMDtcblxuICAvKipcbiAgICogUmV0dXJucyBhbiBpbnN0YW50IGZvciBhIGphdmFzY3JpcHQgZGF0ZSAvIGlzbyBkYXRlIHN0cmluZy5cbiAgICogQHBhcmFtIGRhdGVcbiAgICovXG4gIHB1YmxpYyBzdGF0aWMgaW5zdGFudChkYXRlOiBEYXRlIHwgc3RyaW5nKTogSW5zdGFudCB7XG4gICAgaWYgKGRhdGUgaW5zdGFuY2VvZiBEYXRlKSB7XG4gICAgICByZXR1cm4gSW5zdGFudC5mcm9tKFRpbWVVdGlsLnRlbXBvcmFsQWNjZXNzb3IoZGF0ZSkpO1xuICAgIH0gZWxzZSB7XG4gICAgICByZXR1cm4gSW5zdGFudC5wYXJzZShkYXRlKTtcbiAgICB9XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIGRhdGVUb0xvY2FsRGF0ZShkYXRlOiBEYXRlKTogTG9jYWxEYXRlIHtcbiAgICByZXR1cm4gTG9jYWxEYXRlLmZyb20oVGltZVV0aWwudGVtcG9yYWxBY2Nlc3NvcihkYXRlKSk7XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIHRlbXBvcmFsQWNjZXNzb3IoZGF0ZTogRGF0ZSk6IFRlbXBvcmFsQWNjZXNzb3Ige1xuICAgIHJldHVybiBuYXRpdmVKcyhkYXRlKTtcbiAgfVxuXG4gIHB1YmxpYyBzdGF0aWMgZGF0ZShpbnN0YW50OiBJbnN0YW50KTogRGF0ZSB7XG4gICAgY29uc3QgZCA9IG5ldyBEYXRlKDApOyAvLyBUaGUgMCB0aGVyZSBpcyB0aGUga2V5LCB3aGljaCBzZXRzIHRoZSBkYXRlIHRvIHRoZSBlcG9jaFxuICAgIGQuc2V0VVRDTWlsbGlzZWNvbmRzKGluc3RhbnQudG9FcG9jaE1pbGxpKCkpO1xuICAgIHJldHVybiBkO1xuICB9XG5cbiAgcHVibGljIHN0YXRpYyBsb2NhbERhdGVUb0RhdGUobG9jYWxEYXRlOiBMb2NhbERhdGUsIHpvbmUgPSBab25lSWQuc3lzdGVtRGVmYXVsdCgpKTogRGF0ZSB7XG4gICAgcmV0dXJuIG5ldyBEYXRlKFxuICAgICAgbG9jYWxEYXRlLnllYXIoKSxcbiAgICAgIGxvY2FsRGF0ZS5tb250aFZhbHVlKCkgLSAxLFxuICAgICAgbG9jYWxEYXRlLmRheU9mTW9udGgoKSxcbiAgICAgIDAsIDAsIDAsIDBcbiAgICApO1xuICB9XG5cbiAgcHVibGljIHN0YXRpYyBpc0Z1bGxEYXlzKGR1cmF0aW9uOiBEdXJhdGlvbik6IGJvb2xlYW4ge1xuICAgIGNvbnN0IHIgPSBkdXJhdGlvbi5zZWNvbmRzKCkgJSBUaW1lVXRpbC5TRUNPTkRTX1BFUl9EQVk7XG4gICAgcmV0dXJuIHIgPT09IDA7XG4gIH1cblxuICBwdWJsaWMgc3RhdGljIGlzU3RhcnRPZkRheShkYXRlOiBab25lZERhdGVUaW1lKTogYm9vbGVhbiB7XG4gICAgcmV0dXJuIGRhdGUuc2Vjb25kKCkgPT09IDBcbiAgICAgICYmIGRhdGUubWludXRlKCkgPT09IDBcbiAgICAgICYmIGRhdGUuaG91cigpID09PSAwXG4gICAgICAmJiBkYXRlLm5hbm8oKSA9PT0gMFxuICAgICAgO1xuICB9XG59XG4iXX0=
@@ -3,7 +3,7 @@ import { DatePipe, CommonModule, registerLocaleData, DecimalPipe } from '@angula
3
3
  import * as i0 from '@angular/core';
4
4
  import { Pipe, Injectable, LOCALE_ID, Inject, NgModule, Optional, SkipSelf, Directive, Output, Input, forwardRef, ViewChild, ViewChildren, Component, ChangeDetectionStrategy, EventEmitter, HostListener, HostBinding, ViewEncapsulation, TemplateRef, ContentChild, InjectionToken, ContentChildren, Host, APP_INITIALIZER } from '@angular/core';
5
5
  import * as i1 from '@angular/platform-browser';
6
- import { Duration, Period, TemporalQueries, LocalTime, Instant, LocalDate, ZoneId } from '@js-joda/core';
6
+ import { Duration, Period, TemporalQueries, LocalTime, Instant, LocalDate, nativeJs, ZoneId } from '@js-joda/core';
7
7
  import { LoggerFactory } from '@elderbyte/ts-logger';
8
8
  import { BehaviorSubject, Subject, EMPTY, combineLatest, merge, of, forkJoin, throwError, Observable, ReplaySubject, fromEvent, NEVER } from 'rxjs';
9
9
  import { distinctUntilChanged, map, filter, takeUntil, debounceTime, catchError, first, take, switchMap, mergeMap, takeWhile, tap, expand, reduce, skip, startWith, delay, share, throttleTime, flatMap, skipWhile, timeout } from 'rxjs/operators';
@@ -1325,99 +1325,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImpor
1325
1325
  }]
1326
1326
  }], ctorParameters: function () { return []; } });
1327
1327
 
1328
- class DateUtil {
1329
- /***************************************************************************
1330
- * *
1331
- * Public API *
1332
- * *
1333
- **************************************************************************/
1334
- static instantToDate(instant) {
1335
- return new Date(instant.toEpochMilli());
1336
- }
1337
- /**
1338
- * Returns the given Date as ISO formatted local date string.
1339
- *
1340
- * YYYY-MM-DD
1341
- *
1342
- * @param date
1343
- */
1344
- static toLocalDateIso(date) {
1345
- return DateUtil.dateString(date);
1346
- }
1347
- /**
1348
- * Returns the given Date as ISO formatted local date-time string.
1349
- *
1350
- * YYYY-MM-DDTHH:mm:ss.sss
1351
- *
1352
- * @param date
1353
- */
1354
- static toLocalDateTimeIso(date) {
1355
- const dateString = DateUtil.toLocalDateIso(date);
1356
- const timeString = DateUtil.timeString(date);
1357
- return dateString + DateUtil.DateTimeSeparator + timeString;
1358
- }
1359
- /**
1360
- * Checks if the given DateTime is represents the start of the day.
1361
- *
1362
- * @param dateTime DateTime to check
1363
- */
1364
- static isStartOfDay(date) {
1365
- date = new Date(date);
1366
- return date.getMilliseconds() === 0
1367
- && date.getSeconds() === 0
1368
- && date.getMinutes() === 0
1369
- && date.getHours() === 0;
1370
- }
1371
- /**
1372
- * Sets the given Date to the start of its day by setting its time to 0.
1373
- *
1374
- * @param localDate Date to set to start of day
1375
- */
1376
- static startOfDay(localDate) {
1377
- const startOfDay = new Date(localDate);
1378
- startOfDay.setHours(0, 0, 0, 0);
1379
- return startOfDay;
1380
- }
1381
- static plusDays(date, days) {
1382
- const plus = new Date(date);
1383
- plus.setDate(plus.getDate() + days);
1384
- return plus;
1385
- }
1386
- /***************************************************************************
1387
- * *
1388
- * private Methods *
1389
- * *
1390
- **************************************************************************/
1391
- static dateString(date) {
1392
- const values = [
1393
- String(date.getFullYear()),
1394
- DateUtil.format(date.getMonth() + 1),
1395
- DateUtil.format(date.getDate())
1396
- ];
1397
- return values.join(DateUtil.IsoDateDelimiter);
1398
- }
1399
- static timeString(date) {
1400
- const values = [
1401
- DateUtil.format(date.getHours()),
1402
- DateUtil.format(date.getMinutes()),
1403
- DateUtil.format(date.getSeconds())
1404
- ];
1405
- return values.join(DateUtil.IsoTimeDelimiter) +
1406
- '.' +
1407
- DateUtil.format(date.getMilliseconds(), 3);
1408
- }
1409
- static format(value, digitCount = 2) {
1410
- let zeros = '';
1411
- for (let i = 0; i < digitCount; i++) {
1412
- zeros += '0';
1413
- }
1414
- return (zeros + value).slice(-digitCount);
1415
- }
1416
- }
1417
- DateUtil.IsoDateDelimiter = '-';
1418
- DateUtil.IsoTimeDelimiter = ':';
1419
- DateUtil.DateTimeSeparator = 'T';
1420
-
1421
1328
  class TimeUtil {
1422
1329
  /**
1423
1330
  * Returns an instant for a javascript date / iso date string.
@@ -1425,20 +1332,23 @@ class TimeUtil {
1425
1332
  */
1426
1333
  static instant(date) {
1427
1334
  if (date instanceof Date) {
1428
- return Instant.ofEpochMilli(date.getTime());
1335
+ return Instant.from(TimeUtil.temporalAccessor(date));
1429
1336
  }
1430
1337
  else {
1431
1338
  return Instant.parse(date);
1432
1339
  }
1433
1340
  }
1341
+ static dateToLocalDate(date) {
1342
+ return LocalDate.from(TimeUtil.temporalAccessor(date));
1343
+ }
1344
+ static temporalAccessor(date) {
1345
+ return nativeJs(date);
1346
+ }
1434
1347
  static date(instant) {
1435
1348
  const d = new Date(0); // The 0 there is the key, which sets the date to the epoch
1436
1349
  d.setUTCMilliseconds(instant.toEpochMilli());
1437
1350
  return d;
1438
1351
  }
1439
- static dateToLocalDate(date) {
1440
- return LocalDate.of(date.getFullYear(), date.getMonth() + 1, date.getDate());
1441
- }
1442
1352
  static localDateToDate(localDate, zone = ZoneId.systemDefault()) {
1443
1353
  return new Date(localDate.year(), localDate.monthValue() - 1, localDate.dayOfMonth(), 0, 0, 0, 0);
1444
1354
  }
@@ -1502,16 +1412,17 @@ class Interval {
1502
1412
  }
1503
1413
  /**
1504
1414
  * Creates a Interval from a Date by spreading it to the begin and end of its day.
1505
- *
1506
- * @param localDate Date to spread
1415
+ * @param date Date to spread
1507
1416
  */
1508
- static ofDayDate(localDate) {
1509
- const start = TimeUtil.instant(DateUtil.startOfDay(localDate));
1510
- return Interval.ofStartAndOffset(start, Period.ofDays(1));
1417
+ static ofDayDate(date) {
1418
+ const localDate = LocalDate.from(nativeJs(date));
1419
+ return Interval.ofDay(localDate, ZoneId.systemDefault());
1511
1420
  }
1512
1421
  static ofDay(day, zoneId) {
1513
- const todayStart = day.atStartOfDay(zoneId).toInstant();
1514
- return Interval.ofStartAndOffset(todayStart, Period.ofDays(1));
1422
+ return Interval.betweenDays(day, day.plusDays(1), zoneId);
1423
+ }
1424
+ static betweenDays(startDayInclusive, endDayExclusive, zoneId) {
1425
+ return Interval.of(startDayInclusive.atStartOfDay(zoneId).toInstant(), endDayExclusive.atStartOfDay(zoneId).toInstant());
1515
1426
  }
1516
1427
  /**
1517
1428
  * Creates a new interval with the given start time point
@@ -2091,6 +2002,99 @@ class BytesPerSecondFormat {
2091
2002
  }
2092
2003
  }
2093
2004
 
2005
+ class DateUtil {
2006
+ /***************************************************************************
2007
+ * *
2008
+ * Public API *
2009
+ * *
2010
+ **************************************************************************/
2011
+ static instantToDate(instant) {
2012
+ return new Date(instant.toEpochMilli());
2013
+ }
2014
+ /**
2015
+ * Returns the given Date as ISO formatted local date string.
2016
+ *
2017
+ * YYYY-MM-DD
2018
+ *
2019
+ * @param date
2020
+ */
2021
+ static toLocalDateIso(date) {
2022
+ return DateUtil.dateString(date);
2023
+ }
2024
+ /**
2025
+ * Returns the given Date as ISO formatted local date-time string.
2026
+ *
2027
+ * YYYY-MM-DDTHH:mm:ss.sss
2028
+ *
2029
+ * @param date
2030
+ */
2031
+ static toLocalDateTimeIso(date) {
2032
+ const dateString = DateUtil.toLocalDateIso(date);
2033
+ const timeString = DateUtil.timeString(date);
2034
+ return dateString + DateUtil.DateTimeSeparator + timeString;
2035
+ }
2036
+ /**
2037
+ * Checks if the given DateTime is represents the start of the day.
2038
+ *
2039
+ * @param dateTime DateTime to check
2040
+ */
2041
+ static isStartOfDay(date) {
2042
+ date = new Date(date);
2043
+ return date.getMilliseconds() === 0
2044
+ && date.getSeconds() === 0
2045
+ && date.getMinutes() === 0
2046
+ && date.getHours() === 0;
2047
+ }
2048
+ /**
2049
+ * Sets the given Date to the start of its day by setting its time to 0.
2050
+ *
2051
+ * @param localDate Date to set to start of day
2052
+ */
2053
+ static startOfDay(localDate) {
2054
+ const startOfDay = new Date(localDate);
2055
+ startOfDay.setHours(0, 0, 0, 0);
2056
+ return startOfDay;
2057
+ }
2058
+ static plusDays(date, days) {
2059
+ const plus = new Date(date);
2060
+ plus.setDate(plus.getDate() + days);
2061
+ return plus;
2062
+ }
2063
+ /***************************************************************************
2064
+ * *
2065
+ * private Methods *
2066
+ * *
2067
+ **************************************************************************/
2068
+ static dateString(date) {
2069
+ const values = [
2070
+ String(date.getFullYear()),
2071
+ DateUtil.format(date.getMonth() + 1),
2072
+ DateUtil.format(date.getDate())
2073
+ ];
2074
+ return values.join(DateUtil.IsoDateDelimiter);
2075
+ }
2076
+ static timeString(date) {
2077
+ const values = [
2078
+ DateUtil.format(date.getHours()),
2079
+ DateUtil.format(date.getMinutes()),
2080
+ DateUtil.format(date.getSeconds())
2081
+ ];
2082
+ return values.join(DateUtil.IsoTimeDelimiter) +
2083
+ '.' +
2084
+ DateUtil.format(date.getMilliseconds(), 3);
2085
+ }
2086
+ static format(value, digitCount = 2) {
2087
+ let zeros = '';
2088
+ for (let i = 0; i < digitCount; i++) {
2089
+ zeros += '0';
2090
+ }
2091
+ return (zeros + value).slice(-digitCount);
2092
+ }
2093
+ }
2094
+ DateUtil.IsoDateDelimiter = '-';
2095
+ DateUtil.IsoTimeDelimiter = ':';
2096
+ DateUtil.DateTimeSeparator = 'T';
2097
+
2094
2098
  /**
2095
2099
  * Provides common used object utils
2096
2100
  */