websocket-for-redux-saga

0.1.0 • Public • Published

websocket-for-redux-saga

Websocket for redux-saga.It has an API similar to the browser's API

Install

npm i -S websocket-for-redux-saga

Build

git clone https://github.com/tignear/websocket-for-redux-saga.git
npm run build

Testing

npm run test

Example

import React from 'react';
import { connect } from 'react-redux';
import { open,close,message } from 'websocket-for-redux-saga/action';
import {STATE_ONCLOSE,STATE_ONOPEN,STATE_ONERROR,STATE_ONMESSAGE} from 'websocket-for-redux-saga/reducer'

const wsid='wsid';
class WebSoketEcho extends React.Component{
  constructor(props) {
    super(props);
    this.state = {
      messagearea:'',
      addressarea:''
    };
  }
  sendHandle(){
    this.props.dispatch(message(wsid,this.state.messagearea));
    this.setState({messagearea:''});
  }
  closeHandle(){
    this.props.dispatch(close(wsid,false,{code:1000,reason:'text'}));
  }
  openHandle(){
    this.props.dispatch(close(wsid));
    this.props.dispatch(open(wsid,this.state.addressarea));
  }
  componentWillUnmount(){
    this.closeHandle();
  }
  render(){
    const ws=this.props.websocket;
    const {state='',event=null}=ws[wsid]?ws[wsid]:{};
    let viewValue='';
    switch(state){
      case STATE_ONOPEN:
      case STATE_ONERROR:
        break;
      case STATE_ONMESSAGE:
    viewValue=event.data;
    break;
      case STATE_ONCLOSE:
    viewValue=event.code+":"+event.reason;
    break;
    }
    return (
      <div>
        <p>state:{state}</p>
    <p>value:{viewValue}</p>
    <button type="button" onClick={()=>this.openHandle()}>Open</button>
    <button type="button" onClick={()=>this.closeHandle()}>Close</button><br/>
    <input type="text" value={this.state.addressarea} onChange={(e)=>this.setState({addressarea:e.target.value})} placeholder="input address" /><br/>
    <textarea name="messagearea" value={this.state.messagearea} onChange={(e) => this.setState({messagearea: e.target.value})} placeholder="input your text"></textarea>
    <button type="button" onClick={()=>this.sendHandle()}>Send</button>
      </div>
    );
  }
}
function mapStateToProps(state){
    return state;
}
function mapDispatchToProps(dispatch){
    return {
        dispatch
    };
}
export default connect(mapStateToProps,mapDispatchToProps)(WebSoketEcho);

Readme

Keywords

none

Package Sidebar

Install

npm i websocket-for-redux-saga

Weekly Downloads

1

Version

0.1.0

License

ISC

Unpacked Size

25.4 kB

Total Files

9

Last publish

Collaborators

  • tignear