Signing.tsx 1.83 KiB
Newer Older
Andrei Eres's avatar
Andrei Eres committed
import { SignerPayloadJSON } from '@polkadot/types/types'
import { useStore } from 'nanostores/react'
import React, { useEffect, useState } from 'react'
Andrei Eres's avatar
Andrei Eres committed
import Header from '../components/Header'
Andrei Eres's avatar
Andrei Eres committed
import Loading from '../components/Loading'
Andrei Eres's avatar
Andrei Eres committed
import { signRequests } from '../stores/signRequests'
Andrei Eres's avatar
Andrei Eres committed
import SigningRequest from './SigningRequest'
import TransactionIndex from './TransactionIndex'
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 [requestIndex, setRequestIndex] = useState(0)

  const onNextClick = () => setRequestIndex((requestIndex) => requestIndex + 1)

  const onPreviousClick = () =>
    setRequestIndex((requestIndex) => requestIndex - 1)

  useEffect(() => {
    setRequestIndex((requestIndex) =>
      requestIndex < requests.length ? requestIndex : requests.length - 1
    )
  }, [requests])

  // protect against removal overflows/underflows
  const request =
    requests.length !== 0
      ? requestIndex >= 0
        ? requestIndex < requests.length
          ? requests[requestIndex]
          : requests[requests.length - 1]
        : requests[0]
      : null
  const isTransaction = !!(request?.request?.payload as SignerPayloadJSON)
    ?.blockNumber

  if (!request) return <Loading />

  return (
    <>
Andrei Eres's avatar
Andrei Eres committed
      <Header text={isTransaction ? 'Transaction' : 'Sign message'} />
Andrei Eres's avatar
Andrei Eres committed
      {requests.length > 1 && (
        <TransactionIndex
          index={requestIndex}
          onNextClick={onNextClick}
          onPreviousClick={onPreviousClick}
          totalItems={requests.length}
        />
      )}
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={requestIndex === 0}
        request={request.request}
        signId={request.id}
        url={request.url}
      />
    </>
  )
}

export default Signing