feat: 会话窗口
parent
d80b83b1f3
commit
11e4a44de2
@ -0,0 +1,5 @@
|
||||
import { createContext, useContext } from 'react';
|
||||
|
||||
export const ConversationContext = createContext();
|
||||
|
||||
export const useConversations = () => useContext(ConversationContext);
|
@ -0,0 +1,53 @@
|
||||
import React, { createContext, useContext, useState } from 'react';
|
||||
import { ConversationContext } from '@/stores/ConversationContext';
|
||||
import { RealTimeAPI } from '@/lib/realTimeAPI';
|
||||
|
||||
const URL = 'ws://202.103.68.144:8888/whatever/';
|
||||
// let realtimeAPI = new RealTimeAPI({ url: URL, protocol: 'aaa' });
|
||||
let realtimeAPI = new RealTimeAPI({ url: URL, protocol: 'WhatsApp' });
|
||||
|
||||
export const ConversationProvider = ({ children }) => {
|
||||
const [errors, setErrors] = useState([]);
|
||||
const [messages, setMessages] = useState([]);
|
||||
|
||||
const addError = (reason) => {
|
||||
setErrors(prevErrors => [...prevErrors, { reason }]);
|
||||
}
|
||||
|
||||
const addMessage = (message) => {
|
||||
setMessages(prevMessages => [...prevMessages, message]);
|
||||
}
|
||||
|
||||
const handleMessage = (data) => {
|
||||
const msg = data.result;
|
||||
if (!msg) {
|
||||
return false;
|
||||
}
|
||||
if (typeof msg.type === 'string' && msg.type === 'error') {
|
||||
addError('Error Connecting to Server');
|
||||
}
|
||||
addMessage({ ...msg.message, sender: 'other', id: Date.now().toString(16) });
|
||||
}
|
||||
|
||||
const sendMessage = (msg) => {
|
||||
const msgObj = {
|
||||
type: 'message',
|
||||
message: msg,
|
||||
};
|
||||
realtimeAPI.sendMessage(msgObj);
|
||||
addMessage(msgObj.message);
|
||||
}
|
||||
|
||||
realtimeAPI.onError(addError.bind(null, 'Error'));
|
||||
realtimeAPI.onMessage(handleMessage);
|
||||
realtimeAPI.onCompletion(addError.bind(null, 'Not Connected to Server'));
|
||||
realtimeAPI.keepAlive(); // Ping Server
|
||||
|
||||
return (
|
||||
<ConversationContext.Provider value={{ errors, messages, sendMessage }}>
|
||||
{children}
|
||||
</ConversationContext.Provider>
|
||||
);
|
||||
}
|
||||
|
||||
export default ConversationProvider;
|
Loading…
Reference in New Issue