willba-component-library 0.2.61 → 0.2.63

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.
package/lib/index.js CHANGED
@@ -11091,7 +11091,8 @@ var calendarSelectionRules = function (_a) {
11091
11091
  rangeContext &&
11092
11092
  rangeTo &&
11093
11093
  (checkOutRange === null || checkOutRange === void 0 ? void 0 : checkOutRange.lastCheckOut) &&
11094
- isAfter(rangeTo, endOfDay(checkOutRange.lastCheckOut))) {
11094
+ isAfter(rangeTo, endOfDay(checkOutRange.lastCheckOut)) &&
11095
+ isAfter(rangeTo, endOfDay(rangeContext.to))) {
11095
11096
  setCalendarHasError && setCalendarHasError(true);
11096
11097
  return setCalendarRange(undefined);
11097
11098
  }
@@ -11327,12 +11328,14 @@ var checkForContinuousSelection = function (_a) {
11327
11328
  ? isAfter(endOfDay(calendarRangeTo), endOfDay(rangeContextFrom)) ||
11328
11329
  isEqual(endOfDay(calendarRangeTo), endOfDay(rangeContextFrom))
11329
11330
  : null;
11330
- if ((rangeContext &&
11331
- calendarRangeFrom &&
11332
- !startIsEqualOrBeforeRangeContextEnd) ||
11333
- (rangeContext && calendarRangeTo && !endIsEqualOrAfterRangeContextStart)) {
11334
- setCalendarHasError && !calendarHasError && setCalendarHasError(true);
11335
- }
11331
+ React__default.useEffect(function () {
11332
+ if ((rangeContext &&
11333
+ calendarRangeFrom &&
11334
+ !startIsEqualOrBeforeRangeContextEnd) ||
11335
+ (rangeContext && calendarRangeTo && !endIsEqualOrAfterRangeContextStart)) {
11336
+ setCalendarHasError && !calendarHasError && setCalendarHasError(true);
11337
+ }
11338
+ });
11336
11339
  };
11337
11340
 
