1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- "use strict";
- Object.defineProperty(exports, "__esModule", {
- value: true
- });
- exports.default = nextDay;
- var _index = _interopRequireDefault(require("../_lib/requiredArgs/index.js"));
- var _index2 = _interopRequireDefault(require("../getDay/index.js"));
- var _index3 = _interopRequireDefault(require("../addDays/index.js"));
- var _index4 = _interopRequireDefault(require("../toDate/index.js"));
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
- var baseMap = [7, 6, 5, 4, 3, 2, 1];
- /**
- * @name nextDay
- * @category Weekday Helpers
- * @summary When is the next day of the week?
- *
- * @description
- * When is the next day of the week? 0-6 the day of the week, 0 represents Sunday.
- *
- * @param {Date | number} date - the date to check
- * @param {Day} day - day of the week
- * @returns {Date} - the date is the next day of week
- * @throws {TypeError} - 2 arguments required
- *
- * @example
- * // When is the next Monday after Mar, 20, 2020?
- * const result = nextDay(new Date(2020, 2, 20), 1)
- * //=> Mon Mar 23 2020 00:00:00
- *
- * @example
- * // When is the next Tuesday after Mar, 21, 2020?
- * const result = nextDay(new Date(2020, 2, 21), 2)
- * //=> Tue Mar 24 2020 00:00:00
- */
- function nextDay(date, day) {
- (0, _index.default)(2, arguments);
- var map = genMap(day);
- return (0, _index3.default)((0, _index4.default)(date), map[(0, _index2.default)((0, _index4.default)(date))]);
- }
- function genMap(daysToMove) {
- if (daysToMove === 0) {
- return baseMap;
- } else {
- var mapStart = baseMap.slice(-daysToMove);
- var mapEnd = baseMap.slice(0, baseMap.length - daysToMove);
- return mapStart.concat(mapEnd);
- }
- }
- module.exports = exports.default;
|