mirror of
https://github.com/pezkuwichain/pwap.git
synced 2026-05-09 01:37:55 +00:00
971df8edba
- Remove all 3rd party parachain configurations from endpoints: - productionRelayPolkadot.ts: Keep only system parachains - productionRelayDicle.ts: Keep only system parachains - testingRelayZagros.ts: Keep only system parachains - testingRelayTeyrChain.ts: Keep only system parachains - Update domain references: - polkadot.js.org → pezkuwichain.app - wiki.polkadot.network → wiki.pezkuwichain.io - dotapps.io → pezkuwichain.app - statement.polkadot.network → docs.pezkuwichain.io/statement - support.polkadot.network → docs.pezkuwichain.io - Update repository references: - github.com/pezkuwi-js/apps → github.com/pezkuwichain/pwap - Rename system parachains to Pezkuwi ecosystem: - PolkadotAssetHub → PezkuwiAssetHub - polkadotBridgeHub → pezkuwiBridgeHub - polkadotCollectives → pezkuwiCollectives - polkadotCoretime → pezkuwiCoretime - polkadotPeople → pezkuwiPeople - Update network name in claims utility: - Polkadot → Pezkuwi
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);
|