Skip to content

Commit

Permalink
fix: Keyboard interactions with messages
Browse files Browse the repository at this point in the history
  • Loading branch information
sternetj committed May 23, 2024
1 parent 65a4f30 commit 9c7623a
Showing 1 changed file with 48 additions and 34 deletions.
82 changes: 48 additions & 34 deletions src/screens/DirectMessagesScreen.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@ import {
ScrollView,
Image,
Dimensions,
Keyboard,
} from 'react-native';
import {
useInfinitePrivatePosts,
Expand Down Expand Up @@ -92,6 +93,14 @@ export const DirectMessagesScreen = ({
}
)[]
>([]);
const [isKeyboardOpen, setIsKeyboardOpen] = React.useState(
Keyboard.isVisible(),
);

useEffect(() => {
Keyboard.addListener('keyboardWillShow', () => setIsKeyboardOpen(true));
Keyboard.addListener('keyboardWillHide', () => setIsKeyboardOpen(false));
}, []);

useEffect(() => {
const conversation = conversations?.pages
Expand Down Expand Up @@ -123,7 +132,9 @@ export const DirectMessagesScreen = ({
);

const onSend = useCallback(
(newMessages: IMessage[] = []) => {
async (newMessages: IMessage[] = []) => {
Keyboard.dismiss();

// Shouldn't happen but this makes sure we don't send empty attachments
const removeLoadingImages = (
item:
Expand All @@ -134,36 +145,38 @@ export const DirectMessagesScreen = ({
): item is CreateAttachmentResponse => !item.loading;

// In practice their won't be more than one message at a time
newMessages.map(async (m) => {
const isLastMessage = newMessages.indexOf(m) === newMessages.length - 1;

await mutateAsync({
userIds: users.map((user) => user.id),
post: {
message: m.text,
...(isLastMessage
? {
attachmentsV2: pendingImages
.filter(removeLoadingImages)
.map((i) => ({
...i.attachment,
url: i.uploadConfig.fileLocation.permanentUrl,
})),
}
: {}),
},
});

if (isLastMessage) {
setPendingImages([]);
}
});
await Promise.all(
newMessages.map(async (m) => {
const isLastMessage =
newMessages.indexOf(m) === newMessages.length - 1;

await mutateAsync({
userIds: users.map((user) => user.id),
post: {
message: m.text,
...(isLastMessage
? {
attachmentsV2: pendingImages
.filter(removeLoadingImages)
.map((i) => ({
...i.attachment,
url: i.uploadConfig.fileLocation.permanentUrl,
})),
}
: {}),
},
});
}),
);
setPendingImages([]);
},
[mutateAsync, users, pendingImages],
);

const canUploadImages = !!launchImagePicker;
const addImageAttachment = useCallback(async () => {
Keyboard.dismiss();

const pickerResult = await launchImagePicker({
mediaType: 'photo',
selectionLimit: MAX_IMAGE_UPLOADS_PER_MESSAGE - pendingImages.length,
Expand Down Expand Up @@ -243,7 +256,10 @@ export const DirectMessagesScreen = ({
_id: userData.id,
}}
bottomOffset={Platform.select({ ios: tabsHeight })}
messagesContainerStyle={styles.messagesContainerStyle}
messagesContainerStyle={[
styles.messagesContainerStyle,
isKeyboardOpen && { paddingBottom: 0 },
]}
renderBubble={(props) => {
return (
<Bubble
Expand Down Expand Up @@ -295,6 +311,10 @@ export const DirectMessagesScreen = ({
? styles.textInputBorder?.disabled
: styles.textInputBorder?.enabled,
]}
accessoryStyle={{
height: styles.pendingImagesContainer?.height,
...styles.accessoryContainer,
}}
/>
);
}}
Expand Down Expand Up @@ -351,7 +371,8 @@ export const DirectMessagesScreen = ({
}
renderFooter={() =>
// Add a footer to the bottom of the screen to account for the image preview
!!pendingImages.length && (
!!pendingImages.length &&
!isKeyboardOpen && (
<View
style={[
{ height: styles.pendingImagesContainer?.height },
Expand All @@ -360,13 +381,6 @@ export const DirectMessagesScreen = ({
/>
)
}
{...({
// accessoryStyle overrides are not documented but are supported
accessoryStyle: {
height: styles.pendingImagesContainer?.height,
...styles.accessoryContainer,
},
} as any)}
renderAccessory={
pendingImages.length
? () => (
Expand Down

0 comments on commit 9c7623a

Please sign in to comment.