mirror of
https://github.com/facebook/react-native.git
synced 2025-11-01 09:14:26 +00:00
1977dd6596
Summary: Pull Request resolved: https://github.com/facebook/react-native/pull/51554 Sorts pragma directives file headers in React Native. Changelog: [Internal] Reviewed By: SamChou19815 Differential Revision: D75264593 fbshipit-source-id: 9e4b253dd0fc94dc2fc469d7114b93a8aae305f4
86 lines
2.2 KiB
JavaScript
86 lines
2.2 KiB
JavaScript
/**
|
|
* Copyright (c) Meta Platforms, Inc. and affiliates.
|
|
*
|
|
* This source code is licensed under the MIT license found in the
|
|
* LICENSE file in the root directory of this source tree.
|
|
*
|
|
* @flow strict-local
|
|
* @format
|
|
*/
|
|
|
|
import RNTesterComponentTitle from './RNTesterComponentTitle';
|
|
import {RNTesterThemeContext} from './RNTesterTheme';
|
|
import * as React from 'react';
|
|
import {useContext} from 'react';
|
|
import {Pressable, StyleSheet, Text, View} from 'react-native';
|
|
|
|
type ViewStyleProp = React.ElementConfig<typeof View>['style'];
|
|
type Props = {
|
|
accessibilityLabel?: ?string,
|
|
testID?: ?string,
|
|
onPressIn?: ?() => mixed,
|
|
onPressOut?: ?() => mixed,
|
|
children?: ?React.Node,
|
|
title: string,
|
|
description?: ?string,
|
|
onPress: () => mixed,
|
|
style?: ViewStyleProp | ((pressed: boolean) => ViewStyleProp),
|
|
};
|
|
|
|
export default function RNTPressableRow({
|
|
onPressIn,
|
|
onPressOut,
|
|
title,
|
|
description,
|
|
onPress,
|
|
style,
|
|
accessibilityLabel,
|
|
}: Props): React.Node {
|
|
const theme = useContext(RNTesterThemeContext);
|
|
const label = accessibilityLabel ?? `${title} ${description ?? ''}`;
|
|
return (
|
|
<Pressable
|
|
testID={title}
|
|
onPressIn={onPressIn}
|
|
onPressOut={onPressOut}
|
|
accessibilityLabel={label}
|
|
style={({pressed}) => [
|
|
styles.row,
|
|
typeof style === 'function' ? style(pressed) : style,
|
|
pressed
|
|
? {backgroundColor: theme.SecondarySystemFillColor}
|
|
: {backgroundColor: theme.SecondaryGroupedBackgroundColor},
|
|
]}
|
|
onPress={onPress}>
|
|
<View style={styles.topRowStyle}>
|
|
<RNTesterComponentTitle>{title}</RNTesterComponentTitle>
|
|
</View>
|
|
<Text
|
|
style={[styles.descriptionText, {color: theme.SecondaryLabelColor}]}>
|
|
{description}
|
|
</Text>
|
|
</Pressable>
|
|
);
|
|
}
|
|
|
|
const styles = StyleSheet.create({
|
|
row: {
|
|
justifyContent: 'center',
|
|
paddingHorizontal: 16,
|
|
paddingVertical: 16,
|
|
marginVertical: 5,
|
|
marginHorizontal: 16,
|
|
boxShadow: '0 2px 4px -1px rgba(0, 0, 0, 0.25)',
|
|
borderRadius: 8,
|
|
},
|
|
descriptionText: {
|
|
marginTop: 6,
|
|
fontSize: 12,
|
|
},
|
|
topRowStyle: {
|
|
flexDirection: 'row',
|
|
justifyContent: 'space-between',
|
|
flex: 1,
|
|
},
|
|
});
|