willba-component-library 0.2.30 → 0.2.31
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/components/FilterCalendar/hooks/useFilterCalendar.d.ts +3 -2
- package/lib/core/components/calendar/CalendarTypes.d.ts +3 -2
- package/lib/index.d.ts +3 -2
- package/lib/index.esm.js +14 -14
- package/lib/index.esm.js.map +1 -1
- package/lib/index.js +14 -14
- package/lib/index.js.map +1 -1
- package/lib/index.umd.js +14 -14
- package/lib/index.umd.js.map +1 -1
- package/package.json +1 -1
- package/src/components/FilterCalendar/FilterCalendar.tsx +8 -4
- package/src/components/FilterCalendar/hooks/useFilterCalendar.ts +8 -4
- package/src/core/components/calendar/Calendar.tsx +8 -8
- package/src/core/components/calendar/CalendarTypes.ts +4 -2
package/package.json
CHANGED
|
@@ -42,8 +42,9 @@ export default function FilterCalendar({
|
|
|
42
42
|
calendarRange,
|
|
43
43
|
disabledDates,
|
|
44
44
|
setDisabledDates,
|
|
45
|
-
|
|
46
|
-
|
|
45
|
+
updateCalendarMonthNavigation,
|
|
46
|
+
updateCalendarDefaultMoth,
|
|
47
|
+
setUpdateCalendarMonthNavigation,
|
|
47
48
|
initialCalendarRange,
|
|
48
49
|
} = useFilterCalendar({
|
|
49
50
|
onSubmit,
|
|
@@ -81,8 +82,11 @@ export default function FilterCalendar({
|
|
|
81
82
|
requestDates={requestDates}
|
|
82
83
|
disabledDates={disabledDates}
|
|
83
84
|
setDisabledDates={setDisabledDates}
|
|
84
|
-
|
|
85
|
-
|
|
85
|
+
updateCalendarMonthNavigation={updateCalendarMonthNavigation}
|
|
86
|
+
setUpdateCalendarMonthNavigation={
|
|
87
|
+
setUpdateCalendarMonthNavigation
|
|
88
|
+
}
|
|
89
|
+
updateCalendarDefaultMoth={updateCalendarDefaultMoth}
|
|
86
90
|
loadingData={loadingData}
|
|
87
91
|
initialCalendarRange={initialCalendarRange}
|
|
88
92
|
showFeedback={showFeedback}
|
|
@@ -19,7 +19,10 @@ export const useFilterCalendar = ({
|
|
|
19
19
|
DateRange | undefined
|
|
20
20
|
>()
|
|
21
21
|
const [disabledDates, setDisabledDates] = useState<Matcher[]>([])
|
|
22
|
-
const [
|
|
22
|
+
const [updateCalendarMonthNavigation, setUpdateCalendarMonthNavigation] =
|
|
23
|
+
useState<boolean>(false)
|
|
24
|
+
const [updateCalendarDefaultMoth, setUpdateCalendarDefaultMoth] =
|
|
25
|
+
useState<number>(0)
|
|
23
26
|
|
|
24
27
|
useEffect(() => {
|
|
25
28
|
if (typeof window === 'undefined') return
|
|
@@ -31,8 +34,8 @@ export const useFilterCalendar = ({
|
|
|
31
34
|
|
|
32
35
|
if (startDateParam && endDateParam) {
|
|
33
36
|
if (noActiveSelection) {
|
|
34
|
-
console.log(startDateParam, endDateParam)
|
|
35
37
|
setCalendarRange(undefined)
|
|
38
|
+
setUpdateCalendarDefaultMoth((prev) => prev + 1)
|
|
36
39
|
setInitialCalendarRange({
|
|
37
40
|
from: new Date(startDateParam),
|
|
38
41
|
to: new Date(endDateParam),
|
|
@@ -61,10 +64,11 @@ export const useFilterCalendar = ({
|
|
|
61
64
|
handleClearDates,
|
|
62
65
|
setCalendarRange,
|
|
63
66
|
setDisabledDates,
|
|
64
|
-
|
|
67
|
+
setUpdateCalendarMonthNavigation,
|
|
65
68
|
calendarRange,
|
|
66
69
|
disabledDates,
|
|
67
|
-
|
|
70
|
+
updateCalendarMonthNavigation,
|
|
71
|
+
updateCalendarDefaultMoth,
|
|
68
72
|
initialCalendarRange,
|
|
69
73
|
}
|
|
70
74
|
}
|
|
@@ -22,8 +22,9 @@ export const Calendar = forwardRef<HTMLDivElement, CalendarTypes>(
|
|
|
22
22
|
requestDates,
|
|
23
23
|
disabledDates,
|
|
24
24
|
setDisabledDates,
|
|
25
|
-
|
|
26
|
-
|
|
25
|
+
updateCalendarMonthNavigation,
|
|
26
|
+
setUpdateCalendarMonthNavigation,
|
|
27
|
+
updateCalendarDefaultMoth,
|
|
27
28
|
loadingData,
|
|
28
29
|
initialCalendarRange,
|
|
29
30
|
showFeedback,
|
|
@@ -171,12 +172,13 @@ export const Calendar = forwardRef<HTMLDivElement, CalendarTypes>(
|
|
|
171
172
|
tooltipClonesCheckOut.forEach((clone) => clone.remove())
|
|
172
173
|
tooltipClonesOverlappingDates.forEach((clone) => clone.remove())
|
|
173
174
|
}
|
|
174
|
-
}, [calendarRange,
|
|
175
|
+
}, [calendarRange, updateCalendarMonthNavigation, overlappingDate])
|
|
175
176
|
|
|
176
177
|
return (
|
|
177
178
|
<div className="will-filter-bar-calendar" ref={ref}>
|
|
178
179
|
<div className="will-calendar-filter-container">
|
|
179
180
|
<DayPicker
|
|
181
|
+
key={updateCalendarDefaultMoth}
|
|
180
182
|
id="will-calendar"
|
|
181
183
|
mode="range"
|
|
182
184
|
locale={language === 'en' ? enUS : fi}
|
|
@@ -210,8 +212,9 @@ export const Calendar = forwardRef<HTMLDivElement, CalendarTypes>(
|
|
|
210
212
|
}
|
|
211
213
|
fromMonth={today}
|
|
212
214
|
onMonthChange={(val) => {
|
|
213
|
-
requestDates &&
|
|
214
|
-
? (requestDates(val),
|
|
215
|
+
requestDates && setUpdateCalendarMonthNavigation
|
|
216
|
+
? (requestDates(val),
|
|
217
|
+
setUpdateCalendarMonthNavigation((prev) => !prev))
|
|
215
218
|
: null
|
|
216
219
|
}}
|
|
217
220
|
modifiersClassNames={{
|
|
@@ -303,9 +306,6 @@ const handleSelectedCheckIn = ({
|
|
|
303
306
|
const calendarFrom = calendarRange?.from
|
|
304
307
|
? format(calendarRange?.from, dateFormat)
|
|
305
308
|
: null
|
|
306
|
-
const calendarTo = calendarRange?.to
|
|
307
|
-
? format(calendarRange?.to, dateFormat)
|
|
308
|
-
: null
|
|
309
309
|
|
|
310
310
|
const overlappingDateFrom = overlappingDate?.from
|
|
311
311
|
? format(overlappingDate.from, dateFormat)
|
|
@@ -28,11 +28,13 @@ export type CalendarTypes = {
|
|
|
28
28
|
requestDates?: (val: Date) => void
|
|
29
29
|
disabledDates?: Matcher[]
|
|
30
30
|
setDisabledDates?: (arg: Matcher[]) => void
|
|
31
|
-
updateCalendar?: boolean
|
|
32
|
-
setUpdateCalendar?: (arg: (prev: boolean) => boolean) => void
|
|
33
31
|
loadingData?: boolean
|
|
34
32
|
initialCalendarRange?: DateRange | undefined
|
|
35
33
|
showFeedback?: boolean
|
|
36
34
|
noActiveSelection?: boolean
|
|
37
35
|
palette?: Palette
|
|
36
|
+
|
|
37
|
+
updateCalendarMonthNavigation?: boolean
|
|
38
|
+
setUpdateCalendarMonthNavigation?: (arg: (prev: boolean) => boolean) => void
|
|
39
|
+
updateCalendarDefaultMoth?: number
|
|
38
40
|
}
|