@r0b0t3d/react-native-collapsible 1.5.3 → 1.6.0-alpha.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/lib/commonjs/components/CollapsibleContainer.js +19 -21
- package/lib/commonjs/components/CollapsibleContainer.js.map +1 -1
- package/lib/commonjs/components/CollapsibleView.js +38 -30
- package/lib/commonjs/components/CollapsibleView.js.map +1 -1
- package/lib/commonjs/components/header/AnimatedTopView.js +5 -7
- package/lib/commonjs/components/header/AnimatedTopView.js.map +1 -1
- package/lib/commonjs/components/header/CollapsibleHeaderConsumer.js +10 -13
- package/lib/commonjs/components/header/CollapsibleHeaderConsumer.js.map +1 -1
- package/lib/commonjs/components/header/CollapsibleHeaderContainer.js +22 -17
- package/lib/commonjs/components/header/CollapsibleHeaderContainer.js.map +1 -1
- package/lib/commonjs/components/header/CollapsibleHeaderContainerProvider.js +12 -15
- package/lib/commonjs/components/header/CollapsibleHeaderContainerProvider.js.map +1 -1
- package/lib/commonjs/components/header/StickyView.js +18 -25
- package/lib/commonjs/components/header/StickyView.js.map +1 -1
- package/lib/commonjs/components/scrollable/CollapsibleFlatList.js +27 -41
- package/lib/commonjs/components/scrollable/CollapsibleFlatList.js.map +1 -1
- package/lib/commonjs/components/scrollable/CollapsibleScrollView.js +12 -15
- package/lib/commonjs/components/scrollable/CollapsibleScrollView.js.map +1 -1
- package/lib/commonjs/components/scrollable/CollapsibleSectionList.js +22 -36
- package/lib/commonjs/components/scrollable/CollapsibleSectionList.js.map +1 -1
- package/lib/commonjs/components/scrollable/useAnimatedScroll.js +44 -24
- package/lib/commonjs/components/scrollable/useAnimatedScroll.js.map +1 -1
- package/lib/commonjs/hooks/useCollapsibleContext.js +1 -2
- package/lib/commonjs/hooks/useCollapsibleContext.js.map +1 -1
- package/lib/commonjs/hooks/useCollapsibleHeaderConsumerContext.js +1 -2
- package/lib/commonjs/hooks/useCollapsibleHeaderConsumerContext.js.map +1 -1
- package/lib/commonjs/hooks/useCollapsibleHeaderContext.js +1 -2
- package/lib/commonjs/hooks/useCollapsibleHeaderContext.js.map +1 -1
- package/lib/commonjs/hooks/useInternalCollapsibleContext.js +1 -2
- package/lib/commonjs/hooks/useInternalCollapsibleContext.js.map +1 -1
- package/lib/commonjs/hooks/useKeyboardShowEvent.js.map +1 -1
- package/lib/commonjs/index.js +3 -12
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/plugins/CollapsibleFlashList.js +14 -17
- package/lib/commonjs/plugins/CollapsibleFlashList.js.map +1 -1
- package/lib/commonjs/plugins/CollapsibleLegendList.js +15 -15
- package/lib/commonjs/plugins/CollapsibleLegendList.js.map +1 -1
- package/lib/commonjs/types.js.map +1 -1
- package/lib/commonjs/utils/debounce.js +2 -6
- package/lib/commonjs/utils/debounce.js.map +1 -1
- package/lib/commonjs/utils/useSharedValueRef.js +33 -3
- package/lib/commonjs/utils/useSharedValueRef.js.map +1 -1
- package/lib/commonjs/withCollapsibleContext.js +3 -4
- package/lib/commonjs/withCollapsibleContext.js.map +1 -1
- package/lib/module/components/CollapsibleContainer.js +18 -19
- package/lib/module/components/CollapsibleContainer.js.map +1 -1
- package/lib/module/components/CollapsibleView.js +38 -29
- package/lib/module/components/CollapsibleView.js.map +1 -1
- package/lib/module/components/header/AnimatedTopView.js +3 -4
- package/lib/module/components/header/AnimatedTopView.js.map +1 -1
- package/lib/module/components/header/CollapsibleHeaderConsumer.js +8 -10
- package/lib/module/components/header/CollapsibleHeaderConsumer.js.map +1 -1
- package/lib/module/components/header/CollapsibleHeaderContainer.js +21 -15
- package/lib/module/components/header/CollapsibleHeaderContainer.js.map +1 -1
- package/lib/module/components/header/CollapsibleHeaderContainerProvider.js +10 -12
- package/lib/module/components/header/CollapsibleHeaderContainerProvider.js.map +1 -1
- package/lib/module/components/header/StickyView.js +18 -23
- package/lib/module/components/header/StickyView.js.map +1 -1
- package/lib/module/components/scrollable/CollapsibleFlatList.js +27 -41
- package/lib/module/components/scrollable/CollapsibleFlatList.js.map +1 -1
- package/lib/module/components/scrollable/CollapsibleScrollView.js +10 -12
- package/lib/module/components/scrollable/CollapsibleScrollView.js.map +1 -1
- package/lib/module/components/scrollable/CollapsibleSectionList.js +22 -35
- package/lib/module/components/scrollable/CollapsibleSectionList.js.map +1 -1
- package/lib/module/components/scrollable/useAnimatedScroll.js +44 -23
- package/lib/module/components/scrollable/useAnimatedScroll.js.map +1 -1
- package/lib/module/hooks/useCollapsibleContext.js.map +1 -1
- package/lib/module/hooks/useCollapsibleHeaderConsumerContext.js.map +1 -1
- package/lib/module/hooks/useCollapsibleHeaderContext.js.map +1 -1
- package/lib/module/hooks/useInternalCollapsibleContext.js.map +1 -1
- package/lib/module/hooks/useKeyboardShowEvent.js.map +1 -1
- package/lib/module/index.js +0 -1
- package/lib/module/index.js.map +1 -1
- package/lib/module/plugins/CollapsibleFlashList.js +12 -14
- package/lib/module/plugins/CollapsibleFlashList.js.map +1 -1
- package/lib/module/plugins/CollapsibleLegendList.js +13 -12
- package/lib/module/plugins/CollapsibleLegendList.js.map +1 -1
- package/lib/module/types.js.map +1 -1
- package/lib/module/utils/debounce.js +2 -6
- package/lib/module/utils/debounce.js.map +1 -1
- package/lib/module/utils/useSharedValueRef.js +33 -3
- package/lib/module/utils/useSharedValueRef.js.map +1 -1
- package/lib/module/withCollapsibleContext.js +2 -2
- package/lib/module/withCollapsibleContext.js.map +1 -1
- package/lib/typescript/components/CollapsibleContainer.d.ts.map +1 -1
- package/lib/typescript/components/CollapsibleView.d.ts +4 -4
- package/lib/typescript/components/CollapsibleView.d.ts.map +1 -1
- package/lib/typescript/components/header/AnimatedTopView.d.ts +2 -2
- package/lib/typescript/components/header/AnimatedTopView.d.ts.map +1 -1
- package/lib/typescript/components/header/CollapsibleHeaderContainer.d.ts.map +1 -1
- package/lib/typescript/components/header/StickyView.d.ts.map +1 -1
- package/lib/typescript/components/scrollable/CollapsibleFlatList.d.ts.map +1 -1
- package/lib/typescript/components/scrollable/CollapsibleSectionList.d.ts.map +1 -1
- package/lib/typescript/components/scrollable/useAnimatedScroll.d.ts +2 -2
- package/lib/typescript/components/scrollable/useAnimatedScroll.d.ts.map +1 -1
- package/lib/typescript/hooks/useCollapsibleContext.d.ts +0 -1
- package/lib/typescript/hooks/useCollapsibleContext.d.ts.map +1 -1
- package/lib/typescript/hooks/useCollapsibleHeaderContext.d.ts +2 -3
- package/lib/typescript/hooks/useCollapsibleHeaderContext.d.ts.map +1 -1
- package/lib/typescript/hooks/useInternalCollapsibleContext.d.ts +0 -1
- package/lib/typescript/hooks/useInternalCollapsibleContext.d.ts.map +1 -1
- package/lib/typescript/index.d.ts +0 -1
- package/lib/typescript/index.d.ts.map +1 -1
- package/lib/typescript/plugins/CollapsibleFlashList.d.ts.map +1 -1
- package/lib/typescript/plugins/CollapsibleLegendList.d.ts.map +1 -1
- package/lib/typescript/types.d.ts +12 -12
- package/lib/typescript/types.d.ts.map +1 -1
- package/lib/typescript/utils/debounce.d.ts.map +1 -1
- package/lib/typescript/utils/useSharedValueRef.d.ts +2 -2
- package/lib/typescript/utils/useSharedValueRef.d.ts.map +1 -1
- package/lib/typescript/withCollapsibleContext.d.ts.map +1 -1
- package/package.json +54 -18
- package/src/components/CollapsibleContainer.tsx +12 -3
- package/src/components/CollapsibleView.tsx +31 -10
- package/src/components/header/AnimatedTopView.tsx +5 -2
- package/src/components/header/CollapsibleHeaderContainer.tsx +18 -13
- package/src/components/header/StickyView.tsx +8 -15
- package/src/components/scrollable/CollapsibleFlatList.tsx +27 -46
- package/src/components/scrollable/CollapsibleSectionList.tsx +21 -41
- package/src/components/scrollable/useAnimatedScroll.ts +36 -22
- package/src/hooks/useCollapsibleHeaderContext.ts +2 -2
- package/src/index.tsx +0 -2
- package/src/plugins/CollapsibleFlashList.tsx +9 -9
- package/src/plugins/CollapsibleLegendList.tsx +8 -2
- package/src/types.ts +12 -12
- package/src/utils/useSharedValueRef.ts +37 -6
- package/src/withCollapsibleContext.tsx +7 -4
|
@@ -8,19 +8,14 @@ var _react = _interopRequireWildcard(require("react"));
|
|
|
8
8
|
var _reactNative = require("react-native");
|
|
9
9
|
var _reactNativeReanimated = _interopRequireWildcard(require("react-native-reanimated"));
|
|
10
10
|
var _useCollapsibleHeaderContext = _interopRequireDefault(require("../../hooks/useCollapsibleHeaderContext"));
|
|
11
|
-
function _interopRequireDefault(
|
|
12
|
-
function
|
|
13
|
-
function
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
children,
|
|
20
|
-
style,
|
|
21
|
-
stickyRef
|
|
22
|
-
} = _ref;
|
|
23
|
-
const key = (0, _react.useMemo)(() => `sticky_${stickyKey++}`, []);
|
|
11
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
12
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
13
|
+
function StickyView({
|
|
14
|
+
children,
|
|
15
|
+
style,
|
|
16
|
+
stickyRef
|
|
17
|
+
}) {
|
|
18
|
+
const key = `sticky_${(0, _react.useId)()}`;
|
|
24
19
|
const {
|
|
25
20
|
handleStickyViewLayout,
|
|
26
21
|
animatedY
|
|
@@ -28,16 +23,16 @@ function StickyView(_ref) {
|
|
|
28
23
|
const currentLayout = (0, _reactNativeReanimated.useSharedValue)(undefined);
|
|
29
24
|
(0, _react.useEffect)(() => {
|
|
30
25
|
return () => handleStickyViewLayout(key, undefined);
|
|
26
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
31
27
|
}, [key]);
|
|
32
|
-
const handleLayout = (
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
currentLayout.value = layout;
|
|
28
|
+
const handleLayout = ({
|
|
29
|
+
nativeEvent: {
|
|
30
|
+
layout
|
|
31
|
+
}
|
|
32
|
+
}) => {
|
|
33
|
+
currentLayout.set(layout);
|
|
39
34
|
handleStickyViewLayout(key, layout);
|
|
40
|
-
}
|
|
35
|
+
};
|
|
41
36
|
const translateY = (0, _reactNativeReanimated.useDerivedValue)(() => {
|
|
42
37
|
if (!currentLayout.value) {
|
|
43
38
|
return 0;
|
|
@@ -47,7 +42,7 @@ function StickyView(_ref) {
|
|
|
47
42
|
y: top
|
|
48
43
|
} = currentLayout.value;
|
|
49
44
|
const topValue = top;
|
|
50
|
-
return (0, _reactNativeReanimated.interpolate)(animatedY.value, [0, topValue, topValue + stickyHeight + 100000], [0, 0, stickyHeight + 100000],
|
|
45
|
+
return (0, _reactNativeReanimated.interpolate)(animatedY.value, [0, topValue, topValue + stickyHeight + 100000], [0, 0, stickyHeight + 100000], 'clamp');
|
|
51
46
|
}, []);
|
|
52
47
|
const animatedStyle = (0, _reactNativeReanimated.useAnimatedStyle)(() => {
|
|
53
48
|
return {
|
|
@@ -57,9 +52,7 @@ function StickyView(_ref) {
|
|
|
57
52
|
};
|
|
58
53
|
}, []);
|
|
59
54
|
return /*#__PURE__*/_react.default.createElement(_reactNativeReanimated.default.View, {
|
|
60
|
-
key: key
|
|
61
|
-
// @ts-ignore
|
|
62
|
-
,
|
|
55
|
+
key: key,
|
|
63
56
|
ref: stickyRef,
|
|
64
57
|
onLayout: handleLayout,
|
|
65
58
|
style: [styles.container, style, animatedStyle],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_reactNativeReanimated","_useCollapsibleHeaderContext","_interopRequireDefault","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_reactNativeReanimated","_useCollapsibleHeaderContext","_interopRequireDefault","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","StickyView","children","style","stickyRef","key","useId","handleStickyViewLayout","animatedY","useCollapsibleHeaderContext","currentLayout","useSharedValue","undefined","useEffect","handleLayout","nativeEvent","layout","translateY","useDerivedValue","value","height","stickyHeight","y","top","topValue","interpolate","animatedStyle","useAnimatedStyle","transform","createElement","View","ref","onLayout","styles","container","pointerEvents","StyleSheet","create","backgroundColor","zIndex"],"sourceRoot":"../../../../src","sources":["components/header/StickyView.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -11,16 +11,13 @@ var _useAnimatedScroll = _interopRequireDefault(require("./useAnimatedScroll"));
|
|
|
11
11
|
var _useInternalCollapsibleContext = _interopRequireDefault(require("../../hooks/useInternalCollapsibleContext"));
|
|
12
12
|
var _AnimatedTopView = _interopRequireDefault(require("../header/AnimatedTopView"));
|
|
13
13
|
var _useCollapsibleContext = _interopRequireDefault(require("../../hooks/useCollapsibleContext"));
|
|
14
|
-
function _interopRequireDefault(
|
|
15
|
-
function
|
|
16
|
-
function
|
|
17
|
-
function
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
headerSnappable = true,
|
|
22
|
-
...props
|
|
23
|
-
} = _ref;
|
|
14
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
15
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
16
|
+
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
|
|
17
|
+
function CollapsibleFlatList({
|
|
18
|
+
headerSnappable = true,
|
|
19
|
+
...props
|
|
20
|
+
}) {
|
|
24
21
|
const {
|
|
25
22
|
headerHeight
|
|
26
23
|
} = (0, _useCollapsibleContext.default)();
|
|
@@ -30,25 +27,24 @@ function CollapsibleFlatList(_ref) {
|
|
|
30
27
|
fixedHeaderHeight
|
|
31
28
|
} = (0, _useInternalCollapsibleContext.default)();
|
|
32
29
|
const mounted = (0, _react.useRef)(true);
|
|
33
|
-
const contentHeight = (0, _react.useRef)(0);
|
|
34
|
-
const [internalContentMinHeight, setInternalContentMinHeight] = (0, _react.useState)(contentMinHeight.value);
|
|
35
30
|
const [internalProgressViewOffset, setInternalProgressViewOffset] = (0, _react.useState)(0);
|
|
36
31
|
(0, _react.useEffect)(() => {
|
|
37
32
|
return () => {
|
|
38
33
|
mounted.current = false;
|
|
39
34
|
};
|
|
40
35
|
}, []);
|
|
41
|
-
const scrollTo = (0, _react.useCallback)(
|
|
36
|
+
const scrollTo = (0, _react.useCallback)((yValue, animated = true) => {
|
|
42
37
|
var _scrollViewRef$curren, _scrollViewRef$curren2;
|
|
43
|
-
|
|
44
|
-
(_scrollViewRef$curren = scrollViewRef.current) === null || _scrollViewRef$curren === void 0 || (_scrollViewRef$curren2 = _scrollViewRef$curren.scrollToOffset) === null || _scrollViewRef$curren2 === void 0 ? void 0 : _scrollViewRef$curren2.call(_scrollViewRef$curren, {
|
|
38
|
+
(_scrollViewRef$curren = scrollViewRef.current) === null || _scrollViewRef$curren === void 0 || (_scrollViewRef$curren2 = _scrollViewRef$curren.scrollToOffset) === null || _scrollViewRef$curren2 === void 0 || _scrollViewRef$curren2.call(_scrollViewRef$curren, {
|
|
45
39
|
offset: yValue,
|
|
46
40
|
animated
|
|
47
41
|
});
|
|
42
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
48
43
|
}, []);
|
|
49
44
|
const scrollToIndex = (0, _react.useCallback)(params => {
|
|
50
45
|
var _scrollViewRef$curren3, _scrollViewRef$curren4;
|
|
51
|
-
(_scrollViewRef$curren3 = scrollViewRef.current) === null || _scrollViewRef$curren3 === void 0 || (_scrollViewRef$curren4 = _scrollViewRef$curren3.scrollToIndex) === null || _scrollViewRef$curren4 === void 0
|
|
46
|
+
(_scrollViewRef$curren3 = scrollViewRef.current) === null || _scrollViewRef$curren3 === void 0 || (_scrollViewRef$curren4 = _scrollViewRef$curren3.scrollToIndex) === null || _scrollViewRef$curren4 === void 0 || _scrollViewRef$curren4.call(_scrollViewRef$curren3, params);
|
|
47
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
52
48
|
}, []);
|
|
53
49
|
const scrollToLocation = (0, _react.useCallback)(() => {
|
|
54
50
|
console.warn('CollapsibleFlatList does not support scrollToLocation');
|
|
@@ -61,25 +57,11 @@ function CollapsibleFlatList(_ref) {
|
|
|
61
57
|
scrollToIndex,
|
|
62
58
|
scrollToLocation
|
|
63
59
|
});
|
|
64
|
-
const handleInternalContentHeight = (0, _react.useCallback)(value => {
|
|
65
|
-
if (mounted.current) {
|
|
66
|
-
setInternalContentMinHeight(value);
|
|
67
|
-
}
|
|
68
|
-
}, []);
|
|
69
60
|
const handleInternalProgressViewOffset = (0, _react.useCallback)(value => {
|
|
70
61
|
if (mounted.current) {
|
|
71
62
|
setInternalProgressViewOffset(value);
|
|
72
63
|
}
|
|
73
64
|
}, []);
|
|
74
|
-
(0, _reactNativeReanimated.useAnimatedReaction)(() => {
|
|
75
|
-
return contentMinHeight.value;
|
|
76
|
-
}, (result, previous) => {
|
|
77
|
-
if (result !== previous) {
|
|
78
|
-
if (contentHeight.current < result && internalContentMinHeight !== result) {
|
|
79
|
-
(0, _reactNativeReanimated.runOnJS)(handleInternalContentHeight)(result);
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
});
|
|
83
65
|
(0, _reactNativeReanimated.useAnimatedReaction)(() => {
|
|
84
66
|
return fixedHeaderHeight.value;
|
|
85
67
|
}, (result, previous) => {
|
|
@@ -87,19 +69,24 @@ function CollapsibleFlatList(_ref) {
|
|
|
87
69
|
(0, _reactNativeReanimated.runOnJS)(handleInternalProgressViewOffset)(result);
|
|
88
70
|
}
|
|
89
71
|
});
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
72
|
+
|
|
73
|
+
// Animate minHeight on the UI thread instead of bouncing through React state.
|
|
74
|
+
// Skip applying minHeight when the value is 0 to avoid forcing a 0-height
|
|
75
|
+
// layout on the first frame before the container has been measured.
|
|
76
|
+
const listHeaderStyle = (0, _reactNativeReanimated.useAnimatedStyle)(() => ({
|
|
77
|
+
minHeight: contentMinHeight.value > 0 ? contentMinHeight.value : undefined
|
|
78
|
+
}), []);
|
|
79
|
+
const contentContainerStyle = (0, _react.useMemo)(() => [styles.contentContainer, props.contentContainerStyle], [props.contentContainerStyle]);
|
|
96
80
|
const handleScrollToIndexFailed = (0, _react.useCallback)(() => {}, []);
|
|
81
|
+
const ListHeaderComponent = props.ListHeaderComponent;
|
|
97
82
|
function renderListHeader() {
|
|
98
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
83
|
+
return /*#__PURE__*/_react.default.createElement(_reactNativeReanimated.default.View, {
|
|
84
|
+
style: listHeaderStyle
|
|
85
|
+
}, /*#__PURE__*/_react.default.createElement(_AnimatedTopView.default, {
|
|
99
86
|
height: headerHeight
|
|
100
|
-
}),
|
|
87
|
+
}), ListHeaderComponent && (/*#__PURE__*/_react.default.isValidElement(ListHeaderComponent) ? ListHeaderComponent : /*#__PURE__*/_react.default.createElement(ListHeaderComponent)));
|
|
101
88
|
}
|
|
102
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
89
|
+
return /*#__PURE__*/_react.default.createElement(_reactNativeReanimated.default.FlatList, _extends({
|
|
103
90
|
ref: scrollViewRef,
|
|
104
91
|
keyboardDismissMode: "on-drag",
|
|
105
92
|
keyboardShouldPersistTaps: "handled",
|
|
@@ -109,8 +96,7 @@ function CollapsibleFlatList(_ref) {
|
|
|
109
96
|
style: [_reactNative.StyleSheet.absoluteFill, props.style],
|
|
110
97
|
contentContainerStyle: contentContainerStyle,
|
|
111
98
|
onScroll: scrollHandler,
|
|
112
|
-
ListHeaderComponent: renderListHeader()
|
|
113
|
-
onContentSizeChange: handleContentSizeChange
|
|
99
|
+
ListHeaderComponent: renderListHeader()
|
|
114
100
|
//@ts-ignore
|
|
115
101
|
,
|
|
116
102
|
simultaneousHandlers: [],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_reactNativeReanimated","_useAnimatedScroll","_interopRequireDefault","_useInternalCollapsibleContext","_AnimatedTopView","_useCollapsibleContext","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_reactNativeReanimated","_useAnimatedScroll","_interopRequireDefault","_useInternalCollapsibleContext","_AnimatedTopView","_useCollapsibleContext","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","CollapsibleFlatList","headerSnappable","props","headerHeight","useCollapsibleContext","contentMinHeight","scrollViewRef","fixedHeaderHeight","useInternalCollapsibleContext","mounted","useRef","internalProgressViewOffset","setInternalProgressViewOffset","useState","useEffect","current","scrollTo","useCallback","yValue","animated","_scrollViewRef$curren","_scrollViewRef$curren2","scrollToOffset","offset","scrollToIndex","params","_scrollViewRef$curren3","_scrollViewRef$curren4","scrollToLocation","console","warn","scrollHandler","useAnimatedScroll","handleInternalProgressViewOffset","value","useAnimatedReaction","result","previous","runOnJS","listHeaderStyle","useAnimatedStyle","minHeight","undefined","contentContainerStyle","useMemo","styles","contentContainer","handleScrollToIndexFailed","ListHeaderComponent","renderListHeader","createElement","View","style","height","React","isValidElement","FlatList","ref","keyboardDismissMode","keyboardShouldPersistTaps","scrollEventThrottle","onScrollToIndexFailed","StyleSheet","absoluteFill","onScroll","simultaneousHandlers","progressViewOffset","create","flexGrow","topView","position","top","left","right"],"sourceRoot":"../../../../src","sources":["components/scrollable/CollapsibleFlatList.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -11,18 +11,16 @@ var _reactNative = require("react-native");
|
|
|
11
11
|
var _reactNativeReanimated = _interopRequireWildcard(require("react-native-reanimated"));
|
|
12
12
|
var _useCollapsibleContext = _interopRequireDefault(require("../../hooks/useCollapsibleContext"));
|
|
13
13
|
var _useInternalCollapsibleContext = _interopRequireDefault(require("../../hooks/useInternalCollapsibleContext"));
|
|
14
|
-
function
|
|
15
|
-
function
|
|
16
|
-
function
|
|
17
|
-
function
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
...props
|
|
25
|
-
} = _ref;
|
|
14
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
15
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
16
|
+
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } /* eslint-disable react-hooks/exhaustive-deps */
|
|
17
|
+
function CollapsibleScrollView({
|
|
18
|
+
headerSnappable = true,
|
|
19
|
+
children,
|
|
20
|
+
refreshing = false,
|
|
21
|
+
onRefresh,
|
|
22
|
+
...props
|
|
23
|
+
}) {
|
|
26
24
|
const {
|
|
27
25
|
contentMinHeight,
|
|
28
26
|
scrollViewRef,
|
|
@@ -38,10 +36,9 @@ function CollapsibleScrollView(_ref) {
|
|
|
38
36
|
mounted.current = false;
|
|
39
37
|
};
|
|
40
38
|
}, []);
|
|
41
|
-
const scrollTo = (0, _react.useCallback)(
|
|
39
|
+
const scrollTo = (0, _react.useCallback)((yValue, animated = true) => {
|
|
42
40
|
var _scrollViewRef$curren, _scrollViewRef$curren2;
|
|
43
|
-
|
|
44
|
-
(_scrollViewRef$curren = scrollViewRef.current) === null || _scrollViewRef$curren === void 0 || (_scrollViewRef$curren2 = _scrollViewRef$curren.scrollTo) === null || _scrollViewRef$curren2 === void 0 ? void 0 : _scrollViewRef$curren2.call(_scrollViewRef$curren, {
|
|
41
|
+
(_scrollViewRef$curren = scrollViewRef.current) === null || _scrollViewRef$curren === void 0 || (_scrollViewRef$curren2 = _scrollViewRef$curren.scrollTo) === null || _scrollViewRef$curren2 === void 0 || _scrollViewRef$curren2.call(_scrollViewRef$curren, {
|
|
45
42
|
y: yValue,
|
|
46
43
|
animated
|
|
47
44
|
});
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_AnimatedTopView","_interopRequireDefault","require","_useAnimatedScroll","_react","_interopRequireWildcard","_reactNative","_reactNativeReanimated","_useCollapsibleContext","_useInternalCollapsibleContext","
|
|
1
|
+
{"version":3,"names":["_AnimatedTopView","_interopRequireDefault","require","_useAnimatedScroll","_react","_interopRequireWildcard","_reactNative","_reactNativeReanimated","_useCollapsibleContext","_useInternalCollapsibleContext","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","CollapsibleScrollView","headerSnappable","children","refreshing","onRefresh","props","contentMinHeight","scrollViewRef","fixedHeaderHeight","useInternalCollapsibleContext","headerHeight","useCollapsibleContext","internalProgressViewOffset","setInternalProgressViewOffset","useState","mounted","useRef","useEffect","current","scrollTo","useCallback","yValue","animated","_scrollViewRef$curren","_scrollViewRef$curren2","y","scrollToIndex","console","warn","scrollToLocation","scrollHandler","useAnimatedScroll","animatedStyle","useAnimatedStyle","minHeight","value","handleInternalProgressViewOffset","useAnimatedReaction","result","previous","runOnJS","contentContainerStyle","useMemo","styles","contentContainer","createElement","ScrollView","ref","refreshControl","RefreshControl","progressViewOffset","undefined","style","StyleSheet","absoluteFill","onScroll","keyboardDismissMode","keyboardShouldPersistTaps","scrollEventThrottle","View","height","create","flexGrow"],"sourceRoot":"../../../../src","sources":["components/scrollable/CollapsibleScrollView.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -11,16 +11,14 @@ var _useAnimatedScroll = _interopRequireDefault(require("./useAnimatedScroll"));
|
|
|
11
11
|
var _useInternalCollapsibleContext = _interopRequireDefault(require("../../hooks/useInternalCollapsibleContext"));
|
|
12
12
|
var _AnimatedTopView = _interopRequireDefault(require("../header/AnimatedTopView"));
|
|
13
13
|
var _useCollapsibleContext = _interopRequireDefault(require("../../hooks/useCollapsibleContext"));
|
|
14
|
-
function _interopRequireDefault(
|
|
15
|
-
function
|
|
16
|
-
function
|
|
17
|
-
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
14
|
+
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
15
|
+
function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
|
|
16
|
+
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
|
|
18
17
|
const AnimatedSectionList = _reactNativeReanimated.default.createAnimatedComponent(_reactNative.SectionList);
|
|
19
|
-
function CollapsibleSectionList(
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
} = _ref;
|
|
18
|
+
function CollapsibleSectionList({
|
|
19
|
+
headerSnappable = true,
|
|
20
|
+
...props
|
|
21
|
+
}) {
|
|
24
22
|
const {
|
|
25
23
|
headerHeight
|
|
26
24
|
} = (0, _useCollapsibleContext.default)();
|
|
@@ -30,8 +28,6 @@ function CollapsibleSectionList(_ref) {
|
|
|
30
28
|
fixedHeaderHeight
|
|
31
29
|
} = (0, _useInternalCollapsibleContext.default)();
|
|
32
30
|
const mounted = (0, _react.useRef)(true);
|
|
33
|
-
const contentHeight = (0, _react.useRef)(0);
|
|
34
|
-
const [internalContentMinHeight, setInternalContentMinHeight] = (0, _react.useState)(contentMinHeight.value);
|
|
35
31
|
const [internalProgressViewOffset, setInternalProgressViewOffset] = (0, _react.useState)(0);
|
|
36
32
|
(0, _react.useEffect)(() => {
|
|
37
33
|
return () => {
|
|
@@ -46,7 +42,7 @@ function CollapsibleSectionList(_ref) {
|
|
|
46
42
|
}, []);
|
|
47
43
|
const scrollToLocation = (0, _react.useCallback)(params => {
|
|
48
44
|
var _scrollViewRef$curren, _scrollViewRef$curren2;
|
|
49
|
-
(_scrollViewRef$curren = scrollViewRef.current) === null || _scrollViewRef$curren === void 0 || (_scrollViewRef$curren2 = _scrollViewRef$curren.scrollToLocation) === null || _scrollViewRef$curren2 === void 0
|
|
45
|
+
(_scrollViewRef$curren = scrollViewRef.current) === null || _scrollViewRef$curren === void 0 || (_scrollViewRef$curren2 = _scrollViewRef$curren.scrollToLocation) === null || _scrollViewRef$curren2 === void 0 || _scrollViewRef$curren2.call(_scrollViewRef$curren, params);
|
|
50
46
|
}, [scrollViewRef]);
|
|
51
47
|
const {
|
|
52
48
|
scrollHandler
|
|
@@ -56,25 +52,11 @@ function CollapsibleSectionList(_ref) {
|
|
|
56
52
|
scrollToIndex,
|
|
57
53
|
scrollToLocation
|
|
58
54
|
});
|
|
59
|
-
const handleInternalContentHeight = (0, _react.useCallback)(value => {
|
|
60
|
-
if (mounted.current) {
|
|
61
|
-
setInternalContentMinHeight(value);
|
|
62
|
-
}
|
|
63
|
-
}, []);
|
|
64
55
|
const handleInternalProgressViewOffset = (0, _react.useCallback)(value => {
|
|
65
56
|
if (mounted.current) {
|
|
66
57
|
setInternalProgressViewOffset(value);
|
|
67
58
|
}
|
|
68
59
|
}, []);
|
|
69
|
-
(0, _reactNativeReanimated.useAnimatedReaction)(() => {
|
|
70
|
-
return contentMinHeight.value;
|
|
71
|
-
}, (result, previous) => {
|
|
72
|
-
if (result !== previous) {
|
|
73
|
-
if (contentHeight.current < result && internalContentMinHeight !== result) {
|
|
74
|
-
(0, _reactNativeReanimated.runOnJS)(handleInternalContentHeight)(result);
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
});
|
|
78
60
|
(0, _reactNativeReanimated.useAnimatedReaction)(() => {
|
|
79
61
|
return fixedHeaderHeight.value;
|
|
80
62
|
}, (result, previous) => {
|
|
@@ -82,17 +64,22 @@ function CollapsibleSectionList(_ref) {
|
|
|
82
64
|
(0, _reactNativeReanimated.runOnJS)(handleInternalProgressViewOffset)(result);
|
|
83
65
|
}
|
|
84
66
|
});
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
67
|
+
|
|
68
|
+
// Animate minHeight on the UI thread instead of bouncing through React state.
|
|
69
|
+
// Skip applying minHeight when the value is 0 to avoid forcing a 0-height
|
|
70
|
+
// layout on the first frame before the container has been measured.
|
|
71
|
+
const listHeaderStyle = (0, _reactNativeReanimated.useAnimatedStyle)(() => ({
|
|
72
|
+
minHeight: contentMinHeight.value > 0 ? contentMinHeight.value : undefined
|
|
73
|
+
}), []);
|
|
74
|
+
const contentContainerStyle = (0, _react.useMemo)(() => [styles.contentContainer, props.contentContainerStyle], [props.contentContainerStyle]);
|
|
91
75
|
const handleScrollToIndexFailed = (0, _react.useCallback)(() => {}, []);
|
|
76
|
+
const ListHeaderComponent = props.ListHeaderComponent;
|
|
92
77
|
function renderListHeader() {
|
|
93
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
78
|
+
return /*#__PURE__*/_react.default.createElement(_reactNativeReanimated.default.View, {
|
|
79
|
+
style: listHeaderStyle
|
|
80
|
+
}, /*#__PURE__*/_react.default.createElement(_AnimatedTopView.default, {
|
|
94
81
|
height: headerHeight
|
|
95
|
-
}),
|
|
82
|
+
}), ListHeaderComponent && (/*#__PURE__*/_react.default.isValidElement(ListHeaderComponent) ? ListHeaderComponent : /*#__PURE__*/_react.default.createElement(ListHeaderComponent)));
|
|
96
83
|
}
|
|
97
84
|
return /*#__PURE__*/_react.default.createElement(AnimatedSectionList, _extends({
|
|
98
85
|
ref: scrollViewRef,
|
|
@@ -104,8 +91,7 @@ function CollapsibleSectionList(_ref) {
|
|
|
104
91
|
style: [_reactNative.StyleSheet.absoluteFill, props.style],
|
|
105
92
|
contentContainerStyle: contentContainerStyle,
|
|
106
93
|
onScroll: scrollHandler,
|
|
107
|
-
ListHeaderComponent: renderListHeader()
|
|
108
|
-
onContentSizeChange: handleContentSizeChange
|
|
94
|
+
ListHeaderComponent: renderListHeader()
|
|
109
95
|
//@ts-ignore
|
|
110
96
|
,
|
|
111
97
|
simultaneousHandlers: [],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_reactNativeReanimated","_useAnimatedScroll","_interopRequireDefault","_useInternalCollapsibleContext","_AnimatedTopView","_useCollapsibleContext","
|
|
1
|
+
{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_reactNativeReanimated","_useAnimatedScroll","_interopRequireDefault","_useInternalCollapsibleContext","_AnimatedTopView","_useCollapsibleContext","e","__esModule","default","t","WeakMap","r","n","o","i","f","__proto__","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","AnimatedSectionList","Animated","createAnimatedComponent","SectionList","CollapsibleSectionList","headerSnappable","props","headerHeight","useCollapsibleContext","contentMinHeight","scrollViewRef","fixedHeaderHeight","useInternalCollapsibleContext","mounted","useRef","internalProgressViewOffset","setInternalProgressViewOffset","useState","useEffect","current","scrollTo","useCallback","console","warn","scrollToIndex","scrollToLocation","params","_scrollViewRef$curren","_scrollViewRef$curren2","scrollHandler","useAnimatedScroll","handleInternalProgressViewOffset","value","useAnimatedReaction","result","previous","runOnJS","listHeaderStyle","useAnimatedStyle","minHeight","undefined","contentContainerStyle","useMemo","styles","contentContainer","handleScrollToIndexFailed","ListHeaderComponent","renderListHeader","createElement","View","style","height","React","isValidElement","ref","keyboardDismissMode","keyboardShouldPersistTaps","scrollEventThrottle","onScrollToIndexFailed","StyleSheet","absoluteFill","onScroll","simultaneousHandlers","progressViewOffset","create","flexGrow","topView","position","top","left","right"],"sourceRoot":"../../../../src","sources":["components/scrollable/CollapsibleSectionList.tsx"],"mappings":"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","ignoreList":[]}
|