mirror of
https://github.com/pezkuwichain/pezkuwi-apps.git
synced 2026-06-19 22:51:06 +00:00
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:
@@ -0,0 +1,165 @@
|
||||
// Copyright 2017-2025 @pezkuwi/app-js authors & contributors
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
import type { StrictLabelProps } from 'semantic-ui-react';
|
||||
import type { Snippet } from '../types.js';
|
||||
|
||||
const label: StrictLabelProps = {
|
||||
children: 'Storage',
|
||||
color: 'blue',
|
||||
size: 'tiny'
|
||||
};
|
||||
|
||||
export const storageGetInfo: Snippet = {
|
||||
code: `// Get chain state information
|
||||
// Make our basic chain state / storage queries, all in one go
|
||||
|
||||
const [now, minimumValidatorCount, validators] = await Promise.all([
|
||||
api.query.timestamp.now(),
|
||||
api.query.staking.minimumValidatorCount(),
|
||||
api.query.session.validators()
|
||||
]);
|
||||
|
||||
console.log('The current date is: ' + now);
|
||||
console.log('The minimum validator count: ' + minimumValidatorCount);
|
||||
|
||||
if (validators && validators.length > 0) {
|
||||
// Retrieve the balances for all validators
|
||||
console.log('Validators');
|
||||
|
||||
const validatorBalances = await Promise.all(
|
||||
validators.map((authorityId) => api.query.system.account(authorityId))
|
||||
);
|
||||
|
||||
validators.forEach((authorityId, index) => {
|
||||
console.log('Validator: ' + authorityId.toString() )
|
||||
console.log('AccountData: ' + validatorBalances[index].toHuman() );
|
||||
});
|
||||
}
|
||||
`,
|
||||
label,
|
||||
text: 'Get chain state information',
|
||||
value: 'storageGetInfo'
|
||||
};
|
||||
|
||||
export const storageSystemEvents: Snippet = {
|
||||
code: `// Subscribe to system events via storage
|
||||
api.query.system.events((events) => {
|
||||
console.log('----- Received ' + events.length + ' event(s): -----');
|
||||
// loop through the Vec<EventRecord>
|
||||
events.forEach((record) => {
|
||||
// extract the phase, event and the event types
|
||||
const { event, phase } = record;
|
||||
const types = event.typeDef;
|
||||
// show what we are busy with
|
||||
console.log(event.section + ':' + event.method + '::' + 'phase=' + phase.toString());
|
||||
console.log(event.meta.docs.toString());
|
||||
// loop through each of the parameters, displaying the type and data
|
||||
event.data.forEach((data, index) => {
|
||||
console.log(types[index].type + ';' + data.toString());
|
||||
});
|
||||
});
|
||||
});`,
|
||||
label,
|
||||
text: 'Listen to system events',
|
||||
value: 'storageSystemEvents'
|
||||
};
|
||||
|
||||
export const storageListenToBalanceChange: Snippet = {
|
||||
code: `// You may leave this example running and make a transfer
|
||||
// of any value from or to Alice address in the 'Transfer' App
|
||||
const ALICE = '5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY';
|
||||
|
||||
// Retrieve the initial data
|
||||
let [, { free: previous }] = await api.query.system.account(ALICE);
|
||||
|
||||
console.log('ALICE has a balance of ' + previous);
|
||||
|
||||
// Subscribe and listen to balance changes
|
||||
api.query.system.account(ALICE, ([, { free }]) => {
|
||||
// Calculate the delta
|
||||
const change = free.sub(previous);
|
||||
// Only display positive value changes (Since we are pulling 'previous' above already,
|
||||
// the initial balance change will also be zero)
|
||||
if (!change.isZero()) {
|
||||
previous = free;
|
||||
console.log('New transaction of: '+ change);
|
||||
}
|
||||
});`,
|
||||
label,
|
||||
text: 'Listen to balance changes',
|
||||
value: 'storageListenToBalanceChange'
|
||||
};
|
||||
|
||||
export const storageListenToMultipleBalancesChange: Snippet = {
|
||||
code: `// You may leave this example running and make a transfer
|
||||
// of any value from or to Alice/Bob address in the 'Transfer' App
|
||||
const ALICE = '5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY';
|
||||
const BOB = '5FHneW46xGXgs5mUiveU4sbTyGBzmstUspZC92UhjJM694ty';
|
||||
|
||||
console.log('Tracking balances for:', [ALICE, BOB])
|
||||
|
||||
// Subscribe and listen to several balance changes
|
||||
api.query.system.account.multi([ALICE, BOB], (info) => {
|
||||
console.log('Change detected, new balances: ', info)
|
||||
});`,
|
||||
label,
|
||||
text: 'Listen to multiple balances changes',
|
||||
value: 'storageListenToMultipleBalancesChange'
|
||||
};
|
||||
|
||||
export const storageRetrieveInfoOnQueryKeys: Snippet = {
|
||||
code: `// This example set shows how to make queries at a point
|
||||
const ALICE = '5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY';
|
||||
|
||||
// retrieve the balance, once-off at the latest block
|
||||
const { data: { free } } = await api.query.system.account(ALICE);
|
||||
|
||||
console.log('Alice has a current balance of', free.toHuman());
|
||||
|
||||
// retrieve balance updates with an optional value callback
|
||||
const balanceUnsub = await api.query.system.account(ALICE, ({ data: { free } }) => {
|
||||
console.log('Alice has an updated balance of', free.toHuman());
|
||||
});
|
||||
|
||||
// retrieve the balance at a block hash in the past
|
||||
const header = await api.rpc.chain.getHeader();
|
||||
const prevHash = await api.rpc.chain.getBlockHash(header.number.unwrap().subn(42));
|
||||
const { data: { free: prev } } = await api.query.system.account.at(prevHash, ALICE);
|
||||
|
||||
console.log('Alice had a balance of', prev.toHuman(), '(42 blocks ago)');
|
||||
|
||||
// useful in some situations - the value hash and storage entry size
|
||||
const currHash = await api.query.system.account.hash(ALICE);
|
||||
const currSize = await api.query.system.account.size(ALICE);
|
||||
|
||||
console.log('Alice account entry has a value hash of', currHash, 'with a size of', currSize);`,
|
||||
label,
|
||||
text: 'Retrieve historic query data',
|
||||
value: 'storageRetrieveInfoOnQueryKeys'
|
||||
};
|
||||
|
||||
export const storageKeys: Snippet = {
|
||||
code: `// this example shows how to retrieve the hex representation of a storage key
|
||||
|
||||
const ALICE = '5GrwvaEF5zXb26Fz9rcQpDWS57CtERHpNehXCPcNoHGKutQY';
|
||||
|
||||
// show the key for an entry without arguments
|
||||
console.log(api.query.timestamp.now.key());
|
||||
|
||||
// show the key for a map entry (single argument)
|
||||
console.log(api.query.system.account.key(ALICE));
|
||||
|
||||
// show the key prefix for a map
|
||||
console.log(api.query.system.account.keyPrefix());
|
||||
|
||||
// show the key for a double map
|
||||
console.log(api.query.staking.erasStakers.key(0, ALICE));
|
||||
|
||||
// show the key prefix for a doublemap
|
||||
console.log(api.query.staking.erasStakers.keyPrefix());
|
||||
`,
|
||||
label,
|
||||
text: 'Get underlying storage key hex values',
|
||||
value: 'storageKeys'
|
||||
};
|
||||
Reference in New Issue
Block a user