import React from 'react'; import { StyleSheet, Text, View } from 'react-native'; import { TSupportedThemes } from '../../theme'; import { themes } from '../../lib/constants'; import styles from './styles'; const style = StyleSheet.create({ container: { flexDirection: 'row', alignItems: 'flex-start' }, bullet: { alignItems: 'flex-end', marginRight: 5 }, contents: { flex: 1 } }); interface IListItem { children: React.ReactElement | null; bulletWidth: number; level: number; ordered: boolean; continue: boolean; theme: TSupportedThemes; index: number; } const ListItem = React.memo(({ children, level, bulletWidth, continue: _continue, ordered, index, theme }: IListItem) => { let bullet; if (_continue) { bullet = ''; } else if (ordered) { bullet = `${index}.`; } else if (level % 2 === 0) { bullet = '◦'; } else { bullet = '•'; } return ( {bullet} {children} ); }); export default ListItem;