Ошибка типа: this.state.currentUser.isTypingIn не является функцией

Я создаю приложение чата с React и Chat Kit, но вышеописанная ошибка возникает, когда я пытаюсь реализовать свой индикатор в реальном времени. Я сделал следующие шаги:

Я создал компонент без состояния TypingIndicator.js

` import React, { Component } from 'react'

class TypingIndicator extends Component {
  render() {
if (this.props.usersWhoAreTyping.length > 0) {
  return (
    <div>
      {`${this.props.usersWhoAreTyping
        .slice(0, 2)
        .join(' and ')} is typing`}
    </div>
  )
}
return <div />
 }
}

 export default TypingIndicator`

Затем я подключил свой компонент без сохранения состояния к ChatScreen.js Контейнерный компонент, который управляет состоянием моего приложения и отображает пользовательский интерфейс с использованием презентационных - обычно без сохранения состояния - компонентов

`import React, { Component } from 'react'
 import Chatkit from '@pusher/chatkit-client'
 import MessageList from './components/MessageList'
 import SendMessageForm from './components/SendMessageForm'
 import TypingIndicator from './components/TypingIndicator'
 import WhosOnlineList from './components/WhosOnlineList'

 class ChatScreen extends Component {
  constructor(props) {
   super(props)
  this.state = {
  currentUser: {},
  currentRoom: {},
  messages: [],
  usersWhoAreTyping: [],
}
this.sendMessage = this.sendMessage.bind(this)
this.sendTypingEvent = this.sendTypingEvent.bind(this)
}


sendTypingEvent () {
  this.state.currentUser
  .isTypingIn({ roomId: this.state.currentRoom.id })
  .catch(error => console.error('error', error))
 }

sendMessage(text) {
this.state.currentUser.sendMessage({
  text,
  roomId: this.state.currentRoom.id,
 })
}

componentDidMount () {
const chatManager = new Chatkit.ChatManager({
   instanceLocator: 'v1:us1:aef97d23-a9e1-4eea-955f-3c8a02c98525',
   userId: this.props.currentUsername,
   tokenProvider: new Chatkit.TokenProvider({
    url: 'http://localhost:3001/authenticate',
   }),
 })

chatManager
  .connect()
  .then(currentUser => {
     return currentUser.subscribeToRoom({
      roomId: "19375754",
      messageLimit: 100,
      hooks: {
        onMessage: message => {
          this.setState({
            messages: [...this.state.messages, message],
          })
        },
        onUserStartedTyping: user => {
          this.setState({
            usersWhoAreTyping: [...this.state.usersWhoAreTyping, user.name],
         })
        },
        onUserStoppedTyping: user => {
          this.setState({
            usersWhoAreTyping: this.state.usersWhoAreTyping.filter(
              username => username !== user.name
            ),
          })
        },
        onPresenceChange: () => this.forceUpdate(),
        onUserJoined: () => this.forceUpdate(),
      },
    })
  })
  .then(currentRoom => {
    this.setState({ currentRoom })
   })
  .catch(error => console.error('error', error))
  }

  render() {
   const styles = {
    container: {
    height: '100vh',
    display: 'flex',
    flexDirection: 'column',
  },
  chatContainer: {
    display: 'flex',
    flex: 1,
  },
  whosOnlineListContainer: {
    width: '300px',
    flex: 'none',
    padding: 20,
    backgroundColor: '#2c303b',
    color: 'white',
  },
  chatListContainer: {
    padding: 20,
    width: '85%',
    display: 'flex',
    flexDirection: 'column',
  },
 }

return (
  <div style={styles.container}>
    <div style={styles.chatContainer}>
      <aside style={styles.whosOnlineListContainer}>
        <WhosOnlineList
          currentUser={this.state.currentUser}
          users={this.state.currentRoom.users}
        />
      </aside>
      <section style={styles.chatListContainer}>
          <MessageList
         messages={this.state.messages}
         style={styles.chatList}
        />
       <TypingIndicator usersWhoAreTyping={this.state.usersWhoAreTyping} />
       <SendMessageForm onSubmit={this.sendMessage}
        onChange={this.sendTypingEvent}
        />
      </section>
    </div>
  </div>
  )
 }
}

export default ChatScreen

1 ответ

Это потому, что это не функция. Вы устанавливаете currentUser как пустой объект при запуске, и в isTypingIn нет функции. Вы должны объявить isTypingIn как метод класса и использовать его где угодно. Это сбивает с толку то, что вы хотите достичь, используя isTypingIn() как функцию, когда она еще не была объявлена.

Другие вопросы по тегам