import React, { useEffect, useState } from 'react'; import { FlatList, StyleSheet, Text } from 'react-native'; import PropTypes from 'prop-types'; import { withTheme } from '../theme'; import RocketChat from '../lib/rocketchat'; import { themes } from '../constants/colors'; import openLink from '../utils/openLink'; import I18n from '../i18n'; import debounce from '../utils/debounce'; import sharedStyles from './Styles'; import * as List from '../containers/List'; import SafeAreaView from '../containers/SafeAreaView'; const styles = StyleSheet.create({ noResult: { fontSize: 16, paddingVertical: 56, ...sharedStyles.textSemibold, ...sharedStyles.textAlignCenter } }); const Item = ({ item }) => ( openLink(item.navigation?.page?.location?.href)} translateTitle={false} /> ); Item.propTypes = { item: PropTypes.object }; const VisitorNavigationView = ({ route, theme }) => { let offset; let total = 0; const [pages, setPages] = useState([]); const getPages = async() => { const rid = route.params?.rid; if (rid) { try { const result = await RocketChat.getPagesLivechat(rid, offset); if (result.success) { setPages(result.pages); offset = result.pages.length; ({ total } = result); } } catch { // do nothig } } }; useEffect(() => { getPages(); }, []); const onEndReached = debounce(() => { if (pages.length <= total) { getPages(); } }, 300); return ( } ItemSeparatorComponent={List.Separator} ListFooterComponent={List.Separator} ListHeaderComponent={List.Separator} contentContainerStyle={List.styles.contentContainerStyleFlatList} ListEmptyComponent={() => {I18n.t('No_results_found')}} keyExtractor={item => item} onEndReached={onEndReached} onEndReachedThreshold={5} /> ); }; VisitorNavigationView.propTypes = { theme: PropTypes.string, route: PropTypes.object }; VisitorNavigationView.navigationOptions = { title: I18n.t('Navigation_history') }; export default withTheme(VisitorNavigationView);