feat: initial Pezkuwi Apps rebrand from polkadot-apps

Rebranded terminology:
- Polkadot → Pezkuwi
- Kusama → Dicle
- Westend → Zagros
- Rococo → PezkuwiChain
- Substrate → Bizinikiwi
- parachain → teyrchain

Custom logos with Kurdistan brand colors (#e6007a → #86e62a):
- bizinikiwi-hexagon.svg
- sora-bizinikiwi.svg
- hezscanner.svg
- heztreasury.svg
- pezkuwiscan.svg
- pezkuwistats.svg
- pezkuwiassembly.svg
- pezkuwiholic.svg
This commit is contained in:
2026-01-07 13:05:27 +03:00
commit d21bfb1320
5867 changed files with 329019 additions and 0 deletions
+73
View File
@@ -0,0 +1,73 @@
// Copyright 2017-2025 @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);