import * as React from 'react'; import { useCallback, useMemo, useState } from 'react'; import { View, StyleSheet, Text, ScrollView, RefreshControl } from 'react-native'; import { themeStyle } from '../../global-style'; import ScreenHeader from '../../ScreenHeader'; import { _ } from '@joplin/lib/locale'; import { ShareInvitation, ShareUserStatus } from '@joplin/lib/services/share/reducer'; import { AppState } from '../../../utils/types'; import { connect } from 'react-redux'; import IncomingShareItem from './IncomingShareItem'; import AcceptedShareItem from './AcceptedShareItem'; import ShareService from '@joplin/lib/services/share/ShareService'; import { ThemeStyle } from '../../global-style'; interface Props { themeId: number; shareInvitations: ShareInvitation[]; processingShareInvitationResponse: boolean; } const useStyles = (theme: ThemeStyle) => { return useMemo(() => { const margin = theme.margin; return StyleSheet.create({ root: { flex: 1, backgroundColor: theme.backgroundColor, }, header: { ...theme.headerStyle, marginLeft: margin, marginTop: margin, marginRight: margin, }, noSharesText: { ...theme.normalText, margin, }, shareListContainer: { flex: 1, flexDirection: 'column', margin, }, scrollingContainer: { height: '100%', }, shareListItem: { maxWidth: 700, marginBottom: 5, }, }); }, [theme]); }; export const ShareManagerComponent: React.FC = props => { const theme = themeStyle(props.themeId); const styles = useStyles(theme); const [refreshing, setRefreshing] = useState(false); const onRefresh = useCallback(async () => { setRefreshing(true); await ShareService.instance().refreshShareInvitations(); setRefreshing(false); }, []); const incomingShareComponents: React.ReactNode[] = []; const acceptedShareComponents: React.ReactNode[] = []; for (const share of props.shareInvitations) { if (share.status === ShareUserStatus.Waiting) { incomingShareComponents.push( , ); } else if (share.status === ShareUserStatus.Accepted) { acceptedShareComponents.push( , ); } } const renderNoIncomingShares = () => { if (incomingShareComponents.length > 0) return null; return {_('No incoming shares')}; }; const renderAcceptedShares = () => { if (acceptedShareComponents.length === 0) return null; return <> {_('Accepted shares')} {acceptedShareComponents} ; }; return ( } testID='refreshControl' > {_('Incoming shares')} {renderNoIncomingShares()} {incomingShareComponents} {renderAcceptedShares()} ); }; export default connect((state: AppState) => { return { shareInvitations: state.shareService.shareInvitations, processingShareInvitationResponse: state.shareService.processingShareInvitationResponse, }; })(ShareManagerComponent);