Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@evo/chat-core

Package Overview
Dependencies
Maintainers
12
Versions
82
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@evo/chat-core

core Besida module with base functional set for chat

  • 0.8.5
  • latest
  • npm
  • Socket score

Version published
Weekly downloads
6
decreased by-50%
Maintainers
12
Weekly downloads
 
Created
Source

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-core

Basic 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.

FAQs

Package last updated on 13 Sep 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc