index.js 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. "use strict";
  2. var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
  3. Object.defineProperty(exports, "__esModule", {
  4. value: true
  5. });
  6. exports.default = getOverlappingDaysInIntervals;
  7. var _index = _interopRequireDefault(require("../toDate/index.js"));
  8. var _index2 = _interopRequireDefault(require("../_lib/requiredArgs/index.js"));
  9. var MILLISECONDS_IN_DAY = 24 * 60 * 60 * 1000;
  10. /**
  11. * @name getOverlappingDaysInIntervals
  12. * @category Interval Helpers
  13. * @summary Get the number of days that overlap in two time intervals
  14. *
  15. * @description
  16. * Get the number of days that overlap in two time intervals
  17. *
  18. * @param {Interval} intervalLeft - the first interval to compare. See [Interval]{@link docs/Interval}
  19. * @param {Interval} intervalRight - the second interval to compare. See [Interval]{@link docs/Interval}
  20. * @returns {Number} the number of days that overlap in two time intervals
  21. * @throws {TypeError} 2 arguments required
  22. * @throws {RangeError} The start of an interval cannot be after its end
  23. * @throws {RangeError} Date in interval cannot be `Invalid Date`
  24. *
  25. * @example
  26. * // For overlapping time intervals adds 1 for each started overlapping day:
  27. * getOverlappingDaysInIntervals(
  28. * { start: new Date(2014, 0, 10), end: new Date(2014, 0, 20) },
  29. * { start: new Date(2014, 0, 17), end: new Date(2014, 0, 21) }
  30. * )
  31. * //=> 3
  32. *
  33. * @example
  34. * // For non-overlapping time intervals returns 0:
  35. * getOverlappingDaysInIntervals(
  36. * { start: new Date(2014, 0, 10), end: new Date(2014, 0, 20) },
  37. * { start: new Date(2014, 0, 21), end: new Date(2014, 0, 22) }
  38. * )
  39. * //=> 0
  40. */
  41. function getOverlappingDaysInIntervals(dirtyIntervalLeft, dirtyIntervalRight) {
  42. (0, _index2.default)(2, arguments);
  43. var intervalLeft = dirtyIntervalLeft || {};
  44. var intervalRight = dirtyIntervalRight || {};
  45. var leftStartTime = (0, _index.default)(intervalLeft.start).getTime();
  46. var leftEndTime = (0, _index.default)(intervalLeft.end).getTime();
  47. var rightStartTime = (0, _index.default)(intervalRight.start).getTime();
  48. var rightEndTime = (0, _index.default)(intervalRight.end).getTime();
  49. // Throw an exception if start date is after end date or if any date is `Invalid Date`
  50. if (!(leftStartTime <= leftEndTime && rightStartTime <= rightEndTime)) {
  51. throw new RangeError('Invalid interval');
  52. }
  53. var isOverlapping = leftStartTime < rightEndTime && rightStartTime < leftEndTime;
  54. if (!isOverlapping) {
  55. return 0;
  56. }
  57. var overlapStartDate = rightStartTime < leftStartTime ? leftStartTime : rightStartTime;
  58. var overlapEndDate = rightEndTime > leftEndTime ? leftEndTime : rightEndTime;
  59. var differenceInMs = overlapEndDate - overlapStartDate;
  60. return Math.ceil(differenceInMs / MILLISECONDS_IN_DAY);
  61. }
  62. module.exports = exports.default;