bigbluebutton-Github/bigbluebutton-html5/imports/ui/components/components-data/users-context/adapter.jsx

63 lines
1.6 KiB
JavaScript

import { useContext, useEffect } from 'react';
import Users from '/imports/api/users';
import UsersPersistentData from '/imports/api/users-persistent-data';
import { UsersContext, ACTIONS } from './context';
import { ChatContext, ACTIONS as CHAT_ACTIONS } from '../chat-context/context';
import ChatLogger from '/imports/ui/components/chat/chat-logger/ChatLogger';
const Adapter = () => {
const usingUsersContext = useContext(UsersContext);
const { dispatch } = usingUsersContext;
useEffect(()=> {
const usersPersistentDataCursor = UsersPersistentData.find({}, { sort: { timestamp: 1 } });
usersPersistentDataCursor.observe({
added: (obj) => {
console.log('kkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkkk');
dispatch({
type: ACTIONS.ADDED_USER_PERSISTENT_DATA,
value: {
user: obj,
},
});
},
changed: (obj) => {
dispatch({
type: ACTIONS.CHANGED_USER_PERSISTENT_DATA,
value: {
user: obj,
},
});
},
removed: (obj) => {},
});
}, []);
useEffect(() => {
const usersCursor = Users.find({}, { sort: { timestamp: 1 } });
usersCursor.observe({
added: (obj) => {
ChatLogger.debug("usersAdapter::observe::added", obj);
dispatch({
type: ACTIONS.ADDED,
value: {
user: obj,
},
});
},
changed: (obj) => {
dispatch({
type: ACTIONS.CHANGED,
value: {
user: obj,
},
});
},
});
}, []);
return null;
};
export default Adapter;