Одаренный чат: как сохранить фокус Ввод после выбора кнопки отправки (RN, Native-base, giftedchat) - PullRequest
0 голосов
/ 29 апреля 2020

Используя React-Native и одаренный чат, я сделал экран чата. Однако у меня проблема при отправке сообщения.

КАК ЕСТЬ (Проблема): клавиатура исчезает и фокус исчезает при вводе сообщения и выборе кнопки отправки.

To-Do: хотите сохранить клавиатуру и фокус ввода Поле ввода после кнопки выбора отправки.

Вот мой код

Чат. js

const onSend = messages => {
    const getRoomKey = navigation.getParam("roomKey");
    firebaseService.saveMsg(userData, getRoomKey, messages);
  };

  const renderInputToolBar = () => {
    const props = {
      onSend,
      timeDiffSeconds,
      status
    };

    return <ChatInputBox {...props} />;
  };


  const dateFilter = (previous, current) => {
    const previousDate = moment(previous.createdAt).format(
      "MMMM Do YYYY, h:mm"
    );
    const currentDate = moment(current.createdAt).format("MMMM Do YYYY, h:mm");

    if (previousDate !== currentDate) {
      return current.user.name;
    } else {
      return false;
    }
  };

  const renderAvatar = props => {
    return <Avatar {...props} />;
  };



  const renderBubble = props => {
    const currentMessage = props.currentMessage;
    const previousMessage = props.previousMessage;
    const nextMessage = props.nextMessage;
    console.log(currentMessage);
    if (currentMessage._id == "univel_chat_noti") {

      return (
        <View style={{ justifyContent: "center", alignContent: "center" }}>
          <Text style={{ fontSize: 12, color: "white" }}>
            {currentMessage.text}
          </Text>
        </View>
      );
    } else if (currentMessage.user._id == "univel_chat_leaveroom") {
      return (
        <View style={{ justifyContent: "center", alignContent: "center" }}>
          <Text style={{ fontSize: 12, color: "white" }}>
            {currentMessage.text}
          </Text>
        </View>
      );
    }

    const currentDate = moment(currentMessage.createdAt).format(
      "MMMM Do YYYY, h:mm"
    );
    const previousDate = moment(previousMessage.createdAt).format(
      "MMMM Do YYYY, h:mm"
    );
    const nextDate = moment(nextMessage.createdAt).format("MMMM Do YYYY, h:mm");

    const previousUser = previousMessage.user;
    const currentUser = currentMessage.user;


    if (
      previousDate === currentDate &&
      previousUser &&
      previousUser._id == currentUser._id
    ) {
      props.currentMessage.user.avatar = "is null";
    } else {
      // console.log({
      //   currentDate,
      //   nextDate
      // })
    }

    return (
      <View style={{}}>
        (currentDate !== previousDate ||
          (currentDate == previousDate &&
            previousUser &&
            previousUser._id != currentUser._id)) &&
          userData.nickname !== currentMessage.user.name && (
            <Text style={styles.name}>{currentMessage.user.name}</Text>
          )}
        <Bubble
          textStyle={{
            left: {
              color: "#F7F7F7"
            }
          }}
          wrapperStyle={{
            left: {
              backgroundColor: "#37393B"
            }
          }}
          {...props}
        />
      </View>
    );
  };

  return (
    <View style={styles.container}>
            {
        <GiftedChat
          alwaysShowSend={true}
          textInputProps={{autoFocus: true, blurOnSubmit: false}}
          locale={"kr"}
          messages={msg}
          user={{
            _id: userData._id
          }}
          renderInputToolbar={renderInputToolBar}
          isKeyboardInternallyHandled-={false}
          keyboardShouldPersistTaps="always"
          renderChatEmpty={() => {
            return (
              <StatusAlert
                message={
                  "start"
                }
                image={messageImage}
                imageSetting={{ width: 90, height: 85 }}
                customStyle={{ transform: [{ scaleY: -1 }] }}
              />
            );
          }}
          renderBubble={renderBubble}
          //renderMessage={renderMessage}
          renderChatFooter={() => {
            let hour = Math.floor(timeDiffSeconds / 3600);
            let min = Math.floor((timeDiffSeconds % 3600) / 60);
          }}
          onPressAvatar={user => {
            console.log("click user = ", user);
            setReportPopupState("twoButtonModal");
            setReportTarget(user);
          }}
          showAvatarForEveryMessage={true}
          keyboardShouldPersistTaps="always"
        />      } 

ChatInputBox. js

import React, { useState, useRef, useEffect, useCallback } from 'react'
import { View, Text, Item, Input } from 'native-base'
import {
  Platform,
  StyleSheet,
  TouchableOpacity,
  KeyboardAvoidingView,
  TouchableWithoutFeedback,
  Keyboard,
  TextInput
} from "react-native";

const ChatInputBox = ({ onSend, timeDiffSeconds, status }) => {
  const [message, setMessage] = useState('');
  const send = (message) => {
    if (message !== '') {
      onSend(message)
      setMessage('')
    } else {
      return;
    }
  }
  const inputEl = useRef();
  const focusInput = useCallback(() => {
    inputEl.current.focus();
    console.log("checkFocus", inputEl.current)
  }, [])
  useEffect(() => {
    focusInput
    send
    }, []);

  // }else{


    return (
        <View keyboardShouldPersistTaps="always" style={styles.container} opacity={message !== '' ? .8 : .5}>
          <Item rounded style={styles.inputBox}>
            <Input placeholder='Type a message'
                   multiline={true}
                   style={{ textAlignVertical: 'top' }}
                   autoFocus={true}
                   onChangeText={(message) => setMessage(message)}
                   keyboardAppearance={'light'}
                   value={message}
                   ref={inputEl}
                   blurOnSubmit={true}
            />
            <TouchableOpacity style={styles.sendText} onPress={() => send(message) && focusInput} >
              <Text style={message !== '' && { color: '#FFFFFF', fontWeight: 'bold',  paddingLeft: 5, paddingBottom: 5, paddingTop: 5, paddingRight: 5 }}>send</Text>
            </TouchableOpacity>
          </Item>
        </View>
  )

  }


// }

export default ChatInputBox
...