mirror of
https://github.com/laurent22/joplin.git
synced 2024-12-18 09:35:20 +02:00
137 lines
3.7 KiB
TypeScript
137 lines
3.7 KiB
TypeScript
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> = 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(
|
|
<IncomingShareItem
|
|
key={`incoming-share-${share.id}`}
|
|
invitation={share}
|
|
processing={props.processingShareInvitationResponse}
|
|
containerStyle={styles.shareListItem}
|
|
/>,
|
|
);
|
|
} else if (share.status === ShareUserStatus.Accepted) {
|
|
acceptedShareComponents.push(
|
|
<AcceptedShareItem
|
|
key={`accepted-share-${share.id}`}
|
|
invitation={share}
|
|
processing={props.processingShareInvitationResponse}
|
|
containerStyle={styles.shareListItem}
|
|
/>,
|
|
);
|
|
}
|
|
}
|
|
|
|
const renderNoIncomingShares = () => {
|
|
if (incomingShareComponents.length > 0) return null;
|
|
return <Text key='no-shares' style={styles.noSharesText}>{_('No new invitations')}</Text>;
|
|
};
|
|
|
|
const renderAcceptedShares = () => {
|
|
if (acceptedShareComponents.length === 0) return null;
|
|
return <>
|
|
<Text style={styles.header}>{_('Accepted invitations')}</Text>
|
|
<View style={styles.shareListContainer}>
|
|
{acceptedShareComponents}
|
|
</View>
|
|
</>;
|
|
};
|
|
|
|
return (
|
|
<View style={styles.root}>
|
|
<ScreenHeader title={_('Shares')} />
|
|
<ScrollView
|
|
style={styles.scrollingContainer}
|
|
refreshControl={
|
|
<RefreshControl
|
|
tintColor={theme.color}
|
|
colors={[theme.color]}
|
|
refreshing={refreshing}
|
|
onRefresh={onRefresh}
|
|
/>
|
|
}
|
|
testID='refreshControl'
|
|
>
|
|
<Text style={styles.header}>{_('New invitations')}</Text>
|
|
<View style={styles.shareListContainer}>
|
|
{renderNoIncomingShares()}
|
|
{incomingShareComponents}
|
|
</View>
|
|
{renderAcceptedShares()}
|
|
</ScrollView>
|
|
</View>
|
|
);
|
|
};
|
|
|
|
export default connect((state: AppState) => {
|
|
return {
|
|
shareInvitations: state.shareService.shareInvitations,
|
|
processingShareInvitationResponse: state.shareService.processingShareInvitationResponse,
|
|
};
|
|
})(ShareManagerComponent);
|