@evo/chat-core
v0.8.5
Published
core Besida module with base functional set for chat
Downloads
363
Maintainers
Keywords
Readme
Evo package, that controls all data mutations that are common for chat (message send, history, read counters etc), provides simple api and bunch of utils. It based on swindonJS library, that manages WS connection. All request/response formats are handling by Besida.
Installation
npm install --save -E @evo/chat-coreBasic Usage
import { Swindon } from 'swindon';
import {
Besida,
BESIDA_ROLE_COMPANY
} from '@evo/chat-core';
import { Config } from './path/to/core/config';
const { KOMORA_URL } = Config.data.appState
const swindonObj = Swindon('/ws');
const besida = new Besida(swindonObj, BESIDA_ROLE_COMPANY, KOMORA_URL, IS_DEBUG);
besida.registerHandler('message', (topic, message) => action());
besida.registerHandler('error', (_, error) => action());
await besida.connect();
await besida.chatList();Till that time, u will have besida.store filled with chats data. Basicly store is readonly propety,
dont try to change it, mutation will be cleared, after first interaction with ws. One more thing about store, is that is in immutableJS, so it's convenient to use with Redux
and similar rendering technologies. You can provide, mutableStore=true, so it becomes plain js object, but it doesn't mean u can mutate it. Utils, works only with mutable store for now, will be improved with nearest minor version.
Send message
const currentChatRoom = besida.store.get(['chats']).first();
await besida.sendMessage(
currentChatRoom.get('room_ident'), msgBody, platfrom, source, device
);Try - catch block is unnesessary, all errors from Besida will go in ur callback error function.
