This document list a couple of useful information to develop the NNS-dapp frontend.
NNS-dapp frontend uses an .env
file to read various environment information and variables.
The repo itself does not contain any such file because the source of truth we are using is dfx.json
.
That is why we are providing a ./config.sh
script that generate the above environment file automatically.
To run the dapp against canisters deployed locally on a simulated IC network, use the steps below:
- Run
scripts/setup
to install necessary tools. - Clone the snsdemo repository. We'll use it to set up the test environment.
- In the
snsdemo
repo, run:bin/dfx-sns-demo-install
(to install necessary tools)bin/dfx-snapshot-stock-make --snapshot $HOME/my-snapshot.tar.xz
(to create a snapshot with a test environment)
- Go back to the
nns-dapp
repo - Run
scripts/dfx-snapshot-start --snapshot $HOME/my-snapshot.tar.xz
(this will keep running so switch to another terminal window) - Run
DFX_NETWORK=local ./config.sh
to populate the./frontend/.env
file. - In the
./frontend/
folder, first runnpm ci
and thennpm run dev
to serve the application.
With this setup, you can work on the frontend code without building the
nns-dapp canister. If you want to change the back-end code, you can deploy it
with dfx deploy nns-dapp
and it replace the provided canister.
Once you have a running replica with NNS installed and a fixed
./frontend/.env
file, don't have to take all the steps every time.
The canister_ids.json
data provides the list of canister IDs available for various test environments.
To run a production like environment locally against a replica run:
DFX_NETWORK=<replica-network> ../config.sh
npm run build
npm run preview
To develop and run locally the dapp against a testnet, proceed as following:
- Copy the
canister_ids.json
to the root of your local project - Run
DFX_NETWORK=<testnet_name> ./config.sh
to populate the.env
file - Start
npm run dev
in the./frontend/
folder to serve the application
e.g. replace <testnet_name>
with small11
The dfx
version installed locally should match the one defined in dfx.json
. If not, you will have to either upgrade or manually change the version in the local file. In such case, please do not commit the change!
It's essential to keep our dependencies up-to-date to benefit from the latest features, bug fixes, and security patches.
In this guide, we will walk you through the process of checking for newer dependencies and updating them for your frontend dapp using the npm-check-updates tool.
- Install
npm-check-updates
:
First, make sure you have Node.js and npm (Node Package Manager) installed on your system. If not, you can download and install them from the official Node.js website .
To install the npm-check-updates
tool, open your terminal and run the following command:
npm install -g npm-check-updates
- Navigate to the Frontend Folder:
Navigate to the folder where the frontend dapp is located.
cd frontend
- Check for Newer Dependencies:
Identify the available newer versions of the dependencies. Run the following command in your terminal:
ncu -u
This command will provide you with a list of available updates and automatically update the package.json
file with the newer versions.
- Review and Modify
package.json
:
Open the package.json
file in a text editor. Review the changes made by the tool and consider whether you want to update all the libraries or selectively update specific ones.
If there are dependencies you do not want to update at this point, you can manually revert the changes in the file by reverting the corresponding lines.
- Install Newer Dependencies:
To effectively install the updated dependencies, execute the following command in your terminal:
npm i
This command will install the newer versions of the dependencies and update the package-lock.json
file accordingly.
- Thoroughly Test The Dapp:
After the installation is complete, it's crucial to thoroughly test the frontend dapp. Ensure that all the functionalities are working as expected and there are no compatibility issues with the updated dependencies.
- Create a Pull Request (PR):
If everything looks good and the frontend dapp is functioning correctly with the updated dependencies, it's time to create a pull request. Include the modified package.json
and package-lock.json
files in a new PR to let others review and merge the changes.
Last update: 2023, May 1
ckBTC deployment and development in NNS-dapp are in progress.
To deploy a local Bitcoin network, the documentation on the IC website can be followed.
As ckBTC is not yet implemented in our pipeline, enabling it in dfx.json
has not yet be done neither - i.e. it needs to be manually configured for testing / development purpose:
Add following in defaults
of dfx.json
.
"bitcoin": {
"enabled": true,
"nodes": [
"127.0.0.1:18444"
]
}
Deploying ckBTC ledger, index and minter are as well not yet automated.
Their Wasm and candid file can be downloaded with a script which finds place in ./scripts/ckbtc/download-ckbtc
.
./scripts/ckbtc/download-ckbtc
To deploy the canisters locally, a script is provided in ./scripts/ckbtc/deploy-ckbtc
as well.
However, it requires first to manually edit dfx.json
.
e.g. in canisters
:
"ckbtc_minter": {
"type": "custom",
"candid": "target/ic/ckbtc_minter.did",
"wasm": "target/ic/ckbtc_minter.wasm"
},
"ckbtc_ledger": {
"type": "custom",
"candid": "target/ic/ckbtc_ledger.did",
"wasm": "target/ic/ckbtc_ledger.wasm"
},
"ckbtc_index": {
"type": "custom",
"candid": "target/ic/ckbtc_index.did",
"wasm": "target/ic/ckbtc_index.wasm"
},
"ckbtc_kyt": {
"type": "custom",
"candid": "target/ic/ckbtc_kyt.did",
"wasm": "target/ic/ckbtc_kyt.wasm"
},
Once set, the script can be executed.
Note: when the script is run, the network should be provided
DFX_NETWORK=local ./scripts/ckbtc/deploy-ckbtc
After deployment, their respective IDs shall be collected and updated in ckbtc-canister-ids.constants.ts
.
Likewise, as the configuration is not yet automated, there are no .env
variable that are yet generated.
Because the e2e tests are using the local
environment to perform, we cannot enable ENABLE_CKTESTBTC
per default.
Therefore, this flag should also be manually set to true
in dfx.json
and the .env
should be generated.
Use scripts/nns-dapp/test-config --update
to update arg.did
and env
files under nns-dapp/test-config-assets
To mint bitcoin you should set up a local bitcoin network as display in the documentation.
Once ready, 100 block can be minted to an address. The address can be found in the "ckBTC Receive modal".
Example of command:
./bin/bitcoin-cli -conf=$(pwd)/bitcoin.conf generatetoaddress 100 "bcrt1q286kjxmad4zmhex2dqus4t6u53z49y3shns028"
Once block minted, the minter should be unblocked to attribute reward. This can be done by minting more blocks to another address.
e.g.
./bin/bitcoin-cli -conf=$(pwd)/bitcoin.conf createwallet "test"
./bin/bitcoin-cli -conf=$(pwd)/bitcoin.conf getnewaddress
./bin/bitcoin-cli -conf=$(pwd)/bitcoin.conf generatetoaddress 100 "bcrt1qtq30nuztv40nkncckn70n09tlype96snkxzhmt"
From time to time you will have a task that requires changes on gix-components. For those tasks you can follow the steps below to link gix-components to nns-dapp so you can test your changes faster.
- Run
npm run package -- --watch
from gix-components, this will also watch for changes and rebuild the package - Run
npm link <gix-component-path>
from nns-dapp/frontend to link the gix-components package - Run
npx nodemon --delay 2 --watch ../../gix-components/dist --ext js,ts,svelte --exec 'npm run dev''
from nns-dapp/frontend to watch for changes and rebuild nns-dapp - Accept installation of nodemon when prompted by npm
Need to install the following packages:
nodemon@3.1.4
Ok to proceed? (y)
- Make your changes and test. You will see that nns-dapp restarts due to changes in gix-components. Althought there is a delay of 2 seconds to wait for all the changes to be complete you might see multiple lines of
[nodemon] restarting due to changes...
, that is okay.
[nodemon] restarting due to changes...
[nodemon] starting `npm run dev`
- Once you are done run
npm unlink gix-components
from nns-dapp/frontend to unlink the gix-components package
The steps above are specifically for gix-components, but the process is the same for other local packages that nns-dapp depends on.