Rocket.Chat.ReactNative/app/containers/markdown/new/Code.tsx

38 lines
751 B
TypeScript

import React from 'react';
import { View } from 'react-native';
import { Code as CodeProps } from '@rocket.chat/message-parser';
import styles from '../styles';
import { useTheme } from '../../../theme';
import CodeLine from './CodeLine';
interface ICodeProps {
value: CodeProps['value'];
}
const Code = ({ value }: ICodeProps): React.ReactElement => {
const { colors } = useTheme();
return (
<View
style={[
styles.codeBlock,
{
backgroundColor: colors.bannerBackground,
borderColor: colors.borderColor
}
]}>
{value.map(block => {
switch (block.type) {
case 'CODE_LINE':
return <CodeLine value={block.value} />;
default:
return null;
}
})}
</View>
);
};
export default Code;