Signing.tsx 1.84 KiB
Newer Older
Andrei Eres's avatar
Andrei Eres committed
import { Loading, SigningReqContext } from '@polkadot/extension-ui/components'
import Request from '@polkadot/extension-ui/Popup/Signing/Request'
import TransactionIndex from '@polkadot/extension-ui/Popup/Signing/TransactionIndex'
import type { SignerPayloadJSON } from '@polkadot/types/types'
import React, { useContext, useEffect, useState } from 'react'
import Header from '../components/Header'

const Signing: React.FC = () => {
  const requests = useContext(SigningReqContext)
  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}
        />
      )}
      <Request
        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