import React from 'react'; import { FlatList, StyleSheet, View } from 'react-native'; import PropTypes from 'prop-types'; import { connect } from 'react-redux'; import I18n from '../i18n'; import StatusBar from '../containers/StatusBar'; import { themes } from '../constants/colors'; import ServerItem, { ROW_HEIGHT } from '../presentation/ServerItem'; import sharedStyles from './Styles'; import RocketChat from '../lib/rocketchat'; import { withTheme } from '../theme'; import SafeAreaView from '../containers/SafeAreaView'; const getItemLayout = (data, index) => ({ length: ROW_HEIGHT, offset: ROW_HEIGHT * index, index }); const keyExtractor = item => item.id; const styles = StyleSheet.create({ list: { marginVertical: 32, ...sharedStyles.separatorVertical }, separator: { ...sharedStyles.separatorBottom, marginLeft: 48 } }); class SelectServerView extends React.Component { static navigationOptions = () => ({ title: I18n.t('Select_Server') }) static propTypes = { server: PropTypes.string, route: PropTypes.object, navigation: PropTypes.object, theme: PropTypes.string } constructor(props) { super(props); const { route } = this.props; const servers = route.params?.servers ?? []; const filteredServers = servers.filter(server => server.roomsUpdatedAt); this.state = { servers: filteredServers }; } select = async(server) => { const { server: currentServer, navigation } = this.props; navigation.navigate('ShareListView'); if (currentServer !== server) { await RocketChat.shareExtensionInit(server); } } renderItem = ({ item }) => { const { server, theme } = this.props; return ( this.select(item.id)} item={item} hasCheck={item.id === server} theme={theme} /> ); } renderSeparator = () => { const { theme } = this.props; return ; } render() { const { servers } = this.state; const { theme } = this.props; return ( ); } } const mapStateToProps = (({ share }) => ({ server: share.server.server })); export default connect(mapStateToProps)(withTheme(SelectServerView));