2020-10-30 16:15:58 +00:00
|
|
|
import React from 'react';
|
|
|
|
import { View, Text, StyleSheet } from 'react-native';
|
|
|
|
|
|
|
|
import sharedStyles from '../../views/Styles';
|
|
|
|
import { getUnreadStyle } from './getUnreadStyle';
|
|
|
|
import { withTheme } from '../../theme';
|
|
|
|
|
|
|
|
const styles = StyleSheet.create({
|
|
|
|
unreadNumberContainerNormal: {
|
|
|
|
height: 21,
|
|
|
|
paddingVertical: 3,
|
|
|
|
paddingHorizontal: 5,
|
|
|
|
borderRadius: 10.5,
|
|
|
|
alignItems: 'center',
|
|
|
|
justifyContent: 'center',
|
|
|
|
marginLeft: 10
|
|
|
|
},
|
|
|
|
unreadNumberContainerSmall: {
|
|
|
|
borderRadius: 10.5,
|
|
|
|
alignItems: 'center',
|
|
|
|
justifyContent: 'center'
|
|
|
|
},
|
|
|
|
unreadText: {
|
|
|
|
fontSize: 13,
|
2020-10-30 17:35:07 +00:00
|
|
|
...sharedStyles.textSemibold
|
2020-10-30 16:15:58 +00:00
|
|
|
},
|
|
|
|
textSmall: {
|
|
|
|
fontSize: 10
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2021-07-29 18:15:09 +00:00
|
|
|
interface IUnreadBadge {
|
|
|
|
theme: string;
|
|
|
|
unread: number;
|
|
|
|
userMentions: number;
|
|
|
|
groupMentions: number;
|
|
|
|
style: object;
|
|
|
|
tunread: [];
|
|
|
|
tunreadUser: [];
|
|
|
|
tunreadGroup: [];
|
|
|
|
small: boolean;
|
|
|
|
}
|
|
|
|
|
2020-10-30 16:15:58 +00:00
|
|
|
const UnreadBadge = React.memo(({
|
|
|
|
theme, unread, userMentions, groupMentions, style, tunread, tunreadUser, tunreadGroup, small
|
2021-07-29 18:15:09 +00:00
|
|
|
}: IUnreadBadge) => {
|
2020-10-30 16:15:58 +00:00
|
|
|
if ((!unread || unread <= 0) && (!tunread?.length)) {
|
2021-07-21 15:50:39 +00:00
|
|
|
return null;
|
2020-10-30 16:15:58 +00:00
|
|
|
}
|
|
|
|
const { backgroundColor, color } = getUnreadStyle({
|
|
|
|
theme, unread, userMentions, groupMentions, tunread, tunreadUser, tunreadGroup
|
|
|
|
});
|
|
|
|
|
|
|
|
if (!backgroundColor) {
|
|
|
|
return null;
|
|
|
|
}
|
2021-07-29 18:15:09 +00:00
|
|
|
let text: any = unread || tunread?.length;
|
2020-10-30 16:15:58 +00:00
|
|
|
if (small && text >= 100) {
|
|
|
|
text = '+99';
|
|
|
|
}
|
|
|
|
if (!small && text >= 1000) {
|
|
|
|
text = '+999';
|
|
|
|
}
|
|
|
|
text = text.toString();
|
|
|
|
|
|
|
|
let minWidth = 21;
|
|
|
|
if (small) {
|
|
|
|
minWidth = 11 + text.length * 5;
|
|
|
|
}
|
|
|
|
|
|
|
|
return (
|
|
|
|
<View
|
|
|
|
style={[
|
|
|
|
small ? styles.unreadNumberContainerSmall : styles.unreadNumberContainerNormal,
|
|
|
|
{ backgroundColor, minWidth },
|
|
|
|
style
|
|
|
|
]}
|
|
|
|
>
|
|
|
|
<Text
|
|
|
|
style={[
|
|
|
|
styles.unreadText,
|
|
|
|
small && styles.textSmall,
|
|
|
|
{ color }
|
|
|
|
]}
|
|
|
|
numberOfLines={1}
|
|
|
|
>{text}
|
|
|
|
</Text>
|
|
|
|
</View>
|
|
|
|
);
|
|
|
|
});
|
|
|
|
|
|
|
|
export default withTheme(UnreadBadge);
|