11338
11341
  var useCalendarTooltips = function (_a) {
@@ -11480,7 +11483,7 @@ var css_248z$8 = ".will-calendar-filter-container {\n display: flex;\n justify
11480
11483
  styleInject(css_248z$8);
11481
11484
 
11482
11485
  var Calendar = React__default.forwardRef(function (_a, ref) {
11483
- var _b, _c;
11486
+ var _b, _c, _d;
11484
11487
  var selectedPath = _a.selectedPath, calendarRange = _a.calendarRange, setCalendarRange = _a.setCalendarRange, language = _a.language, disableCalendarDates = _a.disableCalendarDates, requestDates = _a.requestDates, disabledDates = _a.disabledDates, setDisabledDates = _a.setDisabledDates, updateCalendarMonthNavigation = _a.updateCalendarMonthNavigation, setUpdateCalendarMonthNavigation = _a.setUpdateCalendarMonthNavigation, updateCalendarDefaultMonth = _a.updateCalendarDefaultMonth, loadingData = _a.loadingData, showFeedback = _a.showFeedback, palette = _a.palette, setCalendarHasError = _a.setCalendarHasError, setUpdatedForSubmit = _a.setUpdatedForSubmit, rangeContext = _a.rangeContext, calendarHasError = _a.calendarHasError;
11485
11488
  // Translations
11486
11489
  var t = useTranslation('common').t;
@@ -11489,12 +11492,12 @@ var Calendar = React__default.forwardRef(function (_a, ref) {
11489
11492
  var selectedStartDate = calendarRange === null || calendarRange === void 0 ? void 0 : calendarRange.from;
11490
11493
  var rangeContextStartDate = rangeContext === null || rangeContext === void 0 ? void 0 : rangeContext.from;
11491
11494
  // Handle overlapping availableDates.lastCheckOut and disabledDates.start
11492
- var _d = useUpdateDisabledDates({
11495
+ var _e = useUpdateDisabledDates({
11493
11496
  disableCalendarDates: disableCalendarDates,
11494
11497
  calendarRange: calendarRange,
11495
11498
  updateCalendarMonthNavigation: updateCalendarMonthNavigation,
11496
11499
  updateCalendarDefaultMonth: updateCalendarDefaultMonth,
11497
- }), newDisableCalendarDates = _d.newDisableCalendarDates, overlappingDate = _d.overlappingDate;
11500
+ }), newDisableCalendarDates = _e.newDisableCalendarDates, overlappingDate = _e.overlappingDate;
11498
11501
  // Handle disable dates by page
11499
11502
  var disabledDatesByPage$1 = disabledDatesByPage({
11500
11503
  today: today,
@@ -11525,11 +11528,11 @@ var Calendar = React__default.forwardRef(function (_a, ref) {
11525
11528
  setUpdatedForSubmit && setUpdatedForSubmit(true);
11526
11529
  };
11527
11530
  // Handle disabled dates for range context
11528
- var _e = handleRangeContextDisabledDates({
11531
+ var _f = handleRangeContextDisabledDates({
11529
11532
  rangeContext: rangeContext,
11530
11533
  availableDates: newDisableCalendarDates === null || newDisableCalendarDates === void 0 ? void 0 : newDisableCalendarDates.availableDates,
11531
11534
  calendarRange: calendarRange,
11532
- }), findFirstPossibleRangeContextCheckIn = _e.findFirstPossibleRangeContextCheckIn, findLastPossibleRangeContextCheckOut = _e.findLastPossibleRangeContextCheckOut, firstPossibleRangeContextCheckIn = _e.firstPossibleRangeContextCheckIn, lastPossibleRangeContextCheckOut = _e.lastPossibleRangeContextCheckOut, currentSelectionLastCheckoutDate = _e.currentSelectionLastCheckoutDate;
11535
+ }), findFirstPossibleRangeContextCheckIn = _f.findFirstPossibleRangeContextCheckIn, findLastPossibleRangeContextCheckOut = _f.findLastPossibleRangeContextCheckOut, firstPossibleRangeContextCheckIn = _f.firstPossibleRangeContextCheckIn, lastPossibleRangeContextCheckOut = _f.lastPossibleRangeContextCheckOut, currentSelectionLastCheckoutDate = _f.currentSelectionLastCheckoutDate;
11533
11536
  // Handle check for continuous selection in the range context
11534
11537
  checkForContinuousSelection({
11535
11538
  setCalendarHasError: setCalendarHasError,
@@ -11537,18 +11540,26 @@ var Calendar = React__default.forwardRef(function (_a, ref) {
11537
11540
  calendarRange: calendarRange,
11538
11541
  calendarHasError: calendarHasError,
11539
11542
  });
11543
+ // Find last possible checkout for dates
11544
+ var lastPossibleCheckout = !!((_b = newDisableCalendarDates === null || newDisableCalendarDates === void 0 ? void 0 : newDisableCalendarDates.availableDates) === null || _b === void 0 ? void 0 : _b.length)
11545
+ ? newDisableCalendarDates === null || newDisableCalendarDates === void 0 ? void 0 : newDisableCalendarDates.availableDates[newDisableCalendarDates.availableDates.length - 1].lastCheckOut
11546
+ : null;
11540
11547
  return (React__default.createElement("div", { className: "will-filter-bar-calendar", ref: ref },
11541
11548
  React__default.createElement("div", { className: "will-calendar-filter-container" },
11542
11549
  React__default.createElement(DayPicker, { key: updateCalendarDefaultMonth, id: "will-calendar", mode: "range", locale: language === 'en' ? enUS : fi, numberOfMonths: !isTablet ? 2 : 1, weekStartsOn: 1, selected: calendarRange, onSelect: function (range) { return handleOnSelect(range); }, captionLayout: "dropdown-buttons", defaultMonth: (calendarRange === null || calendarRange === void 0 ? void 0 : calendarRange.from) ||
11543
11550
  selectedStartDate ||
11544
11551
  rangeContextStartDate ||
11545
- (((_b = newDisableCalendarDates === null || newDisableCalendarDates === void 0 ? void 0 : newDisableCalendarDates.disabledDates) === null || _b === void 0 ? void 0 : _b.length)
11552
+ (((_c = newDisableCalendarDates === null || newDisableCalendarDates === void 0 ? void 0 : newDisableCalendarDates.disabledDates) === null || _c === void 0 ? void 0 : _c.length)
11546
11553
  ? newDisableCalendarDates.disabledDates[0].from
11547
11554
  : today), disabled: disabledDatesByPage$1.length
11548
11555
  ? disabledDatesByPage$1
11549
11556
  : (disabledDates === null || disabledDates === void 0 ? void 0 : disabledDates.length)
11550
- ? __spreadArray$1(__spreadArray$1(__spreadArray$1([], __read(disabledDates), false), __read(firstPossibleRangeContextCheckIn), false), __read(lastPossibleRangeContextCheckOut), false) : ((_c = newDisableCalendarDates === null || newDisableCalendarDates === void 0 ? void 0 : newDisableCalendarDates.disabledDates) === null || _c === void 0 ? void 0 : _c.length)
11551
- ? __spreadArray$1(__spreadArray$1(__spreadArray$1([], __read(newDisableCalendarDates.disabledDates), false), __read(firstPossibleRangeContextCheckIn), false), __read(lastPossibleRangeContextCheckOut), false) : [], fromMonth: today, onMonthChange: function (val) {
11557
+ ? __spreadArray$1(__spreadArray$1(__spreadArray$1([
11558
+ lastPossibleCheckout ? { after: lastPossibleCheckout } : []
11559
+ ], __read(disabledDates), false), __read(firstPossibleRangeContextCheckIn), false), __read(lastPossibleRangeContextCheckOut), false) : ((_d = newDisableCalendarDates === null || newDisableCalendarDates === void 0 ? void 0 : newDisableCalendarDates.disabledDates) === null || _d === void 0 ? void 0 : _d.length)
11560
+ ? __spreadArray$1(__spreadArray$1(__spreadArray$1([
11561
+ lastPossibleCheckout ? { after: lastPossibleCheckout } : []
11562
+ ], __read(newDisableCalendarDates.disabledDates), false), __read(firstPossibleRangeContextCheckIn), false), __read(lastPossibleRangeContextCheckOut), false) : [], fromMonth: today, onMonthChange: function (val) {
11552
11563
  requestDates && setUpdateCalendarMonthNavigation
11553
11564
  ? (requestDates(val),
11554
11565
  setUpdateCalendarMonthNavigation(function (prev) { return !prev; }))