react-native-ll-calendar 0.9.0 → 0.10.0
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/README.md +48 -38
- package/lib/module/calendar/month-calendar/MonthCalendar.js +31 -3
- package/lib/module/calendar/month-calendar/MonthCalendar.js.map +1 -1
- package/lib/module/calendar/month-calendar/view/MonthCalendarViewItem.js +27 -4
- package/lib/module/calendar/month-calendar/view/MonthCalendarViewItem.js.map +1 -1
- package/lib/module/calendar/month-calendar/view/MonthCalendarWeekRow.js +1 -0
- package/lib/module/calendar/month-calendar/view/MonthCalendarWeekRow.js.map +1 -1
- package/lib/typescript/src/calendar/month-calendar/MonthCalendar.d.ts +9 -3
- package/lib/typescript/src/calendar/month-calendar/MonthCalendar.d.ts.map +1 -1
- package/lib/typescript/src/calendar/month-calendar/view/MonthCalendarViewItem.d.ts +16 -3
- package/lib/typescript/src/calendar/month-calendar/view/MonthCalendarViewItem.d.ts.map +1 -1
- package/lib/typescript/src/calendar/month-calendar/view/MonthCalendarWeekRow.d.ts +2 -0
- package/lib/typescript/src/calendar/month-calendar/view/MonthCalendarWeekRow.d.ts.map +1 -1
- package/lib/typescript/src/index.d.ts +1 -0
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/package.json +2 -2
- package/src/calendar/month-calendar/MonthCalendar.tsx +144 -93
- package/src/calendar/month-calendar/view/MonthCalendarViewItem.tsx +52 -4
- package/src/calendar/month-calendar/view/MonthCalendarWeekRow.tsx +7 -2
- package/src/index.tsx +1 -0
package/README.md
CHANGED
|
@@ -19,7 +19,10 @@ yarn add react-native-ll-calendar
|
|
|
19
19
|
## Usage
|
|
20
20
|
|
|
21
21
|
```tsx
|
|
22
|
-
import {
|
|
22
|
+
import { useState, useRef } from 'react';
|
|
23
|
+
import { View, Button } from 'react-native';
|
|
24
|
+
import dayjs from 'dayjs';
|
|
25
|
+
import { MonthCalendar, CalendarEvent, MonthCalendarRef } from 'react-native-ll-calendar';
|
|
23
26
|
|
|
24
27
|
const events: CalendarEvent[] = [
|
|
25
28
|
{
|
|
@@ -31,51 +34,47 @@ const events: CalendarEvent[] = [
|
|
|
31
34
|
borderColor: '#e55353',
|
|
32
35
|
color: '#0e0e0e',
|
|
33
36
|
},
|
|
34
|
-
|
|
35
|
-
id: '2',
|
|
36
|
-
title: 'Conference',
|
|
37
|
-
start: new Date(2025, 9, 10),
|
|
38
|
-
end: new Date(2025, 9, 12),
|
|
39
|
-
backgroundColor: '#4ecdc4',
|
|
40
|
-
borderColor: '#45b7aa',
|
|
41
|
-
color: '#0e0e0e',
|
|
42
|
-
borderStyle: 'dashed',
|
|
43
|
-
borderWidth: 2,
|
|
44
|
-
borderRadius: 8,
|
|
45
|
-
},
|
|
37
|
+
// ... more events
|
|
46
38
|
];
|
|
47
39
|
|
|
48
40
|
function App() {
|
|
49
41
|
const [date, setDate] = useState(new Date());
|
|
50
|
-
const
|
|
42
|
+
const calendarRef = useRef<MonthCalendarRef>(null);
|
|
43
|
+
|
|
44
|
+
const handleScrollToTop = () => {
|
|
45
|
+
// Scroll to the top of the current month view
|
|
46
|
+
calendarRef.current?.scrollMonthViewToOffset(
|
|
47
|
+
dayjs(date).format('YYYY-MM'),
|
|
48
|
+
0,
|
|
49
|
+
true
|
|
50
|
+
);
|
|
51
|
+
};
|
|
51
52
|
|
|
52
|
-
const
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
53
|
+
const checkRowHeight = () => {
|
|
54
|
+
// Get the height of the row containing the specific date
|
|
55
|
+
const height = calendarRef.current?.getMonthRowHeight(
|
|
56
|
+
dayjs(date).format('YYYY-MM'),
|
|
57
|
+
new Date()
|
|
58
|
+
);
|
|
59
|
+
console.log('Row height:', height);
|
|
56
60
|
};
|
|
57
61
|
|
|
58
62
|
return (
|
|
59
|
-
<
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
color: date.getDay() === 0 ? '#FF3B30' : '#000000',
|
|
75
|
-
})}
|
|
76
|
-
stickyHeaderEnabled={true}
|
|
77
|
-
cellBorderColor="#CCCCCC"
|
|
78
|
-
/>
|
|
63
|
+
<View style={{ flex: 1 }}>
|
|
64
|
+
<View style={{ flexDirection: 'row', justifyContent: 'space-around', padding: 10 }}>
|
|
65
|
+
<Button title="Scroll Top" onPress={handleScrollToTop} />
|
|
66
|
+
<Button title="Check Height" onPress={checkRowHeight} />
|
|
67
|
+
</View>
|
|
68
|
+
<MonthCalendar
|
|
69
|
+
ref={calendarRef}
|
|
70
|
+
defaultDate={date}
|
|
71
|
+
weekStartsOn={1}
|
|
72
|
+
onChangeDate={(newDate) => setDate(newDate)}
|
|
73
|
+
events={events}
|
|
74
|
+
onPressEvent={(event) => console.log('Event pressed:', event.title)}
|
|
75
|
+
// ... other props
|
|
76
|
+
/>
|
|
77
|
+
</View>
|
|
79
78
|
);
|
|
80
79
|
}
|
|
81
80
|
```
|
|
@@ -114,6 +113,15 @@ function App() {
|
|
|
114
113
|
| `eventEllipsizeMode` | `'head' \| 'middle' \| 'tail' \| 'clip'` | No | `'tail'` | Ellipsize mode for event text |
|
|
115
114
|
| `bottomSpacing` | `number` | No | - | Bottom spacing in pixels for scrollable content |
|
|
116
115
|
|
|
116
|
+
### MonthCalendarRef Methods
|
|
117
|
+
|
|
118
|
+
You can access these methods by passing a `ref` to the `MonthCalendar` component.
|
|
119
|
+
|
|
120
|
+
| Method | Signature | Description |
|
|
121
|
+
| ------ | --------- | ----------- |
|
|
122
|
+
| `scrollMonthViewToOffset` | `(monthKey: string, offset: number, animated?: boolean) => void` | Scrolls the view of the specified month (format: 'YYYY-MM') to a vertical offset. |
|
|
123
|
+
| `getMonthRowHeight` | `(monthKey: string, date: Date) => number \| undefined` | Returns the height of the week row containing the specified date in the specified month. |
|
|
124
|
+
|
|
117
125
|
### CalendarEvent
|
|
118
126
|
|
|
119
127
|
| Property | Type | Required | Description |
|
|
@@ -147,6 +155,8 @@ function App() {
|
|
|
147
155
|
- Font scaling control for text elements
|
|
148
156
|
- Customizable event height and text styles
|
|
149
157
|
- Spans 10 years before and after the default date
|
|
158
|
+
- **Programmatic scroll control via Ref**
|
|
159
|
+
- **Dynamic row height retrieval via Ref**
|
|
150
160
|
|
|
151
161
|
## License
|
|
152
162
|
|
|
@@ -2,12 +2,12 @@
|
|
|
2
2
|
|
|
3
3
|
import { useWindowDimensions, FlatList } from 'react-native';
|
|
4
4
|
import dayjs from 'dayjs';
|
|
5
|
-
import { useState } from 'react';
|
|
5
|
+
import { useState, useRef, useImperativeHandle, forwardRef } from 'react';
|
|
6
6
|
import { MonthCalendarViewItem } from "./view/MonthCalendarViewItem.js";
|
|
7
7
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
8
8
|
const HALF_PANEL_LENGTH = 120; // 10 years
|
|
9
9
|
|
|
10
|
-
export const MonthCalendar = props => {
|
|
10
|
+
export const MonthCalendar = /*#__PURE__*/forwardRef((props, ref) => {
|
|
11
11
|
const [dateState] = useState(props.defaultDate);
|
|
12
12
|
const [_activeIndex, setActiveIndex] = useState(HALF_PANEL_LENGTH);
|
|
13
13
|
const defaultDateDjs = dayjs(dateState);
|
|
@@ -26,6 +26,27 @@ export const MonthCalendar = props => {
|
|
|
26
26
|
const {
|
|
27
27
|
width
|
|
28
28
|
} = useWindowDimensions();
|
|
29
|
+
const monthViewRefs = useRef({});
|
|
30
|
+
useImperativeHandle(ref, () => ({
|
|
31
|
+
scrollMonthViewToOffset: (monthKey, offset, animated = true) => {
|
|
32
|
+
const targetRef = monthViewRefs.current[monthKey];
|
|
33
|
+
if (targetRef) {
|
|
34
|
+
targetRef.scrollTo({
|
|
35
|
+
y: offset,
|
|
36
|
+
animated
|
|
37
|
+
});
|
|
38
|
+
} else {
|
|
39
|
+
console.warn(`Month view for ${monthKey} is not currently rendered.`);
|
|
40
|
+
}
|
|
41
|
+
},
|
|
42
|
+
getMonthRowHeight: (monthKey, date) => {
|
|
43
|
+
const targetRef = monthViewRefs.current[monthKey];
|
|
44
|
+
if (targetRef) {
|
|
45
|
+
return targetRef.getRowHeight(date);
|
|
46
|
+
}
|
|
47
|
+
return undefined;
|
|
48
|
+
}
|
|
49
|
+
}));
|
|
29
50
|
return /*#__PURE__*/_jsx(FlatList, {
|
|
30
51
|
horizontal: true,
|
|
31
52
|
pagingEnabled: true,
|
|
@@ -54,6 +75,13 @@ export const MonthCalendar = props => {
|
|
|
54
75
|
index
|
|
55
76
|
}) => {
|
|
56
77
|
return /*#__PURE__*/_jsx(MonthCalendarViewItem, {
|
|
78
|
+
ref: r => {
|
|
79
|
+
if (r) {
|
|
80
|
+
monthViewRefs.current[item] = r;
|
|
81
|
+
} else {
|
|
82
|
+
delete monthViewRefs.current[item];
|
|
83
|
+
}
|
|
84
|
+
},
|
|
57
85
|
month: item,
|
|
58
86
|
weekStartsOn: props.weekStartsOn ?? 0,
|
|
59
87
|
events: props.events,
|
|
@@ -90,5 +118,5 @@ export const MonthCalendar = props => {
|
|
|
90
118
|
maxToRenderPerBatch: 5,
|
|
91
119
|
removeClippedSubviews: false
|
|
92
120
|
});
|
|
93
|
-
};
|
|
121
|
+
});
|
|
94
122
|
//# sourceMappingURL=MonthCalendar.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["useWindowDimensions","FlatList","dayjs","useState","MonthCalendarViewItem","jsx","_jsx","HALF_PANEL_LENGTH","MonthCalendar","props","dateState","defaultDate","_activeIndex","setActiveIndex","defaultDateDjs","startOfDefaultDateDjs","startOf","prevPanels","Array","from","length","_","i","subtract","format","nextPanels","add","panels","width","horizontal","pagingEnabled","getItemLayout","_data","index","
|
|
1
|
+
{"version":3,"names":["useWindowDimensions","FlatList","dayjs","useState","useRef","useImperativeHandle","forwardRef","MonthCalendarViewItem","jsx","_jsx","HALF_PANEL_LENGTH","MonthCalendar","props","ref","dateState","defaultDate","_activeIndex","setActiveIndex","defaultDateDjs","startOfDefaultDateDjs","startOf","prevPanels","Array","from","length","_","i","subtract","format","nextPanels","add","panels","width","monthViewRefs","scrollMonthViewToOffset","monthKey","offset","animated","targetRef","current","scrollTo","y","console","warn","getMonthRowHeight","date","getRowHeight","undefined","horizontal","pagingEnabled","getItemLayout","_data","index","onMomentumScrollEnd","e","scrollX","nativeEvent","contentOffset","x","newIndex","Math","round","month","newDate","Date","onChangeDate","initialScrollIndex","decelerationRate","data","renderItem","item","r","weekStartsOn","events","onPressEvent","onLongPressEvent","delayLongPressEvent","onPressCell","onLongPressCell","delayLongPressCell","flatListIndex","onRefresh","refreshing","dayCellContainerStyle","dayCellTextStyle","locale","weekdayCellContainerStyle","weekdayCellTextStyle","todayCellTextStyle","hiddenMonth","monthFormat","stickyHeaderEnabled","cellBorderColor","allowFontScaling","eventHeight","eventTextStyle","eventEllipsizeMode","bottomSpacing","showsHorizontalScrollIndicator","scrollEnabled","windowSize","initialNumToRender","maxToRenderPerBatch","removeClippedSubviews"],"sourceRoot":"../../../../src","sources":["calendar/month-calendar/MonthCalendar.tsx"],"mappings":";;AAAA,SACEA,mBAAmB,EACnBC,QAAQ,QAGH,cAAc;AACrB,OAAOC,KAAK,MAAM,OAAO;AACzB,SAASC,QAAQ,EAAEC,MAAM,EAAEC,mBAAmB,EAAEC,UAAU,QAAQ,OAAO;AAMzE,SACEC,qBAAqB,QAEhB,iCAA8B;AAAC,SAAAC,GAAA,IAAAC,IAAA;AAEtC,MAAMC,iBAAiB,GAAG,GAAG,CAAC,CAAC;;AAyC/B,OAAO,MAAMC,aAAa,gBAAGL,UAAU,CACrC,CAACM,KAAK,EAAEC,GAAG,KAAK;EACd,MAAM,CAACC,SAAS,CAAC,GAAGX,QAAQ,CAACS,KAAK,CAACG,WAAW,CAAC;EAC/C,MAAM,CAACC,YAAY,EAAEC,cAAc,CAAC,GAAGd,QAAQ,CAACO,iBAAiB,CAAC;EAClE,MAAMQ,cAAc,GAAGhB,KAAK,CAACY,SAAS,CAAC;EACvC,MAAMK,qBAAqB,GAAGD,cAAc,CAACE,OAAO,CAAC,OAAO,CAAC;EAC7D,MAAMC,UAAoB,GAAGC,KAAK,CAACC,IAAI,CACrC;IAAEC,MAAM,EAAEd;EAAkB,CAAC,EAC7B,CAACe,CAAC,EAAEC,CAAC,KAAK;IACR,OAAOP,qBAAqB,CACzBQ,QAAQ,CAACjB,iBAAiB,GAAGgB,CAAC,EAAE,OAAO,CAAC,CACxCE,MAAM,CAAC,SAAS,CAAC;EACtB,CACF,CAAC;EACD,MAAMC,UAAoB,GAAGP,KAAK,CAACC,IAAI,CACrC;IAAEC,MAAM,EAAEd;EAAkB,CAAC,EAC7B,CAACe,CAAC,EAAEC,CAAC,KAAK;IACR,OAAOP,qBAAqB,CAACW,GAAG,CAACJ,CAAC,GAAG,CAAC,EAAE,OAAO,CAAC,CAACE,MAAM,CAAC,SAAS,CAAC;EACpE,CACF,CAAC;EACD,MAAMG,MAAgB,GAAG,CACvB,GAAGV,UAAU,EACbF,qBAAqB,CAACS,MAAM,CAAC,SAAS,CAAC,EACvC,GAAGC,UAAU,CACd;EAED,MAAM;IAAEG;EAAM,CAAC,GAAGhC,mBAAmB,CAAC,CAAC;EAEvC,MAAMiC,aAAa,GAAG7B,MAAM,CAE1B,CAAC,CAAC,CAAC;EAELC,mBAAmB,CAACQ,GAAG,EAAE,OAAO;IAC9BqB,uBAAuB,EAAEA,CACvBC,QAAgB,EAChBC,MAAc,EACdC,QAAQ,GAAG,IAAI,KACZ;MACH,MAAMC,SAAS,GAAGL,aAAa,CAACM,OAAO,CAACJ,QAAQ,CAAC;MAEjD,IAAIG,SAAS,EAAE;QACbA,SAAS,CAACE,QAAQ,CAAC;UAAEC,CAAC,EAAEL,MAAM;UAAEC;QAAS,CAAC,CAAC;MAC7C,CAAC,MAAM;QACLK,OAAO,CAACC,IAAI,CAAC,kBAAkBR,QAAQ,6BAA6B,CAAC;MACvE;IACF,CAAC;IACDS,iBAAiB,EAAEA,CAACT,QAAgB,EAAEU,IAAU,KAAK;MACnD,MAAMP,SAAS,GAAGL,aAAa,CAACM,OAAO,CAACJ,QAAQ,CAAC;MAEjD,IAAIG,SAAS,EAAE;QACb,OAAOA,SAAS,CAACQ,YAAY,CAACD,IAAI,CAAC;MACrC;MACA,OAAOE,SAAS;IAClB;EACF,CAAC,CAAC,CAAC;EAEH,oBACEtC,IAAA,CAACR,QAAQ;IACP+C,UAAU;IACVC,aAAa,EAAE,IAAK;IACpBC,aAAa,EAAEA,CAACC,KAAK,EAAEC,KAAK,KAAK;MAC/B,OAAO;QACL5B,MAAM,EAAEQ,KAAK;QACbI,MAAM,EAAEJ,KAAK,GAAGoB,KAAK;QACrBA;MACF,CAAC;IACH,CAAE;IACFC,mBAAmB,EAAGC,CAAC,IAAK;MAC1B,MAAMC,OAAO,GAAGD,CAAC,CAACE,WAAW,CAACC,aAAa,CAACC,CAAC;MAC7C,MAAMC,QAAQ,GAAGC,IAAI,CAACC,KAAK,CAACN,OAAO,GAAGvB,KAAK,CAAC;MAC5C,MAAM8B,KAAK,GAAG/B,MAAM,CAAC4B,QAAQ,CAAC;MAC9B,IAAIG,KAAK,EAAE;QACT,MAAMC,OAAO,GAAG,IAAIC,IAAI,CAACF,KAAK,CAAC;QAC/BlD,KAAK,CAACqD,YAAY,GAAGF,OAAO,CAAC;MAC/B;MACA9C,cAAc,CAAC0C,QAAQ,CAAC;IAC1B,CAAE;IACFO,kBAAkB,EAAExD,iBAAkB;IACtCyD,gBAAgB,EAAE,MAAO;IACzBC,IAAI,EAAErC,MAAO;IACbsC,UAAU,EAAEA,CAAC;MAAEC,IAAI;MAAElB;IAAM,CAAC,KAAK;MAC/B,oBACE3C,IAAA,CAACF,qBAAqB;QACpBM,GAAG,EAAG0D,CAAC,IAAK;UACV,IAAIA,CAAC,EAAE;YACLtC,aAAa,CAACM,OAAO,CAAC+B,IAAI,CAAC,GAAGC,CAAC;UACjC,CAAC,MAAM;YACL,OAAOtC,aAAa,CAACM,OAAO,CAAC+B,IAAI,CAAC;UACpC;QACF,CAAE;QACFR,KAAK,EAAEQ,IAAK;QACZE,YAAY,EAAE5D,KAAK,CAAC4D,YAAY,IAAI,CAAE;QACtCC,MAAM,EAAE7D,KAAK,CAAC6D,MAAO;QACrBC,YAAY,EAAE9D,KAAK,CAAC8D,YAAa;QACjCC,gBAAgB,EAAE/D,KAAK,CAAC+D,gBAAiB;QACzCC,mBAAmB,EAAEhE,KAAK,CAACgE,mBAAoB;QAC/CC,WAAW,EAAEjE,KAAK,CAACiE,WAAY;QAC/BC,eAAe,EAAElE,KAAK,CAACkE,eAAgB;QACvCC,kBAAkB,EAAEnE,KAAK,CAACmE,kBAAmB;QAC7CC,aAAa,EAAE5B,KAAM;QACrB6B,SAAS,EAAErE,KAAK,CAACqE,SAAU;QAC3BC,UAAU,EAAEtE,KAAK,CAACsE,UAAW;QAC7BC,qBAAqB,EAAEvE,KAAK,CAACuE,qBAAsB;QACnDC,gBAAgB,EAAExE,KAAK,CAACwE,gBAAiB;QACzCC,MAAM,EAAEzE,KAAK,CAACyE,MAAO;QACrBC,yBAAyB,EAAE1E,KAAK,CAAC0E,yBAA0B;QAC3DC,oBAAoB,EAAE3E,KAAK,CAAC2E,oBAAqB;QACjDC,kBAAkB,EAAE5E,KAAK,CAAC4E,kBAAmB;QAC7CC,WAAW,EAAE7E,KAAK,CAAC6E,WAAY;QAC/BC,WAAW,EAAE9E,KAAK,CAAC8E,WAAY;QAC/BC,mBAAmB,EAAE/E,KAAK,CAAC+E,mBAAoB;QAC/CC,eAAe,EAAEhF,KAAK,CAACgF,eAAgB;QACvCC,gBAAgB,EAAEjF,KAAK,CAACiF,gBAAiB;QACzCC,WAAW,EAAElF,KAAK,CAACkF,WAAY;QAC/BC,cAAc,EAAEnF,KAAK,CAACmF,cAAe;QACrCC,kBAAkB,EAAEpF,KAAK,CAACoF,kBAAmB;QAC7CC,aAAa,EAAErF,KAAK,CAACqF;MAAc,CACpC,CAAC;IAEN,CAAE;IACFC,8BAA8B,EAAE,KAAM;IACtCC,aAAa,EAAE,IAAK;IACpBC,UAAU,EAAE,CAAE;IACdC,kBAAkB,EAAE,CAAE;IACtBC,mBAAmB,EAAE,CAAE;IACvBC,qBAAqB,EAAE;EAAM,CAC9B,CAAC;AAEN,CACF,CAAC","ignoreList":[]}
|
|
@@ -8,10 +8,10 @@ import { monthlyEndDate, monthlyStartDate } from "../../../utils/functions.js";
|
|
|
8
8
|
import { useEvents } from "../logic/useEvents.js";
|
|
9
9
|
import { CELL_BORDER_WIDTH } from "../../../constants/size.js";
|
|
10
10
|
import { RefreshControl } from 'react-native';
|
|
11
|
-
import { useCallback, useMemo, useState } from 'react';
|
|
11
|
+
import { useCallback, useMemo, useState, forwardRef, useImperativeHandle, useRef } from 'react';
|
|
12
12
|
import { MonthCalendarWeekDayRow } from "./MonthCalendarWeekDayRow.js";
|
|
13
13
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
14
|
-
export const MonthCalendarViewItem = props => {
|
|
14
|
+
export const MonthCalendarViewItem = /*#__PURE__*/forwardRef((props, ref) => {
|
|
15
15
|
const {
|
|
16
16
|
width
|
|
17
17
|
} = useWindowDimensions();
|
|
@@ -62,7 +62,27 @@ export const MonthCalendarViewItem = props => {
|
|
|
62
62
|
const stickyHeaderIndices = useMemo(() => {
|
|
63
63
|
return props.stickyHeaderEnabled ? [0] : [];
|
|
64
64
|
}, [props.stickyHeaderEnabled]);
|
|
65
|
+
const scrollViewRef = useRef(null);
|
|
66
|
+
const weekHeights = useRef(new Map());
|
|
67
|
+
useImperativeHandle(ref, () => ({
|
|
68
|
+
scrollTo: options => {
|
|
69
|
+
scrollViewRef.current?.scrollTo(options);
|
|
70
|
+
},
|
|
71
|
+
scrollToEnd: options => {
|
|
72
|
+
scrollViewRef.current?.scrollToEnd(options);
|
|
73
|
+
},
|
|
74
|
+
getRowHeight: targetDate => {
|
|
75
|
+
const targetDjs = dayjs(targetDate);
|
|
76
|
+
const foundWeek = weeks.find(week => week.some(day => day.isSame(targetDjs, 'day')));
|
|
77
|
+
if (foundWeek && foundWeek[0]) {
|
|
78
|
+
const weekId = foundWeek[0].format('YYYY-MM-DD');
|
|
79
|
+
return weekHeights.current.get(weekId);
|
|
80
|
+
}
|
|
81
|
+
return undefined;
|
|
82
|
+
}
|
|
83
|
+
}));
|
|
65
84
|
return /*#__PURE__*/_jsxs(ScrollView, {
|
|
85
|
+
ref: scrollViewRef,
|
|
66
86
|
style: [styles.container, {
|
|
67
87
|
width,
|
|
68
88
|
zIndex: props.flatListIndex,
|
|
@@ -126,7 +146,10 @@ export const MonthCalendarViewItem = props => {
|
|
|
126
146
|
allowFontScaling: props.allowFontScaling,
|
|
127
147
|
eventHeight: props.eventHeight,
|
|
128
148
|
eventTextStyle: props.eventTextStyle,
|
|
129
|
-
eventEllipsizeMode: props.eventEllipsizeMode
|
|
149
|
+
eventEllipsizeMode: props.eventEllipsizeMode,
|
|
150
|
+
onLayout: e => {
|
|
151
|
+
weekHeights.current.set(weekId, e.nativeEvent.layout.height);
|
|
152
|
+
}
|
|
130
153
|
}, `row-${index}`);
|
|
131
154
|
})
|
|
132
155
|
}), /*#__PURE__*/_jsx(View, {
|
|
@@ -135,7 +158,7 @@ export const MonthCalendarViewItem = props => {
|
|
|
135
158
|
}
|
|
136
159
|
})]
|
|
137
160
|
});
|
|
138
|
-
};
|
|
161
|
+
});
|
|
139
162
|
const styles = StyleSheet.create({
|
|
140
163
|
container: {
|
|
141
164
|
height: '100%',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["dayjs","ScrollView","StyleSheet","Text","View","useWindowDimensions","MonthCalendarWeekRow","MonthCalendarEventPosition","monthlyEndDate","monthlyStartDate","useEvents","CELL_BORDER_WIDTH","RefreshControl","useCallback","useMemo","useState","MonthCalendarWeekDayRow","jsx","_jsx","jsxs","_jsxs","MonthCalendarViewItem","props","width","eventPosition","date","Date","month","dateDjs","startDate","weekStartsOn","endDate","endDjs","weeks","currentDate","isBefore","week","Array","from","length","_","i","add","push","eventsGroupByWeekId","events","bodyHeight","setBodyHeight","onLayoutBody","e","nativeEvent","layout","height","monthRowHeight","setMonthRowHeight","onLayoutMonthRow","weekdayRowHeight","setWeekdayRowHeight","onLayoutWeekdayRow","weekRowMinHeight","stickyHeaderIndices","stickyHeaderEnabled","style","styles","container","zIndex","flatListIndex","borderColor","cellBorderColor","refreshControl","refreshing","onRefresh","onLayout","children","hiddenMonth","blankMonthContainer","monthContainer","monthText","allowFontScaling","
|
|
1
|
+
{"version":3,"names":["dayjs","ScrollView","StyleSheet","Text","View","useWindowDimensions","MonthCalendarWeekRow","MonthCalendarEventPosition","monthlyEndDate","monthlyStartDate","useEvents","CELL_BORDER_WIDTH","RefreshControl","useCallback","useMemo","useState","forwardRef","useImperativeHandle","useRef","MonthCalendarWeekDayRow","jsx","_jsx","jsxs","_jsxs","MonthCalendarViewItem","props","ref","width","eventPosition","date","Date","month","dateDjs","startDate","weekStartsOn","endDate","endDjs","weeks","currentDate","isBefore","week","Array","from","length","_","i","add","push","eventsGroupByWeekId","events","bodyHeight","setBodyHeight","onLayoutBody","e","nativeEvent","layout","height","monthRowHeight","setMonthRowHeight","onLayoutMonthRow","weekdayRowHeight","setWeekdayRowHeight","onLayoutWeekdayRow","weekRowMinHeight","stickyHeaderIndices","stickyHeaderEnabled","scrollViewRef","weekHeights","Map","scrollTo","options","current","scrollToEnd","getRowHeight","targetDate","targetDjs","foundWeek","find","some","day","isSame","weekId","format","get","undefined","style","styles","container","zIndex","flatListIndex","borderColor","cellBorderColor","refreshControl","refreshing","onRefresh","onLayout","children","hiddenMonth","blankMonthContainer","monthContainer","monthText","allowFontScaling","monthFormat","dates","locale","weekdayCellContainerStyle","weekdayCellTextStyle","map","index","firstDayOfWeek","weekEvents","onPressEvent","onLongPressEvent","delayLongPressEvent","onPressCell","onLongPressCell","delayLongPressCell","dayCellContainerStyle","dayCellTextStyle","todayCellTextStyle","eventHeight","eventTextStyle","eventEllipsizeMode","set","bottomSpacing","create","alignSelf","borderWidth","padding","backgroundColor","textAlign","fontSize"],"sourceRoot":"../../../../../src","sources":["calendar/month-calendar/view/MonthCalendarViewItem.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -17,6 +17,7 @@ export const MonthCalendarWeekRow = props => {
|
|
|
17
17
|
}
|
|
18
18
|
return /*#__PURE__*/_jsx(View, {
|
|
19
19
|
style: styles.container,
|
|
20
|
+
onLayout: props.onLayout,
|
|
20
21
|
children: props.dates.map((djs, dateIndex) => {
|
|
21
22
|
const text = djs.format('D');
|
|
22
23
|
const filteredEvents = props.events?.filter(event => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["dayjs","StyleSheet","useWindowDimensions","Text","TouchableOpacity","View","CELL_BORDER_WIDTH","EVENT_GAP","jsx","_jsx","jsxs","_jsxs","MonthCalendarWeekRow","props","eventHeight","width","screenWidth","dateColumnWidth","weekId","dates","format","eventPosition","resetResource","style","styles","container","children","map","djs","dateIndex","text","filteredEvents","events","filter","event","startDjs","start","isBefore","sort","a","b","aStartDjs","bStartDjs","aEndDjs","end","bEndDjs","aDiffDays","startOf","diff","bDiffDays","rowNums","getRowNums","date","toDate","rowsLength","length","eventIndex","ii","includes","push","dayCellCountainer","minHeight","weekRowMinHeight","zIndex","borderColor","cellBorderColor","onPress","onPressCell","onLongPress","onLongPressCell","delayLongPress","delayLongPressCell","dayCellInner","dayCellContainerStyle","dayCellLabel","dayCellText","dayCellTextStyle","isSame","todayCellTextStyle","allowFontScaling","rowIndex","height","marginBottom","rawStartDjs","endDjs","diffDays","isPrevDateEvent","isLastRow","startDate","days","rowNum","backgroundColor","borderStyle","undefined","borderWidth","borderRadius","prevDateEvent","lastRowEvent","onPressEvent","onLongPressEvent","delayLongPressEvent","numberOfLines","ellipsizeMode","eventEllipsizeMode","eventTitle","color","eventTextStyle","title","id","get","create","display","flexDirection","flex","borderRightWidth","borderBottomWidth","position","top","left","right","bottom","paddingVertical","paddingHorizontal","textAlign","fontSize","alignItems","boxShadow","marginTop","marginLeft","borderTopStartRadius","borderBottomStartRadius"],"sourceRoot":"../../../../../src","sources":["calendar/month-calendar/view/MonthCalendarWeekRow.tsx"],"mappings":";;AAAA,OAAOA,KAAK,MAAM,OAAO;AACzB,
|
|
1
|
+
{"version":3,"names":["dayjs","StyleSheet","useWindowDimensions","Text","TouchableOpacity","View","CELL_BORDER_WIDTH","EVENT_GAP","jsx","_jsx","jsxs","_jsxs","MonthCalendarWeekRow","props","eventHeight","width","screenWidth","dateColumnWidth","weekId","dates","format","eventPosition","resetResource","style","styles","container","onLayout","children","map","djs","dateIndex","text","filteredEvents","events","filter","event","startDjs","start","isBefore","sort","a","b","aStartDjs","bStartDjs","aEndDjs","end","bEndDjs","aDiffDays","startOf","diff","bDiffDays","rowNums","getRowNums","date","toDate","rowsLength","length","eventIndex","ii","includes","push","dayCellCountainer","minHeight","weekRowMinHeight","zIndex","borderColor","cellBorderColor","onPress","onPressCell","onLongPress","onLongPressCell","delayLongPress","delayLongPressCell","dayCellInner","dayCellContainerStyle","dayCellLabel","dayCellText","dayCellTextStyle","isSame","todayCellTextStyle","allowFontScaling","rowIndex","height","marginBottom","rawStartDjs","endDjs","diffDays","isPrevDateEvent","isLastRow","startDate","days","rowNum","backgroundColor","borderStyle","undefined","borderWidth","borderRadius","prevDateEvent","lastRowEvent","onPressEvent","onLongPressEvent","delayLongPressEvent","numberOfLines","ellipsizeMode","eventEllipsizeMode","eventTitle","color","eventTextStyle","title","id","get","create","display","flexDirection","flex","borderRightWidth","borderBottomWidth","position","top","left","right","bottom","paddingVertical","paddingHorizontal","textAlign","fontSize","alignItems","boxShadow","marginTop","marginLeft","borderTopStartRadius","borderBottomStartRadius"],"sourceRoot":"../../../../../src","sources":["calendar/month-calendar/view/MonthCalendarWeekRow.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -1,6 +1,10 @@
|
|
|
1
1
|
import { type ViewStyle, type TextStyle } from 'react-native';
|
|
2
2
|
import type { CalendarEvent, WeekdayNum, WeekStartsOn } from '../../types/month-calendar';
|
|
3
|
-
export
|
|
3
|
+
export interface MonthCalendarRef {
|
|
4
|
+
scrollMonthViewToOffset: (monthKey: string, offset: number, animated?: boolean) => void;
|
|
5
|
+
getMonthRowHeight: (monthKey: string, date: Date) => number | undefined;
|
|
6
|
+
}
|
|
7
|
+
type MonthCalendarProps = {
|
|
4
8
|
defaultDate: Date;
|
|
5
9
|
weekStartsOn?: WeekStartsOn;
|
|
6
10
|
onChangeDate?: (date: Date) => void;
|
|
@@ -26,7 +30,9 @@ export declare const MonthCalendar: (props: {
|
|
|
26
30
|
allowFontScaling?: boolean;
|
|
27
31
|
eventHeight?: number;
|
|
28
32
|
eventTextStyle?: (event: CalendarEvent) => TextStyle;
|
|
29
|
-
eventEllipsizeMode?:
|
|
33
|
+
eventEllipsizeMode?: 'head' | 'middle' | 'tail' | 'clip';
|
|
30
34
|
bottomSpacing?: number;
|
|
31
|
-
}
|
|
35
|
+
};
|
|
36
|
+
export declare const MonthCalendar: import("react").ForwardRefExoticComponent<MonthCalendarProps & import("react").RefAttributes<MonthCalendarRef>>;
|
|
37
|
+
export {};
|
|
32
38
|
//# sourceMappingURL=MonthCalendar.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MonthCalendar.d.ts","sourceRoot":"","sources":["../../../../../src/calendar/month-calendar/MonthCalendar.tsx"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,SAAS,EACd,KAAK,SAAS,EACf,MAAM,cAAc,CAAC;AAGtB,OAAO,KAAK,EACV,aAAa,EACb,UAAU,EACV,YAAY,EACb,MAAM,4BAA4B,CAAC;
|
|
1
|
+
{"version":3,"file":"MonthCalendar.d.ts","sourceRoot":"","sources":["../../../../../src/calendar/month-calendar/MonthCalendar.tsx"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,SAAS,EACd,KAAK,SAAS,EACf,MAAM,cAAc,CAAC;AAGtB,OAAO,KAAK,EACV,aAAa,EACb,UAAU,EACV,YAAY,EACb,MAAM,4BAA4B,CAAC;AAQpC,MAAM,WAAW,gBAAgB;IAC/B,uBAAuB,EAAE,CACvB,QAAQ,EAAE,MAAM,EAChB,MAAM,EAAE,MAAM,EACd,QAAQ,CAAC,EAAE,OAAO,KACf,IAAI,CAAC;IACV,iBAAiB,EAAE,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,IAAI,KAAK,MAAM,GAAG,SAAS,CAAC;CACzE;AAED,KAAK,kBAAkB,GAAG;IACxB,WAAW,EAAE,IAAI,CAAC;IAClB,YAAY,CAAC,EAAE,YAAY,CAAC;IAC5B,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IACpC,MAAM,EAAE,aAAa,EAAE,CAAC;IACxB,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,CAAC;IAC9C,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,CAAC;IAClD,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,WAAW,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IACnC,eAAe,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IACvC,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;IACvB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,qBAAqB,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC;IAClD,gBAAgB,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC;IAC7C,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,yBAAyB,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,SAAS,CAAC;IAClE,oBAAoB,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,SAAS,CAAC;IAC7D,kBAAkB,CAAC,EAAE,SAAS,CAAC;IAC/B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,SAAS,CAAC;IACrD,kBAAkB,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;IACzD,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,eAAO,MAAM,aAAa,iHAiIzB,CAAC"}
|
|
@@ -1,6 +1,17 @@
|
|
|
1
1
|
import { type TextStyle, type ViewStyle } from 'react-native';
|
|
2
2
|
import type { CalendarEvent, WeekdayNum, WeekStartsOn } from '../../../types/month-calendar';
|
|
3
|
-
export
|
|
3
|
+
export interface MonthCalendarViewItemRef {
|
|
4
|
+
scrollTo: (options: {
|
|
5
|
+
x?: number;
|
|
6
|
+
y?: number;
|
|
7
|
+
animated?: boolean;
|
|
8
|
+
}) => void;
|
|
9
|
+
scrollToEnd: (options?: {
|
|
10
|
+
animated?: boolean;
|
|
11
|
+
}) => void;
|
|
12
|
+
getRowHeight: (date: Date) => number | undefined;
|
|
13
|
+
}
|
|
14
|
+
type MonthCalendarViewItemProps = {
|
|
4
15
|
month: string;
|
|
5
16
|
weekStartsOn: WeekStartsOn;
|
|
6
17
|
events: CalendarEvent[];
|
|
@@ -26,7 +37,9 @@ export declare const MonthCalendarViewItem: (props: {
|
|
|
26
37
|
allowFontScaling?: boolean;
|
|
27
38
|
eventHeight?: number;
|
|
28
39
|
eventTextStyle?: (event: CalendarEvent) => TextStyle;
|
|
29
|
-
eventEllipsizeMode?:
|
|
40
|
+
eventEllipsizeMode?: 'head' | 'middle' | 'tail' | 'clip';
|
|
30
41
|
bottomSpacing?: number;
|
|
31
|
-
}
|
|
42
|
+
};
|
|
43
|
+
export declare const MonthCalendarViewItem: import("react").ForwardRefExoticComponent<MonthCalendarViewItemProps & import("react").RefAttributes<MonthCalendarViewItemRef>>;
|
|
44
|
+
export {};
|
|
32
45
|
//# sourceMappingURL=MonthCalendarViewItem.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MonthCalendarViewItem.d.ts","sourceRoot":"","sources":["../../../../../../src/calendar/month-calendar/view/MonthCalendarViewItem.tsx"],"names":[],"mappings":"AACA,OAAO,EAOL,KAAK,SAAS,EACd,KAAK,SAAS,EACf,MAAM,cAAc,CAAC;AAEtB,OAAO,KAAK,EACV,aAAa,EACb,UAAU,EACV,YAAY,EACb,MAAM,+BAA+B,CAAC;
|
|
1
|
+
{"version":3,"file":"MonthCalendarViewItem.d.ts","sourceRoot":"","sources":["../../../../../../src/calendar/month-calendar/view/MonthCalendarViewItem.tsx"],"names":[],"mappings":"AACA,OAAO,EAOL,KAAK,SAAS,EACd,KAAK,SAAS,EACf,MAAM,cAAc,CAAC;AAEtB,OAAO,KAAK,EACV,aAAa,EACb,UAAU,EACV,YAAY,EACb,MAAM,+BAA+B,CAAC;AAgBvC,MAAM,WAAW,wBAAwB;IACvC,QAAQ,EAAE,CAAC,OAAO,EAAE;QAAE,CAAC,CAAC,EAAE,MAAM,CAAC;QAAC,CAAC,CAAC,EAAE,MAAM,CAAC;QAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;KAAE,KAAK,IAAI,CAAC;IAC5E,WAAW,EAAE,CAAC,OAAO,CAAC,EAAE;QAAE,QAAQ,CAAC,EAAE,OAAO,CAAA;KAAE,KAAK,IAAI,CAAC;IACxD,YAAY,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,MAAM,GAAG,SAAS,CAAC;CAClD;AAED,KAAK,0BAA0B,GAAG;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,YAAY,EAAE,YAAY,CAAC;IAC3B,MAAM,EAAE,aAAa,EAAE,CAAC;IACxB,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,CAAC;IAC9C,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,CAAC;IAClD,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,WAAW,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IACnC,eAAe,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IACvC,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,aAAa,EAAE,MAAM,CAAC;IACtB,SAAS,CAAC,EAAE,MAAM,IAAI,CAAC;IACvB,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,qBAAqB,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC;IAClD,gBAAgB,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC;IAC7C,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,yBAAyB,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,SAAS,CAAC;IAClE,oBAAoB,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,SAAS,CAAC;IAC7D,kBAAkB,CAAC,EAAE,SAAS,CAAC;IAC/B,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAC9B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,SAAS,CAAC;IACrD,kBAAkB,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;IACzD,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB,CAAC;AAEF,eAAO,MAAM,qBAAqB,iIA4KhC,CAAC"}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import dayjs from 'dayjs';
|
|
2
|
+
import { type LayoutChangeEvent } from 'react-native';
|
|
2
3
|
import { type ViewStyle } from 'react-native';
|
|
3
4
|
import type { CalendarEvent, WeekdayNum } from '../../../types/month-calendar';
|
|
4
5
|
import type MonthCalendarEventPosition from '../../../utils/month-calendar-event-position';
|
|
@@ -24,5 +25,6 @@ export declare const MonthCalendarWeekRow: (props: {
|
|
|
24
25
|
eventHeight?: number;
|
|
25
26
|
eventTextStyle?: (event: CalendarEvent) => TextStyle;
|
|
26
27
|
eventEllipsizeMode?: "head" | "middle" | "tail" | "clip";
|
|
28
|
+
onLayout?: (event: LayoutChangeEvent) => void;
|
|
27
29
|
}) => import("react/jsx-runtime").JSX.Element;
|
|
28
30
|
//# sourceMappingURL=MonthCalendarWeekRow.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MonthCalendarWeekRow.d.ts","sourceRoot":"","sources":["../../../../../../src/calendar/month-calendar/view/MonthCalendarWeekRow.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;
|
|
1
|
+
{"version":3,"file":"MonthCalendarWeekRow.d.ts","sourceRoot":"","sources":["../../../../../../src/calendar/month-calendar/view/MonthCalendarWeekRow.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAGL,KAAK,iBAAiB,EACvB,MAAM,cAAc,CAAC;AACtB,OAAO,EAAgC,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAC5E,OAAO,KAAK,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,+BAA+B,CAAC;AAC/E,OAAO,KAAK,0BAA0B,MAAM,8CAA8C,CAAC;AAE3F,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AAE9C,eAAO,MAAM,oBAAoB,GAAI,OAAO;IAC1C,KAAK,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC;IACrB,MAAM,EAAE,aAAa,EAAE,CAAC;IACxB,aAAa,CAAC,EAAE,0BAA0B,CAAC;IAC3C,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,CAAC;IAC9C,gBAAgB,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,IAAI,CAAC;IAClD,mBAAmB,CAAC,EAAE,MAAM,CAAC;IAC7B,WAAW,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IACnC,eAAe,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IACvC,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,qBAAqB,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC;IAClD,gBAAgB,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,SAAS,CAAC;IAC7C,yBAAyB,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,SAAS,CAAC;IAClE,oBAAoB,CAAC,EAAE,CAAC,UAAU,EAAE,UAAU,KAAK,SAAS,CAAC;IAC7D,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAC1B,kBAAkB,CAAC,EAAE,SAAS,CAAC;IAC/B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,aAAa,KAAK,SAAS,CAAC;IACrD,kBAAkB,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,CAAC;IACzD,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,iBAAiB,KAAK,IAAI,CAAC;CAC/C,4CA0LA,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,yCAAyC,CAAC;AACxE,YAAY,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/index.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,yCAAyC,CAAC;AACxE,YAAY,EAAE,aAAa,EAAE,MAAM,wBAAwB,CAAC;AAC5D,YAAY,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "react-native-ll-calendar",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.10.0",
|
|
4
4
|
"description": "ReactNative Calendar Library",
|
|
5
5
|
"main": "./lib/module/index.js",
|
|
6
6
|
"types": "./lib/typescript/src/index.d.ts",
|
|
@@ -79,7 +79,7 @@
|
|
|
79
79
|
"react": "19.1.0",
|
|
80
80
|
"react-native": "0.81.4",
|
|
81
81
|
"react-native-builder-bob": "^0.40.13",
|
|
82
|
-
"release-it": "^19.0.
|
|
82
|
+
"release-it": "^19.0.6",
|
|
83
83
|
"typescript": "^5.9.2"
|
|
84
84
|
},
|
|
85
85
|
"peerDependencies": {
|
|
@@ -5,17 +5,29 @@ import {
|
|
|
5
5
|
type TextStyle,
|
|
6
6
|
} from 'react-native';
|
|
7
7
|
import dayjs from 'dayjs';
|
|
8
|
-
import { useState } from 'react';
|
|
8
|
+
import { useState, useRef, useImperativeHandle, forwardRef } from 'react';
|
|
9
9
|
import type {
|
|
10
10
|
CalendarEvent,
|
|
11
11
|
WeekdayNum,
|
|
12
12
|
WeekStartsOn,
|
|
13
13
|
} from '../../types/month-calendar';
|
|
14
|
-
import {
|
|
14
|
+
import {
|
|
15
|
+
MonthCalendarViewItem,
|
|
16
|
+
type MonthCalendarViewItemRef,
|
|
17
|
+
} from './view/MonthCalendarViewItem';
|
|
15
18
|
|
|
16
19
|
const HALF_PANEL_LENGTH = 120; // 10 years
|
|
17
20
|
|
|
18
|
-
export
|
|
21
|
+
export interface MonthCalendarRef {
|
|
22
|
+
scrollMonthViewToOffset: (
|
|
23
|
+
monthKey: string,
|
|
24
|
+
offset: number,
|
|
25
|
+
animated?: boolean
|
|
26
|
+
) => void;
|
|
27
|
+
getMonthRowHeight: (monthKey: string, date: Date) => number | undefined;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
type MonthCalendarProps = {
|
|
19
31
|
defaultDate: Date;
|
|
20
32
|
weekStartsOn?: WeekStartsOn;
|
|
21
33
|
onChangeDate?: (date: Date) => void;
|
|
@@ -43,96 +55,135 @@ export const MonthCalendar = (props: {
|
|
|
43
55
|
eventTextStyle?: (event: CalendarEvent) => TextStyle;
|
|
44
56
|
eventEllipsizeMode?: 'head' | 'middle' | 'tail' | 'clip';
|
|
45
57
|
bottomSpacing?: number;
|
|
46
|
-
}
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
export const MonthCalendar = forwardRef<MonthCalendarRef, MonthCalendarProps>(
|
|
61
|
+
(props, ref) => {
|
|
62
|
+
const [dateState] = useState(props.defaultDate);
|
|
63
|
+
const [_activeIndex, setActiveIndex] = useState(HALF_PANEL_LENGTH);
|
|
64
|
+
const defaultDateDjs = dayjs(dateState);
|
|
65
|
+
const startOfDefaultDateDjs = defaultDateDjs.startOf('month');
|
|
66
|
+
const prevPanels: string[] = Array.from(
|
|
67
|
+
{ length: HALF_PANEL_LENGTH },
|
|
68
|
+
(_, i) => {
|
|
69
|
+
return startOfDefaultDateDjs
|
|
70
|
+
.subtract(HALF_PANEL_LENGTH - i, 'month')
|
|
71
|
+
.format('YYYY-MM');
|
|
72
|
+
}
|
|
73
|
+
);
|
|
74
|
+
const nextPanels: string[] = Array.from(
|
|
75
|
+
{ length: HALF_PANEL_LENGTH },
|
|
76
|
+
(_, i) => {
|
|
77
|
+
return startOfDefaultDateDjs.add(i + 1, 'month').format('YYYY-MM');
|
|
78
|
+
}
|
|
79
|
+
);
|
|
80
|
+
const panels: string[] = [
|
|
81
|
+
...prevPanels,
|
|
82
|
+
startOfDefaultDateDjs.format('YYYY-MM'),
|
|
83
|
+
...nextPanels,
|
|
84
|
+
];
|
|
85
|
+
|
|
86
|
+
const { width } = useWindowDimensions();
|
|
70
87
|
|
|
71
|
-
|
|
88
|
+
const monthViewRefs = useRef<
|
|
89
|
+
Record<string, MonthCalendarViewItemRef | null>
|
|
90
|
+
>({});
|
|
72
91
|
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
const scrollX = e.nativeEvent.contentOffset.x;
|
|
86
|
-
const newIndex = Math.round(scrollX / width);
|
|
87
|
-
const month = panels[newIndex];
|
|
88
|
-
if (month) {
|
|
89
|
-
const newDate = new Date(month);
|
|
90
|
-
props.onChangeDate?.(newDate);
|
|
92
|
+
useImperativeHandle(ref, () => ({
|
|
93
|
+
scrollMonthViewToOffset: (
|
|
94
|
+
monthKey: string,
|
|
95
|
+
offset: number,
|
|
96
|
+
animated = true
|
|
97
|
+
) => {
|
|
98
|
+
const targetRef = monthViewRefs.current[monthKey];
|
|
99
|
+
|
|
100
|
+
if (targetRef) {
|
|
101
|
+
targetRef.scrollTo({ y: offset, animated });
|
|
102
|
+
} else {
|
|
103
|
+
console.warn(`Month view for ${monthKey} is not currently rendered.`);
|
|
91
104
|
}
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
}
|
|
105
|
+
},
|
|
106
|
+
getMonthRowHeight: (monthKey: string, date: Date) => {
|
|
107
|
+
const targetRef = monthViewRefs.current[monthKey];
|
|
108
|
+
|
|
109
|
+
if (targetRef) {
|
|
110
|
+
return targetRef.getRowHeight(date);
|
|
111
|
+
}
|
|
112
|
+
return undefined;
|
|
113
|
+
},
|
|
114
|
+
}));
|
|
115
|
+
|
|
116
|
+
return (
|
|
117
|
+
<FlatList
|
|
118
|
+
horizontal
|
|
119
|
+
pagingEnabled={true}
|
|
120
|
+
getItemLayout={(_data, index) => {
|
|
121
|
+
return {
|
|
122
|
+
length: width,
|
|
123
|
+
offset: width * index,
|
|
124
|
+
index,
|
|
125
|
+
};
|
|
126
|
+
}}
|
|
127
|
+
onMomentumScrollEnd={(e) => {
|
|
128
|
+
const scrollX = e.nativeEvent.contentOffset.x;
|
|
129
|
+
const newIndex = Math.round(scrollX / width);
|
|
130
|
+
const month = panels[newIndex];
|
|
131
|
+
if (month) {
|
|
132
|
+
const newDate = new Date(month);
|
|
133
|
+
props.onChangeDate?.(newDate);
|
|
134
|
+
}
|
|
135
|
+
setActiveIndex(newIndex);
|
|
136
|
+
}}
|
|
137
|
+
initialScrollIndex={HALF_PANEL_LENGTH}
|
|
138
|
+
decelerationRate={'fast'}
|
|
139
|
+
data={panels}
|
|
140
|
+
renderItem={({ item, index }) => {
|
|
141
|
+
return (
|
|
142
|
+
<MonthCalendarViewItem
|
|
143
|
+
ref={(r) => {
|
|
144
|
+
if (r) {
|
|
145
|
+
monthViewRefs.current[item] = r;
|
|
146
|
+
} else {
|
|
147
|
+
delete monthViewRefs.current[item];
|
|
148
|
+
}
|
|
149
|
+
}}
|
|
150
|
+
month={item}
|
|
151
|
+
weekStartsOn={props.weekStartsOn ?? 0}
|
|
152
|
+
events={props.events}
|
|
153
|
+
onPressEvent={props.onPressEvent}
|
|
154
|
+
onLongPressEvent={props.onLongPressEvent}
|
|
155
|
+
delayLongPressEvent={props.delayLongPressEvent}
|
|
156
|
+
onPressCell={props.onPressCell}
|
|
157
|
+
onLongPressCell={props.onLongPressCell}
|
|
158
|
+
delayLongPressCell={props.delayLongPressCell}
|
|
159
|
+
flatListIndex={index}
|
|
160
|
+
onRefresh={props.onRefresh}
|
|
161
|
+
refreshing={props.refreshing}
|
|
162
|
+
dayCellContainerStyle={props.dayCellContainerStyle}
|
|
163
|
+
dayCellTextStyle={props.dayCellTextStyle}
|
|
164
|
+
locale={props.locale}
|
|
165
|
+
weekdayCellContainerStyle={props.weekdayCellContainerStyle}
|
|
166
|
+
weekdayCellTextStyle={props.weekdayCellTextStyle}
|
|
167
|
+
todayCellTextStyle={props.todayCellTextStyle}
|
|
168
|
+
hiddenMonth={props.hiddenMonth}
|
|
169
|
+
monthFormat={props.monthFormat}
|
|
170
|
+
stickyHeaderEnabled={props.stickyHeaderEnabled}
|
|
171
|
+
cellBorderColor={props.cellBorderColor}
|
|
172
|
+
allowFontScaling={props.allowFontScaling}
|
|
173
|
+
eventHeight={props.eventHeight}
|
|
174
|
+
eventTextStyle={props.eventTextStyle}
|
|
175
|
+
eventEllipsizeMode={props.eventEllipsizeMode}
|
|
176
|
+
bottomSpacing={props.bottomSpacing}
|
|
177
|
+
/>
|
|
178
|
+
);
|
|
179
|
+
}}
|
|
180
|
+
showsHorizontalScrollIndicator={false}
|
|
181
|
+
scrollEnabled={true}
|
|
182
|
+
windowSize={5}
|
|
183
|
+
initialNumToRender={5}
|
|
184
|
+
maxToRenderPerBatch={5}
|
|
185
|
+
removeClippedSubviews={false}
|
|
186
|
+
/>
|
|
187
|
+
);
|
|
188
|
+
}
|
|
189
|
+
);
|
|
@@ -20,10 +20,23 @@ import { monthlyEndDate, monthlyStartDate } from '../../../utils/functions';
|
|
|
20
20
|
import { useEvents } from '../logic/useEvents';
|
|
21
21
|
import { CELL_BORDER_WIDTH } from '../../../constants/size';
|
|
22
22
|
import { RefreshControl } from 'react-native';
|
|
23
|
-
import {
|
|
23
|
+
import {
|
|
24
|
+
useCallback,
|
|
25
|
+
useMemo,
|
|
26
|
+
useState,
|
|
27
|
+
forwardRef,
|
|
28
|
+
useImperativeHandle,
|
|
29
|
+
useRef,
|
|
30
|
+
} from 'react';
|
|
24
31
|
import { MonthCalendarWeekDayRow } from './MonthCalendarWeekDayRow';
|
|
25
32
|
|
|
26
|
-
export
|
|
33
|
+
export interface MonthCalendarViewItemRef {
|
|
34
|
+
scrollTo: (options: { x?: number; y?: number; animated?: boolean }) => void;
|
|
35
|
+
scrollToEnd: (options?: { animated?: boolean }) => void;
|
|
36
|
+
getRowHeight: (date: Date) => number | undefined;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
type MonthCalendarViewItemProps = {
|
|
27
40
|
month: string;
|
|
28
41
|
weekStartsOn: WeekStartsOn;
|
|
29
42
|
events: CalendarEvent[];
|
|
@@ -51,7 +64,12 @@ export const MonthCalendarViewItem = (props: {
|
|
|
51
64
|
eventTextStyle?: (event: CalendarEvent) => TextStyle;
|
|
52
65
|
eventEllipsizeMode?: 'head' | 'middle' | 'tail' | 'clip';
|
|
53
66
|
bottomSpacing?: number;
|
|
54
|
-
}
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
export const MonthCalendarViewItem = forwardRef<
|
|
70
|
+
MonthCalendarViewItemRef,
|
|
71
|
+
MonthCalendarViewItemProps
|
|
72
|
+
>((props, ref) => {
|
|
55
73
|
const { width } = useWindowDimensions();
|
|
56
74
|
const eventPosition = new MonthCalendarEventPosition();
|
|
57
75
|
const date = new Date(props.month);
|
|
@@ -100,8 +118,35 @@ export const MonthCalendarViewItem = (props: {
|
|
|
100
118
|
return props.stickyHeaderEnabled ? [0] : [];
|
|
101
119
|
}, [props.stickyHeaderEnabled]);
|
|
102
120
|
|
|
121
|
+
const scrollViewRef = useRef<any>(null);
|
|
122
|
+
|
|
123
|
+
const weekHeights = useRef(new Map<string, number>());
|
|
124
|
+
|
|
125
|
+
useImperativeHandle(ref, () => ({
|
|
126
|
+
scrollTo: (options) => {
|
|
127
|
+
scrollViewRef.current?.scrollTo(options);
|
|
128
|
+
},
|
|
129
|
+
scrollToEnd: (options) => {
|
|
130
|
+
scrollViewRef.current?.scrollToEnd(options);
|
|
131
|
+
},
|
|
132
|
+
getRowHeight: (targetDate: Date) => {
|
|
133
|
+
const targetDjs = dayjs(targetDate);
|
|
134
|
+
|
|
135
|
+
const foundWeek = weeks.find((week) =>
|
|
136
|
+
week.some((day) => day.isSame(targetDjs, 'day'))
|
|
137
|
+
);
|
|
138
|
+
|
|
139
|
+
if (foundWeek && foundWeek[0]) {
|
|
140
|
+
const weekId = foundWeek[0].format('YYYY-MM-DD');
|
|
141
|
+
return weekHeights.current.get(weekId);
|
|
142
|
+
}
|
|
143
|
+
return undefined;
|
|
144
|
+
},
|
|
145
|
+
}));
|
|
146
|
+
|
|
103
147
|
return (
|
|
104
148
|
<ScrollView
|
|
149
|
+
ref={scrollViewRef}
|
|
105
150
|
style={[
|
|
106
151
|
styles.container,
|
|
107
152
|
{
|
|
@@ -183,6 +228,9 @@ export const MonthCalendarViewItem = (props: {
|
|
|
183
228
|
eventHeight={props.eventHeight}
|
|
184
229
|
eventTextStyle={props.eventTextStyle}
|
|
185
230
|
eventEllipsizeMode={props.eventEllipsizeMode}
|
|
231
|
+
onLayout={(e) => {
|
|
232
|
+
weekHeights.current.set(weekId, e.nativeEvent.layout.height);
|
|
233
|
+
}}
|
|
186
234
|
/>
|
|
187
235
|
);
|
|
188
236
|
})}
|
|
@@ -190,7 +238,7 @@ export const MonthCalendarViewItem = (props: {
|
|
|
190
238
|
<View style={{ height: props.bottomSpacing }} />
|
|
191
239
|
</ScrollView>
|
|
192
240
|
);
|
|
193
|
-
};
|
|
241
|
+
});
|
|
194
242
|
|
|
195
243
|
const styles = StyleSheet.create({
|
|
196
244
|
container: {
|
|
@@ -1,5 +1,9 @@
|
|
|
1
1
|
import dayjs from 'dayjs';
|
|
2
|
-
import {
|
|
2
|
+
import {
|
|
3
|
+
StyleSheet,
|
|
4
|
+
useWindowDimensions,
|
|
5
|
+
type LayoutChangeEvent,
|
|
6
|
+
} from 'react-native';
|
|
3
7
|
import { Text, TouchableOpacity, View, type ViewStyle } from 'react-native';
|
|
4
8
|
import type { CalendarEvent, WeekdayNum } from '../../../types/month-calendar';
|
|
5
9
|
import type MonthCalendarEventPosition from '../../../utils/month-calendar-event-position';
|
|
@@ -27,6 +31,7 @@ export const MonthCalendarWeekRow = (props: {
|
|
|
27
31
|
eventHeight?: number;
|
|
28
32
|
eventTextStyle?: (event: CalendarEvent) => TextStyle;
|
|
29
33
|
eventEllipsizeMode?: 'head' | 'middle' | 'tail' | 'clip';
|
|
34
|
+
onLayout?: (event: LayoutChangeEvent) => void;
|
|
30
35
|
}) => {
|
|
31
36
|
const eventHeight = props.eventHeight || 26;
|
|
32
37
|
const { width: screenWidth } = useWindowDimensions();
|
|
@@ -37,7 +42,7 @@ export const MonthCalendarWeekRow = (props: {
|
|
|
37
42
|
}
|
|
38
43
|
|
|
39
44
|
return (
|
|
40
|
-
<View style={styles.container}>
|
|
45
|
+
<View style={styles.container} onLayout={props.onLayout}>
|
|
41
46
|
{props.dates.map((djs, dateIndex) => {
|
|
42
47
|
const text = djs.format('D');
|
|
43
48
|
const filteredEvents = props.events
|
package/src/index.tsx
CHANGED