import React from 'react'; import PropTypes from 'prop-types'; import { View, FlatList, Text } from 'react-native'; import { connect } from 'react-redux'; import { SafeAreaView } from 'react-navigation'; import Touch from '../../utils/touch'; import RocketChat from '../../lib/rocketchat'; import DirectoryItem from '../../presentation/DirectoryItem'; import sharedStyles from '../Styles'; import I18n from '../../i18n'; import SearchBox from '../../containers/SearchBox'; import { CustomIcon } from '../../lib/Icons'; import StatusBar from '../../containers/StatusBar'; import ActivityIndicator from '../../containers/ActivityIndicator'; import { CloseModalButton } from '../../containers/HeaderButton'; import debounce from '../../utils/debounce'; import log from '../../utils/log'; import Options from './Options'; import { withTheme } from '../../theme'; import { themes } from '../../constants/colors'; import styles from './styles'; import { themedHeader } from '../../utils/navigation'; import { getUserSelector } from '../../selectors/login'; class DirectoryView extends React.Component { static navigationOptions = ({ navigation, screenProps }) => { const options = { ...themedHeader(screenProps.theme), title: I18n.t('Directory') }; if (screenProps.split) { options.headerLeft = ; } return options; } static propTypes = { navigation: PropTypes.object, baseUrl: PropTypes.string, isFederationEnabled: PropTypes.bool, user: PropTypes.shape({ id: PropTypes.string, token: PropTypes.string }), theme: PropTypes.string, directoryDefaultView: PropTypes.string }; constructor(props) { super(props); this.state = { data: [], loading: false, text: '', total: -1, showOptionsDropdown: false, globalUsers: true, type: props.directoryDefaultView }; } componentDidMount() { this.load({}); } onSearchChangeText = (text) => { this.setState({ text }); } // eslint-disable-next-line react/sort-comp load = debounce(async({ newSearch = false }) => { if (newSearch) { this.setState({ data: [], total: -1, loading: false }); } const { loading, text, total, data: { length } } = this.state; if (loading || length === total) { return; } this.setState({ loading: true }); try { const { data, type, globalUsers } = this.state; const query = { text, type, workspace: globalUsers ? 'all' : 'local' }; const directories = await RocketChat.getDirectory({ query, offset: data.length, count: 50, sort: (type === 'users') ? { username: 1 } : { usersCount: -1 } }); if (directories.success) { this.setState({ data: [...data, ...directories.result], loading: false, total: directories.total }); } else { this.setState({ loading: false }); } } catch (e) { log(e); this.setState({ loading: false }); } }, 200) search = () => { this.load({ newSearch: true }); } changeType = (type) => { this.setState({ type, data: [] }, () => this.search()); } toggleWorkspace = () => { this.setState(({ globalUsers }) => ({ globalUsers: !globalUsers, data: [] }), () => this.search()); } toggleDropdown = () => { this.setState(({ showOptionsDropdown }) => ({ showOptionsDropdown: !showOptionsDropdown })); } goRoom = async({ rid, name, t }) => { const { navigation } = this.props; await navigation.navigate('RoomsListView'); navigation.navigate('RoomView', { rid, name, t }); } onPressItem = async(item) => { const { type } = this.state; if (type === 'users') { const result = await RocketChat.createDirectMessage(item.username); if (result.success) { this.goRoom({ rid: result.room._id, name: item.username, t: 'd' }); } } else { this.goRoom({ rid: item._id, name: item.name, t: 'c' }); } } renderHeader = () => { const { type } = this.state; const { theme } = this.props; return ( <> {type === 'users' ? I18n.t('Users') : I18n.t('Channels')} ); } renderSeparator = () => { const { theme } = this.props; return ; } renderItem = ({ item, index }) => { const { data, type } = this.state; const { baseUrl, user, theme } = this.props; let style; if (index === data.length - 1) { style = sharedStyles.separatorBottom; } const commonProps = { title: item.name, onPress: () => this.onPressItem(item), baseUrl, testID: `federation-view-item-${ item.name }`, style, user, theme }; if (type === 'users') { return ( ); } return ( ); } render = () => { const { data, loading, showOptionsDropdown, type, globalUsers } = this.state; const { isFederationEnabled, theme } = this.props; return ( item._id} ListHeaderComponent={this.renderHeader} renderItem={this.renderItem} ItemSeparatorComponent={this.renderSeparator} keyboardShouldPersistTaps='always' ListFooterComponent={loading ? : null} onEndReached={() => this.load({})} /> {showOptionsDropdown ? ( ) : null} ); } } const mapStateToProps = state => ({ baseUrl: state.server.server, user: getUserSelector(state), isFederationEnabled: state.settings.FEDERATION_Enabled, directoryDefaultView: state.settings.Accounts_Directory_DefaultView }); export default connect(mapStateToProps)(withTheme(DirectoryView));