Signing.tsx 1.03 KiB
Newer Older
Andrei Eres's avatar
Andrei Eres committed
import { RequestSign } from '@polkadot/extension-base/background/types'
Andrei Eres's avatar
Andrei Eres committed
import { SignerPayloadJSON } from '@polkadot/types/types'
import { useStore } from 'nanostores/react'
Andrei Eres's avatar
Andrei Eres committed
import React, { useState } from 'react'
Andrei Eres's avatar
Andrei Eres committed
import { signRequests } from '../../stores/signRequests'
Andrei Eres's avatar
Andrei Eres committed
import RequestIndex from './RequestIndex'
import SigningRequest from './SigningRequest'
Andrei Eres's avatar
Andrei Eres committed

const Signing: React.FC = () => {
Andrei Eres's avatar
Andrei Eres committed
  const requests = useStore(signRequests)
Andrei Eres's avatar
Andrei Eres committed
  const [idx, setIdx] = useState(0)
  const request = requests[idx]
Andrei Eres's avatar
Andrei Eres committed
  const isTransaction = !!(request?.request?.payload as SignerPayloadJSON)
    ?.blockNumber

  return (
    <>
      {requests.length > 1 && (
Andrei Eres's avatar
Andrei Eres committed
        <RequestIndex index={idx} total={requests.length} onChange={setIdx} />
Andrei Eres's avatar
Andrei Eres committed
      )}
Andrei Eres's avatar
Andrei Eres committed
      <SigningRequest
Andrei Eres's avatar
Andrei Eres committed
        account={request.account}
Andrei Eres's avatar
Andrei Eres committed
        buttonText={isTransaction ? 'Sign the transaction' : 'Sign the message'}
Andrei Eres's avatar
Andrei Eres committed
        isFirst={idx === 0}
Andrei Eres's avatar
Andrei Eres committed
        request={request.request as RequestSign}
Andrei Eres's avatar
Andrei Eres committed
        signId={request.id}
        url={request.url}
      />
    </>
  )
}

export default Signing