differenceInBusinessDays.cjs 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990
  1. "use strict";
  2. exports.differenceInBusinessDays = differenceInBusinessDays;
  3. var _index = require("./_lib/normalizeDates.cjs");
  4. var _index2 = require("./addDays.cjs");
  5. var _index3 = require("./differenceInCalendarDays.cjs");
  6. var _index4 = require("./isSameDay.cjs");
  7. var _index5 = require("./isValid.cjs");
  8. var _index6 = require("./isWeekend.cjs");
  9. /**
  10. * The {@link differenceInBusinessDays} function options.
  11. */
  12. /**
  13. * @name differenceInBusinessDays
  14. * @category Day Helpers
  15. * @summary Get the number of business days between the given dates.
  16. *
  17. * @description
  18. * Get the number of business day periods between the given dates.
  19. * Business days being days that aren't in the weekend.
  20. * Like `differenceInCalendarDays`, the function removes the times from
  21. * the dates before calculating the difference.
  22. *
  23. * @param laterDate - The later date
  24. * @param earlierDate - The earlier date
  25. * @param options - An object with options
  26. *
  27. * @returns The number of business days
  28. *
  29. * @example
  30. * // How many business days are between
  31. * // 10 January 2014 and 20 July 2014?
  32. * const result = differenceInBusinessDays(
  33. * new Date(2014, 6, 20),
  34. * new Date(2014, 0, 10)
  35. * )
  36. * //=> 136
  37. *
  38. * // How many business days are between
  39. * // 30 November 2021 and 1 November 2021?
  40. * const result = differenceInBusinessDays(
  41. * new Date(2021, 10, 30),
  42. * new Date(2021, 10, 1)
  43. * )
  44. * //=> 21
  45. *
  46. * // How many business days are between
  47. * // 1 November 2021 and 1 December 2021?
  48. * const result = differenceInBusinessDays(
  49. * new Date(2021, 10, 1),
  50. * new Date(2021, 11, 1)
  51. * )
  52. * //=> -22
  53. *
  54. * // How many business days are between
  55. * // 1 November 2021 and 1 November 2021 ?
  56. * const result = differenceInBusinessDays(
  57. * new Date(2021, 10, 1),
  58. * new Date(2021, 10, 1)
  59. * )
  60. * //=> 0
  61. */
  62. function differenceInBusinessDays(laterDate, earlierDate, options) {
  63. const [laterDate_, earlierDate_] = (0, _index.normalizeDates)(
  64. options?.in,
  65. laterDate,
  66. earlierDate,
  67. );
  68. if (!(0, _index5.isValid)(laterDate_) || !(0, _index5.isValid)(earlierDate_))
  69. return NaN;
  70. const diff = (0, _index3.differenceInCalendarDays)(laterDate_, earlierDate_);
  71. const sign = diff < 0 ? -1 : 1;
  72. const weeks = Math.trunc(diff / 7);
  73. let result = weeks * 5;
  74. let movingDate = (0, _index2.addDays)(earlierDate_, weeks * 7);
  75. // the loop below will run at most 6 times to account for the remaining days that don't makeup a full week
  76. while (!(0, _index4.isSameDay)(laterDate_, movingDate)) {
  77. // sign is used to account for both negative and positive differences
  78. result += (0, _index6.isWeekend)(movingDate, options) ? 0 : sign;
  79. movingDate = (0, _index2.addDays)(movingDate, sign);
  80. }
  81. // Prevent negative zero
  82. return result === 0 ? 0 : result;
  83. }