Ошибка типа: 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() как функцию, когда она еще не была объявлена.