willba-component-library 0.2.30 → 0.2.32
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 +19 -14
- package/lib/index.esm.js.map +1 -1
- package/lib/index.js +19 -14
- package/lib/index.js.map +1 -1
- package/lib/index.umd.js +19 -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 +13 -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,18 @@ export const Calendar = forwardRef<HTMLDivElement, CalendarTypes>(
|
|
|
171
172
|
tooltipClonesCheckOut.forEach((clone) => clone.remove())
|
|
172
173
|
tooltipClonesOverlappingDates.forEach((clone) => clone.remove())
|
|
173
174
|
}
|
|
174
|
-
}, [
|
|
175
|
+
}, [
|
|
176
|
+
calendarRange,
|
|
177
|
+
updateCalendarMonthNavigation,
|
|
178
|
+
overlappingDate,
|
|
179
|
+
initialCalendarRange,
|
|
180
|
+
])
|
|
175
181
|
|
|
176
182
|
return (
|
|
177
183
|
<div className="will-filter-bar-calendar" ref={ref}>
|
|
178
184
|
<div className="will-calendar-filter-container">
|
|
179
185
|
<DayPicker
|
|
186
|
+
key={updateCalendarDefaultMoth}
|
|
180
187
|
id="will-calendar"
|
|
181
188
|
mode="range"
|
|
182
189
|
locale={language === 'en' ? enUS : fi}
|
|
@@ -210,8 +217,9 @@ export const Calendar = forwardRef<HTMLDivElement, CalendarTypes>(
|
|
|
210
217
|
}
|
|
211
218
|
fromMonth={today}
|
|
212
219
|
onMonthChange={(val) => {
|
|
213
|
-
requestDates &&
|
|
214
|
-
? (requestDates(val),
|
|
220
|
+
requestDates && setUpdateCalendarMonthNavigation
|
|
221
|
+
? (requestDates(val),
|
|
222
|
+
setUpdateCalendarMonthNavigation((prev) => !prev))
|
|
215
223
|
: null
|
|
216
224
|
}}
|
|
217
225
|
modifiersClassNames={{
|
|
@@ -303,9 +311,6 @@ const handleSelectedCheckIn = ({
|
|
|
303
311
|
const calendarFrom = calendarRange?.from
|
|
304
312
|
? format(calendarRange?.from, dateFormat)
|
|
305
313
|
: null
|
|
306
|
-
const calendarTo = calendarRange?.to
|
|
307
|
-
? format(calendarRange?.to, dateFormat)
|
|
308
|
-
: null
|
|
309
314
|
|
|
310
315
|
const overlappingDateFrom = overlappingDate?.from
|
|
311
316
|
? 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
|
}
|