@parity/light.js
TypeScript icon, indicating that this package has built-in type declarations

5.1.19 • Public • Published

@parity/light.js

A high-level reactive JS library optimized for light clients.

Build Status npm (scoped) npm dependencies Status docs

Full Documentation

Getting Started

yarn add @parity/light.js rxjs # RxJS is a needed peer-dependency

Usage

Reactively observe JSONRPC methods:

import light, { defaultAccount$ } from '@parity/light.js';

light.setProvider(/* put your ethereum provider here */);

defaultAccount$().subscribe(publicAddress => console.log(publicAddress));
// Outputs your public address 0x...
// Everytime you change your default account (e.g. via MetaMask), it will output your new public address

All RxJS tools are available for manipulating Observables:

import { balanceOf$, blockNumber$, defaultAccount$ } from '@parity/light.js';
import { filter, map, switchMap } from 'rxjs/operators';

// Only log pair blocks
blockNumber$()
  .pipe(filter(n => n % 2 === 0))
  .subscribe(console.log);

// Get the balance of the default account
// Will update when balance or default account changes
defaultAccount$()
  .pipe(
    switchMap(balanceOf$),
    map(value => +value) // Return number instead of BigNumber
  )
  .subscribe(console.log);

// There's actually an alias for the above Observable:
import { myBalance$ } from '@parity/light.js';
myBalance$().subscribe(console.log);

Contract support:

import { defaultAccount$, makeContract } from '@parity/light.js';
import { map, switchMap } from 'rxjs/operators';

defaultAccount$()
  .pipe(
    switchMap(defaultAccount =>
      makeContract(/* contract address */, /* abi */)
        .myMethod$(defaultAccount) // Calling method of contract with arguments
    )  )
  .subscribe(console.log); // Will log the result, and everytime the result changes

All available methods are documented in the docs.

Usage with React

We provide another library, @parity/light.js-react, with a higher-order component to use these Observables easily with React apps.

import light from 'parity/ligth.js-react';
import { syncStatus$ } from '@parity/light.js';

@light({
  mySyncVariable: syncStatus$
})
class MyClass extends React.Component {
  render() {
    return <div>{JSON.stringify(this.props.mySyncVariable)}</div>;
  }
}

The UI will automatically update when the syncing state changes.

Package Sidebar

Install

npm i @parity/light.js

Weekly Downloads

12

Version

5.1.19

License

MIT

Unpacked Size

3.8 MB

Total Files

270

Last publish

Collaborators

  • vincecorsica
  • stefan-sopic
  • wirednkod
  • nachopalparity
  • pepo
  • mcornholio
  • dvdplm
  • paritytech-ci
  • parity-jacogr
  • jacogr
  • paritytech
  • kianenigma