mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-04-22 07:48:00 +00:00
74 lines
2.2 KiB
TypeScript
74 lines
2.2 KiB
TypeScript
// Copyright 2017-2026 @pezkuwi/react-signer authors & contributors
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
import type { SubmittableExtrinsic } from '@pezkuwi/api/types';
|
|
import type { QueueTx, QueueTxMessageSetStatus } from '@pezkuwi/react-components/Status/types';
|
|
|
|
import React, { useCallback } from 'react';
|
|
|
|
import { Button, ErrorBoundary, Modal } from '@pezkuwi/react-components';
|
|
import { useQueue, useToggle } from '@pezkuwi/react-hooks';
|
|
|
|
import Transaction from './Transaction.js';
|
|
import { useTranslation } from './translate.js';
|
|
import { handleTxResults } from './util.js';
|
|
|
|
interface Props {
|
|
className?: string;
|
|
currentItem: QueueTx;
|
|
}
|
|
|
|
async function send (queueSetTxStatus: QueueTxMessageSetStatus, currentItem: QueueTx, tx: SubmittableExtrinsic<'promise'>): Promise<void> {
|
|
currentItem.txStartCb && currentItem.txStartCb();
|
|
|
|
try {
|
|
const unsubscribe = await tx.send(handleTxResults('send', queueSetTxStatus, currentItem, (): void => {
|
|
unsubscribe();
|
|
}));
|
|
} catch (error) {
|
|
console.error('send: error:', error);
|
|
queueSetTxStatus(currentItem.id, 'error', {}, error as Error);
|
|
|
|
currentItem.txFailedCb && currentItem.txFailedCb(null);
|
|
}
|
|
}
|
|
|
|
function TxUnsigned ({ className, currentItem }: Props): React.ReactElement<Props> | null {
|
|
const { t } = useTranslation();
|
|
const { queueSetTxStatus } = useQueue();
|
|
const [isRenderError, toggleRenderError] = useToggle();
|
|
|
|
const _onSend = useCallback(
|
|
async (): Promise<void> => {
|
|
if (currentItem.extrinsic) {
|
|
await send(queueSetTxStatus, currentItem, currentItem.extrinsic);
|
|
}
|
|
},
|
|
[currentItem, queueSetTxStatus]
|
|
);
|
|
|
|
return (
|
|
<>
|
|
<Modal.Content className={className}>
|
|
<ErrorBoundary onError={toggleRenderError}>
|
|
<Transaction
|
|
currentItem={currentItem}
|
|
onError={toggleRenderError}
|
|
/>
|
|
</ErrorBoundary>
|
|
</Modal.Content>
|
|
<Modal.Actions>
|
|
<Button
|
|
icon='sign-in-alt'
|
|
isDisabled={isRenderError}
|
|
label={t('Submit (no signature)')}
|
|
onClick={_onSend}
|
|
tabIndex={2}
|
|
/>
|
|
</Modal.Actions>
|
|
</>
|
|
);
|
|
}
|
|
|
|
export default React.memo(TxUnsigned);
|