forked from Ivasoft/mattermost-mobile
* Remove mattermost-redux * Move mm-redux files into app/redux * Add @redux path to tsconfig.json * Fix imports * Install missing dependencies * Fix tsc errors * Fix i18n_utils test * Fix more imports * Remove redux websocket * Fix tests * Rename @redux * Apply changes from mattermost-redux PR 1103 * Remove mattermost-redux mention in template * Add missing imports * Rename app/redux/ to app/mm-redux/ * Remove test file * Fix fetching Sidebar GM profiles Co-authored-by: Elias Nahum <nahumhbl@gmail.com>
232 lines
7.0 KiB
JavaScript
232 lines
7.0 KiB
JavaScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
import React from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import {
|
|
Text,
|
|
View,
|
|
} from 'react-native';
|
|
|
|
import {General} from '@mm-redux/constants';
|
|
|
|
import Icon from 'app/components/vector_icon';
|
|
|
|
import {changeOpacity, makeStyleSheetFromTheme} from 'app/utils/theme';
|
|
|
|
export default class ChannelIcon extends React.PureComponent {
|
|
static propTypes = {
|
|
isActive: PropTypes.bool,
|
|
isInfo: PropTypes.bool,
|
|
isUnread: PropTypes.bool,
|
|
hasDraft: PropTypes.bool,
|
|
membersCount: PropTypes.number,
|
|
size: PropTypes.number,
|
|
status: PropTypes.string,
|
|
theme: PropTypes.object.isRequired,
|
|
type: PropTypes.string.isRequired,
|
|
isArchived: PropTypes.bool.isRequired,
|
|
isBot: PropTypes.bool.isRequired,
|
|
};
|
|
|
|
static defaultProps = {
|
|
isActive: false,
|
|
isInfo: false,
|
|
isUnread: false,
|
|
size: 12,
|
|
};
|
|
|
|
render() {
|
|
const {
|
|
isActive,
|
|
isUnread,
|
|
isInfo,
|
|
hasDraft,
|
|
membersCount,
|
|
size,
|
|
status,
|
|
theme,
|
|
type,
|
|
isArchived,
|
|
isBot,
|
|
} = this.props;
|
|
const style = getStyleSheet(theme);
|
|
|
|
let activeIcon;
|
|
let unreadIcon;
|
|
let activeGroupBox;
|
|
let unreadGroupBox;
|
|
let activeGroup;
|
|
let unreadGroup;
|
|
let offlineColor = changeOpacity(theme.sidebarText, 0.5);
|
|
|
|
if (isUnread) {
|
|
unreadIcon = style.iconUnread;
|
|
unreadGroupBox = style.groupBoxUnread;
|
|
unreadGroup = style.groupUnread;
|
|
}
|
|
|
|
if (isActive) {
|
|
activeIcon = style.iconActive;
|
|
activeGroupBox = style.groupBoxActive;
|
|
activeGroup = style.groupActive;
|
|
}
|
|
|
|
if (isInfo) {
|
|
activeIcon = style.iconInfo;
|
|
activeGroupBox = style.groupBoxInfo;
|
|
activeGroup = style.groupInfo;
|
|
offlineColor = changeOpacity(theme.centerChannelColor, 0.5);
|
|
}
|
|
|
|
let icon;
|
|
if (isArchived) {
|
|
icon = (
|
|
<Icon
|
|
name='archive'
|
|
style={[style.icon, unreadIcon, activeIcon, {fontSize: size}]}
|
|
type='mattermost'
|
|
/>
|
|
);
|
|
} else if (isBot) {
|
|
icon = (
|
|
<Icon
|
|
name='bot'
|
|
style={[style.icon, unreadIcon, activeIcon, {fontSize: (size - 1), left: -1.5, top: -1}]}
|
|
type='mattermost'
|
|
/>
|
|
);
|
|
} else if (hasDraft) {
|
|
icon = (
|
|
<Icon
|
|
name='draft'
|
|
style={[style.icon, unreadIcon, activeIcon, {fontSize: size}]}
|
|
type='mattermost'
|
|
/>
|
|
);
|
|
} else if (type === General.OPEN_CHANNEL) {
|
|
icon = (
|
|
<Icon
|
|
name='public'
|
|
style={[style.icon, unreadIcon, activeIcon, {fontSize: size}]}
|
|
type='mattermost'
|
|
/>
|
|
);
|
|
} else if (type === General.PRIVATE_CHANNEL) {
|
|
icon = (
|
|
<Icon
|
|
name='private'
|
|
style={[style.icon, unreadIcon, activeIcon, {fontSize: size, left: 0.5}]}
|
|
type='mattermost'
|
|
/>
|
|
);
|
|
} else if (type === General.GM_CHANNEL) {
|
|
icon = (
|
|
<View style={[style.groupBox, unreadGroupBox, activeGroupBox, {width: size + 1, height: size + 1}]}>
|
|
<Text style={[style.group, unreadGroup, activeGroup, {fontSize: (size - 4)}]}>
|
|
{membersCount}
|
|
</Text>
|
|
</View>
|
|
);
|
|
} else if (type === General.DM_CHANNEL) {
|
|
switch (status) {
|
|
case General.AWAY:
|
|
icon = (
|
|
<Icon
|
|
name='away-avatar'
|
|
style={[style.icon, unreadIcon, activeIcon, {fontSize: size, color: theme.awayIndicator}]}
|
|
type='mattermost'
|
|
/>
|
|
);
|
|
break;
|
|
case General.DND:
|
|
icon = (
|
|
<Icon
|
|
name='dnd-avatar'
|
|
style={[style.icon, unreadIcon, activeIcon, {fontSize: size, color: theme.dndIndicator}]}
|
|
type='mattermost'
|
|
/>
|
|
);
|
|
break;
|
|
case General.ONLINE:
|
|
icon = (
|
|
<Icon
|
|
name='online-avatar'
|
|
style={[style.icon, unreadIcon, activeIcon, {fontSize: size, color: theme.onlineIndicator}]}
|
|
type='mattermost'
|
|
/>
|
|
);
|
|
break;
|
|
default:
|
|
icon = (
|
|
<Icon
|
|
name='offline-avatar'
|
|
style={[style.icon, unreadIcon, activeIcon, {fontSize: size, color: offlineColor}]}
|
|
type='mattermost'
|
|
/>
|
|
);
|
|
break;
|
|
}
|
|
}
|
|
|
|
return (
|
|
<View style={[style.container, {height: size}]}>
|
|
{icon}
|
|
</View>
|
|
);
|
|
}
|
|
}
|
|
|
|
const getStyleSheet = makeStyleSheetFromTheme((theme) => {
|
|
return {
|
|
container: {
|
|
marginRight: 12,
|
|
alignItems: 'center',
|
|
},
|
|
icon: {
|
|
color: changeOpacity(theme.sidebarText, 0.4),
|
|
},
|
|
iconActive: {
|
|
color: theme.sidebarTextActiveColor,
|
|
},
|
|
iconUnread: {
|
|
color: theme.sidebarUnreadText,
|
|
},
|
|
iconInfo: {
|
|
color: theme.centerChannelColor,
|
|
},
|
|
groupBox: {
|
|
alignSelf: 'flex-start',
|
|
alignItems: 'center',
|
|
backgroundColor: changeOpacity(theme.sidebarText, 0.3),
|
|
borderColor: changeOpacity(theme.sidebarText, 0.3),
|
|
borderWidth: 1,
|
|
borderRadius: 2,
|
|
justifyContent: 'center',
|
|
},
|
|
groupBoxActive: {
|
|
backgroundColor: changeOpacity(theme.sidebarTextActiveColor, 0.3),
|
|
},
|
|
groupBoxUnread: {
|
|
backgroundColor: changeOpacity(theme.sidebarUnreadText, 0.3),
|
|
},
|
|
groupBoxInfo: {
|
|
backgroundColor: changeOpacity(theme.centerChannelColor, 0.3),
|
|
},
|
|
group: {
|
|
color: changeOpacity(theme.sidebarText, 0.6),
|
|
fontSize: 10,
|
|
fontWeight: '600',
|
|
},
|
|
groupActive: {
|
|
color: theme.sidebarTextActiveColor,
|
|
},
|
|
groupUnread: {
|
|
color: theme.sidebarUnreadText,
|
|
},
|
|
groupInfo: {
|
|
color: theme.centerChannelColor,
|
|
},
|
|
};
|
|
});
|