@office-iss/react-native-win32 0.71.4 → 0.72.0-preview.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/.flowconfig +15 -3
- package/CHANGELOG.json +310 -40
- package/CHANGELOG.md +145 -23
- package/IntegrationTests/IntegrationTestHarnessTest.js +1 -0
- package/Libraries/ActionSheetIOS/ActionSheetIOS.js +1 -1
- package/Libraries/Alert/Alert.d.ts +4 -4
- package/Libraries/Alert/Alert.win32.js +1 -0
- package/Libraries/Animated/Animated.d.ts +17 -6
- package/Libraries/Animated/NativeAnimatedHelper.js +18 -6
- package/Libraries/Animated/NativeAnimatedHelper.win32.js +606 -0
- package/Libraries/Animated/bezier.js +1 -1
- package/Libraries/Animated/components/AnimatedFlatList.js +8 -3
- package/Libraries/Animated/components/AnimatedScrollView.js +4 -1
- package/Libraries/Animated/components/AnimatedSectionList.js +12 -3
- package/Libraries/Animated/createAnimatedComponent.js +26 -239
- package/Libraries/Animated/nodes/AnimatedColor.js +47 -80
- package/Libraries/Animated/nodes/AnimatedInterpolation.js +167 -121
- package/Libraries/Animated/nodes/AnimatedNode.js +3 -5
- package/Libraries/Animated/nodes/AnimatedProps.js +7 -6
- package/Libraries/Animated/nodes/AnimatedStyle.js +42 -8
- package/Libraries/Animated/nodes/AnimatedTransform.js +1 -1
- package/Libraries/Animated/nodes/AnimatedValue.js +8 -12
- package/Libraries/Animated/nodes/AnimatedWithChildren.js +1 -1
- package/Libraries/Animated/useAnimatedProps.js +7 -10
- package/Libraries/BatchedBridge/MessageQueue.js +2 -1
- package/Libraries/BatchedBridge/NativeModules.d.ts +1 -1
- package/Libraries/BatchedBridge/NativeModules.js +1 -0
- package/Libraries/Blob/Blob.js +4 -0
- package/Libraries/Blob/FileReader.js +30 -2
- package/Libraries/Blob/URL.js +3 -1
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.d.ts +2 -2
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.js +2 -3
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.win32.js +2 -3
- package/Libraries/Components/ActivityIndicator/ActivityIndicator.js +6 -4
- package/Libraries/Components/Button.js +3 -2
- package/Libraries/Components/Button.win32.js +451 -0
- package/Libraries/Components/Clipboard/Clipboard.js +1 -1
- package/Libraries/Components/DrawerAndroid/DrawerLayoutAndroid.android.js +4 -0
- package/Libraries/Components/Keyboard/KeyboardAvoidingView.js +1 -0
- package/Libraries/Components/Pressable/Pressable.d.ts +1 -1
- package/Libraries/Components/Pressable/Pressable.js +1 -1
- package/Libraries/Components/RefreshControl/RefreshControl.js +1 -0
- package/Libraries/Components/SafeAreaView/SafeAreaView.js +1 -2
- package/Libraries/Components/SafeAreaView/SafeAreaView.win32.js +1 -2
- package/Libraries/Components/ScrollView/AndroidHorizontalScrollViewNativeComponent.js +12 -6
- package/Libraries/Components/ScrollView/ScrollView.d.ts +2 -2
- package/Libraries/Components/ScrollView/ScrollView.js +149 -91
- package/Libraries/Components/ScrollView/ScrollView.win32.js +1939 -0
- package/Libraries/Components/ScrollView/ScrollViewNativeComponent.js +16 -6
- package/Libraries/Components/ScrollView/ScrollViewStickyHeader.js +5 -7
- package/Libraries/Components/ScrollView/ScrollViewViewConfig.js +1 -1
- package/Libraries/Components/StatusBar/StatusBar.js +3 -0
- package/Libraries/Components/Switch/Switch.js +3 -1
- package/Libraries/Components/TextInput/AndroidTextInputNativeComponent.js +21 -11
- package/Libraries/Components/TextInput/InputAccessoryView.d.ts +1 -1
- package/Libraries/Components/TextInput/RCTTextInputViewConfig.js +11 -5
- package/Libraries/Components/TextInput/TextInput.Types.win32.d.ts +51 -0
- package/Libraries/Components/TextInput/TextInput.Types.win32.js +3 -0
- package/Libraries/Components/TextInput/TextInput.Types.win32.js.map +1 -0
- package/Libraries/Components/TextInput/TextInput.d.ts +15 -5
- package/Libraries/Components/TextInput/TextInput.flow.js +1 -1
- package/Libraries/Components/TextInput/TextInput.js +130 -103
- package/Libraries/Components/TextInput/TextInput.win32.js +202 -890
- package/Libraries/Components/Touchable/Touchable.d.ts +1 -1
- package/Libraries/Components/Touchable/Touchable.flow.js +30 -4
- package/Libraries/Components/Touchable/Touchable.js +6 -3
- package/Libraries/Components/Touchable/Touchable.win32.js +6 -3
- package/Libraries/Components/Touchable/TouchableHighlight.js +1 -1
- package/Libraries/Components/Touchable/TouchableNativeFeedback.js +2 -2
- package/Libraries/Components/Touchable/TouchableOpacity.js +3 -0
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.d.ts +1 -1
- package/Libraries/Components/Touchable/TouchableWithoutFeedback.js +2 -2
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlay.js +189 -0
- package/Libraries/Components/TraceUpdateOverlay/TraceUpdateOverlayNativeComponent.js +43 -0
- package/Libraries/Components/View/ReactNativeStyleAttributes.js +26 -0
- package/Libraries/Components/View/View.js +71 -45
- package/Libraries/Components/View/View.win32.js +38 -16
- package/Libraries/Components/View/ViewAccessibility.d.ts +6 -6
- package/Libraries/Components/View/ViewAccessibility.js +10 -1
- package/Libraries/Components/View/ViewAccessibility.win32.d.ts +5 -5
- package/Libraries/Components/View/ViewNativeComponent.js +32 -8
- package/Libraries/Components/View/ViewPropTypes.d.ts +1 -1
- package/Libraries/Components/View/ViewPropTypes.js +1 -1
- package/Libraries/Components/View/ViewPropTypes.win32.d.ts +1 -1
- package/Libraries/Components/View/ViewPropTypes.win32.js +1 -1
- package/Libraries/Core/Devtools/openFileInEditor.js +1 -0
- package/Libraries/Core/Devtools/openURLInBrowser.js +1 -0
- package/Libraries/Core/Devtools/parseErrorStack.js +2 -2
- package/Libraries/Core/Devtools/parseHermesStack.js +54 -34
- package/Libraries/Core/ExceptionsManager.js +2 -2
- package/Libraries/Core/InitializeCore.js +2 -1
- package/Libraries/Core/ReactNativeVersion.js +3 -3
- package/Libraries/Core/ReactNativeVersionCheck.js +1 -9
- package/Libraries/Core/ReactNativeVersionCheck.win32.js +1 -9
- package/Libraries/Core/Timers/JSTimers.js +1 -1
- package/Libraries/Core/Timers/immediateShim.js +1 -0
- package/Libraries/Core/Timers/queueMicrotask.js +1 -1
- package/Libraries/Core/setUpAlert.js +1 -1
- package/Libraries/Core/setUpDOM.js +18 -0
- package/Libraries/Core/setUpDeveloperTools.js +1 -1
- package/Libraries/Core/setUpGlobals.js +5 -2
- package/Libraries/Core/setUpNavigator.js +6 -5
- package/Libraries/Core/setUpPerformance.js +23 -13
- package/Libraries/Core/setUpReactDevTools.js +2 -0
- package/Libraries/Core/setUpSegmentFetcher.js +0 -41
- package/Libraries/Core/setUpTimers.js +2 -2
- package/Libraries/DOM/Geometry/DOMRect.js +82 -0
- package/Libraries/DOM/Geometry/DOMRectReadOnly.js +188 -0
- package/Libraries/DOM/Nodes/ReactNativeElement.js +75 -0
- package/Libraries/DOM/Nodes/ReadOnlyElement.js +89 -0
- package/Libraries/DOM/Nodes/ReadOnlyNode.js +167 -0
- package/Libraries/DOM/OldStyleCollections/ArrayLikeUtils.js +46 -0
- package/Libraries/DOM/OldStyleCollections/DOMRectList.js +76 -0
- package/Libraries/DOM/OldStyleCollections/HTMLCollection.js +82 -0
- package/Libraries/DOM/OldStyleCollections/NodeList.js +104 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.android.js +35 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.d.ts +20 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.ios.js +49 -0
- package/Libraries/DevToolsSettings/DevToolsSettingsManager.win32.js +35 -0
- package/Libraries/{Utilities/NativeDevSplitBundleLoader.js → DevToolsSettings/NativeDevToolsSettingsManager.js} +7 -2
- package/Libraries/EventEmitter/NativeEventEmitter.d.ts +1 -2
- package/Libraries/EventEmitter/RCTDeviceEventEmitter.d.ts +1 -2
- package/Libraries/EventEmitter/RCTDeviceEventEmitter.js +9 -1
- package/Libraries/Events/EventPolyfill.js +1 -1
- package/Libraries/Image/AssetRegistry.js +1 -1
- package/Libraries/Image/AssetSourceResolver.js +3 -3
- package/Libraries/Image/Image.android.js +4 -1
- package/Libraries/Image/Image.d.ts +63 -2
- package/Libraries/Image/Image.ios.js +3 -0
- package/Libraries/Image/Image.win32.js +3 -0
- package/Libraries/Image/ImageBackground.js +1 -0
- package/Libraries/Image/ImageProps.js +1 -1
- package/Libraries/Image/ImageViewNativeComponent.js +4 -4
- package/Libraries/Image/RelativeImageStub.js +1 -1
- package/Libraries/Image/TextInlineImageNativeComponent.js +1 -1
- package/Libraries/Image/resolveAssetSource.js +1 -1
- package/Libraries/Inspector/DevtoolsOverlay.js +29 -19
- package/Libraries/Inspector/ElementBox.js +4 -1
- package/Libraries/Inspector/Inspector.js +5 -6
- package/Libraries/Inspector/Inspector.win32.js +7 -6
- package/Libraries/Inspector/InspectorOverlay.js +3 -3
- package/Libraries/Inspector/InspectorOverlay.win32.js +2 -1
- package/Libraries/Inspector/NetworkOverlay.js +1 -1
- package/Libraries/Interaction/JSEventLoopWatchdog.js +1 -1
- package/Libraries/Interaction/PanResponder.js +5 -6
- package/Libraries/LayoutAnimation/LayoutAnimation.js +2 -1
- package/Libraries/Linking/Linking.js +1 -4
- package/Libraries/Lists/FillRateHelper.js +4 -238
- package/Libraries/Lists/FlatList.d.ts +15 -22
- package/Libraries/Lists/FlatList.js +9 -6
- package/Libraries/Lists/SectionList.d.ts +10 -6
- package/Libraries/Lists/SectionList.js +5 -3
- package/Libraries/Lists/SectionListModern.js +3 -3
- package/Libraries/Lists/ViewabilityHelper.js +8 -344
- package/Libraries/Lists/VirtualizeUtils.js +4 -244
- package/Libraries/Lists/VirtualizedList.js +10 -1867
- package/Libraries/Lists/VirtualizedListContext.js +6 -104
- package/Libraries/Lists/VirtualizedSectionList.js +9 -602
- package/Libraries/Lists/__flowtests__/FlatList-flowtest.js +1 -0
- package/Libraries/Lists/__flowtests__/SectionList-flowtest.js +1 -1
- package/Libraries/LogBox/Data/LogBoxData.js +1 -1
- package/Libraries/LogBox/Data/parseLogBoxLog.js +1 -1
- package/Libraries/LogBox/LogBox.js +1 -1
- package/Libraries/LogBox/UI/LogBoxInspector.js +1 -3
- package/Libraries/LogBox/UI/LogBoxInspectorCodeFrame.win32.js +168 -0
- package/Libraries/LogBox/UI/LogBoxInspectorHeader.win32.js +3 -0
- package/Libraries/LogBox/UI/LogBoxInspectorReactFrames.win32.js +193 -0
- package/Libraries/LogBox/UI/LogBoxInspectorSourceMapStatus.js +1 -0
- package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.js +2 -2
- package/Libraries/LogBox/UI/LogBoxInspectorStackFrame.win32.js +7 -3
- package/Libraries/LogBox/UI/LogBoxMessage.js +87 -5
- package/Libraries/LogBox/UI/LogBoxNotification.js +5 -7
- package/Libraries/Modal/Modal.js +2 -2
- package/Libraries/NativeComponent/BaseViewConfig.android.js +32 -12
- package/Libraries/NativeComponent/BaseViewConfig.ios.js +43 -19
- package/Libraries/NativeComponent/BaseViewConfig.win32.js +43 -19
- package/Libraries/NativeComponent/NativeComponentRegistryUnstable.js +4 -1
- package/Libraries/NativeComponent/ViewConfig.js +1 -0
- package/Libraries/NativeComponent/ViewConfigIgnore.js +1 -4
- package/Libraries/Network/RCTNetworking.android.js +2 -2
- package/Libraries/Network/RCTNetworking.ios.js +1 -1
- package/Libraries/Network/RCTNetworking.win32.js +1 -1
- package/Libraries/Network/XMLHttpRequest.js +1 -1
- package/Libraries/Pressability/Pressability.js +11 -5
- package/Libraries/Pressability/Pressability.win32.js +9 -3
- package/Libraries/ReactNative/AppContainer.js +7 -1
- package/Libraries/ReactNative/AppRegistry.d.ts +1 -1
- package/Libraries/ReactNative/AppRegistry.js +10 -13
- package/Libraries/ReactNative/FabricUIManager.js +24 -8
- package/Libraries/ReactNative/NativeUIManager.js +5 -5
- package/Libraries/ReactNative/ReactNativeFeatureFlags.js +10 -10
- package/Libraries/ReactNative/UIManager.js +142 -1
- package/Libraries/ReactNative/getCachedComponentWithDebugName.js +5 -5
- package/Libraries/ReactNative/getNativeComponentAttributes.js +1 -1
- package/Libraries/ReactNative/requireNativeComponent.d.ts +1 -1
- package/Libraries/ReactNative/requireNativeComponent.js +1 -1
- package/Libraries/ReactPrivate/ReactNativePrivateInterface.js +1 -0
- package/Libraries/Renderer/implementations/ReactFabric-dev.js +26 -3
- package/Libraries/Renderer/implementations/ReactFabric-prod.js +13 -1
- package/Libraries/Renderer/implementations/ReactFabric-profiling.js +13 -1
- package/Libraries/Renderer/public/ReactFabricPublicInstanceUtils.js +38 -0
- package/Libraries/Renderer/shims/ReactNativeTypes.js +38 -20
- package/Libraries/Renderer/shims/ReactNativeViewConfigRegistry.js +7 -7
- package/Libraries/Renderer/shims/createReactNativeComponentClass.js +2 -2
- package/Libraries/Share/Share.js +1 -1
- package/Libraries/StyleSheet/PlatformColorValueTypes.ios.js +1 -1
- package/Libraries/StyleSheet/StyleSheet.js +1 -1
- package/Libraries/StyleSheet/StyleSheet.win32.js +1 -1
- package/Libraries/StyleSheet/StyleSheetTypes.d.ts +115 -76
- package/Libraries/StyleSheet/StyleSheetTypes.js +188 -33
- package/Libraries/StyleSheet/flattenStyle.js +2 -0
- package/Libraries/StyleSheet/normalizeColor.js +1 -1
- package/Libraries/StyleSheet/processColor.js +1 -1
- package/Libraries/Text/Text.d.ts +12 -2
- package/Libraries/Text/Text.js +50 -41
- package/Libraries/Text/TextProps.js +3 -4
- package/Libraries/TurboModule/samples/NativeSampleTurboModule.js +6 -0
- package/Libraries/Types/CodegenTypes.js +1 -0
- package/Libraries/UTFSequence.js +3 -1
- package/Libraries/Utilities/Appearance.d.ts +10 -0
- package/Libraries/Utilities/Appearance.js +13 -0
- package/Libraries/Utilities/Dimensions.js +1 -1
- package/Libraries/Utilities/Dimensions.win32.js +1 -1
- package/Libraries/Utilities/GlobalPerformanceLogger.js +12 -1
- package/Libraries/Utilities/HMRClient.js +16 -10
- package/Libraries/Utilities/{createPerformanceLogger.d.ts → IPerformanceLogger.d.ts} +4 -4
- package/Libraries/Utilities/IPerformanceLogger.js +49 -0
- package/Libraries/Utilities/LoadingView.android.js +28 -11
- package/Libraries/Utilities/NativeAppearance.js +1 -0
- package/Libraries/Utilities/NativePlatformConstantsWin.js +1 -1
- package/Libraries/Utilities/PixelRatio.js +2 -2
- package/Libraries/Utilities/Platform.win32.js +1 -1
- package/Libraries/Utilities/ReactNativeTestTools.js +1 -1
- package/Libraries/Utilities/__mocks__/PixelRatio.js +1 -1
- package/Libraries/Utilities/codegenNativeCommands.js +2 -0
- package/Libraries/Utilities/createPerformanceLogger.js +55 -43
- package/Libraries/Utilities/stringifySafe.js +2 -7
- package/Libraries/Utilities/useColorScheme.js +1 -1
- package/Libraries/Utilities/useWindowDimensions.js +3 -3
- package/Libraries/WebPerformance/EventCounts.js +78 -0
- package/Libraries/WebPerformance/MemoryInfo.js +54 -0
- package/Libraries/WebPerformance/NativePerformance.js +38 -0
- package/Libraries/WebPerformance/NativePerformanceObserver.js +22 -7
- package/Libraries/WebPerformance/Performance.js +312 -0
- package/Libraries/WebPerformance/PerformanceEntry.js +45 -0
- package/Libraries/WebPerformance/PerformanceEventTiming.js +38 -0
- package/Libraries/WebPerformance/PerformanceObserver.js +196 -101
- package/Libraries/WebPerformance/RawPerformanceEntry.js +87 -0
- package/Libraries/WebPerformance/ReactNativeStartupTiming.js +65 -0
- package/Libraries/WebPerformance/__mocks__/NativePerformance.js +65 -0
- package/Libraries/WebPerformance/__mocks__/NativePerformanceObserver.js +101 -0
- package/Libraries/YellowBox/YellowBoxDeprecated.js +1 -1
- package/Libraries/vendor/core/ErrorUtils.js +1 -1
- package/Libraries/vendor/emitter/EventEmitter.d.ts +2 -2
- package/Libraries/vendor/emitter/EventEmitter.js +9 -1
- package/flow/global.js +29 -4
- package/flow/jest.js +258 -164
- package/index.js +56 -42
- package/index.win32.js +56 -42
- package/interface.js +1 -1
- package/jest/local-setup.js +33 -0
- package/jest/mockComponent.js +4 -2
- package/jest/mockNativeComponent.js +1 -1
- package/jest/mockScrollView.js +2 -1
- package/jest/react-native-env.js +1 -3
- package/jest/setup.js +11 -8
- package/overrides.json +115 -85
- package/package.json +38 -28
- package/rn-get-polyfills.js +1 -1
- package/src/Libraries/Components/TextInput/TextInput.Types.win32.ts +68 -0
- package/src/Libraries/Components/View/ViewAccessibility.win32.d.ts +5 -5
- package/src/Libraries/Components/View/ViewPropTypes.win32.d.ts +1 -1
- package/types/index.d.ts +2 -6
- package/types/modules/Codegen.d.ts +4 -4
- package/types/modules/globals.d.ts +27 -25
- package/types/public/DeprecatedPropertiesAlias.d.ts +0 -20
- package/types/public/ReactNativeRenderer.d.ts +2 -7
- package/Libraries/Animated/createAnimatedComponentInjection.js +0 -48
- package/Libraries/Animated/createAnimatedComponent_EXPERIMENTAL.js +0 -48
- package/Libraries/Components/AccessibilityInfo/AccessibilityInfo.flow.js +0 -208
- package/Libraries/Components/ActivityIndicator/ActivityIndicator.flow.js +0 -58
- package/Libraries/Components/DatePicker/DatePickerIOS.android.js +0 -47
- package/Libraries/Components/DatePicker/DatePickerIOS.d.ts +0 -92
- package/Libraries/Components/DatePicker/DatePickerIOS.flow.android.js +0 -14
- package/Libraries/Components/DatePicker/DatePickerIOS.flow.ios.js +0 -113
- package/Libraries/Components/DatePicker/DatePickerIOS.ios.js +0 -242
- package/Libraries/Components/DatePicker/DatePickerIOS.win32.js +0 -47
- package/Libraries/Components/DatePicker/RCTDatePickerNativeComponent.js +0 -60
- package/Libraries/Components/DatePickerAndroid/NativeDatePickerAndroid.js +0 -26
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.android.js +0 -45
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.d.ts +0 -62
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.ios.js +0 -75
- package/Libraries/Components/ProgressViewIOS/ProgressViewIOS.win32.js +0 -45
- package/Libraries/Components/ProgressViewIOS/RCTProgressViewNativeComponent.js +0 -33
- package/Libraries/Components/SafeAreaView/SafeAreaView.flow.js +0 -19
- package/Libraries/Components/Slider/Slider.d.ts +0 -132
- package/Libraries/Components/Slider/Slider.js +0 -282
- package/Libraries/Components/Slider/SliderNativeComponent.js +0 -56
- package/Libraries/Components/TextInput/Win32TextInputNativeComponent.js +0 -23
- package/Libraries/Interaction/Batchinator.js +0 -76
- package/Libraries/Interaction/BridgeSpyStallHandler.js +0 -63
- package/Libraries/Interaction/InteractionStallDebugger.js +0 -23
- package/Libraries/Interaction/PanResponder.flow.js +0 -257
- package/Libraries/Lists/CellRenderMask.js +0 -155
- package/Libraries/Lists/ChildListCollection.js +0 -72
- package/Libraries/Lists/StateSafePureComponent.js +0 -85
- package/Libraries/Lists/VirtualizedList.d.ts +0 -347
- package/Libraries/Lists/VirtualizedListCellRenderer.js +0 -259
- package/Libraries/Lists/VirtualizedListProps.js +0 -279
- package/Libraries/Performance/PureComponentDebug.js +0 -74
- package/Libraries/Reliability/UserFlow.js +0 -158
- package/Libraries/Renderer/implementations/ReactNativeRenderer.d.ts +0 -149
- package/Libraries/Renderer/shims/ReactNativeTypes.d.ts +0 -141
- package/Libraries/Utilities/MatrixMath.js +0 -748
- package/Libraries/Utilities/buildStyleInterpolator.js +0 -209
- package/Libraries/Utilities/clamp.js +0 -23
- package/Libraries/Utilities/deprecatedPropType.js +0 -36
- package/Libraries/Utilities/groupByEveryN.js +0 -51
- package/Libraries/Utilities/mergeIntoFast.js +0 -26
- package/Libraries/Utilities/setAndForwardRef.js +0 -71
- package/Libraries/Utilities/truncate.js +0 -51
- package/flow/JSITimerInternalType.js +0 -30
- package/flow/use-sync-external-store.js +0 -19
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the MIT license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
* @format
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
'use strict';
|
|
11
|
-
import StyleSheet from '../../StyleSheet/StyleSheet';
|
|
12
|
-
import Text from '../../Text/Text';
|
|
13
|
-
import View from '../View/View';
|
|
14
|
-
import * as React from 'react';
|
|
15
|
-
|
|
16
|
-
class DummyProgressViewIOS extends React.Component {
|
|
17
|
-
render() {
|
|
18
|
-
return (
|
|
19
|
-
<View style={[styles.dummy, this.props.style]}>
|
|
20
|
-
<Text style={styles.text}>
|
|
21
|
-
ProgressViewIOS is not supported on this platform!
|
|
22
|
-
</Text>
|
|
23
|
-
</View>
|
|
24
|
-
);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
const styles = StyleSheet.create({
|
|
29
|
-
dummy: {
|
|
30
|
-
width: 120,
|
|
31
|
-
height: 20,
|
|
32
|
-
backgroundColor: '#ffbcbc',
|
|
33
|
-
borderWidth: 1,
|
|
34
|
-
borderColor: 'red',
|
|
35
|
-
alignItems: 'center',
|
|
36
|
-
justifyContent: 'center',
|
|
37
|
-
},
|
|
38
|
-
text: {
|
|
39
|
-
color: '#333333',
|
|
40
|
-
margin: 5,
|
|
41
|
-
fontSize: 10,
|
|
42
|
-
},
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
module.exports = DummyProgressViewIOS;
|
|
@@ -1,62 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the MIT license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
* @format
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import type * as React from 'react';
|
|
11
|
-
import {Constructor} from '../../../types/private/Utilities';
|
|
12
|
-
import {ImageURISource} from '../../Image/ImageSource';
|
|
13
|
-
import {NativeMethods} from '../../../types/public/ReactNativeTypes';
|
|
14
|
-
import {ColorValue} from '../../StyleSheet/StyleSheet';
|
|
15
|
-
import {ViewProps} from '../View/ViewPropTypes';
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* @see https://reactnative.dev/docs/progressviewios
|
|
19
|
-
* @see ProgressViewIOS.ios.js
|
|
20
|
-
*/
|
|
21
|
-
export interface ProgressViewIOSProps extends ViewProps {
|
|
22
|
-
/**
|
|
23
|
-
* The progress bar style.
|
|
24
|
-
*/
|
|
25
|
-
progressViewStyle?: 'default' | 'bar' | undefined;
|
|
26
|
-
|
|
27
|
-
/**
|
|
28
|
-
* The progress value (between 0 and 1).
|
|
29
|
-
*/
|
|
30
|
-
progress?: number | undefined;
|
|
31
|
-
|
|
32
|
-
/**
|
|
33
|
-
* The tint color of the progress bar itself.
|
|
34
|
-
*/
|
|
35
|
-
progressTintColor?: ColorValue | undefined;
|
|
36
|
-
|
|
37
|
-
/**
|
|
38
|
-
* The tint color of the progress bar track.
|
|
39
|
-
*/
|
|
40
|
-
trackTintColor?: ColorValue | undefined;
|
|
41
|
-
|
|
42
|
-
/**
|
|
43
|
-
* A stretchable image to display as the progress bar.
|
|
44
|
-
*/
|
|
45
|
-
progressImage?: ImageURISource | ImageURISource[] | undefined;
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* A stretchable image to display behind the progress bar.
|
|
49
|
-
*/
|
|
50
|
-
trackImage?: ImageURISource | ImageURISource[] | undefined;
|
|
51
|
-
}
|
|
52
|
-
|
|
53
|
-
declare class ProgressViewIOSComponent extends React.Component<ProgressViewIOSProps> {}
|
|
54
|
-
declare const ProgressViewIOSBase: Constructor<NativeMethods> &
|
|
55
|
-
typeof ProgressViewIOSComponent;
|
|
56
|
-
/**
|
|
57
|
-
* ProgressViewIOS has been extracted from react-native core and will be removed in a future release.
|
|
58
|
-
* It can now be installed and imported from `@react-native-community/progress-view` instead of 'react-native'.
|
|
59
|
-
* @see https://github.com/react-native-community/progress-view
|
|
60
|
-
* @deprecated
|
|
61
|
-
*/
|
|
62
|
-
export class ProgressViewIOS extends ProgressViewIOSBase {}
|
|
@@ -1,75 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the MIT license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
* @format
|
|
8
|
-
* @flow strict-local
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import type {ImageSource} from '../../Image/ImageSource';
|
|
12
|
-
import type {ViewProps} from '../View/ViewPropTypes';
|
|
13
|
-
|
|
14
|
-
import StyleSheet, {type ColorValue} from '../../StyleSheet/StyleSheet';
|
|
15
|
-
import RCTProgressViewNativeComponent from './RCTProgressViewNativeComponent';
|
|
16
|
-
import * as React from 'react';
|
|
17
|
-
|
|
18
|
-
type Props = $ReadOnly<{|
|
|
19
|
-
...ViewProps,
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* The progress bar style.
|
|
23
|
-
*/
|
|
24
|
-
progressViewStyle?: ?('default' | 'bar'),
|
|
25
|
-
|
|
26
|
-
/**
|
|
27
|
-
* The progress value (between 0 and 1).
|
|
28
|
-
*/
|
|
29
|
-
progress?: ?number,
|
|
30
|
-
|
|
31
|
-
/**
|
|
32
|
-
* The tint color of the progress bar itself.
|
|
33
|
-
*/
|
|
34
|
-
progressTintColor?: ?ColorValue,
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* The tint color of the progress bar track.
|
|
38
|
-
*/
|
|
39
|
-
trackTintColor?: ?ColorValue,
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* A stretchable image to display as the progress bar.
|
|
43
|
-
*/
|
|
44
|
-
progressImage?: ?ImageSource,
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* A stretchable image to display behind the progress bar.
|
|
48
|
-
*/
|
|
49
|
-
trackImage?: ?ImageSource,
|
|
50
|
-
|}>;
|
|
51
|
-
|
|
52
|
-
/**
|
|
53
|
-
* Use `ProgressViewIOS` to render a UIProgressView on iOS.
|
|
54
|
-
*/
|
|
55
|
-
const ProgressViewIOS = (
|
|
56
|
-
props: Props,
|
|
57
|
-
forwardedRef?: ?React.Ref<typeof RCTProgressViewNativeComponent>,
|
|
58
|
-
) => (
|
|
59
|
-
<RCTProgressViewNativeComponent
|
|
60
|
-
{...props}
|
|
61
|
-
style={[styles.progressView, props.style]}
|
|
62
|
-
ref={forwardedRef}
|
|
63
|
-
/>
|
|
64
|
-
);
|
|
65
|
-
|
|
66
|
-
const styles = StyleSheet.create({
|
|
67
|
-
progressView: {
|
|
68
|
-
height: 2,
|
|
69
|
-
},
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
const ProgressViewIOSWithRef = React.forwardRef(ProgressViewIOS);
|
|
73
|
-
|
|
74
|
-
module.exports =
|
|
75
|
-
(ProgressViewIOSWithRef: typeof RCTProgressViewNativeComponent);
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the MIT license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
* @format
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
'use strict';
|
|
11
|
-
import StyleSheet from '../../StyleSheet/StyleSheet';
|
|
12
|
-
import Text from '../../Text/Text';
|
|
13
|
-
import View from '../View/View';
|
|
14
|
-
import * as React from 'react';
|
|
15
|
-
|
|
16
|
-
class DummyProgressViewIOS extends React.Component {
|
|
17
|
-
render() {
|
|
18
|
-
return (
|
|
19
|
-
<View style={[styles.dummy, this.props.style]}>
|
|
20
|
-
<Text style={styles.text}>
|
|
21
|
-
ProgressViewIOS is not supported on this platform!
|
|
22
|
-
</Text>
|
|
23
|
-
</View>
|
|
24
|
-
);
|
|
25
|
-
}
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
const styles = StyleSheet.create({
|
|
29
|
-
dummy: {
|
|
30
|
-
width: 120,
|
|
31
|
-
height: 20,
|
|
32
|
-
backgroundColor: '#ffbcbc',
|
|
33
|
-
borderWidth: 1,
|
|
34
|
-
borderColor: 'red',
|
|
35
|
-
alignItems: 'center',
|
|
36
|
-
justifyContent: 'center',
|
|
37
|
-
},
|
|
38
|
-
text: {
|
|
39
|
-
color: '#333333',
|
|
40
|
-
margin: 5,
|
|
41
|
-
fontSize: 10,
|
|
42
|
-
},
|
|
43
|
-
});
|
|
44
|
-
|
|
45
|
-
module.exports = DummyProgressViewIOS;
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the MIT license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
* @flow strict-local
|
|
8
|
-
* @format
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import type {ImageSource} from '../../Image/ImageSource';
|
|
12
|
-
import type {HostComponent} from '../../Renderer/shims/ReactNativeTypes';
|
|
13
|
-
import type {ColorValue} from '../../StyleSheet/StyleSheet';
|
|
14
|
-
import type {Float, WithDefault} from '../../Types/CodegenTypes';
|
|
15
|
-
import type {ViewProps} from '../View/ViewPropTypes';
|
|
16
|
-
|
|
17
|
-
import codegenNativeComponent from '../../Utilities/codegenNativeComponent';
|
|
18
|
-
|
|
19
|
-
type NativeProps = $ReadOnly<{|
|
|
20
|
-
...ViewProps,
|
|
21
|
-
|
|
22
|
-
// Props
|
|
23
|
-
progressViewStyle?: WithDefault<'default' | 'bar', 'default'>,
|
|
24
|
-
progress?: WithDefault<Float, 0>,
|
|
25
|
-
progressTintColor?: ?ColorValue,
|
|
26
|
-
trackTintColor?: ?ColorValue,
|
|
27
|
-
progressImage?: ?ImageSource,
|
|
28
|
-
trackImage?: ?ImageSource,
|
|
29
|
-
|}>;
|
|
30
|
-
|
|
31
|
-
export default (codegenNativeComponent<NativeProps>(
|
|
32
|
-
'RCTProgressView',
|
|
33
|
-
): HostComponent<NativeProps>);
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the MIT license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
* @flow strict-local
|
|
8
|
-
* @format
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import type {ViewProps} from '../View/ViewPropTypes';
|
|
12
|
-
|
|
13
|
-
import View from '../View/View';
|
|
14
|
-
import * as React from 'react';
|
|
15
|
-
|
|
16
|
-
export type SafeAreaViewType = React.AbstractComponent<
|
|
17
|
-
ViewProps,
|
|
18
|
-
React.ElementRef<typeof View>,
|
|
19
|
-
>;
|
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the MIT license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
* @format
|
|
8
|
-
*/
|
|
9
|
-
|
|
10
|
-
import type * as React from 'react';
|
|
11
|
-
import {Constructor} from '../../../types/private/Utilities';
|
|
12
|
-
import {ImageURISource} from '../../Image/ImageSource';
|
|
13
|
-
import {NativeMethods} from '../../../types/public/ReactNativeTypes';
|
|
14
|
-
import {ColorValue, StyleProp} from '../../StyleSheet/StyleSheet';
|
|
15
|
-
import {ViewStyle} from '../../StyleSheet/StyleSheetTypes';
|
|
16
|
-
import {ViewProps} from '../View/ViewPropTypes';
|
|
17
|
-
|
|
18
|
-
export interface SliderPropsAndroid extends ViewProps {
|
|
19
|
-
/**
|
|
20
|
-
* Color of the foreground switch grip.
|
|
21
|
-
*/
|
|
22
|
-
thumbTintColor?: ColorValue | undefined;
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export interface SliderPropsIOS extends ViewProps {
|
|
26
|
-
/**
|
|
27
|
-
* Assigns a maximum track image. Only static images are supported.
|
|
28
|
-
* The leftmost pixel of the image will be stretched to fill the track.
|
|
29
|
-
*/
|
|
30
|
-
maximumTrackImage?: ImageURISource | undefined;
|
|
31
|
-
|
|
32
|
-
/**
|
|
33
|
-
* Assigns a minimum track image. Only static images are supported.
|
|
34
|
-
* The rightmost pixel of the image will be stretched to fill the track.
|
|
35
|
-
*/
|
|
36
|
-
minimumTrackImage?: ImageURISource | undefined;
|
|
37
|
-
|
|
38
|
-
/**
|
|
39
|
-
* Sets an image for the thumb. Only static images are supported.
|
|
40
|
-
*/
|
|
41
|
-
thumbImage?: ImageURISource | undefined;
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* Assigns a single image for the track. Only static images
|
|
45
|
-
* are supported. The center pixel of the image will be stretched
|
|
46
|
-
* to fill the track.
|
|
47
|
-
*/
|
|
48
|
-
trackImage?: ImageURISource | undefined;
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
export interface SliderProps extends SliderPropsIOS, SliderPropsAndroid {
|
|
52
|
-
/**
|
|
53
|
-
* If true the user won't be able to move the slider.
|
|
54
|
-
* Default value is false.
|
|
55
|
-
*/
|
|
56
|
-
disabled?: boolean | undefined;
|
|
57
|
-
|
|
58
|
-
/**
|
|
59
|
-
* The color used for the track to the right of the button.
|
|
60
|
-
* Overrides the default blue gradient image.
|
|
61
|
-
*/
|
|
62
|
-
maximumTrackTintColor?: ColorValue | undefined;
|
|
63
|
-
|
|
64
|
-
/**
|
|
65
|
-
* Initial maximum value of the slider. Default value is 1.
|
|
66
|
-
*/
|
|
67
|
-
maximumValue?: number | undefined;
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* The color used for the track to the left of the button.
|
|
71
|
-
* Overrides the default blue gradient image.
|
|
72
|
-
*/
|
|
73
|
-
minimumTrackTintColor?: ColorValue | undefined;
|
|
74
|
-
|
|
75
|
-
/**
|
|
76
|
-
* Initial minimum value of the slider. Default value is 0.
|
|
77
|
-
*/
|
|
78
|
-
minimumValue?: number | undefined;
|
|
79
|
-
|
|
80
|
-
/**
|
|
81
|
-
* Callback called when the user finishes changing the value (e.g. when the slider is released).
|
|
82
|
-
*/
|
|
83
|
-
onSlidingComplete?: ((value: number) => void) | undefined;
|
|
84
|
-
|
|
85
|
-
/**
|
|
86
|
-
* Callback continuously called while the user is dragging the slider.
|
|
87
|
-
*/
|
|
88
|
-
onValueChange?: ((value: number) => void) | undefined;
|
|
89
|
-
|
|
90
|
-
/**
|
|
91
|
-
* Step value of the slider. The value should be between 0 and (maximumValue - minimumValue). Default value is 0.
|
|
92
|
-
*/
|
|
93
|
-
step?: number | undefined;
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Used to style and layout the Slider. See StyleSheet.js for more info.
|
|
97
|
-
*/
|
|
98
|
-
style?: StyleProp<ViewStyle> | undefined;
|
|
99
|
-
|
|
100
|
-
/**
|
|
101
|
-
* Used to locate this view in UI automation tests.
|
|
102
|
-
*/
|
|
103
|
-
testID?: string | undefined;
|
|
104
|
-
|
|
105
|
-
/**
|
|
106
|
-
* Initial value of the slider. The value should be between minimumValue
|
|
107
|
-
* and maximumValue, which default to 0 and 1 respectively.
|
|
108
|
-
* Default value is 0.
|
|
109
|
-
* This is not a controlled component, you don't need to update
|
|
110
|
-
* the value during dragging.
|
|
111
|
-
*/
|
|
112
|
-
value?: number | undefined;
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
/**
|
|
116
|
-
* A component used to select a single value from a range of values.
|
|
117
|
-
*/
|
|
118
|
-
declare class SliderComponent extends React.Component<SliderProps> {}
|
|
119
|
-
declare const SliderBase: Constructor<NativeMethods> & typeof SliderComponent;
|
|
120
|
-
/**
|
|
121
|
-
* Slider has been extracted from react-native core and will be removed in a future release.
|
|
122
|
-
* It can now be installed and imported from `@react-native-community/slider` instead of 'react-native'.
|
|
123
|
-
* @see https://github.com/callstack/react-native-slider
|
|
124
|
-
* @deprecated
|
|
125
|
-
*/
|
|
126
|
-
export class Slider extends SliderBase {}
|
|
127
|
-
/** SliderIOS has been removed from react-native.
|
|
128
|
-
* It can now be installed and imported from `@react-native-community/slider` instead of 'react-native'.
|
|
129
|
-
* @see https://github.com/callstack/react-native-slider
|
|
130
|
-
* @deprecated
|
|
131
|
-
*/
|
|
132
|
-
export type SliderIOS = Slider;
|
|
@@ -1,282 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
3
|
-
*
|
|
4
|
-
* This source code is licensed under the MIT license found in the
|
|
5
|
-
* LICENSE file in the root directory of this source tree.
|
|
6
|
-
*
|
|
7
|
-
* @format
|
|
8
|
-
* @flow strict-local
|
|
9
|
-
*/
|
|
10
|
-
|
|
11
|
-
import type {ImageSource} from '../../Image/ImageSource';
|
|
12
|
-
import type {SyntheticEvent} from '../../Types/CoreEventTypes';
|
|
13
|
-
import type {AccessibilityState} from '../View/ViewAccessibility';
|
|
14
|
-
import type {ViewProps} from '../View/ViewPropTypes';
|
|
15
|
-
|
|
16
|
-
import StyleSheet, {
|
|
17
|
-
type ColorValue,
|
|
18
|
-
type ViewStyleProp,
|
|
19
|
-
} from '../../StyleSheet/StyleSheet';
|
|
20
|
-
import Platform from '../../Utilities/Platform';
|
|
21
|
-
import SliderNativeComponent from './SliderNativeComponent';
|
|
22
|
-
import * as React from 'react';
|
|
23
|
-
|
|
24
|
-
type Event = SyntheticEvent<
|
|
25
|
-
$ReadOnly<{|
|
|
26
|
-
value: number,
|
|
27
|
-
/**
|
|
28
|
-
* Android Only.
|
|
29
|
-
*/
|
|
30
|
-
fromUser?: boolean,
|
|
31
|
-
|}>,
|
|
32
|
-
>;
|
|
33
|
-
|
|
34
|
-
type IOSProps = $ReadOnly<{|
|
|
35
|
-
/**
|
|
36
|
-
* Assigns a single image for the track. Only static images are supported.
|
|
37
|
-
* The center pixel of the image will be stretched to fill the track.
|
|
38
|
-
*/
|
|
39
|
-
trackImage?: ?ImageSource,
|
|
40
|
-
|
|
41
|
-
/**
|
|
42
|
-
* Assigns a minimum track image. Only static images are supported. The
|
|
43
|
-
* rightmost pixel of the image will be stretched to fill the track.
|
|
44
|
-
*/
|
|
45
|
-
minimumTrackImage?: ?ImageSource,
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* Assigns a maximum track image. Only static images are supported. The
|
|
49
|
-
* leftmost pixel of the image will be stretched to fill the track.
|
|
50
|
-
*/
|
|
51
|
-
maximumTrackImage?: ?ImageSource,
|
|
52
|
-
|
|
53
|
-
/**
|
|
54
|
-
* Sets an image for the thumb. Only static images are supported.
|
|
55
|
-
*/
|
|
56
|
-
thumbImage?: ?ImageSource,
|
|
57
|
-
|}>;
|
|
58
|
-
|
|
59
|
-
type Props = $ReadOnly<{|
|
|
60
|
-
...ViewProps,
|
|
61
|
-
...IOSProps,
|
|
62
|
-
|
|
63
|
-
/**
|
|
64
|
-
* Used to style and layout the `Slider`. See `StyleSheet.js` and
|
|
65
|
-
* `DeprecatedViewStylePropTypes.js` for more info.
|
|
66
|
-
*/
|
|
67
|
-
style?: ?ViewStyleProp,
|
|
68
|
-
|
|
69
|
-
/**
|
|
70
|
-
* Initial value of the slider. The value should be between minimumValue
|
|
71
|
-
* and maximumValue, which default to 0 and 1 respectively.
|
|
72
|
-
* Default value is 0.
|
|
73
|
-
*
|
|
74
|
-
* *This is not a controlled component*, you don't need to update the
|
|
75
|
-
* value during dragging.
|
|
76
|
-
*/
|
|
77
|
-
value?: ?number,
|
|
78
|
-
|
|
79
|
-
/**
|
|
80
|
-
* Step value of the slider. The value should be
|
|
81
|
-
* between 0 and (maximumValue - minimumValue).
|
|
82
|
-
* Default value is 0.
|
|
83
|
-
*/
|
|
84
|
-
step?: ?number,
|
|
85
|
-
|
|
86
|
-
/**
|
|
87
|
-
* Initial minimum value of the slider. Default value is 0.
|
|
88
|
-
*/
|
|
89
|
-
minimumValue?: ?number,
|
|
90
|
-
|
|
91
|
-
/**
|
|
92
|
-
* Initial maximum value of the slider. Default value is 1.
|
|
93
|
-
*/
|
|
94
|
-
maximumValue?: ?number,
|
|
95
|
-
|
|
96
|
-
/**
|
|
97
|
-
* The color used for the track to the left of the button.
|
|
98
|
-
* Overrides the default blue gradient image on iOS.
|
|
99
|
-
*/
|
|
100
|
-
minimumTrackTintColor?: ?ColorValue,
|
|
101
|
-
|
|
102
|
-
/**
|
|
103
|
-
* The color used for the track to the right of the button.
|
|
104
|
-
* Overrides the default blue gradient image on iOS.
|
|
105
|
-
*/
|
|
106
|
-
maximumTrackTintColor?: ?ColorValue,
|
|
107
|
-
/**
|
|
108
|
-
* The color used to tint the default thumb images on iOS, or the
|
|
109
|
-
* color of the foreground switch grip on Android.
|
|
110
|
-
*/
|
|
111
|
-
thumbTintColor?: ?ColorValue,
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* If true the user won't be able to move the slider.
|
|
115
|
-
* Default value is false.
|
|
116
|
-
*/
|
|
117
|
-
disabled?: ?boolean,
|
|
118
|
-
|
|
119
|
-
/**
|
|
120
|
-
* Callback continuously called while the user is dragging the slider.
|
|
121
|
-
*/
|
|
122
|
-
onValueChange?: ?(value: number) => void,
|
|
123
|
-
|
|
124
|
-
/**
|
|
125
|
-
* Callback that is called when the user releases the slider,
|
|
126
|
-
* regardless if the value has changed. The current value is passed
|
|
127
|
-
* as an argument to the callback handler.
|
|
128
|
-
*/
|
|
129
|
-
onSlidingComplete?: ?(value: number) => void,
|
|
130
|
-
|
|
131
|
-
/**
|
|
132
|
-
* Used to locate this view in UI automation tests.
|
|
133
|
-
*/
|
|
134
|
-
testID?: ?string,
|
|
135
|
-
|
|
136
|
-
/**
|
|
137
|
-
Indicates to accessibility services that UI Component is in a specific State.
|
|
138
|
-
*/
|
|
139
|
-
accessibilityState?: ?AccessibilityState,
|
|
140
|
-
|}>;
|
|
141
|
-
|
|
142
|
-
/**
|
|
143
|
-
* A component used to select a single value from a range of values.
|
|
144
|
-
*
|
|
145
|
-
* ### Usage
|
|
146
|
-
*
|
|
147
|
-
* The example below shows how to use `Slider` to change
|
|
148
|
-
* a value used by `Text`. The value is stored using
|
|
149
|
-
* the state of the root component (`App`). The same component
|
|
150
|
-
* subscribes to the `onValueChange` of `Slider` and changes
|
|
151
|
-
* the value using `setState`.
|
|
152
|
-
*
|
|
153
|
-
*```
|
|
154
|
-
* import React from 'react';
|
|
155
|
-
* import { StyleSheet, Text, View, Slider } from 'react-native';
|
|
156
|
-
*
|
|
157
|
-
* export default class App extends React.Component {
|
|
158
|
-
* constructor(props) {
|
|
159
|
-
* super(props);
|
|
160
|
-
* this.state = {
|
|
161
|
-
* value: 50
|
|
162
|
-
* }
|
|
163
|
-
* }
|
|
164
|
-
*
|
|
165
|
-
* change(value) {
|
|
166
|
-
* this.setState(() => {
|
|
167
|
-
* return {
|
|
168
|
-
* value: parseFloat(value)
|
|
169
|
-
* };
|
|
170
|
-
* });
|
|
171
|
-
* }
|
|
172
|
-
*
|
|
173
|
-
* render() {
|
|
174
|
-
* const {value} = this.state;
|
|
175
|
-
* return (
|
|
176
|
-
* <View style={styles.container}>
|
|
177
|
-
* <Text style={styles.text}>{String(value)}</Text>
|
|
178
|
-
* <Slider
|
|
179
|
-
* step={1}
|
|
180
|
-
* maximumValue={100}
|
|
181
|
-
* onValueChange={this.change.bind(this)}
|
|
182
|
-
* value={value} />
|
|
183
|
-
* </View>
|
|
184
|
-
* );
|
|
185
|
-
* }
|
|
186
|
-
* }
|
|
187
|
-
*
|
|
188
|
-
* const styles = StyleSheet.create({
|
|
189
|
-
* container: {
|
|
190
|
-
* flex: 1,
|
|
191
|
-
* flexDirection: 'column',
|
|
192
|
-
* justifyContent: 'center'
|
|
193
|
-
* },
|
|
194
|
-
* text: {
|
|
195
|
-
* fontSize: 50,
|
|
196
|
-
* textAlign: 'center'
|
|
197
|
-
* }
|
|
198
|
-
* });
|
|
199
|
-
*```
|
|
200
|
-
*
|
|
201
|
-
*/
|
|
202
|
-
const Slider = (
|
|
203
|
-
props: Props,
|
|
204
|
-
forwardedRef?: ?React.Ref<typeof SliderNativeComponent>,
|
|
205
|
-
) => {
|
|
206
|
-
const style = StyleSheet.compose(styles.slider, props.style);
|
|
207
|
-
|
|
208
|
-
const {
|
|
209
|
-
value = 0.5,
|
|
210
|
-
minimumValue = 0,
|
|
211
|
-
maximumValue = 1,
|
|
212
|
-
step = 0,
|
|
213
|
-
onValueChange,
|
|
214
|
-
onSlidingComplete,
|
|
215
|
-
...localProps
|
|
216
|
-
} = props;
|
|
217
|
-
|
|
218
|
-
const onValueChangeEvent = onValueChange
|
|
219
|
-
? (event: Event) => {
|
|
220
|
-
let userEvent = true;
|
|
221
|
-
if (Platform.OS === 'android') {
|
|
222
|
-
// On Android there's a special flag telling us the user is
|
|
223
|
-
// dragging the slider.
|
|
224
|
-
userEvent =
|
|
225
|
-
event.nativeEvent.fromUser != null && event.nativeEvent.fromUser;
|
|
226
|
-
}
|
|
227
|
-
userEvent && onValueChange(event.nativeEvent.value);
|
|
228
|
-
}
|
|
229
|
-
: null;
|
|
230
|
-
|
|
231
|
-
const onSlidingCompleteEvent = onSlidingComplete
|
|
232
|
-
? (event: Event) => {
|
|
233
|
-
onSlidingComplete(event.nativeEvent.value);
|
|
234
|
-
}
|
|
235
|
-
: null;
|
|
236
|
-
|
|
237
|
-
const disabled =
|
|
238
|
-
props.disabled === true || props.accessibilityState?.disabled === true;
|
|
239
|
-
const accessibilityState = disabled
|
|
240
|
-
? {...props.accessibilityState, disabled: true}
|
|
241
|
-
: props.accessibilityState;
|
|
242
|
-
|
|
243
|
-
return (
|
|
244
|
-
<SliderNativeComponent
|
|
245
|
-
{...localProps}
|
|
246
|
-
accessibilityState={accessibilityState}
|
|
247
|
-
// TODO: Reconcile these across the two platforms.
|
|
248
|
-
enabled={!disabled}
|
|
249
|
-
disabled={disabled}
|
|
250
|
-
maximumValue={maximumValue}
|
|
251
|
-
minimumValue={minimumValue}
|
|
252
|
-
onResponderTerminationRequest={() => false}
|
|
253
|
-
onSlidingComplete={onSlidingCompleteEvent}
|
|
254
|
-
onStartShouldSetResponder={() => true}
|
|
255
|
-
onValueChange={onValueChangeEvent}
|
|
256
|
-
ref={forwardedRef}
|
|
257
|
-
step={step}
|
|
258
|
-
style={style}
|
|
259
|
-
value={value}
|
|
260
|
-
/>
|
|
261
|
-
);
|
|
262
|
-
};
|
|
263
|
-
|
|
264
|
-
const SliderWithRef: React.AbstractComponent<
|
|
265
|
-
Props,
|
|
266
|
-
React.ElementRef<typeof SliderNativeComponent>,
|
|
267
|
-
> = React.forwardRef(Slider);
|
|
268
|
-
|
|
269
|
-
let styles;
|
|
270
|
-
if (Platform.OS === 'ios') {
|
|
271
|
-
styles = StyleSheet.create({
|
|
272
|
-
slider: {
|
|
273
|
-
height: 40,
|
|
274
|
-
},
|
|
275
|
-
});
|
|
276
|
-
} else {
|
|
277
|
-
styles = StyleSheet.create({
|
|
278
|
-
slider: {},
|
|
279
|
-
});
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
module.exports = SliderWithRef;
|