From b88e38626c94fff0e7c29f08247c9ed0a3aa4410 Mon Sep 17 00:00:00 2001 From: David Dal Busco Date: Mon, 6 Nov 2023 06:52:26 +0100 Subject: [PATCH 1/3] docs: update outdated nns-js README --- packages/nns/README.md | 36 ++++++++++++------------------------ 1 file changed, 12 insertions(+), 24 deletions(-) diff --git a/packages/nns/README.md b/packages/nns/README.md index 7f2400981..334777674 100644 --- a/packages/nns/README.md +++ b/packages/nns/README.md @@ -9,13 +9,6 @@ A library for interfacing with the Internet Computer's Network Nervous System. - [Installation](#installation) - [Usage](#usage) - [Features](#features) - - [AccountIdentifier](#factory-accountidentifier) - - [SubAccount](#factory-subaccount) - - [GenesisTokenCanister](#factory-genesistokencanister) - - [ICP](#factory-icp) - - [LedgerCanister](#factory-ledgercanister) - - [GovernanceCanister](#factory-governancecanister) - - [SnsWasmCanister](#factory-snswasmcanister) ## Installation @@ -33,28 +26,23 @@ npm i @dfinity/agent @dfinity/candid @dfinity/principal @dfinity/utils @dfinity/ ## Usage -Most features are provided through the use of classes. e.g. querying the `ledger` for an account balance in a NodeJS context can be developed as following: +Most features are provided through the use of classes. For example, querying the list of neurons controlled by the caller with the `governance` canister: ```ts -import { AccountIdentifier, LedgerCanister } from "@dfinity/nns"; +import { GovernanceCanister } from "@dfinity/ledger-icrc"; +import { createAgent } from "@dfinity/utils"; -// If not running in browser, add polyfill of `window.fetch` for agent-js to work. -import fetch from "cross-fetch"; -global.fetch = fetch; +const agent = await createAgent({ + identity, + host: HOST, +}); -const main = async () => { - const ledger = LedgerCanister.create(); +const { listNeurons } = GovernanceCanister.create({ + agent, + canisterId: MY_GOVERNANCE_CANISTER_ID, +}); - const accountIdentifier = AccountIdentifier.fromHex( - "efa01544f509c56dd85449edf2381244a48fad1ede5183836229c00ab00d52df", - ); - - const balance = await ledger.accountBalance({ accountIdentifier }); - - console.log(`Balance: ${balance}`); -}; - -await main(); +const myNeurons = await listNeurons(); ``` ## Features From e294b0237b54c4e815f567823cc8d3d8fd425bf1 Mon Sep 17 00:00:00 2001 From: David Dal Busco Date: Mon, 6 Nov 2023 06:53:51 +0100 Subject: [PATCH 2/3] docs: update snippet --- packages/nns/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/nns/README.md b/packages/nns/README.md index 334777674..1763fc3bc 100644 --- a/packages/nns/README.md +++ b/packages/nns/README.md @@ -42,7 +42,7 @@ const { listNeurons } = GovernanceCanister.create({ canisterId: MY_GOVERNANCE_CANISTER_ID, }); -const myNeurons = await listNeurons(); +const myNeurons = await listNeurons({ certified: false }); ``` ## Features From e514892dd32a89217157446c64cdba5069b761ef Mon Sep 17 00:00:00 2001 From: David Dal Busco Date: Mon, 6 Nov 2023 09:28:35 +0100 Subject: [PATCH 3/3] docs: fix import in snippet --- packages/nns/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/nns/README.md b/packages/nns/README.md index 1763fc3bc..26e7fd752 100644 --- a/packages/nns/README.md +++ b/packages/nns/README.md @@ -29,7 +29,7 @@ npm i @dfinity/agent @dfinity/candid @dfinity/principal @dfinity/utils @dfinity/ Most features are provided through the use of classes. For example, querying the list of neurons controlled by the caller with the `governance` canister: ```ts -import { GovernanceCanister } from "@dfinity/ledger-icrc"; +import { GovernanceCanister } from "@dfinity/nns"; import { createAgent } from "@dfinity/utils"; const agent = await createAgent({