Files
pwap/pezkuwi-sdk-ui/packages/react-hooks/src/useTreasury.ts
T
pezkuwichain 971df8edba Rebrand: Remove 3rd party chains, update domains to PezkuwiChain
- 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
2026-01-09 03:08:11 +03:00

88 lines
2.8 KiB
TypeScript

// Copyright 2017-2026 @pezkuwi/react-hooks authors & contributors
// SPDX-License-Identifier: Apache-2.0
import type { DeriveBalancesAccount, DeriveBounties, DeriveTreasuryProposals } from '@pezkuwi/api-derive/types';
import type { Balance } from '@pezkuwi/types/interfaces';
import { useEffect, useState } from 'react';
import { BN, BN_MILLION, BN_ZERO, u8aConcat } from '@pezkuwi/util';
import { createNamedHook } from './createNamedHook.js';
import { useApi } from './useApi.js';
import { useCall } from './useCall.js';
const EMPTY_U8A_32 = new Uint8Array(32);
interface Result {
value?: Balance;
burn?: BN;
pendingBounties: BN;
pendingProposals: BN;
spendPeriod: BN;
totalProposals?: number;
treasuryAccount: Uint8Array;
}
function useTreasuryImpl (): Result {
const { api } = useApi();
const [result, setResult] = useState<Result>(() => ({
pendingBounties: BN_ZERO,
pendingProposals: BN_ZERO,
spendPeriod: api.consts.treasury
? api.consts.treasury.spendPeriod
: BN_ZERO,
treasuryAccount: u8aConcat(
'modl',
api.consts.treasury && api.consts.treasury.palletId
? api.consts.treasury.palletId.toU8a(true)
: 'py/trsry',
EMPTY_U8A_32
).subarray(0, 32)
}));
const bounties = useCall<DeriveBounties>(api.derive.bounties?.bounties);
const treasuryProposals = useCall<DeriveTreasuryProposals>(api.derive.treasury.proposals);
const treasuryBalance = useCall<DeriveBalancesAccount>(api.derive.balances?.account, [result.treasuryAccount]);
useEffect((): void => {
treasuryBalance && api.consts.treasury &&
setResult(({ pendingBounties, pendingProposals, spendPeriod, treasuryAccount }) => ({
burn: treasuryBalance.freeBalance.gt(BN_ZERO) && !api.consts.treasury.burn.isZero()
? api.consts.treasury.burn.mul(treasuryBalance.freeBalance).div(BN_MILLION)
: BN_ZERO,
pendingBounties,
pendingProposals,
spendPeriod,
treasuryAccount,
value: treasuryBalance.freeBalance.gt(BN_ZERO)
? treasuryBalance.freeBalance
: undefined
}));
}, [api, treasuryBalance]);
useEffect((): void => {
treasuryProposals &&
setResult((prev) => ({
...prev,
pendingProposals: treasuryProposals.approvals.reduce((total, { proposal: { value } }) =>
total.iadd(value), new BN(0)
),
totalProposals: treasuryProposals.proposalCount.toNumber()
}));
}, [treasuryProposals]);
useEffect((): void => {
bounties &&
setResult((prev) => ({
...prev,
pendingBounties: bounties.reduce((total, { bounty: { status, value } }) =>
total.iadd(status.isApproved ? value : BN_ZERO), new BN(0)
)
}));
}, [bounties]);
return result;
}
export const useTreasury = createNamedHook('useTreasury', useTreasuryImpl);