Rocket.Chat.ReactNative/app/containers/MessageComposer/components/Autocomplete/Autocomplete.tsx

72 lines
2.0 KiB
TypeScript

import React, { ReactElement } from 'react';
import { View, FlatList } from 'react-native';
import { useSafeAreaInsets } from 'react-native-safe-area-context';
import { useAutocompleteParams, useKeyboardHeight, useTrackingViewHeight } from '../../context';
import { AutocompleteItem } from './AutocompleteItem';
import { useAutocomplete } from '../../hooks';
import { IAutocompleteItemProps } from '../../interfaces';
import { AutocompletePreview } from './AutocompletePreview';
import { useRoomContext } from '../../../../views/RoomView/context';
import { useStyle, getBottom } from './styles';
export const Autocomplete = ({ onPress }: { onPress: IAutocompleteItemProps['onPress'] }): ReactElement | null => {
const { rid } = useRoomContext();
const trackingViewHeight = useTrackingViewHeight();
const keyboardHeight = useKeyboardHeight();
const { bottom } = useSafeAreaInsets();
const { text, type, params } = useAutocompleteParams();
const items = useAutocomplete({
rid,
text,
type,
commandParams: params
});
const [styles, colors] = useStyle();
if (items.length === 0 || !type) {
return null;
}
const viewBottom = getBottom(trackingViewHeight, keyboardHeight, bottom);
if (type !== '/preview') {
return (
<View
style={[
styles.root,
{
bottom: viewBottom
}
]}
>
<FlatList
contentContainerStyle={styles.listContentContainer}
data={items}
renderItem={({ item }) => <AutocompleteItem item={item} onPress={onPress} />}
keyboardShouldPersistTaps='always'
testID='autocomplete'
/>
</View>
);
}
if (type === '/preview') {
return (
<View style={[styles.root, { backgroundColor: colors.surfaceLight, bottom: viewBottom }]}>
<FlatList
contentContainerStyle={styles.listContentContainer}
style={styles.list}
horizontal
data={items}
renderItem={({ item }) => <AutocompletePreview item={item} onPress={onPress} />}
keyboardShouldPersistTaps='always'
testID='autocomplete'
/>
</View>
);
}
return null;
};