@pezkuwi/api-derive 16.5.5 → 16.5.6
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +201 -0
- package/README.md +2 -2
- package/accounts/accountId.js +29 -0
- package/{build/accounts → accounts}/flags.d.ts +2 -2
- package/accounts/flags.js +55 -0
- package/accounts/idAndIndex.js +34 -0
- package/accounts/idToIndex.js +17 -0
- package/{build/accounts → accounts}/identity.d.ts +3 -3
- package/accounts/identity.js +153 -0
- package/{src/accounts/index.ts → accounts/index.js} +0 -3
- package/accounts/indexToId.js +18 -0
- package/accounts/indexes.js +34 -0
- package/accounts/info.js +33 -0
- package/{src/alliance/index.ts → alliance/index.js} +0 -5
- package/augment.js +1 -0
- package/bagsList/get.js +42 -0
- package/bagsList/getExpanded.js +19 -0
- package/bagsList/index.js +3 -0
- package/bagsList/listNodes.d.ts +9 -0
- package/bagsList/listNodes.js +26 -0
- package/{build/bagsList → bagsList}/types.d.ts +3 -3
- package/bagsList/types.js +1 -0
- package/bagsList/util.js +8 -0
- package/balances/account.js +149 -0
- package/balances/all.js +167 -0
- package/{src/balances/index.ts → balances/index.js} +0 -6
- package/{build/balances → balances}/types.d.ts +7 -7
- package/balances/types.js +1 -0
- package/balances/votingBalances.js +18 -0
- package/bounties/bounties.js +50 -0
- package/bounties/helpers/filterBountyProposals.js +5 -0
- package/bounties/index.js +1 -0
- package/bundle.js +107 -0
- package/{src/chain/bestNumber.ts → chain/bestNumber.js} +1 -10
- package/{src/chain/bestNumberFinalized.ts → chain/bestNumberFinalized.js} +1 -10
- package/chain/bestNumberLag.js +19 -0
- package/chain/getBlock.js +25 -0
- package/chain/getBlockByNumber.js +16 -0
- package/chain/getHeader.js +19 -0
- package/{src/chain/index.ts → chain/index.js} +0 -3
- package/chain/subscribeFinalizedBlocks.js +15 -0
- package/chain/subscribeFinalizedHeads.js +37 -0
- package/chain/subscribeNewBlocks.js +15 -0
- package/chain/subscribeNewHeads.js +21 -0
- package/chain/util.js +57 -0
- package/cjs/accounts/accountId.d.ts +17 -0
- package/cjs/accounts/accountId.js +32 -0
- package/cjs/accounts/flags.d.ts +29 -0
- package/cjs/accounts/flags.js +59 -0
- package/cjs/accounts/idAndIndex.d.ts +15 -0
- package/cjs/accounts/idAndIndex.js +37 -0
- package/cjs/accounts/idToIndex.d.ts +16 -0
- package/cjs/accounts/idToIndex.js +20 -0
- package/cjs/accounts/identity.d.ts +48 -0
- package/cjs/accounts/identity.js +159 -0
- package/cjs/accounts/index.d.ts +8 -0
- package/cjs/accounts/index.js +11 -0
- package/cjs/accounts/indexToId.d.ts +15 -0
- package/cjs/accounts/indexToId.js +21 -0
- package/cjs/accounts/indexes.d.ts +16 -0
- package/cjs/accounts/indexes.js +37 -0
- package/cjs/accounts/info.d.ts +18 -0
- package/cjs/accounts/info.js +36 -0
- package/cjs/accounts/types.d.ts +39 -0
- package/cjs/accounts/types.js +2 -0
- package/cjs/alliance/index.d.ts +70 -0
- package/cjs/alliance/index.js +74 -0
- package/cjs/augment.d.ts +1 -0
- package/cjs/augment.js +3 -0
- package/cjs/bagsList/get.d.ts +12 -0
- package/cjs/bagsList/get.js +47 -0
- package/cjs/bagsList/getExpanded.d.ts +16 -0
- package/cjs/bagsList/getExpanded.js +23 -0
- package/cjs/bagsList/index.d.ts +3 -0
- package/cjs/bagsList/index.js +6 -0
- package/cjs/bagsList/listNodes.d.ts +9 -0
- package/cjs/bagsList/listNodes.js +29 -0
- package/cjs/bagsList/types.d.ts +13 -0
- package/cjs/bagsList/types.js +2 -0
- package/cjs/bagsList/util.d.ts +2 -0
- package/cjs/bagsList/util.js +11 -0
- package/cjs/balances/account.d.ts +17 -0
- package/cjs/balances/account.js +152 -0
- package/cjs/balances/all.d.ts +20 -0
- package/cjs/balances/all.js +170 -0
- package/cjs/balances/index.d.ts +20 -0
- package/cjs/balances/index.js +25 -0
- package/cjs/balances/types.d.ts +69 -0
- package/cjs/balances/types.js +2 -0
- package/cjs/balances/votingBalances.d.ts +15 -0
- package/cjs/balances/votingBalances.js +21 -0
- package/cjs/bounties/bounties.d.ts +12 -0
- package/cjs/bounties/bounties.js +53 -0
- package/cjs/bounties/helpers/filterBountyProposals.d.ts +2 -0
- package/cjs/bounties/helpers/filterBountyProposals.js +8 -0
- package/cjs/bounties/index.d.ts +1 -0
- package/cjs/bounties/index.js +4 -0
- package/cjs/bundle.d.ts +9 -0
- package/cjs/bundle.js +112 -0
- package/cjs/chain/bestNumber.d.ts +11 -0
- package/cjs/chain/bestNumber.js +15 -0
- package/cjs/chain/bestNumberFinalized.d.ts +12 -0
- package/cjs/chain/bestNumberFinalized.js +16 -0
- package/cjs/chain/bestNumberLag.d.ts +15 -0
- package/cjs/chain/bestNumberLag.js +22 -0
- package/cjs/chain/getBlock.d.ts +15 -0
- package/cjs/chain/getBlock.js +28 -0
- package/{src/chain/getBlockByNumber.ts → cjs/chain/getBlockByNumber.d.ts} +1 -15
- package/cjs/chain/getBlockByNumber.js +19 -0
- package/cjs/chain/getHeader.d.ts +16 -0
- package/cjs/chain/getHeader.js +22 -0
- package/cjs/chain/index.d.ts +10 -0
- package/cjs/chain/index.js +13 -0
- package/cjs/chain/subscribeFinalizedBlocks.d.ts +14 -0
- package/cjs/chain/subscribeFinalizedBlocks.js +18 -0
- package/cjs/chain/subscribeFinalizedHeads.d.ts +22 -0
- package/cjs/chain/subscribeFinalizedHeads.js +41 -0
- package/cjs/chain/subscribeNewBlocks.d.ts +14 -0
- package/cjs/chain/subscribeNewBlocks.js +18 -0
- package/cjs/chain/subscribeNewHeads.d.ts +15 -0
- package/cjs/chain/subscribeNewHeads.js +24 -0
- package/cjs/chain/util.d.ts +9 -0
- package/cjs/chain/util.js +61 -0
- package/cjs/collective/helpers.js +23 -0
- package/cjs/collective/index.js +6 -0
- package/cjs/collective/members.js +5 -0
- package/cjs/collective/prime.js +11 -0
- package/cjs/collective/proposals.js +44 -0
- package/cjs/collective/types.js +2 -0
- package/{build → cjs}/contracts/fees.d.ts +1 -1
- package/cjs/contracts/fees.js +48 -0
- package/cjs/contracts/index.js +4 -0
- package/cjs/council/index.js +77 -0
- package/cjs/council/types.js +2 -0
- package/cjs/council/votes.js +59 -0
- package/cjs/council/votesOf.js +21 -0
- package/{build → cjs}/crowdloan/childKey.d.ts +2 -2
- package/cjs/crowdloan/childKey.js +26 -0
- package/{build → cjs}/crowdloan/contributions.d.ts +2 -2
- package/cjs/crowdloan/contributions.js +83 -0
- package/cjs/crowdloan/index.js +6 -0
- package/{build → cjs}/crowdloan/ownContributions.d.ts +2 -2
- package/cjs/crowdloan/ownContributions.js +48 -0
- package/cjs/crowdloan/types.js +2 -0
- package/{build → cjs}/crowdloan/util.d.ts +2 -2
- package/cjs/crowdloan/util.js +20 -0
- package/cjs/democracy/dispatchQueue.js +90 -0
- package/cjs/democracy/index.js +14 -0
- package/cjs/democracy/locks.js +65 -0
- package/cjs/democracy/nextExternal.js +31 -0
- package/{build → cjs}/democracy/preimages.d.ts +5 -5
- package/cjs/democracy/preimages.js +117 -0
- package/cjs/democracy/proposals.js +46 -0
- package/cjs/democracy/referendumIds.js +24 -0
- package/cjs/democracy/referendums.js +22 -0
- package/cjs/democracy/referendumsActive.js +19 -0
- package/{build → cjs}/democracy/referendumsFinished.d.ts +2 -2
- package/cjs/democracy/referendumsFinished.js +20 -0
- package/{build → cjs}/democracy/referendumsInfo.d.ts +2 -2
- package/cjs/democracy/referendumsInfo.js +114 -0
- package/cjs/democracy/sqrtElectorate.js +18 -0
- package/{build → cjs}/democracy/types.d.ts +3 -3
- package/cjs/democracy/types.js +2 -0
- package/{build → cjs}/democracy/util.d.ts +5 -5
- package/cjs/democracy/util.js +137 -0
- package/{build → cjs}/derive.d.ts +2 -2
- package/cjs/derive.js +25 -0
- package/cjs/elections/index.js +4 -0
- package/cjs/elections/info.js +93 -0
- package/cjs/elections/types.js +2 -0
- package/cjs/imOnline/index.js +4 -0
- package/cjs/imOnline/receivedHeartbeats.js +42 -0
- package/cjs/index.js +5 -0
- package/cjs/membership/index.js +74 -0
- package/cjs/package.json +3 -0
- package/cjs/packageDetect.d.ts +1 -0
- package/cjs/packageDetect.js +5 -0
- package/cjs/packageInfo.js +4 -0
- package/cjs/session/index.js +6 -0
- package/cjs/session/indexes.js +68 -0
- package/cjs/session/info.js +28 -0
- package/cjs/session/progress.js +93 -0
- package/cjs/session/types.js +2 -0
- package/cjs/society/candidates.js +42 -0
- package/cjs/society/index.js +7 -0
- package/cjs/society/info.js +36 -0
- package/cjs/society/member.js +18 -0
- package/cjs/society/members.js +70 -0
- package/{build → cjs}/society/types.d.ts +5 -5
- package/cjs/society/types.js +2 -0
- package/{build → cjs}/staking/account.d.ts +1 -1
- package/cjs/staking/account.js +80 -0
- package/cjs/staking/cache.js +39 -0
- package/{build → cjs}/staking/currentPoints.d.ts +2 -2
- package/cjs/staking/currentPoints.js +17 -0
- package/cjs/staking/electedInfo.js +37 -0
- package/cjs/staking/erasExposure.js +76 -0
- package/cjs/staking/erasHistoric.js +31 -0
- package/cjs/staking/erasPoints.js +51 -0
- package/cjs/staking/erasPrefs.js +47 -0
- package/cjs/staking/erasRewards.js +38 -0
- package/cjs/staking/erasSlashes.js +53 -0
- package/cjs/staking/index.js +25 -0
- package/{build → cjs}/staking/keys.d.ts +1 -1
- package/cjs/staking/keys.js +61 -0
- package/cjs/staking/overview.js +31 -0
- package/{build → cjs}/staking/ownExposure.d.ts +1 -1
- package/cjs/staking/ownExposure.js +64 -0
- package/{build → cjs}/staking/ownSlashes.d.ts +1 -1
- package/cjs/staking/ownSlashes.js +51 -0
- package/{build → cjs}/staking/query.d.ts +1 -1
- package/cjs/staking/query.js +176 -0
- package/{build → cjs}/staking/stakerExposure.d.ts +1 -1
- package/cjs/staking/stakerExposure.js +56 -0
- package/cjs/staking/stakerPoints.js +35 -0
- package/cjs/staking/stakerPrefs.js +33 -0
- package/{build → cjs}/staking/stakerRewards.d.ts +1 -1
- package/cjs/staking/stakerRewards.js +222 -0
- package/cjs/staking/stakerSlashes.js +34 -0
- package/cjs/staking/stashes.js +38 -0
- package/{build → cjs}/staking/types.d.ts +15 -15
- package/cjs/staking/types.js +2 -0
- package/cjs/staking/util.js +53 -0
- package/cjs/staking/validators.js +71 -0
- package/cjs/staking/waitingInfo.js +32 -0
- package/cjs/technicalCommittee/index.js +74 -0
- package/cjs/teyrchains/index.js +5 -0
- package/{build/parachains → cjs/teyrchains}/info.d.ts +7 -7
- package/cjs/teyrchains/info.js +75 -0
- package/cjs/teyrchains/overview.d.ts +15 -0
- package/cjs/teyrchains/overview.js +39 -0
- package/{build/parachains → cjs/teyrchains}/types.d.ts +6 -6
- package/cjs/teyrchains/types.js +2 -0
- package/cjs/teyrchains/util.js +8 -0
- package/cjs/treasury/index.js +4 -0
- package/cjs/treasury/proposals.js +71 -0
- package/cjs/tx/constants.js +8 -0
- package/cjs/tx/events.js +24 -0
- package/cjs/tx/extrinsicInfo.js +87 -0
- package/cjs/tx/index.js +6 -0
- package/cjs/tx/signingInfo.js +81 -0
- package/cjs/type/HeaderExtended.js +23 -0
- package/cjs/type/SignedBlockExtended.js +60 -0
- package/cjs/type/index.js +7 -0
- package/cjs/type/types.js +2 -0
- package/cjs/type/util.js +36 -0
- package/{build → cjs}/types.d.ts +4 -4
- package/cjs/types.js +15 -0
- package/cjs/util/approvalFlagsToBools.js +19 -0
- package/cjs/util/blockNumber.js +9 -0
- package/cjs/util/cache.js +45 -0
- package/cjs/util/cacheImpl.js +26 -0
- package/cjs/util/first.js +12 -0
- package/cjs/util/index.js +13 -0
- package/cjs/util/lazy.js +7 -0
- package/cjs/util/types.js +2 -0
- package/collective/helpers.d.ts +6 -0
- package/collective/helpers.js +18 -0
- package/collective/index.d.ts +3 -0
- package/collective/index.js +3 -0
- package/collective/members.d.ts +2 -0
- package/collective/members.js +2 -0
- package/collective/prime.d.ts +2 -0
- package/collective/prime.js +8 -0
- package/collective/proposals.d.ts +6 -0
- package/collective/proposals.js +38 -0
- package/{src/collective/types.ts → collective/types.d.ts} +0 -11
- package/collective/types.js +1 -0
- package/contracts/fees.d.ts +14 -0
- package/contracts/fees.js +45 -0
- package/contracts/index.d.ts +1 -0
- package/contracts/index.js +1 -0
- package/council/index.d.ts +72 -0
- package/{src/council/index.ts → council/index.js} +0 -6
- package/{src/council/types.ts → council/types.d.ts} +2 -7
- package/council/types.js +1 -0
- package/council/votes.d.ts +11 -0
- package/council/votes.js +56 -0
- package/council/votesOf.d.ts +16 -0
- package/council/votesOf.js +18 -0
- package/crowdloan/childKey.d.ts +15 -0
- package/crowdloan/childKey.js +23 -0
- package/crowdloan/contributions.d.ts +14 -0
- package/crowdloan/contributions.js +80 -0
- package/crowdloan/index.d.ts +3 -0
- package/crowdloan/index.js +3 -0
- package/crowdloan/ownContributions.d.ts +15 -0
- package/crowdloan/ownContributions.js +45 -0
- package/{src/crowdloan/types.ts → crowdloan/types.d.ts} +2 -7
- package/crowdloan/types.js +1 -0
- package/crowdloan/util.d.ts +10 -0
- package/crowdloan/util.js +17 -0
- package/democracy/dispatchQueue.d.ts +12 -0
- package/democracy/dispatchQueue.js +87 -0
- package/{src/democracy/index.ts → democracy/index.d.ts} +0 -3
- package/democracy/index.js +11 -0
- package/democracy/locks.d.ts +14 -0
- package/democracy/locks.js +62 -0
- package/democracy/nextExternal.d.ts +12 -0
- package/democracy/nextExternal.js +28 -0
- package/democracy/preimages.d.ts +24 -0
- package/democracy/preimages.js +113 -0
- package/democracy/proposals.d.ts +12 -0
- package/democracy/proposals.js +43 -0
- package/democracy/referendumIds.d.ts +12 -0
- package/democracy/referendumIds.js +21 -0
- package/democracy/referendums.d.ts +11 -0
- package/democracy/referendums.js +19 -0
- package/democracy/referendumsActive.d.ts +12 -0
- package/democracy/referendumsActive.js +16 -0
- package/democracy/referendumsFinished.d.ts +15 -0
- package/democracy/referendumsFinished.js +17 -0
- package/democracy/referendumsInfo.d.ts +23 -0
- package/democracy/referendumsInfo.js +108 -0
- package/democracy/sqrtElectorate.d.ts +13 -0
- package/democracy/sqrtElectorate.js +15 -0
- package/democracy/types.d.ts +70 -0
- package/democracy/types.js +1 -0
- package/democracy/util.d.ts +18 -0
- package/democracy/util.js +129 -0
- package/derive.d.ts +52 -0
- package/{src/derive.ts → derive.js} +2 -22
- package/elections/index.d.ts +1 -0
- package/elections/index.js +1 -0
- package/elections/info.d.ts +14 -0
- package/elections/info.js +90 -0
- package/elections/types.d.ts +18 -0
- package/elections/types.js +1 -0
- package/imOnline/index.d.ts +1 -0
- package/imOnline/index.js +1 -0
- package/imOnline/receivedHeartbeats.d.ts +13 -0
- package/imOnline/receivedHeartbeats.js +39 -0
- package/index.d.ts +2 -0
- package/index.js +2 -0
- package/membership/index.d.ts +70 -0
- package/{src/membership/index.ts → membership/index.js} +0 -5
- package/package.json +2066 -19
- package/packageDetect.d.ts +1 -0
- package/packageDetect.js +3 -0
- package/packageInfo.d.ts +6 -0
- package/packageInfo.js +1 -0
- package/session/index.d.ts +3 -0
- package/session/index.js +3 -0
- package/session/indexes.d.ts +15 -0
- package/session/indexes.js +65 -0
- package/session/info.d.ts +13 -0
- package/{src/session/info.ts → session/info.js} +7 -21
- package/session/progress.d.ts +47 -0
- package/session/progress.js +89 -0
- package/session/types.d.ts +19 -0
- package/session/types.js +1 -0
- package/society/candidates.d.ts +12 -0
- package/society/candidates.js +39 -0
- package/{src/society/index.ts → society/index.d.ts} +0 -3
- package/society/index.js +4 -0
- package/society/info.d.ts +12 -0
- package/society/info.js +33 -0
- package/society/member.d.ts +14 -0
- package/society/member.js +15 -0
- package/society/members.d.ts +14 -0
- package/society/members.js +66 -0
- package/society/types.d.ts +27 -0
- package/society/types.js +1 -0
- package/staking/account.d.ts +31 -0
- package/staking/account.js +76 -0
- package/staking/cache.d.ts +12 -0
- package/staking/cache.js +32 -0
- package/staking/currentPoints.d.ts +13 -0
- package/staking/currentPoints.js +14 -0
- package/staking/electedInfo.d.ts +23 -0
- package/staking/electedInfo.js +34 -0
- package/staking/erasExposure.d.ts +30 -0
- package/staking/erasExposure.js +72 -0
- package/staking/erasHistoric.d.ts +8 -0
- package/staking/erasHistoric.js +28 -0
- package/staking/erasPoints.d.ts +18 -0
- package/staking/erasPoints.js +47 -0
- package/staking/erasPrefs.d.ts +27 -0
- package/staking/erasPrefs.js +43 -0
- package/staking/erasRewards.d.ts +14 -0
- package/staking/erasRewards.js +34 -0
- package/staking/erasSlashes.d.ts +26 -0
- package/staking/erasSlashes.js +49 -0
- package/{src/staking/index.ts → staking/index.d.ts} +0 -3
- package/staking/index.js +22 -0
- package/staking/keys.d.ts +35 -0
- package/staking/keys.js +57 -0
- package/staking/overview.d.ts +19 -0
- package/staking/overview.js +28 -0
- package/staking/ownExposure.d.ts +37 -0
- package/staking/ownExposure.js +60 -0
- package/staking/ownSlashes.d.ts +35 -0
- package/staking/ownSlashes.js +47 -0
- package/staking/query.d.ts +31 -0
- package/staking/query.js +172 -0
- package/staking/stakerExposure.d.ts +33 -0
- package/staking/stakerExposure.js +51 -0
- package/staking/stakerPoints.d.ts +22 -0
- package/staking/stakerPoints.js +31 -0
- package/staking/stakerPrefs.d.ts +24 -0
- package/staking/stakerPrefs.js +29 -0
- package/staking/stakerRewards.d.ts +49 -0
- package/staking/stakerRewards.js +215 -0
- package/staking/stakerSlashes.d.ts +22 -0
- package/staking/stakerSlashes.js +30 -0
- package/staking/stashes.d.ts +16 -0
- package/staking/stashes.js +35 -0
- package/staking/types.d.ts +139 -0
- package/staking/types.js +1 -0
- package/staking/util.d.ts +14 -0
- package/staking/util.js +46 -0
- package/staking/validators.d.ts +33 -0
- package/{src/staking/validators.ts → staking/validators.js} +25 -40
- package/staking/waitingInfo.d.ts +16 -0
- package/{src/staking/waitingInfo.ts → staking/waitingInfo.js} +8 -24
- package/technicalCommittee/index.d.ts +70 -0
- package/{src/technicalCommittee/index.ts → technicalCommittee/index.js} +0 -5
- package/teyrchains/index.d.ts +2 -0
- package/teyrchains/index.js +2 -0
- package/teyrchains/info.d.ts +19 -0
- package/teyrchains/info.js +72 -0
- package/teyrchains/overview.d.ts +15 -0
- package/teyrchains/overview.js +36 -0
- package/teyrchains/types.d.ts +38 -0
- package/teyrchains/types.js +1 -0
- package/teyrchains/util.d.ts +3 -0
- package/teyrchains/util.js +5 -0
- package/treasury/index.d.ts +1 -0
- package/treasury/index.js +1 -0
- package/treasury/proposals.d.ts +12 -0
- package/treasury/proposals.js +68 -0
- package/tx/constants.d.ts +5 -0
- package/{src/tx/constants.ts → tx/constants.js} +0 -8
- package/tx/events.d.ts +22 -0
- package/tx/events.js +21 -0
- package/tx/extrinsicInfo.d.ts +61 -0
- package/tx/extrinsicInfo.js +83 -0
- package/tx/index.d.ts +3 -0
- package/tx/index.js +3 -0
- package/tx/signingInfo.d.ts +25 -0
- package/tx/signingInfo.js +78 -0
- package/type/HeaderExtended.d.ts +4 -0
- package/type/HeaderExtended.js +20 -0
- package/type/SignedBlockExtended.d.ts +4 -0
- package/type/SignedBlockExtended.js +57 -0
- package/{src/type/index.ts → type/index.d.ts} +0 -3
- package/type/index.js +2 -0
- package/type/types.d.ts +15 -0
- package/type/types.js +1 -0
- package/type/util.d.ts +2 -0
- package/type/util.js +33 -0
- package/{src/types.ts → types.d.ts} +39 -57
- package/types.js +12 -0
- package/util/approvalFlagsToBools.d.ts +4 -0
- package/util/approvalFlagsToBools.js +16 -0
- package/util/blockNumber.d.ts +7 -0
- package/util/blockNumber.js +6 -0
- package/util/cache.d.ts +4 -0
- package/util/cache.js +42 -0
- package/util/cacheImpl.d.ts +3 -0
- package/util/cacheImpl.js +23 -0
- package/util/first.d.ts +4 -0
- package/util/first.js +8 -0
- package/{src/util/index.ts → util/index.d.ts} +0 -6
- package/util/index.js +7 -0
- package/util/lazy.d.ts +4 -0
- package/util/lazy.js +4 -0
- package/util/types.d.ts +6 -0
- package/util/types.js +1 -0
- package/build/bagsList/listNodes.d.ts +0 -9
- package/build/parachains/overview.d.ts +0 -15
- package/src/accounts/accountId.ts +0 -44
- package/src/accounts/flags.ts +0 -90
- package/src/accounts/idAndIndex.ts +0 -51
- package/src/accounts/idToIndex.ts +0 -31
- package/src/accounts/identity.ts +0 -235
- package/src/accounts/indexToId.ts +0 -33
- package/src/accounts/indexes.ts +0 -56
- package/src/accounts/info.ts +0 -58
- package/src/accounts/types.ts +0 -48
- package/src/augment.ts +0 -4
- package/src/bagsList/get.ts +0 -79
- package/src/bagsList/getExpanded.ts +0 -41
- package/src/bagsList/index.ts +0 -6
- package/src/bagsList/listNodes.ts +0 -50
- package/src/bagsList/types.ts +0 -18
- package/src/bagsList/util.ts +0 -14
- package/src/balances/account.ts +0 -210
- package/src/balances/all.ts +0 -246
- package/src/balances/types.ts +0 -79
- package/src/balances/votingBalances.ts +0 -33
- package/src/bounties/bounties.spec.ts +0 -162
- package/src/bounties/bounties.ts +0 -76
- package/src/bounties/helpers/filterBountyProposals.ts +0 -13
- package/src/bounties/index.ts +0 -4
- package/src/bundle.ts +0 -140
- package/src/chain/bestNumberLag.ts +0 -33
- package/src/chain/getBlock.ts +0 -43
- package/src/chain/getHeader.ts +0 -37
- package/src/chain/subscribeFinalizedBlocks.ts +0 -30
- package/src/chain/subscribeFinalizedHeads.ts +0 -62
- package/src/chain/subscribeNewBlocks.ts +0 -30
- package/src/chain/subscribeNewHeads.ts +0 -38
- package/src/chain/util.ts +0 -112
- package/src/checkTypes.manual.ts +0 -8
- package/src/collective/helpers.ts +0 -36
- package/src/collective/index.ts +0 -6
- package/src/collective/members.ts +0 -8
- package/src/collective/prime.ts +0 -25
- package/src/collective/proposals.ts +0 -73
- package/src/contracts/fees.ts +0 -61
- package/src/contracts/index.ts +0 -4
- package/src/council/votes.ts +0 -97
- package/src/council/votesOf.ts +0 -35
- package/src/crowdloan/childKey.ts +0 -57
- package/src/crowdloan/contributions.ts +0 -142
- package/src/crowdloan/index.ts +0 -6
- package/src/crowdloan/ownContributions.ts +0 -81
- package/src/crowdloan/util.ts +0 -33
- package/src/democracy/dispatchQueue.ts +0 -158
- package/src/democracy/locks.ts +0 -114
- package/src/democracy/nextExternal.ts +0 -49
- package/src/democracy/preimages.ts +0 -171
- package/src/democracy/proposals.ts +0 -81
- package/src/democracy/referendumIds.ts +0 -37
- package/src/democracy/referendums.ts +0 -39
- package/src/democracy/referendumsActive.ts +0 -30
- package/src/democracy/referendumsFinished.ts +0 -37
- package/src/democracy/referendumsInfo.ts +0 -181
- package/src/democracy/sqrtElectorate.ts +0 -29
- package/src/democracy/types.ts +0 -84
- package/src/democracy/util.ts +0 -166
- package/src/elections/index.ts +0 -4
- package/src/elections/info.ts +0 -126
- package/src/elections/types.ts +0 -22
- package/src/imOnline/index.ts +0 -4
- package/src/imOnline/receivedHeartbeats.ts +0 -65
- package/src/index.spec.ts +0 -103
- package/src/index.ts +0 -6
- package/src/mod.ts +0 -4
- package/src/packageDetect.ts +0 -11
- package/src/packageInfo.ts +0 -6
- package/src/parachains/index.ts +0 -5
- package/src/parachains/info.ts +0 -111
- package/src/parachains/overview.ts +0 -63
- package/src/parachains/types.ts +0 -46
- package/src/parachains/util.ts +0 -11
- package/src/session/index.ts +0 -6
- package/src/session/indexes.ts +0 -90
- package/src/session/progress.ts +0 -130
- package/src/session/types.ts +0 -25
- package/src/society/candidates.ts +0 -71
- package/src/society/info.ts +0 -50
- package/src/society/member.ts +0 -28
- package/src/society/members.ts +0 -107
- package/src/society/types.ts +0 -33
- package/src/staking/account.ts +0 -112
- package/src/staking/cache.ts +0 -48
- package/src/staking/currentPoints.ts +0 -28
- package/src/staking/electedInfo.ts +0 -54
- package/src/staking/erasExposure.ts +0 -105
- package/src/staking/erasHistoric.ts +0 -47
- package/src/staking/erasPoints.ts +0 -67
- package/src/staking/erasPrefs.ts +0 -63
- package/src/staking/erasRewards.ts +0 -52
- package/src/staking/erasSlashes.ts +0 -69
- package/src/staking/keys.ts +0 -86
- package/src/staking/overview.ts +0 -42
- package/src/staking/ownExposure.ts +0 -83
- package/src/staking/ownSlashes.ts +0 -68
- package/src/staking/query.ts +0 -230
- package/src/staking/stakerExposure.ts +0 -78
- package/src/staking/stakerPoints.ts +0 -46
- package/src/staking/stakerPrefs.ts +0 -45
- package/src/staking/stakerRewards.ts +0 -298
- package/src/staking/stakerSlashes.ts +0 -45
- package/src/staking/stashes.ts +0 -55
- package/src/staking/types.ts +0 -174
- package/src/staking/util.ts +0 -94
- package/src/test/bountyFactory.ts +0 -39
- package/src/test/bytesFactory.ts +0 -15
- package/src/test/helpers.ts +0 -23
- package/src/test/proposalFactory.ts +0 -25
- package/src/treasury/index.ts +0 -4
- package/src/treasury/proposals.ts +0 -109
- package/src/tx/events.ts +0 -43
- package/src/tx/extrinsicInfo.ts +0 -123
- package/src/tx/index.ts +0 -6
- package/src/tx/signingInfo.ts +0 -129
- package/src/type/HeaderExtended.ts +0 -33
- package/src/type/SignedBlockExtended.ts +0 -75
- package/src/type/types.ts +0 -21
- package/src/type/util.ts +0 -45
- package/src/util/approvalFlagToBools.spec.ts +0 -37
- package/src/util/approvalFlagsToBools.ts +0 -26
- package/src/util/blockNumber.ts +0 -15
- package/src/util/cache.ts +0 -65
- package/src/util/cacheImpl.ts +0 -30
- package/src/util/first.ts +0 -20
- package/src/util/lazy.ts +0 -16
- package/src/util/types.ts +0 -9
- package/tsconfig.build.json +0 -21
- package/tsconfig.build.tsbuildinfo +0 -1
- package/tsconfig.spec.json +0 -27
- /package/{build/accounts → accounts}/accountId.d.ts +0 -0
- /package/{build/accounts → accounts}/idAndIndex.d.ts +0 -0
- /package/{build/accounts → accounts}/idToIndex.d.ts +0 -0
- /package/{build/accounts → accounts}/index.d.ts +0 -0
- /package/{build/accounts → accounts}/indexToId.d.ts +0 -0
- /package/{build/accounts → accounts}/indexes.d.ts +0 -0
- /package/{build/accounts → accounts}/info.d.ts +0 -0
- /package/{build/accounts → accounts}/types.d.ts +0 -0
- /package/{build/packageDetect.d.ts → accounts/types.js} +0 -0
- /package/{build/alliance → alliance}/index.d.ts +0 -0
- /package/{build/augment.d.ts → augment.d.ts} +0 -0
- /package/{build/bagsList → bagsList}/get.d.ts +0 -0
- /package/{build/bagsList → bagsList}/getExpanded.d.ts +0 -0
- /package/{build/bagsList → bagsList}/index.d.ts +0 -0
- /package/{build/bagsList → bagsList}/util.d.ts +0 -0
- /package/{build/balances → balances}/account.d.ts +0 -0
- /package/{build/balances → balances}/all.d.ts +0 -0
- /package/{build/balances → balances}/index.d.ts +0 -0
- /package/{build/balances → balances}/votingBalances.d.ts +0 -0
- /package/{build/bounties → bounties}/bounties.d.ts +0 -0
- /package/{build/bounties → bounties}/helpers/filterBountyProposals.d.ts +0 -0
- /package/{build/bounties → bounties}/index.d.ts +0 -0
- /package/{build/bundle.d.ts → bundle.d.ts} +0 -0
- /package/{build/chain → chain}/bestNumber.d.ts +0 -0
- /package/{build/chain → chain}/bestNumberFinalized.d.ts +0 -0
- /package/{build/chain → chain}/bestNumberLag.d.ts +0 -0
- /package/{build/chain → chain}/getBlock.d.ts +0 -0
- /package/{build/chain → chain}/getBlockByNumber.d.ts +0 -0
- /package/{build/chain → chain}/getHeader.d.ts +0 -0
- /package/{build/chain → chain}/index.d.ts +0 -0
- /package/{build/chain → chain}/subscribeFinalizedBlocks.d.ts +0 -0
- /package/{build/chain → chain}/subscribeFinalizedHeads.d.ts +0 -0
- /package/{build/chain → chain}/subscribeNewBlocks.d.ts +0 -0
- /package/{build/chain → chain}/subscribeNewHeads.d.ts +0 -0
- /package/{build/chain → chain}/util.d.ts +0 -0
- /package/{build → cjs}/collective/helpers.d.ts +0 -0
- /package/{build → cjs}/collective/index.d.ts +0 -0
- /package/{build → cjs}/collective/members.d.ts +0 -0
- /package/{build → cjs}/collective/prime.d.ts +0 -0
- /package/{build → cjs}/collective/proposals.d.ts +0 -0
- /package/{build → cjs}/collective/types.d.ts +0 -0
- /package/{build → cjs}/contracts/index.d.ts +0 -0
- /package/{build → cjs}/council/index.d.ts +0 -0
- /package/{build → cjs}/council/types.d.ts +0 -0
- /package/{build → cjs}/council/votes.d.ts +0 -0
- /package/{build → cjs}/council/votesOf.d.ts +0 -0
- /package/{build → cjs}/crowdloan/index.d.ts +0 -0
- /package/{build → cjs}/crowdloan/types.d.ts +0 -0
- /package/{build → cjs}/democracy/dispatchQueue.d.ts +0 -0
- /package/{build → cjs}/democracy/index.d.ts +0 -0
- /package/{build → cjs}/democracy/locks.d.ts +0 -0
- /package/{build → cjs}/democracy/nextExternal.d.ts +0 -0
- /package/{build → cjs}/democracy/proposals.d.ts +0 -0
- /package/{build → cjs}/democracy/referendumIds.d.ts +0 -0
- /package/{build → cjs}/democracy/referendums.d.ts +0 -0
- /package/{build → cjs}/democracy/referendumsActive.d.ts +0 -0
- /package/{build → cjs}/democracy/sqrtElectorate.d.ts +0 -0
- /package/{build → cjs}/elections/index.d.ts +0 -0
- /package/{build → cjs}/elections/info.d.ts +0 -0
- /package/{build → cjs}/elections/types.d.ts +0 -0
- /package/{build → cjs}/imOnline/index.d.ts +0 -0
- /package/{build → cjs}/imOnline/receivedHeartbeats.d.ts +0 -0
- /package/{build → cjs}/index.d.ts +0 -0
- /package/{build → cjs}/membership/index.d.ts +0 -0
- /package/{build → cjs}/packageInfo.d.ts +0 -0
- /package/{build → cjs}/session/index.d.ts +0 -0
- /package/{build → cjs}/session/indexes.d.ts +0 -0
- /package/{build → cjs}/session/info.d.ts +0 -0
- /package/{build → cjs}/session/progress.d.ts +0 -0
- /package/{build → cjs}/session/types.d.ts +0 -0
- /package/{build → cjs}/society/candidates.d.ts +0 -0
- /package/{build → cjs}/society/index.d.ts +0 -0
- /package/{build → cjs}/society/info.d.ts +0 -0
- /package/{build → cjs}/society/member.d.ts +0 -0
- /package/{build → cjs}/society/members.d.ts +0 -0
- /package/{build → cjs}/staking/cache.d.ts +0 -0
- /package/{build → cjs}/staking/electedInfo.d.ts +0 -0
- /package/{build → cjs}/staking/erasExposure.d.ts +0 -0
- /package/{build → cjs}/staking/erasHistoric.d.ts +0 -0
- /package/{build → cjs}/staking/erasPoints.d.ts +0 -0
- /package/{build → cjs}/staking/erasPrefs.d.ts +0 -0
- /package/{build → cjs}/staking/erasRewards.d.ts +0 -0
- /package/{build → cjs}/staking/erasSlashes.d.ts +0 -0
- /package/{build → cjs}/staking/index.d.ts +0 -0
- /package/{build → cjs}/staking/overview.d.ts +0 -0
- /package/{build → cjs}/staking/stakerPoints.d.ts +0 -0
- /package/{build → cjs}/staking/stakerPrefs.d.ts +0 -0
- /package/{build → cjs}/staking/stakerSlashes.d.ts +0 -0
- /package/{build → cjs}/staking/stashes.d.ts +0 -0
- /package/{build → cjs}/staking/util.d.ts +0 -0
- /package/{build → cjs}/staking/validators.d.ts +0 -0
- /package/{build → cjs}/staking/waitingInfo.d.ts +0 -0
- /package/{build → cjs}/technicalCommittee/index.d.ts +0 -0
- /package/{build/parachains → cjs/teyrchains}/index.d.ts +0 -0
- /package/{build/parachains → cjs/teyrchains}/util.d.ts +0 -0
- /package/{build → cjs}/treasury/index.d.ts +0 -0
- /package/{build → cjs}/treasury/proposals.d.ts +0 -0
- /package/{build → cjs}/tx/constants.d.ts +0 -0
- /package/{build → cjs}/tx/events.d.ts +0 -0
- /package/{build → cjs}/tx/extrinsicInfo.d.ts +0 -0
- /package/{build → cjs}/tx/index.d.ts +0 -0
- /package/{build → cjs}/tx/signingInfo.d.ts +0 -0
- /package/{build → cjs}/type/HeaderExtended.d.ts +0 -0
- /package/{build → cjs}/type/SignedBlockExtended.d.ts +0 -0
- /package/{build → cjs}/type/index.d.ts +0 -0
- /package/{build → cjs}/type/types.d.ts +0 -0
- /package/{build → cjs}/type/util.d.ts +0 -0
- /package/{build → cjs}/util/approvalFlagsToBools.d.ts +0 -0
- /package/{build → cjs}/util/blockNumber.d.ts +0 -0
- /package/{build → cjs}/util/cache.d.ts +0 -0
- /package/{build → cjs}/util/cacheImpl.d.ts +0 -0
- /package/{build → cjs}/util/first.d.ts +0 -0
- /package/{build → cjs}/util/index.d.ts +0 -0
- /package/{build → cjs}/util/lazy.d.ts +0 -0
- /package/{build → cjs}/util/types.d.ts +0 -0
package/bagsList/get.js
ADDED
|
@@ -0,0 +1,42 @@
|
|
|
1
|
+
import { map, of, switchMap } from 'rxjs';
|
|
2
|
+
import { BN_ZERO, bnToBn, objectSpread } from '@pezkuwi/util';
|
|
3
|
+
import { memo } from '../util/index.js';
|
|
4
|
+
import { getQueryInterface } from './util.js';
|
|
5
|
+
function orderBags(ids, bags) {
|
|
6
|
+
const sorted = ids
|
|
7
|
+
.map((id, index) => ({
|
|
8
|
+
bag: bags[index].unwrapOr(null),
|
|
9
|
+
id,
|
|
10
|
+
key: id.toString()
|
|
11
|
+
}))
|
|
12
|
+
.sort((a, b) => b.id.cmp(a.id));
|
|
13
|
+
const max = sorted.length - 1;
|
|
14
|
+
return sorted.map((entry, index) => objectSpread(entry, {
|
|
15
|
+
bagLower: index === max
|
|
16
|
+
? BN_ZERO
|
|
17
|
+
: sorted[index + 1].id,
|
|
18
|
+
bagUpper: entry.id,
|
|
19
|
+
index
|
|
20
|
+
}));
|
|
21
|
+
}
|
|
22
|
+
export function _getIds(instanceId, api) {
|
|
23
|
+
const query = getQueryInterface(api);
|
|
24
|
+
return memo(instanceId, (_ids) => {
|
|
25
|
+
const ids = _ids.map((id) => bnToBn(id));
|
|
26
|
+
return ids.length
|
|
27
|
+
? query.listBags.multi(ids).pipe(map((bags) => orderBags(ids, bags)))
|
|
28
|
+
: of([]);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
export function all(instanceId, api) {
|
|
32
|
+
const query = getQueryInterface(api);
|
|
33
|
+
return memo(instanceId, () => query.listBags.keys().pipe(switchMap((keys) => api.derive.bagsList._getIds(keys.map(({ args: [id] }) => id))), map((list) => list.filter(({ bag }) => bag))));
|
|
34
|
+
}
|
|
35
|
+
/**
|
|
36
|
+
* @name get
|
|
37
|
+
* @param {(BN | number)} id The id of the bag to retrieve.
|
|
38
|
+
* @description Retrieves a specific bag from the BagsList pallet by its id.
|
|
39
|
+
*/
|
|
40
|
+
export function get(instanceId, api) {
|
|
41
|
+
return memo(instanceId, (id) => api.derive.bagsList._getIds([bnToBn(id)]).pipe(map((bags) => bags[0])));
|
|
42
|
+
}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { map, switchMap } from 'rxjs';
|
|
2
|
+
import { objectSpread } from '@pezkuwi/util';
|
|
3
|
+
import { memo } from '../util/index.js';
|
|
4
|
+
/**
|
|
5
|
+
* @name expand
|
|
6
|
+
* @description Expands a given bag by retrieving all its nodes (accounts contained within the bag).
|
|
7
|
+
* @param {Bag} bag The bag to be expanded.
|
|
8
|
+
*/
|
|
9
|
+
export function expand(instanceId, api) {
|
|
10
|
+
return memo(instanceId, (bag) => api.derive.bagsList.listNodes(bag.bag).pipe(map((nodes) => objectSpread({ nodes }, bag))));
|
|
11
|
+
}
|
|
12
|
+
/**
|
|
13
|
+
* @name getExpanded
|
|
14
|
+
* @description Retrieves and expands a specific bag from the BagsList pallet.
|
|
15
|
+
* @param {BN | number} id The id of the bag to expand.
|
|
16
|
+
*/
|
|
17
|
+
export function getExpanded(instanceId, api) {
|
|
18
|
+
return memo(instanceId, (id) => api.derive.bagsList.get(id).pipe(switchMap((bag) => api.derive.bagsList.expand(bag))));
|
|
19
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Observable } from 'rxjs';
|
|
2
|
+
import type { PezpalletBagsListListBag, PezpalletBagsListListNode } from '@pezkuwi/types/lookup';
|
|
3
|
+
import type { DeriveApi } from '../types.js';
|
|
4
|
+
/**
|
|
5
|
+
* @name listNodes
|
|
6
|
+
* @param {(PezpalletBagsListListBag | null)} bag A reference to a specific bag in the BagsList pallet.
|
|
7
|
+
* @description Retrieves the list of nodes (accounts) contained in a specific bag within the BagsList pallet.
|
|
8
|
+
*/
|
|
9
|
+
export declare function listNodes(instanceId: string, api: DeriveApi): (bag: PezpalletBagsListListBag | null) => Observable<PezpalletBagsListListNode[]>;
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { BehaviorSubject, map, of, switchMap, tap, toArray } from 'rxjs';
|
|
2
|
+
import { nextTick } from '@pezkuwi/util';
|
|
3
|
+
import { memo } from '../util/index.js';
|
|
4
|
+
import { getQueryInterface } from './util.js';
|
|
5
|
+
function traverseLinks(api, head) {
|
|
6
|
+
const subject = new BehaviorSubject(head);
|
|
7
|
+
const query = getQueryInterface(api);
|
|
8
|
+
return subject.pipe(switchMap((account) => query.listNodes(account)), tap((node) => {
|
|
9
|
+
nextTick(() => {
|
|
10
|
+
node.isSome && node.value.next.isSome
|
|
11
|
+
? subject.next(node.unwrap().next.unwrap())
|
|
12
|
+
: subject.complete();
|
|
13
|
+
});
|
|
14
|
+
}), toArray(), // toArray since we want to startSubject to be completed
|
|
15
|
+
map((all) => all.map((o) => o.unwrap())));
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* @name listNodes
|
|
19
|
+
* @param {(PezpalletBagsListListBag | null)} bag A reference to a specific bag in the BagsList pallet.
|
|
20
|
+
* @description Retrieves the list of nodes (accounts) contained in a specific bag within the BagsList pallet.
|
|
21
|
+
*/
|
|
22
|
+
export function listNodes(instanceId, api) {
|
|
23
|
+
return memo(instanceId, (bag) => bag && bag.head.isSome
|
|
24
|
+
? traverseLinks(api, bag.head.unwrap())
|
|
25
|
+
: of([]));
|
|
26
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
import type {
|
|
1
|
+
import type { PezpalletBagsListListBag, PezpalletBagsListListNode } from '@pezkuwi/types/lookup';
|
|
2
2
|
import type { BN } from '@pezkuwi/util';
|
|
3
3
|
export interface Bag {
|
|
4
|
-
bag:
|
|
4
|
+
bag: PezpalletBagsListListBag | null;
|
|
5
5
|
bagUpper: BN;
|
|
6
6
|
bagLower: BN;
|
|
7
7
|
id: BN;
|
|
@@ -9,5 +9,5 @@ export interface Bag {
|
|
|
9
9
|
key: string;
|
|
10
10
|
}
|
|
11
11
|
export interface BagExpanded extends Bag {
|
|
12
|
-
nodes:
|
|
12
|
+
nodes: PezpalletBagsListListNode[];
|
|
13
13
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
package/bagsList/util.js
ADDED
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
import { combineLatest, map, of, switchMap } from 'rxjs';
|
|
2
|
+
import { isFunction, objectSpread } from '@pezkuwi/util';
|
|
3
|
+
import { memo } from '../util/index.js';
|
|
4
|
+
function zeroBalance(api) {
|
|
5
|
+
return api.registry.createType('Balance');
|
|
6
|
+
}
|
|
7
|
+
function getBalance(api, [freeBalance, reservedBalance, frozenFeeOrFrozen, frozenMiscOrFlags], accType) {
|
|
8
|
+
const votingBalance = api.registry.createType('Balance', freeBalance.toBn());
|
|
9
|
+
if (accType.isFrameAccountData) {
|
|
10
|
+
return {
|
|
11
|
+
frameSystemAccountInfo: {
|
|
12
|
+
flags: frozenMiscOrFlags,
|
|
13
|
+
frozen: frozenFeeOrFrozen
|
|
14
|
+
},
|
|
15
|
+
freeBalance,
|
|
16
|
+
frozenFee: api.registry.createType('Balance', 0),
|
|
17
|
+
frozenMisc: api.registry.createType('Balance', 0),
|
|
18
|
+
reservedBalance,
|
|
19
|
+
votingBalance
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
return {
|
|
23
|
+
freeBalance,
|
|
24
|
+
frozenFee: frozenFeeOrFrozen,
|
|
25
|
+
frozenMisc: frozenMiscOrFlags,
|
|
26
|
+
reservedBalance,
|
|
27
|
+
votingBalance
|
|
28
|
+
};
|
|
29
|
+
}
|
|
30
|
+
function calcBalances(api, [accountId, [accountNonce, [primary, ...additional], accType]]) {
|
|
31
|
+
return objectSpread({
|
|
32
|
+
accountId,
|
|
33
|
+
accountNonce,
|
|
34
|
+
additional: additional.map((b) => getBalance(api, b, accType))
|
|
35
|
+
}, getBalance(api, primary, accType));
|
|
36
|
+
}
|
|
37
|
+
function queryBalancesFree(api, accountId) {
|
|
38
|
+
return combineLatest([
|
|
39
|
+
api.query.balances['freeBalance'](accountId),
|
|
40
|
+
api.query.balances['reservedBalance'](accountId),
|
|
41
|
+
api.query.system['accountNonce'](accountId)
|
|
42
|
+
]).pipe(map(([freeBalance, reservedBalance, accountNonce]) => [
|
|
43
|
+
accountNonce,
|
|
44
|
+
[[freeBalance, reservedBalance, zeroBalance(api), zeroBalance(api)]],
|
|
45
|
+
{ isFrameAccountData: false }
|
|
46
|
+
]));
|
|
47
|
+
}
|
|
48
|
+
function queryNonceOnly(api, accountId) {
|
|
49
|
+
const fill = (nonce) => [
|
|
50
|
+
nonce,
|
|
51
|
+
[[zeroBalance(api), zeroBalance(api), zeroBalance(api), zeroBalance(api)]],
|
|
52
|
+
{ isFrameAccountData: false }
|
|
53
|
+
];
|
|
54
|
+
return isFunction(api.query.system.account)
|
|
55
|
+
? api.query.system.account(accountId).pipe(map(({ nonce }) => fill(nonce)))
|
|
56
|
+
: isFunction(api.query.system['accountNonce'])
|
|
57
|
+
? api.query.system['accountNonce'](accountId).pipe(map((nonce) => fill(nonce)))
|
|
58
|
+
: of(fill(api.registry.createType('Index')));
|
|
59
|
+
}
|
|
60
|
+
function queryBalancesAccount(api, accountId, modules = ['balances']) {
|
|
61
|
+
const balances = modules
|
|
62
|
+
.map((m) => api.derive[m]?.customAccount || api.query[m]?.account)
|
|
63
|
+
.filter((q) => isFunction(q));
|
|
64
|
+
const extract = (nonce, data) => [
|
|
65
|
+
nonce,
|
|
66
|
+
data.map(({ feeFrozen, free, miscFrozen, reserved }) => [free, reserved, feeFrozen, miscFrozen]),
|
|
67
|
+
{ isFrameAccountData: false }
|
|
68
|
+
];
|
|
69
|
+
// NOTE this is for the first case where we do have instances specified
|
|
70
|
+
return balances.length
|
|
71
|
+
? isFunction(api.query.system.account)
|
|
72
|
+
? combineLatest([
|
|
73
|
+
api.query.system.account(accountId),
|
|
74
|
+
...balances.map((c) => c(accountId))
|
|
75
|
+
]).pipe(map(([{ nonce }, ...balances]) => extract(nonce, balances)))
|
|
76
|
+
: combineLatest([
|
|
77
|
+
api.query.system['accountNonce'](accountId),
|
|
78
|
+
...balances.map((c) => c(accountId))
|
|
79
|
+
]).pipe(map(([nonce, ...balances]) => extract(nonce, balances)))
|
|
80
|
+
: queryNonceOnly(api, accountId);
|
|
81
|
+
}
|
|
82
|
+
function querySystemAccount(api, accountId) {
|
|
83
|
+
// AccountInfo is current, support old, eg. Edgeware
|
|
84
|
+
return api.query.system.account(accountId).pipe(map((infoOrTuple) => {
|
|
85
|
+
const data = infoOrTuple.nonce
|
|
86
|
+
? infoOrTuple.data
|
|
87
|
+
: infoOrTuple[1];
|
|
88
|
+
const nonce = infoOrTuple.nonce || infoOrTuple[0];
|
|
89
|
+
if (!data || data.isEmpty) {
|
|
90
|
+
return [
|
|
91
|
+
nonce,
|
|
92
|
+
[[zeroBalance(api), zeroBalance(api), zeroBalance(api), zeroBalance(api)]],
|
|
93
|
+
{ isFrameAccountData: false }
|
|
94
|
+
];
|
|
95
|
+
}
|
|
96
|
+
const isFrameType = !!infoOrTuple.data.frozen;
|
|
97
|
+
if (isFrameType) {
|
|
98
|
+
const { flags, free, frozen, reserved } = data;
|
|
99
|
+
return [
|
|
100
|
+
nonce,
|
|
101
|
+
[[free, reserved, frozen, flags]],
|
|
102
|
+
{ isFrameAccountData: true }
|
|
103
|
+
];
|
|
104
|
+
}
|
|
105
|
+
else {
|
|
106
|
+
const { feeFrozen, free, miscFrozen, reserved } = data;
|
|
107
|
+
return [
|
|
108
|
+
nonce,
|
|
109
|
+
[[free, reserved, feeFrozen, miscFrozen]],
|
|
110
|
+
{ isFrameAccountData: false }
|
|
111
|
+
];
|
|
112
|
+
}
|
|
113
|
+
}));
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* @name account
|
|
117
|
+
* @description Retrieves the essential balance details for an account, such as free balance and account nonce.
|
|
118
|
+
* @param {( AccountIndex | AccountId | Address | string )} address An accountsId in different formats.
|
|
119
|
+
* @example
|
|
120
|
+
* ```javascript
|
|
121
|
+
* const ALICE = 'F7Hs';
|
|
122
|
+
*
|
|
123
|
+
* api.derive.balances.all(ALICE, ({ accountId, lockedBalance }) => {
|
|
124
|
+
* console.log(`The account ${accountId} has a locked balance ${lockedBalance} units.`);
|
|
125
|
+
* });
|
|
126
|
+
* ```
|
|
127
|
+
*/
|
|
128
|
+
export function account(instanceId, api) {
|
|
129
|
+
const balanceInstances = api.registry.getModuleInstances(api.runtimeVersion.specName, 'balances');
|
|
130
|
+
const nonDefaultBalances = balanceInstances && balanceInstances[0] !== 'balances';
|
|
131
|
+
return memo(instanceId, (address) => api.derive.accounts.accountId(address).pipe(switchMap((accountId) => (accountId
|
|
132
|
+
? combineLatest([
|
|
133
|
+
of(accountId),
|
|
134
|
+
nonDefaultBalances
|
|
135
|
+
? queryBalancesAccount(api, accountId, balanceInstances)
|
|
136
|
+
: isFunction(api.query.system?.account)
|
|
137
|
+
? querySystemAccount(api, accountId)
|
|
138
|
+
: isFunction(api.query.balances?.account)
|
|
139
|
+
? queryBalancesAccount(api, accountId)
|
|
140
|
+
: isFunction(api.query.balances?.['freeBalance'])
|
|
141
|
+
? queryBalancesFree(api, accountId)
|
|
142
|
+
: queryNonceOnly(api, accountId)
|
|
143
|
+
])
|
|
144
|
+
: of([api.registry.createType('AccountId'), [
|
|
145
|
+
api.registry.createType('Index'),
|
|
146
|
+
[[zeroBalance(api), zeroBalance(api), zeroBalance(api), zeroBalance(api)]],
|
|
147
|
+
{ isFrameAccountData: false }
|
|
148
|
+
]]))), map((result) => calcBalances(api, result))));
|
|
149
|
+
}
|
package/balances/all.js
ADDED
|
@@ -0,0 +1,167 @@
|
|
|
1
|
+
import { combineLatest, map, of, switchMap } from 'rxjs';
|
|
2
|
+
import { BN, BN_ZERO, bnMax, bnMin, isFunction, objectSpread } from '@pezkuwi/util';
|
|
3
|
+
import { memo } from '../util/index.js';
|
|
4
|
+
const VESTING_ID = '0x76657374696e6720';
|
|
5
|
+
function calcLocked(api, bestNumber, locks) {
|
|
6
|
+
let lockedBalance = api.registry.createType('Balance');
|
|
7
|
+
let lockedBreakdown = [];
|
|
8
|
+
let vestingLocked = api.registry.createType('Balance');
|
|
9
|
+
let allLocked = false;
|
|
10
|
+
if (Array.isArray(locks)) {
|
|
11
|
+
// only get the locks that are valid until passed the current block
|
|
12
|
+
lockedBreakdown = locks.filter(({ until }) => !until || (bestNumber && until.gt(bestNumber)));
|
|
13
|
+
allLocked = lockedBreakdown.some(({ amount }) => amount && amount.isMax());
|
|
14
|
+
vestingLocked = api.registry.createType('Balance', lockedBreakdown.filter(({ id }) => id.eq(VESTING_ID)).reduce((result, { amount }) => result.iadd(amount), new BN(0)));
|
|
15
|
+
// get the maximum of the locks according to https://github.com/pezkuwichain/bizinikiwi/blob/master/srml/balances/src/lib.rs#L699
|
|
16
|
+
const notAll = lockedBreakdown.filter(({ amount }) => amount && !amount.isMax());
|
|
17
|
+
if (notAll.length) {
|
|
18
|
+
lockedBalance = api.registry.createType('Balance', bnMax(...notAll.map(({ amount }) => amount)));
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
return { allLocked, lockedBalance, lockedBreakdown, vestingLocked };
|
|
22
|
+
}
|
|
23
|
+
function calcShared(api, bestNumber, data, locks) {
|
|
24
|
+
const { allLocked, lockedBalance, lockedBreakdown, vestingLocked } = calcLocked(api, bestNumber, locks);
|
|
25
|
+
let transferable = null;
|
|
26
|
+
if (data?.frameSystemAccountInfo?.frozen) {
|
|
27
|
+
const { frameSystemAccountInfo, freeBalance, reservedBalance } = data;
|
|
28
|
+
const noFrozenReserved = frameSystemAccountInfo.frozen.isZero() && reservedBalance.isZero();
|
|
29
|
+
const ED = api.consts.balances.existentialDeposit;
|
|
30
|
+
const maybeED = noFrozenReserved ? new BN(0) : ED;
|
|
31
|
+
const frozenReserveDif = frameSystemAccountInfo.frozen.sub(reservedBalance);
|
|
32
|
+
transferable = api.registry.createType('Balance', allLocked
|
|
33
|
+
? 0
|
|
34
|
+
: bnMax(new BN(0), freeBalance.sub(bnMax(maybeED, frozenReserveDif))));
|
|
35
|
+
}
|
|
36
|
+
return objectSpread({}, data, {
|
|
37
|
+
availableBalance: api.registry.createType('Balance', allLocked ? 0 : bnMax(new BN(0), data?.freeBalance ? data.freeBalance.sub(lockedBalance) : new BN(0))),
|
|
38
|
+
lockedBalance,
|
|
39
|
+
lockedBreakdown,
|
|
40
|
+
transferable,
|
|
41
|
+
vestingLocked
|
|
42
|
+
});
|
|
43
|
+
}
|
|
44
|
+
function calcVesting(bestNumber, shared, _vesting) {
|
|
45
|
+
// Calculate the vesting balances,
|
|
46
|
+
// - offset = balance locked at startingBlock
|
|
47
|
+
// - perBlock is the unlock amount
|
|
48
|
+
const vesting = _vesting || [];
|
|
49
|
+
const isVesting = !shared.vestingLocked.isZero();
|
|
50
|
+
const vestedBalances = vesting.map(({ locked, perBlock, startingBlock }) => bestNumber.gt(startingBlock)
|
|
51
|
+
? bnMin(locked, perBlock.mul(bestNumber.sub(startingBlock)))
|
|
52
|
+
: BN_ZERO);
|
|
53
|
+
const vestedBalance = vestedBalances.reduce((all, value) => all.iadd(value), new BN(0));
|
|
54
|
+
const vestingTotal = vesting.reduce((all, { locked }) => all.iadd(locked), new BN(0));
|
|
55
|
+
return {
|
|
56
|
+
isVesting,
|
|
57
|
+
vestedBalance,
|
|
58
|
+
vestedClaimable: isVesting
|
|
59
|
+
? shared.vestingLocked.sub(vestingTotal.sub(vestedBalance))
|
|
60
|
+
: BN_ZERO,
|
|
61
|
+
vesting: vesting
|
|
62
|
+
.map(({ locked, perBlock, startingBlock }, index) => ({
|
|
63
|
+
endBlock: locked.div(perBlock).iadd(startingBlock),
|
|
64
|
+
locked,
|
|
65
|
+
perBlock,
|
|
66
|
+
startingBlock,
|
|
67
|
+
vested: vestedBalances[index]
|
|
68
|
+
}))
|
|
69
|
+
.filter(({ locked }) => !locked.isZero()),
|
|
70
|
+
vestingTotal
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
function calcBalances(api, result) {
|
|
74
|
+
const [data, [vesting, allLocks, namedReserves], bestNumber] = result;
|
|
75
|
+
const shared = calcShared(api, bestNumber, data, allLocks[0]);
|
|
76
|
+
return objectSpread(shared, calcVesting(bestNumber, shared, vesting), {
|
|
77
|
+
accountId: data.accountId,
|
|
78
|
+
accountNonce: data.accountNonce,
|
|
79
|
+
additional: allLocks
|
|
80
|
+
.slice(1)
|
|
81
|
+
.map((l, index) => calcShared(api, bestNumber, data.additional[index], l)),
|
|
82
|
+
namedReserves
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
function queryOld(api, accountId) {
|
|
86
|
+
return combineLatest([
|
|
87
|
+
api.query.balances.locks(accountId),
|
|
88
|
+
api.query.balances['vesting'](accountId)
|
|
89
|
+
]).pipe(map(([locks, optVesting]) => {
|
|
90
|
+
let vestingNew = null;
|
|
91
|
+
if (optVesting.isSome) {
|
|
92
|
+
const { offset: locked, perBlock, startingBlock } = optVesting.unwrap();
|
|
93
|
+
vestingNew = api.registry.createType('VestingInfo', { locked, perBlock, startingBlock });
|
|
94
|
+
}
|
|
95
|
+
return [
|
|
96
|
+
vestingNew
|
|
97
|
+
? [vestingNew]
|
|
98
|
+
: null,
|
|
99
|
+
[locks],
|
|
100
|
+
[]
|
|
101
|
+
];
|
|
102
|
+
}));
|
|
103
|
+
}
|
|
104
|
+
const isNonNullable = (nullable) => !!nullable;
|
|
105
|
+
function createCalls(calls) {
|
|
106
|
+
return [
|
|
107
|
+
calls.map((c) => !c),
|
|
108
|
+
calls.filter(isNonNullable)
|
|
109
|
+
];
|
|
110
|
+
}
|
|
111
|
+
function queryCurrent(api, accountId, balanceInstances = ['balances']) {
|
|
112
|
+
const [lockEmpty, lockQueries] = createCalls(balanceInstances.map((m) => api.derive[m]?.customLocks || api.query[m]?.locks));
|
|
113
|
+
const [reserveEmpty, reserveQueries] = createCalls(balanceInstances.map((m) => api.query[m]?.reserves));
|
|
114
|
+
return combineLatest([
|
|
115
|
+
api.query.vesting?.vesting
|
|
116
|
+
? api.query.vesting.vesting(accountId)
|
|
117
|
+
: of(api.registry.createType('Option<VestingInfo>')),
|
|
118
|
+
lockQueries.length
|
|
119
|
+
? combineLatest(lockQueries.map((c) => c(accountId)))
|
|
120
|
+
: of([]),
|
|
121
|
+
reserveQueries.length
|
|
122
|
+
? combineLatest(reserveQueries.map((c) => c(accountId)))
|
|
123
|
+
: of([])
|
|
124
|
+
]).pipe(map(([opt, locks, reserves]) => {
|
|
125
|
+
let offsetLock = -1;
|
|
126
|
+
let offsetReserve = -1;
|
|
127
|
+
const vesting = opt.unwrapOr(null);
|
|
128
|
+
return [
|
|
129
|
+
vesting
|
|
130
|
+
? Array.isArray(vesting)
|
|
131
|
+
? vesting
|
|
132
|
+
: [vesting]
|
|
133
|
+
: null,
|
|
134
|
+
lockEmpty.map((e) => e ? api.registry.createType('Vec<BalanceLock>') : locks[++offsetLock]),
|
|
135
|
+
reserveEmpty.map((e) => e ? api.registry.createType('Vec<PezpalletBalancesReserveData>') : reserves[++offsetReserve])
|
|
136
|
+
];
|
|
137
|
+
}));
|
|
138
|
+
}
|
|
139
|
+
/**
|
|
140
|
+
* @name all
|
|
141
|
+
* @description Retrieves the complete balance information for an account, including free balance, locked balance, reserved balance, and more.
|
|
142
|
+
* @param {( AccountId | string )} address An accountsId in different formats.
|
|
143
|
+
* @example
|
|
144
|
+
* ```javascript
|
|
145
|
+
* const ALICE = 'F7Hs';
|
|
146
|
+
*
|
|
147
|
+
* api.derive.balances.account(ALICE, (accountInfo) => {
|
|
148
|
+
* console.log(
|
|
149
|
+
* `${accountInfo.accountId} info:`,
|
|
150
|
+
* Object.keys(accountInfo).map((key) => `${key}: ${accountInfo[key]}`)
|
|
151
|
+
* );
|
|
152
|
+
* });
|
|
153
|
+
* ```
|
|
154
|
+
*/
|
|
155
|
+
export function all(instanceId, api) {
|
|
156
|
+
const balanceInstances = api.registry.getModuleInstances(api.runtimeVersion.specName, 'balances');
|
|
157
|
+
return memo(instanceId, (address) => combineLatest([
|
|
158
|
+
api.derive.balances.account(address),
|
|
159
|
+
isFunction(api.query.system?.account) || isFunction(api.query.balances?.account)
|
|
160
|
+
? queryCurrent(api, address, balanceInstances)
|
|
161
|
+
: queryOld(api, address)
|
|
162
|
+
]).pipe(switchMap(([account, locks]) => combineLatest([
|
|
163
|
+
of(account),
|
|
164
|
+
of(locks),
|
|
165
|
+
api.derive.chain.bestNumber()
|
|
166
|
+
])), map((result) => calcBalances(api, result))));
|
|
167
|
+
}
|
|
@@ -1,11 +1,6 @@
|
|
|
1
|
-
// Copyright 2017-2025 @polkadot/api-derive authors & contributors
|
|
2
|
-
// SPDX-License-Identifier: Apache-2.0
|
|
3
|
-
|
|
4
1
|
import { all } from './all.js';
|
|
5
|
-
|
|
6
2
|
export * from './account.js';
|
|
7
3
|
export * from './votingBalances.js';
|
|
8
|
-
|
|
9
4
|
/**
|
|
10
5
|
* @name votingBalance
|
|
11
6
|
* @param {( AccountId | string )} address An accounts Id in different formats.
|
|
@@ -22,5 +17,4 @@ export * from './votingBalances.js';
|
|
|
22
17
|
* ```
|
|
23
18
|
*/
|
|
24
19
|
const votingBalance = all;
|
|
25
|
-
|
|
26
20
|
export { all, votingBalance };
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import type { AccountId, Balance, BalanceLockTo212, Index } from '@pezkuwi/types/interfaces';
|
|
2
|
-
import type {
|
|
2
|
+
import type { PezpalletBalancesBalanceLock, PezpalletBalancesReserveData } from '@pezkuwi/types/lookup';
|
|
3
3
|
import type { BN } from '@pezkuwi/util';
|
|
4
4
|
export interface DeriveBalancesAccountData {
|
|
5
5
|
frameSystemAccountInfo?: {
|
|
@@ -20,10 +20,10 @@ export interface DeriveBalancesAccount extends DeriveBalancesAccountData {
|
|
|
20
20
|
export interface DeriveBalancesAllAccountData extends DeriveBalancesAccountData {
|
|
21
21
|
/**
|
|
22
22
|
* Calculated available balance. This uses the formula: max(0, free - locked)
|
|
23
|
-
* This is only correct when the return type of `api.query.system.account` is `AccountInfo` which was replaced by `
|
|
23
|
+
* This is only correct when the return type of `api.query.system.account` is `AccountInfo` which was replaced by `PezframeSystemAccountInfo`.
|
|
24
24
|
* See `transferable` for the correct balance calculation.
|
|
25
25
|
*
|
|
26
|
-
* ref: https://github.com/
|
|
26
|
+
* ref: https://github.com/pezkuwichain/bizinikiwi/pull/12951
|
|
27
27
|
*/
|
|
28
28
|
availableBalance: Balance;
|
|
29
29
|
/**
|
|
@@ -33,14 +33,14 @@ export interface DeriveBalancesAllAccountData extends DeriveBalancesAccountData
|
|
|
33
33
|
/**
|
|
34
34
|
* The breakdown of locked balances.
|
|
35
35
|
*/
|
|
36
|
-
lockedBreakdown: (
|
|
36
|
+
lockedBreakdown: (PezpalletBalancesBalanceLock | BalanceLockTo212)[];
|
|
37
37
|
/**
|
|
38
38
|
* Calculated transferable balance. This uses the formula: free - max(maybeEd, frozen - reserve)
|
|
39
39
|
* Where `maybeEd` means if there is no frozen and reserves it will be zero, else it will be the existential deposit.
|
|
40
|
-
* This is only correct when the return type of `api.query.system.account` is `
|
|
40
|
+
* This is only correct when the return type of `api.query.system.account` is `PezframeSystemAccountInfo`.
|
|
41
41
|
* Which is the most up to date calulcation for transferrable balances.
|
|
42
42
|
*
|
|
43
|
-
* ref: https://github.com/
|
|
43
|
+
* ref: https://github.com/pezkuwichain/pezkuwi-sdk/issues/1833
|
|
44
44
|
*/
|
|
45
45
|
transferable: Balance | null;
|
|
46
46
|
/**
|
|
@@ -64,6 +64,6 @@ export interface DeriveBalancesAllVesting {
|
|
|
64
64
|
}
|
|
65
65
|
export interface DeriveBalancesAll extends DeriveBalancesAccount, DeriveBalancesAllAccountData, DeriveBalancesAllVesting {
|
|
66
66
|
additional: DeriveBalancesAllAccountData[];
|
|
67
|
-
namedReserves:
|
|
67
|
+
namedReserves: PezpalletBalancesReserveData[][];
|
|
68
68
|
}
|
|
69
69
|
export type DeriveBalancesMap = Record<string, DeriveBalancesAll>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { combineLatest, of } from 'rxjs';
|
|
2
|
+
import { memo } from '../util/index.js';
|
|
3
|
+
/**
|
|
4
|
+
* @name votingBalances
|
|
5
|
+
* @description Retrieves the balance information for multiple accounts, typically used in governance-related contexts to check voting power.
|
|
6
|
+
* @param {(AccountId | AccountIndex | Address | string)[]} addresses An array of account identifiers.
|
|
7
|
+
* @example
|
|
8
|
+
* ```javascript
|
|
9
|
+
* const addresses = ["5D4b...Zf1", "5HGj...yrV"];
|
|
10
|
+
* const balances = await api.derive.balances.votingBalances(addresses);
|
|
11
|
+
* console.log("Voting Balances:", balances);
|
|
12
|
+
* ```
|
|
13
|
+
*/
|
|
14
|
+
export function votingBalances(instanceId, api) {
|
|
15
|
+
return memo(instanceId, (addresses) => !addresses?.length
|
|
16
|
+
? of([])
|
|
17
|
+
: combineLatest(addresses.map((accountId) => api.derive.balances.account(accountId))));
|
|
18
|
+
}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { combineLatest, map, of, switchMap } from 'rxjs';
|
|
2
|
+
import { memo } from '../util/index.js';
|
|
3
|
+
import { filterBountiesProposals } from './helpers/filterBountyProposals.js';
|
|
4
|
+
function parseResult([maybeBounties, maybeDescriptions, ids, bountyProposals]) {
|
|
5
|
+
const bounties = [];
|
|
6
|
+
maybeBounties.forEach((bounty, index) => {
|
|
7
|
+
if (bounty.isSome) {
|
|
8
|
+
bounties.push({
|
|
9
|
+
bounty: bounty.unwrap(),
|
|
10
|
+
description: maybeDescriptions[index].unwrapOrDefault().toUtf8(),
|
|
11
|
+
index: ids[index],
|
|
12
|
+
proposals: bountyProposals.filter((bountyProposal) => bountyProposal.proposal && ids[index].eq(bountyProposal.proposal.args[0]))
|
|
13
|
+
});
|
|
14
|
+
}
|
|
15
|
+
});
|
|
16
|
+
return bounties;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* @name bounties
|
|
20
|
+
* @descrive Retrieves all active bounties, their descriptions, and associated proposals.
|
|
21
|
+
* @example
|
|
22
|
+
* ```javascript
|
|
23
|
+
* const bounties = await api.derive.bounties();
|
|
24
|
+
* console.log("Active bounties:", bounties);
|
|
25
|
+
* ```
|
|
26
|
+
*/
|
|
27
|
+
export function bounties(instanceId, api) {
|
|
28
|
+
const bountyBase = api.query.bounties || api.query.treasury;
|
|
29
|
+
return memo(instanceId, () => bountyBase.bounties
|
|
30
|
+
? combineLatest([
|
|
31
|
+
bountyBase.bountyCount(),
|
|
32
|
+
api.query.council
|
|
33
|
+
? api.query.council.proposalCount()
|
|
34
|
+
: of(0)
|
|
35
|
+
]).pipe(switchMap(() => combineLatest([
|
|
36
|
+
bountyBase.bounties.keys(),
|
|
37
|
+
api.derive.council
|
|
38
|
+
? api.derive.council.proposals()
|
|
39
|
+
: of([])
|
|
40
|
+
])), switchMap(([keys, proposals]) => {
|
|
41
|
+
const ids = keys.map(({ args: [id] }) => id);
|
|
42
|
+
return combineLatest([
|
|
43
|
+
bountyBase.bounties.multi(ids),
|
|
44
|
+
bountyBase.bountyDescriptions.multi(ids),
|
|
45
|
+
of(ids),
|
|
46
|
+
of(filterBountiesProposals(api, proposals))
|
|
47
|
+
]);
|
|
48
|
+
}), map(parseResult))
|
|
49
|
+
: of(parseResult([[], [], [], []])));
|
|
50
|
+
}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export function filterBountiesProposals(api, allProposals) {
|
|
2
|
+
const bountyTxBase = api.tx.bounties ? api.tx.bounties : api.tx.treasury;
|
|
3
|
+
const bountyProposalCalls = [bountyTxBase.approveBounty, bountyTxBase.closeBounty, bountyTxBase.proposeCurator, bountyTxBase.unassignCurator];
|
|
4
|
+
return allProposals.filter((proposal) => bountyProposalCalls.find((bountyCall) => proposal.proposal && bountyCall.is(proposal.proposal)));
|
|
5
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './bounties.js';
|