import React from 'react';
import {
FlatList, StyleSheet, View
} from 'react-native';
import PropTypes from 'prop-types';
import { connect } from 'react-redux';
import { SafeAreaView } from 'react-navigation';
import I18n from '../i18n';
import StatusBar from '../containers/StatusBar';
import { themes } from '../constants/colors';
import Navigation from '../lib/ShareNavigation';
import ServerItem, { ROW_HEIGHT } from '../presentation/ServerItem';
import sharedStyles from './Styles';
import RocketChat from '../lib/rocketchat';
import { withTheme } from '../theme';
import { themedHeader } from '../utils/navigation';
const getItemLayout = (data, index) => ({ length: ROW_HEIGHT, offset: ROW_HEIGHT * index, index });
const keyExtractor = item => item.id;
const styles = StyleSheet.create({
container: {
flex: 1
},
list: {
marginVertical: 32,
...sharedStyles.separatorVertical
separator: {
...sharedStyles.separatorBottom,
marginLeft: 48
}
});
class SelectServerView extends React.Component {
static navigationOptions = ({ screenProps }) => ({
...themedHeader(screenProps.theme),
title: I18n.t('Select_Server')
})
static propTypes = {
server: PropTypes.string,
navigation: PropTypes.object,
theme: PropTypes.string
constructor(props) {
super(props);
const { navigation } = this.props;
const servers = navigation.getParam('servers', []);
const filteredServers = servers.filter(server => server.roomsUpdatedAt);
this.state = {
servers: filteredServers
};
select = async(server) => {
const {
server: currentServer
} = this.props;
Navigation.navigate('ShareListView');
if (currentServer !== server) {
await RocketChat.shareExtensionInit(server);
renderItem = ({ item }) => {
const { server, theme } = this.props;
return (
<ServerItem
server={server}
onPress={() => this.select(item.id)}
item={item}
hasCheck
theme={theme}
/>
);
renderSeparator = () => {
const { theme } = this.props;
return <View style={[styles.separator, { borderColor: themes[theme].separatorColor }]} />;
render() {
const { servers } = this.state;
<SafeAreaView
style={[styles.container, { backgroundColor: themes[theme].auxiliaryBackground }]}
forceInset={{ vertical: 'never' }}
>
<StatusBar theme={theme} />
<View style={[styles.list, { borderColor: themes[theme].separatorColor }]}>
<FlatList
data={servers}
keyExtractor={keyExtractor}
renderItem={this.renderItem}
getItemLayout={getItemLayout}
contentContainerStyle={{ backgroundColor: themes[theme].backgroundColor }}
ItemSeparatorComponent={this.renderSeparator}
enableEmptySections
removeClippedSubviews
keyboardShouldPersistTaps='always'
windowSize={7}
bounces={false}
</View>
</SafeAreaView>
const mapStateToProps = (({ share }) => ({
server: share.server
}));
export default connect(mapStateToProps)(withTheme(SelectServerView));