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

@zeitgeistpm/avatara-react

Package Overview
Dependencies
Maintainers
3
Versions
107
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@zeitgeistpm/avatara-react

This package contains react components and utility hooks for rendering the zeitgeist rmrk2 avatar and managing its equipment.

  • 1.3.0
  • npm
  • Socket score

Version published
Weekly downloads
837
increased by1992.5%
Maintainers
3
Weekly downloads
 
Created
Source

@zeitgeistpm/avatara-react

This package contains react components and utility hooks for rendering the zeitgeist rmrk2 avatar and managing its equipment.

ZeitgeistAvatar

Render the zeitgeist avatar

import { AvatarContext, ZeitgeistAvatar } from "@zeitgeistpm/avatara-react"

const App = () => (
  <AvatarContext.Provider>
    <Component />
  </AvatarContext.Provider>
)

const Component = () => (
  <ZeitgeistAvatar 
    address={"3H7sh...Dj2jS"}     // optional, will try to use fallback component if empty
    size={44} 
    copy={true}                   // optional, default = true, copy address on click polkadot style.
    zoomed={false}                // optional, default = false, set to true when rendering very small avatar.
    fallback={<GenericAvatar />}  // optional
    loader={<Spinner />}          // optional
    onClick={clickedAvatar}       // optional
  />
)

useInventoryManagement

Hook to manage equipment for the avatar. Can accept items/badges when they are earned, preview items in inventory and commit a new set of equippment.

import { AvatarContext, ZeitgeistAvatar, useInventoryManagement } from "@zeitgeistpm/avatara-react"

const App = () => (
  <AvatarContext.Provider>
    <InventoryManagement />
  </AvatarContext.Provider>
)

const InventoryManagement = () => {

  const sdkContext = useAvatarContext()
  const inventory = useInventoryManagement(selectedAddress)

  return (
    <div>

      <ZeitgeistAvatar 
        address={"3H7sh...Dj2jS"}
        size={196}
        layoutPreview={inventory.layout} // will preview selected items
      />

      <div>
        <h2>Inventory.</h2>
        {
          inventory.items.accepted.map((item) => (
            <Item 
              item={item}
              checked={inventory.hasSelected(item)}
              onCheck={(checked) => {
                if(checked) {
                  inventory.select(item) 
                }
                else {
                  inventory.unselect(item) 
                }
              }} 
              loading={inventory.isAccepting(item)}
            />
          ))
        }
      </div>

      <div>
        <h2>Pending items!</h2>
        {
          inventory.items.pending.map((item) => (
            <PendingItem 
              item={item} 
              onClickAccept={() => inventory.accept(item)} 
              loading={inventory.isAccepting(item)}
            />
          ))
        }
      </div>

      <button 
        onClick={() => {() => inventory.commit()}
        disabled={inventory.comitting}
      >
        Commit equipment changes.
      </button>

    </div>
  )
}

FAQs

Package last updated on 15 Nov 2022

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