Files
mattermost-mobile/app/screens/select_team/team_list.tsx
Daniel Espino García 28526034d4 Refactor makeStylesFromTheme to use the correct types (#6801)
* Refactor makeStylesFromTheme to use the correct types

* Address feedback
2022-12-12 10:53:54 +01:00

85 lines
2.8 KiB
TypeScript

// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
// See LICENSE.txt for license information.
import React, {useMemo} from 'react';
import {useIntl} from 'react-intl';
import {Text, View} from 'react-native';
import {handleTeamChange} from '@actions/remote/team';
import TeamFlatList from '@components/team_sidebar/add_team/team_list';
import {useServerUrl} from '@context/server';
import {useTheme} from '@context/theme';
import {useIsTablet} from '@hooks/device';
import {resetToHome} from '@screens/navigation';
import {changeOpacity, makeStyleSheetFromTheme} from '@utils/theme';
import {typography} from '@utils/typography';
const getStyleSheet = makeStyleSheetFromTheme((theme: Theme) => ({
container: {
flex: 1,
backgroundColor: theme.sidebarBg,
marginHorizontal: 24,
},
title: {
color: theme.sidebarHeaderTextColor,
marginTop: 40,
...typography('Heading', 800),
},
description: {
color: changeOpacity(theme.sidebarText, 0.72),
marginTop: 12,
marginBottom: 25,
...typography('Body', 200, 'Regular'),
},
separator: {
borderColor: changeOpacity(theme.sidebarText, 0.08),
borderTopWidth: 1,
marginVertical: 8,
},
}));
type Props = {
teams: Team[];
};
function TeamList({
teams,
}: Props) {
const theme = useTheme();
const styles = getStyleSheet(theme);
const intl = useIntl();
const serverUrl = useServerUrl();
const isTablet = useIsTablet();
const onTeamAdded = async (id: string) => {
await handleTeamChange(serverUrl, id);
resetToHome();
};
const containerStyle = useMemo(() => {
return isTablet ? [styles.container, {maxWidth: 600, alignItems: 'center' as const}] : styles.container;
}, [isTablet, styles]);
return (
<View style={containerStyle}>
<View>
<Text style={styles.title}>{intl.formatMessage({id: 'select_team.title', defaultMessage: 'Select a team'})}</Text>
<Text style={styles.description}>{intl.formatMessage({id: 'select_team.description', defaultMessage: 'You are not yet a member of any teams. Select one below to get started.'})}</Text>
</View>
{/* {canCreateTeam && ( // TODO https://mattermost.atlassian.net/browse/MM-43622
<>
<AddTeamItem/>
<View style={styles.separator}/>
</>
)} */}
<TeamFlatList
teams={teams}
textColor={theme.sidebarText}
iconBackgroundColor={changeOpacity(theme.sidebarText, 0.16)}
iconTextColor={theme.sidebarText}
onPress={onTeamAdded}
/>
</View>
);
}
export default TeamList;