Files
mattermost-mobile/app/components/server_icon/index.tsx
Elias Nahum 1b62c10dcc [Gekidou] various fixes (#5951)
* Specify the screen to be dismissed from the bottom sheet on tablets

* reposition unread badge on server icon

* Skip setNavigatorStyles and set correct theme for login flow screens

* Fetch current user status with fetchMe and when the WS connects

* switchToChannel skip setting current channel if id is the same

* ChannelMention component to use switchToChannelById instead of switchToChannel

* loginEntry only set initialChannel if isTablet

* deferredAppEntryActions mark channel as read and fetch channel stats if initialChannel is set

* feedback review

* feedback review
2022-02-10 11:46:35 -03:00

82 lines
2.3 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React, {useMemo} from 'react';
import {StyleProp, StyleSheet, View, ViewStyle} from 'react-native';
import Badge from '@components/badge';
import CompassIcon from '@components/compass_icon';
import TouchableWithFeedback from '@components/touchable_with_feedback';
import {useTheme} from '@context/theme';
import {changeOpacity} from '@utils/theme';
type Props = {
badgeBackgroundColor?: string;
badgeBorderColor?: string;
badgeColor?: string;
badgeStyle?: StyleProp<ViewStyle>;
hasUnreads: boolean;
iconColor?: string;
mentionCount: number;
onPress?: () => void;
size?: number;
style?: StyleProp<ViewStyle>;
unreadStyle?: StyleProp<ViewStyle>;
}
const styles = StyleSheet.create({
badge: {
left: 25,
},
unread: {
left: 18,
top: -5,
},
});
export default function ServerIcon({
badgeBackgroundColor,
badgeBorderColor,
badgeColor,
badgeStyle,
hasUnreads,
iconColor,
mentionCount,
onPress,
size = 24,
style,
unreadStyle,
}: Props) {
const theme = useTheme();
const hasBadge = Boolean(mentionCount || hasUnreads);
const count = mentionCount || (hasUnreads ? -1 : 0);
const memoizedStyle = useMemo(() => {
return [(badgeStyle || styles.badge), count > -1 ? undefined : (unreadStyle || styles.unread)];
}, [badgeStyle, count, unreadStyle]);
return (
<View style={style}>
<TouchableWithFeedback
disabled={onPress === undefined}
onPress={onPress}
type='opacity'
>
<CompassIcon
size={size}
name='server-variant'
color={iconColor || changeOpacity(theme.sidebarHeaderTextColor, 0.56)}
/>
<Badge
borderColor={badgeBorderColor || theme.sidebarTeamBarBg}
backgroundColor={badgeBackgroundColor}
color={badgeColor}
visible={hasBadge}
style={memoizedStyle}
value={count}
/>
</TouchableWithFeedback>
</View>
);
}