JSPM

@polkadot/ui-keyring

0.80.1
  • ESM via JSPM
  • ES Module Entrypoint
  • Export Map
  • Keywords
  • License
  • Repository URL
  • TypeScript Types
  • README
  • Created
  • Published
  • Downloads 9603
  • Score
    100M100P100Q127243F
  • License Apache-2.0

Package Exports

  • @polkadot/ui-keyring
  • @polkadot/ui-keyring/Base
  • @polkadot/ui-keyring/Base.d.ts
  • @polkadot/ui-keyring/Keyring
  • @polkadot/ui-keyring/Keyring.d.ts
  • @polkadot/ui-keyring/README.md
  • @polkadot/ui-keyring/defaults
  • @polkadot/ui-keyring/defaults.d.ts
  • @polkadot/ui-keyring/detectPackage
  • @polkadot/ui-keyring/detectPackage.d.ts
  • @polkadot/ui-keyring/index.d.ts
  • @polkadot/ui-keyring/observable
  • @polkadot/ui-keyring/observable/accounts
  • @polkadot/ui-keyring/observable/accounts.d.ts
  • @polkadot/ui-keyring/observable/addresses
  • @polkadot/ui-keyring/observable/addresses.d.ts
  • @polkadot/ui-keyring/observable/contracts
  • @polkadot/ui-keyring/observable/contracts.d.ts
  • @polkadot/ui-keyring/observable/env
  • @polkadot/ui-keyring/observable/env.d.ts
  • @polkadot/ui-keyring/observable/genericSubject
  • @polkadot/ui-keyring/observable/genericSubject.d.ts
  • @polkadot/ui-keyring/observable/index.d.ts
  • @polkadot/ui-keyring/observable/types
  • @polkadot/ui-keyring/observable/types.d.ts
  • @polkadot/ui-keyring/options
  • @polkadot/ui-keyring/options/index.d.ts
  • @polkadot/ui-keyring/options/item
  • @polkadot/ui-keyring/options/item.d.ts
  • @polkadot/ui-keyring/options/types
  • @polkadot/ui-keyring/options/types.d.ts
  • @polkadot/ui-keyring/package.json
  • @polkadot/ui-keyring/packageInfo
  • @polkadot/ui-keyring/packageInfo.d.ts
  • @polkadot/ui-keyring/stores
  • @polkadot/ui-keyring/stores/Browser
  • @polkadot/ui-keyring/stores/Browser.d.ts
  • @polkadot/ui-keyring/stores/File
  • @polkadot/ui-keyring/stores/File.d.ts
  • @polkadot/ui-keyring/stores/index.d.ts
  • @polkadot/ui-keyring/types
  • @polkadot/ui-keyring/types.d.ts

Readme

@polkadot/ui-keyring

A wrapper extending the base @polkadot/keyring interface for usage in the browser: Key management of user accounts including generation and retrieval of keyring pairs from a variety of input combinations.

Usage Examples

All module methods are exposed through a single default export.

Regular

import keyring from @polkadot/ui-keyring

render () {
  // encode publicKey to ss58 address
  const address = keyring.encodeAddress(publicKey);

  // get keyring pair from ss58 address
  const pair = keyring.getPair(address);

  // ask questions about that particular keyring pair
  const isLocked = pair.isLocked;
  const meta = pair.meta;

  // save account from pair
  keyring.saveAccount(pair, password);

  // save address without unlocking it
  keyring.saveAddress(address, { ...meta });
}

Observables

Option 1: Declarative subscribe/unsubscribe w/ react-with-observable (recommended 'React' way)

import accountObservable from '@polkadot/ui-keyring/observable/accounts';
import { SingleAddress, SubjectInfo } from '@polkadot/ui-keyring/observable/types';
import React from 'react';
import { Subscribe } from 'react-with-observable';
import { map } from 'rxjs/operators';

class MyReactComponent extends React.PureComponent {
  render () {
    <Subscribe>
      {accountObservable.subject.pipe(
        map((allAccounts: SubjectInfo) =>
          !allAccounts
            ? this.renderEmpty()
            : Object.values(allAccounts).map((account: SingleAddress) =>
                // Your component goes here
                console.log(account.json.address)
            )
        ))}
    </Subscribe>
  }

  renderEmpty () {
    return (
      <div> no accounts to display ... </div>
    );
  }
}

Option 2: Imperative subscribe/unsubscribe

import accountObservable from '@polkadot/ui-keyring/observable/accounts';
import { SingleAddress, SubjectInfo } from '@polkadot/ui-keyring/observable/types';
import React from 'react';
import { Subscription } from 'rxjs';

type State = {
  allAccounts?: SubjectInfo,
  subscriptions?: [Subscription]
}

class MyReactComponent extends React.PureComponent<State> {
  componentDidMount () {
    const accountSubscription = accountObservable.subject.subscribe((observedAccounts) => {
      this.setState({
        accounts: observedAccounts
      });
    })

    this.setState({
      subscriptions: [accountSubscription]
    });
  }

  componentWillUnmount () {
    const { subscriptions } = this.state;

    for (s in subscriptions) {
      s.subject.unsubscribe();
    }
  }

  render () {
    const { accounts } = this.state;

    return (
      <h1>All Accounts</h1>
      {
        Object.keys(accounts).map((address: SingleAddress) => {
          return <p> {address} </p>;
        })
      }
    )
  }
}

FAQ

  • Difference between Keyring Accounts and Addresses?
    • From the perspective of the keyring, it saves a particular user's unlocked identities as an account, a la keyring.saveAccount(pair, password). So with these accounts you are able to send and sign transactions.
    • To save addresses without unlocking them (i.e. because a user might want to have easy access to addresses they frequently transact with), use keyring.saveAddress(address, meta)
  • What are 'external' accounts, i.e. when to set the isExternal meta key to true?
    • An external account is one where the keys are not managed by keyring, e.g. in Parity Signer or Ledger Nano.
  • SS58 Encode / Decode?
    • SS58 is a simple address format designed for Substrate based chains. You can read about its specification in more detail in the Parity Wiki.

If you have any unanswered/undocumented questions, please raise an issue here.

Users

Keyring is core to many polkadot/substrate apps.