forked from Ivasoft/mattermost-mobile
* 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
82 lines
2.3 KiB
TypeScript
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>
|
|
);
|
|
}
|
|
|