Files
react-native/packages/rn-tester/js/components/RNTesterBlock.js
Sam Zhou 0666885f6a Deploy 0.275.0 to xplat
Summary: Changelog: [Internal]

Reviewed By: marcoww6

Differential Revision: D77800436

fbshipit-source-id: ff5a6a629c950959678d6a6311cda053f6b5dd4c
2025-07-04 11:55:28 -07:00

80 lines
1.8 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
* @format
*/
import {RNTesterThemeContext} from './RNTesterTheme';
import * as React from 'react';
import {useContext} from 'react';
import {StyleSheet, Text, View} from 'react-native';
type Props = $ReadOnly<{
children?: React.Node,
title?: ?string,
description?: ?string,
}>;
const RNTesterBlock = ({description, title, children}: Props): React.Node => {
const theme = useContext(RNTesterThemeContext);
return (
<View
style={[
[styles.container],
{
borderColor: theme.SeparatorColor,
backgroundColor: theme.SecondaryGroupedBackgroundColor,
},
]}>
<View style={[styles.titleContainer]}>
{title && (
<Text style={[styles.titleText, {color: theme.LabelColor}]}>
{title}
</Text>
)}
{description && (
<Text
style={[
styles.descriptionText,
// $FlowFixMe[constant-condition]
{color: theme.LabelColor, marginTop: description ? 10 : 0},
]}>
{description}
</Text>
)}
</View>
<View style={styles.children}>{children}</View>
</View>
);
};
const styles = StyleSheet.create({
container: {
borderRadius: 0,
borderWidth: 1,
marginHorizontal: 20,
},
titleText: {
fontSize: 18,
fontWeight: '300',
},
titleContainer: {
paddingHorizontal: 10,
paddingVertical: 5,
},
descriptionText: {
fontSize: 12,
opacity: 0.5,
},
children: {
marginHorizontal: 20,
marginVertical: 10,
},
});
module.exports = RNTesterBlock;