Files
mattermost-mobile/app/components/channel_icon/index.tsx
Daniel Espino García a8ee3a1b5a Fix and unify channel and user list items (#7175)
* Fix channel and user list items

* Fixes on members and create a dm lists

* Fix tutorial and ipad

* Fix test

* Address feedback

* Several fixes on Android

* Fix tests

* Address feedback

* Add more non breaking strings

---------

Co-authored-by: Daniel Espino <danielespino@MacBook-Pro-de-Daniel.local>
2023-04-19 10:13:14 +02:00

228 lines
6.3 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React from 'react';
import {StyleProp, Text, View, ViewStyle} from 'react-native';
import CompassIcon from '@components/compass_icon';
import General from '@constants/general';
import {useTheme} from '@context/theme';
import {changeOpacity, makeStyleSheetFromTheme} from '@utils/theme';
import {typography} from '@utils/typography';
import DmAvatar from './dm_avatar';
type ChannelIconProps = {
hasDraft?: boolean;
isActive?: boolean;
isArchived?: boolean;
isOnCenterBg?: boolean;
isUnread?: boolean;
isMuted?: boolean;
membersCount?: number;
name: string;
shared: boolean;
size?: number;
style?: StyleProp<ViewStyle>;
testID?: string;
type: string;
};
const getStyleSheet = makeStyleSheetFromTheme((theme: Theme) => {
return {
container: {
alignItems: 'center',
justifyContent: 'center',
},
icon: {
color: changeOpacity(theme.sidebarText, 0.4),
},
iconActive: {
color: theme.sidebarText,
},
iconUnread: {
color: theme.sidebarUnreadText,
},
iconOnCenterBg: {
color: changeOpacity(theme.centerChannelColor, 0.72),
},
iconUnreadOnCenterBg: {
color: theme.centerChannelColor,
},
groupBox: {
alignItems: 'center',
backgroundColor: changeOpacity(theme.sidebarText, 0.16),
borderRadius: 4,
justifyContent: 'center',
},
groupBoxActive: {
backgroundColor: changeOpacity(theme.sidebarText, 0.3),
},
groupBoxUnread: {
backgroundColor: changeOpacity(theme.sidebarUnreadText, 0.3),
},
groupBoxOnCenterBg: {
backgroundColor: changeOpacity(theme.centerChannelColor, 0.3),
},
group: {
color: theme.sidebarText,
...typography('Body', 75, 'SemiBold'),
},
groupActive: {
color: theme.sidebarText,
},
groupUnread: {
color: theme.sidebarUnreadText,
},
groupOnCenterBg: {
color: changeOpacity(theme.centerChannelColor, 0.72),
},
groupUnreadOnCenterBg: {
color: theme.centerChannelColor,
},
muted: {
opacity: 0.4,
},
};
});
const ChannelIcon = ({
hasDraft = false, isActive = false, isArchived = false,
isOnCenterBg = false, isUnread = false, isMuted = false,
membersCount = 0, name,
shared, size = 12, style, testID, type,
}: ChannelIconProps) => {
const theme = useTheme();
const styles = getStyleSheet(theme);
let activeIcon;
let unreadIcon;
let activeGroupBox;
let unreadGroupBox;
let activeGroup;
let unreadGroup;
let mutedStyle;
if (isUnread && !isMuted) {
unreadIcon = styles.iconUnread;
unreadGroupBox = styles.groupBoxUnread;
unreadGroup = styles.groupUnread;
}
if (isActive) {
activeIcon = styles.iconActive;
activeGroupBox = styles.groupBoxActive;
activeGroup = styles.groupActive;
}
if (isOnCenterBg) {
activeIcon = isUnread && !isMuted ? styles.iconUnreadOnCenterBg : styles.iconOnCenterBg;
activeGroupBox = styles.groupBoxOnCenterBg;
activeGroup = isUnread ? styles.groupUnreadOnCenterBg : styles.groupOnCenterBg;
}
if (isMuted) {
mutedStyle = styles.muted;
}
const commonStyles = [
style,
mutedStyle,
];
const commonIconStyles = [
styles.icon,
unreadIcon,
activeIcon,
commonStyles,
{fontSize: size},
];
let icon = null;
if (isArchived) {
icon = (
<CompassIcon
name='archive-outline'
style={[
commonIconStyles,
{left: 1},
]}
testID={`${testID}.archive`}
/>
);
} else if (hasDraft) {
icon = (
<CompassIcon
name='pencil-outline'
style={[
commonIconStyles,
{left: 2},
]}
testID={`${testID}.draft`}
/>
);
} else if (shared) {
const iconName = type === General.PRIVATE_CHANNEL ? 'circle-multiple-outline-lock' : 'circle-multiple-outline';
const sharedTestID = type === General.PRIVATE_CHANNEL ? 'channel_icon.shared_private' : 'channel_icon.shared_open';
icon = (
<CompassIcon
name={iconName}
style={[
commonIconStyles,
{left: 0.5},
]}
testID={sharedTestID}
/>
);
} else if (type === General.OPEN_CHANNEL) {
icon = (
<CompassIcon
name='globe'
style={[
commonIconStyles,
{left: 1},
]}
testID={`${testID}.public`}
/>
);
} else if (type === General.PRIVATE_CHANNEL) {
icon = (
<CompassIcon
name='lock-outline'
style={[
commonIconStyles,
{left: 0.5},
]}
testID={`${testID}.private`}
/>
);
} else if (type === General.GM_CHANNEL) {
const fontSize = size - 12;
icon = (
<View
style={[styles.groupBox, unreadGroupBox, activeGroupBox, commonStyles, {width: size, height: size}]}
>
<Text
style={[styles.group, unreadGroup, activeGroup, {fontSize}]}
testID={`${testID}.gm_member_count`}
>
{membersCount - 1}
</Text>
</View>
);
} else if (type === General.DM_CHANNEL) {
icon = (
<DmAvatar
channelName={name}
isOnCenterBg={isOnCenterBg}
style={commonStyles}
size={size}
/>
);
}
return icon;
};
export default React.memo(ChannelIcon);