verdnatura-chat/app/views/RoomView/Header/Header.js

161 lines
3.6 KiB
JavaScript
Raw Normal View History

2019-04-08 12:35:28 +00:00
import React from 'react';
import PropTypes from 'prop-types';
import {
2019-12-11 23:01:12 +00:00
View, Text, StyleSheet, ScrollView, TouchableOpacity
2019-04-08 12:35:28 +00:00
} from 'react-native';
import { shortnameToUnicode } from 'emoji-toolkit';
import removeMarkdown from 'remove-markdown';
2019-04-08 12:35:28 +00:00
import I18n from '../../../i18n';
import sharedStyles from '../../Styles';
2019-12-11 23:01:12 +00:00
import { isAndroid, isTablet } from '../../../utils/deviceInfo';
2019-04-08 12:35:28 +00:00
import Icon from './Icon';
2019-12-11 23:01:12 +00:00
import { themes } from '../../../constants/colors';
const androidMarginLeft = isTablet ? 0 : 10;
2019-04-08 12:35:28 +00:00
const TITLE_SIZE = 16;
const styles = StyleSheet.create({
container: {
flex: 1,
height: '100%',
marginRight: isAndroid ? 15 : 5,
2019-12-11 23:01:12 +00:00
marginLeft: isAndroid ? androidMarginLeft : -12
2019-04-08 12:35:28 +00:00
},
titleContainer: {
flex: 6,
flexDirection: 'row'
},
2019-04-17 17:01:03 +00:00
threadContainer: {
marginRight: isAndroid ? 20 : undefined
},
2019-04-08 12:35:28 +00:00
title: {
...sharedStyles.textSemibold,
fontSize: TITLE_SIZE
},
scroll: {
alignItems: 'center'
},
typing: {
...sharedStyles.textRegular,
fontSize: 12,
flex: 4
},
typingUsers: {
...sharedStyles.textSemibold
}
});
2019-12-11 23:01:12 +00:00
const Typing = React.memo(({ usersTyping, theme }) => {
2019-04-08 12:35:28 +00:00
let usersText;
if (!usersTyping.length) {
2019-04-08 12:35:28 +00:00
return null;
} else if (usersTyping.length === 2) {
usersText = usersTyping.join(` ${ I18n.t('and') } `);
2019-04-08 12:35:28 +00:00
} else {
usersText = usersTyping.join(', ');
2019-04-08 12:35:28 +00:00
}
return (
2019-12-11 23:01:12 +00:00
<Text style={[styles.typing, { color: themes[theme].headerTitleColor }]} numberOfLines={1}>
2019-04-08 12:35:28 +00:00
<Text style={styles.typingUsers}>{usersText} </Text>
{ usersTyping.length > 1 ? I18n.t('are_typing') : I18n.t('is_typing') }...
2019-04-08 12:35:28 +00:00
</Text>
);
});
Typing.propTypes = {
2019-12-11 23:01:12 +00:00
usersTyping: PropTypes.array,
theme: PropTypes.string
2019-04-08 12:35:28 +00:00
};
const HeaderTitle = React.memo(({
2019-12-11 23:01:12 +00:00
title, scale, connecting, theme
}) => {
if (connecting) {
title = I18n.t('Connecting');
}
return (
<Text
2019-12-11 23:01:12 +00:00
style={[styles.title, { fontSize: TITLE_SIZE * scale, color: themes[theme].headerTitleColor }]}
numberOfLines={1}
testID={`room-view-title-${ title }`}
>{title}
</Text>
);
});
HeaderTitle.propTypes = {
title: PropTypes.string,
scale: PropTypes.number,
2019-12-11 23:01:12 +00:00
connecting: PropTypes.bool,
theme: PropTypes.string
};
2019-04-08 12:35:28 +00:00
const Header = React.memo(({
2019-12-11 23:01:12 +00:00
title, type, status, usersTyping, width, height, prid, tmid, widthOffset, connecting, goRoomActionsView, theme
2019-04-08 12:35:28 +00:00
}) => {
const portrait = height > width;
let scale = 1;
2019-12-11 23:01:12 +00:00
if (!portrait && !tmid) {
2019-04-08 12:35:28 +00:00
if (usersTyping.length > 0) {
scale = 0.8;
}
}
2019-04-17 17:01:03 +00:00
if (title) {
title = shortnameToUnicode(title);
if (tmid) {
title = removeMarkdown(title);
}
2019-04-17 17:01:03 +00:00
}
2019-12-11 23:01:12 +00:00
const onPress = () => {
if (!tmid) {
goRoomActionsView();
}
};
2019-04-08 12:35:28 +00:00
return (
2019-12-11 23:01:12 +00:00
<TouchableOpacity onPress={onPress} style={[styles.container, { width: width - widthOffset }]}>
2019-04-17 17:01:03 +00:00
<View style={[styles.titleContainer, tmid && styles.threadContainer]}>
2019-04-08 12:35:28 +00:00
<ScrollView
showsHorizontalScrollIndicator={false}
horizontal
bounces={false}
contentContainerStyle={styles.scroll}
>
2019-12-11 23:01:12 +00:00
<Icon type={prid ? 'discussion' : type} status={status} theme={theme} />
<HeaderTitle
title={title}
scale={scale}
connecting={connecting}
2019-12-11 23:01:12 +00:00
theme={theme}
/>
2019-04-08 12:35:28 +00:00
</ScrollView>
</View>
2019-12-11 23:01:12 +00:00
{type === 'thread' ? null : <Typing usersTyping={usersTyping} theme={theme} />}
</TouchableOpacity>
2019-04-08 12:35:28 +00:00
);
});
Header.propTypes = {
title: PropTypes.string.isRequired,
type: PropTypes.string.isRequired,
width: PropTypes.number.isRequired,
height: PropTypes.number.isRequired,
prid: PropTypes.string,
2019-04-17 17:01:03 +00:00
tmid: PropTypes.string,
2019-04-08 12:35:28 +00:00
status: PropTypes.string,
2019-12-11 23:01:12 +00:00
theme: PropTypes.string,
2019-04-17 17:01:03 +00:00
usersTyping: PropTypes.array,
widthOffset: PropTypes.number,
2019-12-11 23:01:12 +00:00
connecting: PropTypes.bool,
goRoomActionsView: PropTypes.func
2019-04-08 12:35:28 +00:00
};
Header.defaultProps = {
usersTyping: []
};
export default Header;