Files
react-native/packages/rn-tester/js/components/RNTesterBlock.js
Moti Zilberman d6e0bc714a Enable lint/sort-imports everywhere (#41334)
Summary:
Pull Request resolved: https://github.com/facebook/react-native/pull/41334

TSIA.

Changelog: [Internal]

Reviewed By: robhogan

Differential Revision: D51025812

fbshipit-source-id: e10d437be775a6b80946483aa96460f34927f870
2023-11-06 12:59:38 -08:00

78 lines
1.7 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.
*
* @format
* @flow
*/
import {RNTesterThemeContext} from './RNTesterTheme';
import * as React 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 = React.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,
{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;