@react-native-ohos/react-native-tab-view 4.0.11-rc.1
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/LICENSE +21 -0
- package/README.OpenSource +11 -0
- package/README.md +9 -0
- package/lib/module/Pager.android.js +4 -0
- package/lib/module/Pager.android.js.map +1 -0
- package/lib/module/Pager.ios.js +4 -0
- package/lib/module/Pager.ios.js.map +1 -0
- package/lib/module/Pager.js +4 -0
- package/lib/module/Pager.js.map +1 -0
- package/lib/module/PagerViewAdapter.js +126 -0
- package/lib/module/PagerViewAdapter.js.map +1 -0
- package/lib/module/PanResponderAdapter.js +200 -0
- package/lib/module/PanResponderAdapter.js.map +1 -0
- package/lib/module/PlatformPressable.js +59 -0
- package/lib/module/PlatformPressable.js.map +1 -0
- package/lib/module/SceneMap.js +24 -0
- package/lib/module/SceneMap.js.map +1 -0
- package/lib/module/SceneView.js +73 -0
- package/lib/module/SceneView.js.map +1 -0
- package/lib/module/TabBar.js +472 -0
- package/lib/module/TabBar.js.map +1 -0
- package/lib/module/TabBarIndicator.js +122 -0
- package/lib/module/TabBarIndicator.js.map +1 -0
- package/lib/module/TabBarItem.js +218 -0
- package/lib/module/TabBarItem.js.map +1 -0
- package/lib/module/TabBarItemLabel.js +33 -0
- package/lib/module/TabBarItemLabel.js.map +1 -0
- package/lib/module/TabView.js +140 -0
- package/lib/module/TabView.js.map +1 -0
- package/lib/module/index.js +8 -0
- package/lib/module/index.js.map +1 -0
- package/lib/module/package.json +1 -0
- package/lib/module/types.js +4 -0
- package/lib/module/types.js.map +1 -0
- package/lib/module/useAnimatedValue.js +12 -0
- package/lib/module/useAnimatedValue.js.map +1 -0
- package/lib/typescript/package.json +1 -0
- package/lib/typescript/src/Pager.android.d.ts +2 -0
- package/lib/typescript/src/Pager.android.d.ts.map +1 -0
- package/lib/typescript/src/Pager.d.ts +2 -0
- package/lib/typescript/src/Pager.d.ts.map +1 -0
- package/lib/typescript/src/Pager.ios.d.ts +2 -0
- package/lib/typescript/src/Pager.ios.d.ts.map +1 -0
- package/lib/typescript/src/PagerViewAdapter.d.ts +15 -0
- package/lib/typescript/src/PagerViewAdapter.d.ts.map +1 -0
- package/lib/typescript/src/PanResponderAdapter.d.ts +16 -0
- package/lib/typescript/src/PanResponderAdapter.d.ts.map +1 -0
- package/lib/typescript/src/PlatformPressable.d.ts +13 -0
- package/lib/typescript/src/PlatformPressable.d.ts.map +1 -0
- package/lib/typescript/src/SceneMap.d.ts +10 -0
- package/lib/typescript/src/SceneMap.d.ts.map +1 -0
- package/lib/typescript/src/SceneView.d.ts +16 -0
- package/lib/typescript/src/SceneView.d.ts.map +1 -0
- package/lib/typescript/src/TabBar.d.ts +32 -0
- package/lib/typescript/src/TabBar.d.ts.map +1 -0
- package/lib/typescript/src/TabBarIndicator.d.ts +15 -0
- package/lib/typescript/src/TabBarIndicator.d.ts.map +1 -0
- package/lib/typescript/src/TabBarItem.d.ts +19 -0
- package/lib/typescript/src/TabBarItem.d.ts.map +1 -0
- package/lib/typescript/src/TabBarItemLabel.d.ts +11 -0
- package/lib/typescript/src/TabBarItemLabel.d.ts.map +1 -0
- package/lib/typescript/src/TabView.d.ts +30 -0
- package/lib/typescript/src/TabView.d.ts.map +1 -0
- package/lib/typescript/src/index.d.ts +11 -0
- package/lib/typescript/src/index.d.ts.map +1 -0
- package/lib/typescript/src/types.d.ts +70 -0
- package/lib/typescript/src/types.d.ts.map +1 -0
- package/lib/typescript/src/useAnimatedValue.d.ts +3 -0
- package/lib/typescript/src/useAnimatedValue.d.ts.map +1 -0
- package/package.json +79 -0
- package/src/Pager.android.tsx +1 -0
- package/src/Pager.ios.tsx +1 -0
- package/src/Pager.tsx +1 -0
- package/src/PagerViewAdapter.tsx +182 -0
- package/src/PanResponderAdapter.tsx +339 -0
- package/src/PlatformPressable.tsx +75 -0
- package/src/SceneMap.tsx +30 -0
- package/src/SceneView.tsx +107 -0
- package/src/TabBar.tsx +729 -0
- package/src/TabBarIndicator.tsx +190 -0
- package/src/TabBarItem.tsx +305 -0
- package/src/TabBarItemLabel.tsx +42 -0
- package/src/TabView.tsx +195 -0
- package/src/index.tsx +15 -0
- package/src/types.tsx +87 -0
- package/src/useAnimatedValue.tsx +12 -0
|
@@ -0,0 +1,472 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import { Animated, I18nManager, Platform, StyleSheet, View } from 'react-native';
|
|
5
|
+
import useLatestCallback from 'use-latest-callback';
|
|
6
|
+
import { TabBarIndicator } from "./TabBarIndicator.js";
|
|
7
|
+
import { TabBarItem } from "./TabBarItem.js";
|
|
8
|
+
import { useAnimatedValue } from "./useAnimatedValue.js";
|
|
9
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
10
|
+
import { createElement as _createElement } from "react";
|
|
11
|
+
const useNativeDriver = Platform.OS !== 'web';
|
|
12
|
+
const Separator = ({
|
|
13
|
+
width
|
|
14
|
+
}) => {
|
|
15
|
+
return /*#__PURE__*/_jsx(View, {
|
|
16
|
+
style: {
|
|
17
|
+
width
|
|
18
|
+
}
|
|
19
|
+
});
|
|
20
|
+
};
|
|
21
|
+
const getFlattenedTabWidth = style => {
|
|
22
|
+
const tabStyle = StyleSheet.flatten(style);
|
|
23
|
+
return tabStyle?.width;
|
|
24
|
+
};
|
|
25
|
+
const getFlattenedPaddingStart = style => {
|
|
26
|
+
const flattenStyle = StyleSheet.flatten(style);
|
|
27
|
+
return flattenStyle ? flattenStyle.paddingLeft || flattenStyle.paddingStart || flattenStyle.paddingHorizontal || 0 : 0;
|
|
28
|
+
};
|
|
29
|
+
const getFlattenedPaddingEnd = style => {
|
|
30
|
+
const flattenStyle = StyleSheet.flatten(style);
|
|
31
|
+
return flattenStyle ? flattenStyle.paddingRight || flattenStyle.paddingEnd || flattenStyle.paddingHorizontal || 0 : 0;
|
|
32
|
+
};
|
|
33
|
+
const convertPaddingPercentToSize = (value, layout) => {
|
|
34
|
+
switch (typeof value) {
|
|
35
|
+
case 'number':
|
|
36
|
+
return value;
|
|
37
|
+
case 'string':
|
|
38
|
+
if (value.endsWith('%')) {
|
|
39
|
+
const width = parseFloat(value);
|
|
40
|
+
if (Number.isFinite(width)) {
|
|
41
|
+
return layout.width * (width / 100);
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
return 0;
|
|
46
|
+
};
|
|
47
|
+
const getComputedTabWidth = (index, layout, routes, scrollEnabled, tabWidths, flattenedWidth, flattenedPaddingStart, flattenedPaddingEnd, gap) => {
|
|
48
|
+
if (flattenedWidth === 'auto') {
|
|
49
|
+
return tabWidths[routes[index].key] || 0;
|
|
50
|
+
}
|
|
51
|
+
switch (typeof flattenedWidth) {
|
|
52
|
+
case 'number':
|
|
53
|
+
return flattenedWidth;
|
|
54
|
+
case 'string':
|
|
55
|
+
if (flattenedWidth.endsWith('%')) {
|
|
56
|
+
const width = parseFloat(flattenedWidth);
|
|
57
|
+
if (Number.isFinite(width)) {
|
|
58
|
+
return layout.width * (width / 100);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
if (scrollEnabled) {
|
|
63
|
+
return layout.width / 5 * 2;
|
|
64
|
+
}
|
|
65
|
+
const gapTotalWidth = (gap ?? 0) * (routes.length - 1);
|
|
66
|
+
const paddingTotalWidth = convertPaddingPercentToSize(flattenedPaddingStart, layout) + convertPaddingPercentToSize(flattenedPaddingEnd, layout);
|
|
67
|
+
return (layout.width - gapTotalWidth - paddingTotalWidth) / routes.length;
|
|
68
|
+
};
|
|
69
|
+
const getMaxScrollDistance = (tabBarWidth, layoutWidth) => tabBarWidth - layoutWidth;
|
|
70
|
+
const getTranslateX = (scrollAmount, maxScrollDistance, direction) => Animated.multiply(Platform.OS === 'android' && direction === 'rtl' ? Animated.add(maxScrollDistance, Animated.multiply(scrollAmount, -1)) : scrollAmount, direction === 'rtl' ? 1 : -1);
|
|
71
|
+
const getTabBarWidth = ({
|
|
72
|
+
navigationState,
|
|
73
|
+
layout,
|
|
74
|
+
gap,
|
|
75
|
+
scrollEnabled,
|
|
76
|
+
flattenedTabWidth,
|
|
77
|
+
flattenedPaddingStart,
|
|
78
|
+
flattenedPaddingEnd,
|
|
79
|
+
tabWidths
|
|
80
|
+
}) => {
|
|
81
|
+
const {
|
|
82
|
+
routes
|
|
83
|
+
} = navigationState;
|
|
84
|
+
const paddingsWidth = Math.max(0, convertPaddingPercentToSize(flattenedPaddingStart, layout) + convertPaddingPercentToSize(flattenedPaddingEnd, layout));
|
|
85
|
+
return routes.reduce((acc, _, i) => acc + (i > 0 ? gap ?? 0 : 0) + getComputedTabWidth(i, layout, routes, scrollEnabled, tabWidths, flattenedTabWidth, flattenedPaddingStart, flattenedPaddingEnd, gap), paddingsWidth);
|
|
86
|
+
};
|
|
87
|
+
const normalizeScrollValue = ({
|
|
88
|
+
layout,
|
|
89
|
+
navigationState,
|
|
90
|
+
gap,
|
|
91
|
+
scrollEnabled,
|
|
92
|
+
tabWidths,
|
|
93
|
+
value,
|
|
94
|
+
flattenedTabWidth,
|
|
95
|
+
flattenedPaddingStart,
|
|
96
|
+
flattenedPaddingEnd,
|
|
97
|
+
direction
|
|
98
|
+
}) => {
|
|
99
|
+
const tabBarWidth = getTabBarWidth({
|
|
100
|
+
layout,
|
|
101
|
+
navigationState,
|
|
102
|
+
tabWidths,
|
|
103
|
+
gap,
|
|
104
|
+
scrollEnabled,
|
|
105
|
+
flattenedTabWidth,
|
|
106
|
+
flattenedPaddingStart,
|
|
107
|
+
flattenedPaddingEnd
|
|
108
|
+
});
|
|
109
|
+
const maxDistance = getMaxScrollDistance(tabBarWidth, layout.width);
|
|
110
|
+
const scrollValue = Math.max(Math.min(value, maxDistance), 0);
|
|
111
|
+
if (Platform.OS === 'android' && direction === 'rtl') {
|
|
112
|
+
// On Android, scroll value is not applied in reverse in RTL
|
|
113
|
+
// so we need to manually adjust it to apply correct value
|
|
114
|
+
return maxDistance - scrollValue;
|
|
115
|
+
}
|
|
116
|
+
return scrollValue;
|
|
117
|
+
};
|
|
118
|
+
const getScrollAmount = ({
|
|
119
|
+
layout,
|
|
120
|
+
navigationState,
|
|
121
|
+
gap,
|
|
122
|
+
scrollEnabled,
|
|
123
|
+
flattenedTabWidth,
|
|
124
|
+
tabWidths,
|
|
125
|
+
flattenedPaddingStart,
|
|
126
|
+
flattenedPaddingEnd,
|
|
127
|
+
direction
|
|
128
|
+
}) => {
|
|
129
|
+
const paddingInitial = direction === 'rtl' ? convertPaddingPercentToSize(flattenedPaddingEnd, layout) : convertPaddingPercentToSize(flattenedPaddingStart, layout);
|
|
130
|
+
const centerDistance = Array.from({
|
|
131
|
+
length: navigationState.index + 1
|
|
132
|
+
}).reduce((total, _, i) => {
|
|
133
|
+
const tabWidth = getComputedTabWidth(i, layout, navigationState.routes, scrollEnabled, tabWidths, flattenedTabWidth, flattenedPaddingStart, flattenedPaddingEnd, gap);
|
|
134
|
+
|
|
135
|
+
// To get the current index centered we adjust scroll amount by width of indexes
|
|
136
|
+
// 0 through (i - 1) and add half the width of current index i
|
|
137
|
+
return total + (i > 0 ? gap ?? 0 : 0) + (navigationState.index === i ? tabWidth / 2 : tabWidth);
|
|
138
|
+
}, paddingInitial);
|
|
139
|
+
const scrollAmount = centerDistance - layout.width / 2;
|
|
140
|
+
return normalizeScrollValue({
|
|
141
|
+
layout,
|
|
142
|
+
navigationState,
|
|
143
|
+
tabWidths,
|
|
144
|
+
value: scrollAmount,
|
|
145
|
+
gap,
|
|
146
|
+
scrollEnabled,
|
|
147
|
+
flattenedTabWidth,
|
|
148
|
+
flattenedPaddingStart,
|
|
149
|
+
flattenedPaddingEnd,
|
|
150
|
+
direction
|
|
151
|
+
});
|
|
152
|
+
};
|
|
153
|
+
const getLabelTextDefault = ({
|
|
154
|
+
route
|
|
155
|
+
}) => route.title;
|
|
156
|
+
const getAccessibleDefault = ({
|
|
157
|
+
route
|
|
158
|
+
}) => typeof route.accessible !== 'undefined' ? route.accessible : true;
|
|
159
|
+
const getAccessibilityLabelDefault = ({
|
|
160
|
+
route
|
|
161
|
+
}) => typeof route.accessibilityLabel === 'string' ? route.accessibilityLabel : typeof route.title === 'string' ? route.title : undefined;
|
|
162
|
+
const renderIndicatorDefault = props => /*#__PURE__*/_jsx(TabBarIndicator, {
|
|
163
|
+
...props
|
|
164
|
+
});
|
|
165
|
+
const getTestIdDefault = ({
|
|
166
|
+
route
|
|
167
|
+
}) => route.testID;
|
|
168
|
+
|
|
169
|
+
// How many items measurements should we update per batch.
|
|
170
|
+
// Defaults to 10, since that's whats FlatList is using in initialNumToRender.
|
|
171
|
+
const MEASURE_PER_BATCH = 10;
|
|
172
|
+
export function TabBar({
|
|
173
|
+
renderIndicator = renderIndicatorDefault,
|
|
174
|
+
gap = 0,
|
|
175
|
+
scrollEnabled,
|
|
176
|
+
jumpTo,
|
|
177
|
+
navigationState,
|
|
178
|
+
position,
|
|
179
|
+
activeColor,
|
|
180
|
+
bounces,
|
|
181
|
+
contentContainerStyle,
|
|
182
|
+
inactiveColor,
|
|
183
|
+
indicatorContainerStyle,
|
|
184
|
+
indicatorStyle,
|
|
185
|
+
onTabLongPress,
|
|
186
|
+
onTabPress,
|
|
187
|
+
pressColor,
|
|
188
|
+
pressOpacity,
|
|
189
|
+
direction = I18nManager.getConstants().isRTL ? 'rtl' : 'ltr',
|
|
190
|
+
renderTabBarItem,
|
|
191
|
+
style,
|
|
192
|
+
tabStyle,
|
|
193
|
+
layout: propLayout,
|
|
194
|
+
testID,
|
|
195
|
+
android_ripple,
|
|
196
|
+
options
|
|
197
|
+
}) {
|
|
198
|
+
const [layout, setLayout] = React.useState(propLayout ?? {
|
|
199
|
+
width: 0,
|
|
200
|
+
height: 0
|
|
201
|
+
});
|
|
202
|
+
const [tabWidths, setTabWidths] = React.useState({});
|
|
203
|
+
const flatListRef = React.useRef(null);
|
|
204
|
+
const isFirst = React.useRef(true);
|
|
205
|
+
const scrollAmount = useAnimatedValue(0);
|
|
206
|
+
const measuredTabWidths = React.useRef({});
|
|
207
|
+
const {
|
|
208
|
+
routes
|
|
209
|
+
} = navigationState;
|
|
210
|
+
const flattenedTabWidth = getFlattenedTabWidth(tabStyle);
|
|
211
|
+
const isWidthDynamic = flattenedTabWidth === 'auto';
|
|
212
|
+
const flattenedPaddingEnd = getFlattenedPaddingEnd(contentContainerStyle);
|
|
213
|
+
const flattenedPaddingStart = getFlattenedPaddingStart(contentContainerStyle);
|
|
214
|
+
const scrollOffset = getScrollAmount({
|
|
215
|
+
layout,
|
|
216
|
+
navigationState,
|
|
217
|
+
tabWidths,
|
|
218
|
+
gap,
|
|
219
|
+
scrollEnabled,
|
|
220
|
+
flattenedTabWidth,
|
|
221
|
+
flattenedPaddingStart,
|
|
222
|
+
flattenedPaddingEnd,
|
|
223
|
+
direction
|
|
224
|
+
});
|
|
225
|
+
const hasMeasuredTabWidths = Boolean(layout.width) && routes.slice(0, navigationState.index).every(r => typeof tabWidths[r.key] === 'number');
|
|
226
|
+
React.useEffect(() => {
|
|
227
|
+
if (isFirst.current) {
|
|
228
|
+
isFirst.current = false;
|
|
229
|
+
return;
|
|
230
|
+
}
|
|
231
|
+
if (isWidthDynamic && !hasMeasuredTabWidths) {
|
|
232
|
+
return;
|
|
233
|
+
}
|
|
234
|
+
if (scrollEnabled) {
|
|
235
|
+
flatListRef.current?.scrollToOffset({
|
|
236
|
+
offset: scrollOffset,
|
|
237
|
+
animated: true
|
|
238
|
+
});
|
|
239
|
+
}
|
|
240
|
+
}, [hasMeasuredTabWidths, isWidthDynamic, scrollEnabled, scrollOffset]);
|
|
241
|
+
const handleLayout = e => {
|
|
242
|
+
const {
|
|
243
|
+
height,
|
|
244
|
+
width
|
|
245
|
+
} = e.nativeEvent.layout;
|
|
246
|
+
setLayout(layout => layout.width === width && layout.height === height ? layout : {
|
|
247
|
+
width,
|
|
248
|
+
height
|
|
249
|
+
});
|
|
250
|
+
};
|
|
251
|
+
const tabBarWidth = getTabBarWidth({
|
|
252
|
+
layout,
|
|
253
|
+
navigationState,
|
|
254
|
+
tabWidths,
|
|
255
|
+
gap,
|
|
256
|
+
scrollEnabled,
|
|
257
|
+
flattenedTabWidth,
|
|
258
|
+
flattenedPaddingStart,
|
|
259
|
+
flattenedPaddingEnd
|
|
260
|
+
});
|
|
261
|
+
const separatorsWidth = Math.max(0, routes.length - 1) * gap;
|
|
262
|
+
const paddingsWidth = Math.max(0, convertPaddingPercentToSize(flattenedPaddingStart, layout) + convertPaddingPercentToSize(flattenedPaddingEnd, layout));
|
|
263
|
+
const translateX = React.useMemo(() => getTranslateX(scrollAmount, getMaxScrollDistance(tabBarWidth, layout.width), direction), [direction, layout.width, scrollAmount, tabBarWidth]);
|
|
264
|
+
const renderItem = React.useCallback(({
|
|
265
|
+
item: route,
|
|
266
|
+
index
|
|
267
|
+
}) => {
|
|
268
|
+
const {
|
|
269
|
+
testID = getTestIdDefault({
|
|
270
|
+
route
|
|
271
|
+
}),
|
|
272
|
+
labelText = getLabelTextDefault({
|
|
273
|
+
route
|
|
274
|
+
}),
|
|
275
|
+
accessible = getAccessibleDefault({
|
|
276
|
+
route
|
|
277
|
+
}),
|
|
278
|
+
accessibilityLabel = getAccessibilityLabelDefault({
|
|
279
|
+
route
|
|
280
|
+
}),
|
|
281
|
+
...rest
|
|
282
|
+
} = options?.[route.key] ?? {};
|
|
283
|
+
const onLayout = isWidthDynamic ? e => {
|
|
284
|
+
measuredTabWidths.current[route.key] = e.nativeEvent.layout.width;
|
|
285
|
+
|
|
286
|
+
// When we have measured widths for all of the tabs, we should updates the state
|
|
287
|
+
// We avoid doing separate setState for each layout since it triggers multiple renders and slows down app
|
|
288
|
+
// If we have more than 10 routes divide updating tabWidths into multiple batches. Here we update only first batch of 10 items.
|
|
289
|
+
if (routes.length > MEASURE_PER_BATCH && index === MEASURE_PER_BATCH && routes.slice(0, MEASURE_PER_BATCH).every(r => typeof measuredTabWidths.current[r.key] === 'number')) {
|
|
290
|
+
setTabWidths({
|
|
291
|
+
...measuredTabWidths.current
|
|
292
|
+
});
|
|
293
|
+
} else if (routes.every(r => typeof measuredTabWidths.current[r.key] === 'number')) {
|
|
294
|
+
// When we have measured widths for all of the tabs, we should updates the state
|
|
295
|
+
// We avoid doing separate setState for each layout since it triggers multiple renders and slows down app
|
|
296
|
+
setTabWidths({
|
|
297
|
+
...measuredTabWidths.current
|
|
298
|
+
});
|
|
299
|
+
}
|
|
300
|
+
} : undefined;
|
|
301
|
+
const onPress = () => {
|
|
302
|
+
const event = {
|
|
303
|
+
route,
|
|
304
|
+
defaultPrevented: false,
|
|
305
|
+
preventDefault: () => {
|
|
306
|
+
event.defaultPrevented = true;
|
|
307
|
+
}
|
|
308
|
+
};
|
|
309
|
+
onTabPress?.(event);
|
|
310
|
+
if (event.defaultPrevented) {
|
|
311
|
+
return;
|
|
312
|
+
}
|
|
313
|
+
jumpTo(route.key);
|
|
314
|
+
};
|
|
315
|
+
const onLongPress = () => onTabLongPress?.({
|
|
316
|
+
route
|
|
317
|
+
});
|
|
318
|
+
|
|
319
|
+
// Calculate the default width for tab for FlatList to work
|
|
320
|
+
const defaultTabWidth = !isWidthDynamic ? getComputedTabWidth(index, layout, routes, scrollEnabled, tabWidths, getFlattenedTabWidth(tabStyle), getFlattenedPaddingEnd(contentContainerStyle), getFlattenedPaddingStart(contentContainerStyle), gap) : undefined;
|
|
321
|
+
const props = {
|
|
322
|
+
...rest,
|
|
323
|
+
key: route.key,
|
|
324
|
+
position,
|
|
325
|
+
route,
|
|
326
|
+
navigationState,
|
|
327
|
+
testID,
|
|
328
|
+
labelText,
|
|
329
|
+
accessible,
|
|
330
|
+
accessibilityLabel,
|
|
331
|
+
activeColor,
|
|
332
|
+
inactiveColor,
|
|
333
|
+
pressColor,
|
|
334
|
+
pressOpacity,
|
|
335
|
+
onLayout,
|
|
336
|
+
onPress,
|
|
337
|
+
onLongPress,
|
|
338
|
+
style: tabStyle,
|
|
339
|
+
defaultTabWidth,
|
|
340
|
+
android_ripple
|
|
341
|
+
};
|
|
342
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
343
|
+
children: [gap > 0 && index > 0 ? /*#__PURE__*/_jsx(Separator, {
|
|
344
|
+
width: gap
|
|
345
|
+
}) : null, renderTabBarItem ? renderTabBarItem(props) : /*#__PURE__*/_createElement(TabBarItem, {
|
|
346
|
+
...props,
|
|
347
|
+
key: props.key
|
|
348
|
+
})]
|
|
349
|
+
});
|
|
350
|
+
}, [position, navigationState, options, activeColor, inactiveColor, pressColor, pressOpacity, isWidthDynamic, tabStyle, layout, routes, scrollEnabled, tabWidths, contentContainerStyle, gap, android_ripple, renderTabBarItem, onTabPress, jumpTo, onTabLongPress]);
|
|
351
|
+
const keyExtractor = React.useCallback(item => item.key, []);
|
|
352
|
+
const contentContainerStyleMemoized = React.useMemo(() => [styles.tabContent, scrollEnabled ? {
|
|
353
|
+
width: tabBarWidth
|
|
354
|
+
} : null, contentContainerStyle], [contentContainerStyle, scrollEnabled, tabBarWidth]);
|
|
355
|
+
const handleScroll = React.useMemo(() => Animated.event([{
|
|
356
|
+
nativeEvent: {
|
|
357
|
+
contentOffset: {
|
|
358
|
+
x: scrollAmount
|
|
359
|
+
}
|
|
360
|
+
}
|
|
361
|
+
}], {
|
|
362
|
+
useNativeDriver
|
|
363
|
+
}), [scrollAmount]);
|
|
364
|
+
const handleViewableItemsChanged = useLatestCallback(({
|
|
365
|
+
changed
|
|
366
|
+
}) => {
|
|
367
|
+
if (routes.length <= MEASURE_PER_BATCH) {
|
|
368
|
+
return;
|
|
369
|
+
}
|
|
370
|
+
// Get next vievable item
|
|
371
|
+
const item = changed[changed.length - 1];
|
|
372
|
+
const index = item?.index || 0;
|
|
373
|
+
if (item.isViewable && (index % 10 === 0 || index === navigationState.index || index === routes.length - 1)) {
|
|
374
|
+
setTabWidths({
|
|
375
|
+
...measuredTabWidths.current
|
|
376
|
+
});
|
|
377
|
+
}
|
|
378
|
+
});
|
|
379
|
+
return /*#__PURE__*/_jsxs(Animated.View, {
|
|
380
|
+
onLayout: handleLayout,
|
|
381
|
+
style: [styles.tabBar, style],
|
|
382
|
+
children: [/*#__PURE__*/_jsx(Animated.View, {
|
|
383
|
+
pointerEvents: "none",
|
|
384
|
+
style: [styles.indicatorContainer, scrollEnabled ? {
|
|
385
|
+
transform: [{
|
|
386
|
+
translateX
|
|
387
|
+
}]
|
|
388
|
+
} : null, scrollEnabled ? {
|
|
389
|
+
width: tabBarWidth
|
|
390
|
+
} : null, indicatorContainerStyle],
|
|
391
|
+
children: renderIndicator({
|
|
392
|
+
position,
|
|
393
|
+
layout,
|
|
394
|
+
navigationState,
|
|
395
|
+
jumpTo,
|
|
396
|
+
direction,
|
|
397
|
+
width: isWidthDynamic ? 'auto' : Math.max(0, (tabBarWidth - separatorsWidth - paddingsWidth) / routes.length),
|
|
398
|
+
style: [indicatorStyle, {
|
|
399
|
+
start: flattenedPaddingStart,
|
|
400
|
+
end: flattenedPaddingEnd
|
|
401
|
+
}],
|
|
402
|
+
getTabWidth: i => getComputedTabWidth(i, layout, routes, scrollEnabled, tabWidths, flattenedTabWidth, flattenedPaddingEnd, flattenedPaddingStart, gap),
|
|
403
|
+
gap
|
|
404
|
+
})
|
|
405
|
+
}), /*#__PURE__*/_jsx(View, {
|
|
406
|
+
style: styles.scroll,
|
|
407
|
+
children: /*#__PURE__*/_jsx(Animated.FlatList, {
|
|
408
|
+
data: routes,
|
|
409
|
+
keyExtractor: keyExtractor,
|
|
410
|
+
horizontal: true,
|
|
411
|
+
accessibilityRole: "tablist",
|
|
412
|
+
keyboardShouldPersistTaps: "handled",
|
|
413
|
+
scrollEnabled: scrollEnabled,
|
|
414
|
+
bounces: bounces,
|
|
415
|
+
initialNumToRender: MEASURE_PER_BATCH,
|
|
416
|
+
onViewableItemsChanged: handleViewableItemsChanged,
|
|
417
|
+
alwaysBounceHorizontal: false,
|
|
418
|
+
scrollsToTop: false,
|
|
419
|
+
showsHorizontalScrollIndicator: false,
|
|
420
|
+
showsVerticalScrollIndicator: false,
|
|
421
|
+
automaticallyAdjustContentInsets: false,
|
|
422
|
+
overScrollMode: "never",
|
|
423
|
+
contentContainerStyle: contentContainerStyleMemoized,
|
|
424
|
+
scrollEventThrottle: 16,
|
|
425
|
+
renderItem: renderItem,
|
|
426
|
+
onScroll: handleScroll,
|
|
427
|
+
ref: flatListRef,
|
|
428
|
+
testID: testID
|
|
429
|
+
})
|
|
430
|
+
})]
|
|
431
|
+
});
|
|
432
|
+
}
|
|
433
|
+
const styles = StyleSheet.create({
|
|
434
|
+
scroll: {
|
|
435
|
+
overflow: Platform.select({
|
|
436
|
+
default: 'scroll',
|
|
437
|
+
web: undefined
|
|
438
|
+
})
|
|
439
|
+
},
|
|
440
|
+
tabBar: {
|
|
441
|
+
zIndex: 1,
|
|
442
|
+
backgroundColor: '#2196f3',
|
|
443
|
+
elevation: 4,
|
|
444
|
+
...Platform.select({
|
|
445
|
+
default: {
|
|
446
|
+
shadowColor: 'black',
|
|
447
|
+
shadowOpacity: 0.1,
|
|
448
|
+
shadowRadius: StyleSheet.hairlineWidth,
|
|
449
|
+
shadowOffset: {
|
|
450
|
+
height: StyleSheet.hairlineWidth,
|
|
451
|
+
width: 0
|
|
452
|
+
}
|
|
453
|
+
},
|
|
454
|
+
web: {
|
|
455
|
+
boxShadow: '0 1px 1px rgba(0, 0, 0, 0.1)'
|
|
456
|
+
}
|
|
457
|
+
})
|
|
458
|
+
},
|
|
459
|
+
tabContent: {
|
|
460
|
+
flexGrow: 1,
|
|
461
|
+
flexDirection: 'row',
|
|
462
|
+
flexWrap: 'nowrap'
|
|
463
|
+
},
|
|
464
|
+
indicatorContainer: {
|
|
465
|
+
position: 'absolute',
|
|
466
|
+
top: 0,
|
|
467
|
+
start: 0,
|
|
468
|
+
end: 0,
|
|
469
|
+
bottom: 0
|
|
470
|
+
}
|
|
471
|
+
});
|
|
472
|
+
//# sourceMappingURL=TabBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","Animated","I18nManager","Platform","StyleSheet","View","useLatestCallback","TabBarIndicator","TabBarItem","useAnimatedValue","jsx","_jsx","Fragment","_Fragment","jsxs","_jsxs","createElement","_createElement","useNativeDriver","OS","Separator","width","style","getFlattenedTabWidth","tabStyle","flatten","getFlattenedPaddingStart","flattenStyle","paddingLeft","paddingStart","paddingHorizontal","getFlattenedPaddingEnd","paddingRight","paddingEnd","convertPaddingPercentToSize","value","layout","endsWith","parseFloat","Number","isFinite","getComputedTabWidth","index","routes","scrollEnabled","tabWidths","flattenedWidth","flattenedPaddingStart","flattenedPaddingEnd","gap","key","gapTotalWidth","length","paddingTotalWidth","getMaxScrollDistance","tabBarWidth","layoutWidth","getTranslateX","scrollAmount","maxScrollDistance","direction","multiply","add","getTabBarWidth","navigationState","flattenedTabWidth","paddingsWidth","Math","max","reduce","acc","_","i","normalizeScrollValue","maxDistance","scrollValue","min","getScrollAmount","paddingInitial","centerDistance","Array","from","total","tabWidth","getLabelTextDefault","route","title","getAccessibleDefault","accessible","getAccessibilityLabelDefault","accessibilityLabel","undefined","renderIndicatorDefault","props","getTestIdDefault","testID","MEASURE_PER_BATCH","TabBar","renderIndicator","jumpTo","position","activeColor","bounces","contentContainerStyle","inactiveColor","indicatorContainerStyle","indicatorStyle","onTabLongPress","onTabPress","pressColor","pressOpacity","getConstants","isRTL","renderTabBarItem","propLayout","android_ripple","options","setLayout","useState","height","setTabWidths","flatListRef","useRef","isFirst","measuredTabWidths","isWidthDynamic","scrollOffset","hasMeasuredTabWidths","Boolean","slice","every","r","useEffect","current","scrollToOffset","offset","animated","handleLayout","e","nativeEvent","separatorsWidth","translateX","useMemo","renderItem","useCallback","item","labelText","rest","onLayout","onPress","event","defaultPrevented","preventDefault","onLongPress","defaultTabWidth","children","keyExtractor","contentContainerStyleMemoized","styles","tabContent","handleScroll","contentOffset","x","handleViewableItemsChanged","changed","isViewable","tabBar","pointerEvents","indicatorContainer","transform","start","end","getTabWidth","scroll","FlatList","data","horizontal","accessibilityRole","keyboardShouldPersistTaps","initialNumToRender","onViewableItemsChanged","alwaysBounceHorizontal","scrollsToTop","showsHorizontalScrollIndicator","showsVerticalScrollIndicator","automaticallyAdjustContentInsets","overScrollMode","scrollEventThrottle","onScroll","ref","create","overflow","select","default","web","zIndex","backgroundColor","elevation","shadowColor","shadowOpacity","shadowRadius","hairlineWidth","shadowOffset","boxShadow","flexGrow","flexDirection","flexWrap","top","bottom"],"sourceRoot":"..\\..\\src","sources":["TabBar.tsx"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,122 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import * as React from 'react';
|
|
4
|
+
import { Animated, Easing, Platform, StyleSheet } from 'react-native';
|
|
5
|
+
import { useAnimatedValue } from "./useAnimatedValue.js";
|
|
6
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
7
|
+
const useNativeDriver = Platform.OS !== 'web';
|
|
8
|
+
const getTranslateX = (position, routes, getTabWidth, direction, gap, width) => {
|
|
9
|
+
const inputRange = routes.map((_, i) => i);
|
|
10
|
+
|
|
11
|
+
// every index contains widths at all previous indices
|
|
12
|
+
const outputRange = routes.reduce((acc, _, i) => {
|
|
13
|
+
if (typeof width === 'number') {
|
|
14
|
+
if (i === 0) return [getTabWidth(i) / 2 - width / 2];
|
|
15
|
+
let sumTabWidth = 0;
|
|
16
|
+
for (let j = 0; j < i; j++) {
|
|
17
|
+
sumTabWidth += getTabWidth(j);
|
|
18
|
+
}
|
|
19
|
+
return [...acc, sumTabWidth + getTabWidth(i) / 2 + (gap ? gap * i : 0) - width / 2];
|
|
20
|
+
} else {
|
|
21
|
+
if (i === 0) return [0];
|
|
22
|
+
return [...acc, acc[i - 1] + getTabWidth(i - 1) + (gap ?? 0)];
|
|
23
|
+
}
|
|
24
|
+
}, []);
|
|
25
|
+
const translateX = position.interpolate({
|
|
26
|
+
inputRange,
|
|
27
|
+
outputRange,
|
|
28
|
+
extrapolate: 'clamp'
|
|
29
|
+
});
|
|
30
|
+
return Animated.multiply(translateX, direction === 'rtl' ? -1 : 1);
|
|
31
|
+
};
|
|
32
|
+
export function TabBarIndicator({
|
|
33
|
+
getTabWidth,
|
|
34
|
+
layout,
|
|
35
|
+
navigationState,
|
|
36
|
+
position,
|
|
37
|
+
width,
|
|
38
|
+
direction,
|
|
39
|
+
gap,
|
|
40
|
+
style,
|
|
41
|
+
children
|
|
42
|
+
}) {
|
|
43
|
+
const isIndicatorShown = React.useRef(false);
|
|
44
|
+
const isWidthDynamic = width === 'auto';
|
|
45
|
+
const opacity = useAnimatedValue(isWidthDynamic ? 0 : 1);
|
|
46
|
+
const indicatorVisible = isWidthDynamic ? layout.width && navigationState.routes.slice(0, navigationState.index).every((_, r) => getTabWidth(r)) : true;
|
|
47
|
+
React.useEffect(() => {
|
|
48
|
+
const fadeInIndicator = () => {
|
|
49
|
+
if (!isIndicatorShown.current && isWidthDynamic &&
|
|
50
|
+
// We should fade-in the indicator when we have widths for all the tab items
|
|
51
|
+
indicatorVisible) {
|
|
52
|
+
isIndicatorShown.current = true;
|
|
53
|
+
Animated.timing(opacity, {
|
|
54
|
+
toValue: 1,
|
|
55
|
+
duration: 150,
|
|
56
|
+
easing: Easing.in(Easing.linear),
|
|
57
|
+
useNativeDriver
|
|
58
|
+
}).start();
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
fadeInIndicator();
|
|
62
|
+
return () => opacity.stopAnimation();
|
|
63
|
+
}, [indicatorVisible, isWidthDynamic, opacity]);
|
|
64
|
+
const {
|
|
65
|
+
routes
|
|
66
|
+
} = navigationState;
|
|
67
|
+
const transform = [];
|
|
68
|
+
if (layout.width) {
|
|
69
|
+
const translateX = routes.length > 1 ? getTranslateX(position, routes, getTabWidth, direction, gap, width) : 0;
|
|
70
|
+
transform.push({
|
|
71
|
+
translateX
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
if (width === 'auto') {
|
|
75
|
+
const inputRange = routes.map((_, i) => i);
|
|
76
|
+
const outputRange = inputRange.map(getTabWidth);
|
|
77
|
+
transform.push({
|
|
78
|
+
scaleX: routes.length > 1 ? position.interpolate({
|
|
79
|
+
inputRange,
|
|
80
|
+
outputRange,
|
|
81
|
+
extrapolate: 'clamp'
|
|
82
|
+
}) : outputRange[0]
|
|
83
|
+
}, {
|
|
84
|
+
translateX: direction === 'rtl' ? -0.5 : 0.5
|
|
85
|
+
});
|
|
86
|
+
}
|
|
87
|
+
const styleList = [];
|
|
88
|
+
|
|
89
|
+
// scaleX doesn't work properly on chrome and opera for linux and android
|
|
90
|
+
if (Platform.OS === 'web' && width === 'auto') {
|
|
91
|
+
styleList.push({
|
|
92
|
+
width: transform[1].scaleX
|
|
93
|
+
}, {
|
|
94
|
+
left: transform[0].translateX
|
|
95
|
+
});
|
|
96
|
+
} else {
|
|
97
|
+
styleList.push({
|
|
98
|
+
width: width === 'auto' ? 1 : width
|
|
99
|
+
}, {
|
|
100
|
+
start: `${100 / routes.length * navigationState.index}%`
|
|
101
|
+
}, {
|
|
102
|
+
transform
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
return /*#__PURE__*/_jsx(Animated.View, {
|
|
106
|
+
style: [styles.indicator, styleList, width === 'auto' ? {
|
|
107
|
+
opacity: opacity
|
|
108
|
+
} : null, style],
|
|
109
|
+
children: children
|
|
110
|
+
});
|
|
111
|
+
}
|
|
112
|
+
const styles = StyleSheet.create({
|
|
113
|
+
indicator: {
|
|
114
|
+
backgroundColor: '#ffeb3b',
|
|
115
|
+
position: 'absolute',
|
|
116
|
+
start: 0,
|
|
117
|
+
bottom: 0,
|
|
118
|
+
end: 0,
|
|
119
|
+
height: 2
|
|
120
|
+
}
|
|
121
|
+
});
|
|
122
|
+
//# sourceMappingURL=TabBarIndicator.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","Animated","Easing","Platform","StyleSheet","useAnimatedValue","jsx","_jsx","useNativeDriver","OS","getTranslateX","position","routes","getTabWidth","direction","gap","width","inputRange","map","_","i","outputRange","reduce","acc","sumTabWidth","j","translateX","interpolate","extrapolate","multiply","TabBarIndicator","layout","navigationState","style","children","isIndicatorShown","useRef","isWidthDynamic","opacity","indicatorVisible","slice","index","every","r","useEffect","fadeInIndicator","current","timing","toValue","duration","easing","in","linear","start","stopAnimation","transform","length","push","scaleX","styleList","left","View","styles","indicator","create","backgroundColor","bottom","end","height"],"sourceRoot":"..\\..\\src","sources":["TabBarIndicator.tsx"],"mappings":"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","ignoreList":[]}
|