vega-frontend-monorepo/apps/explorer
Dexter Edwards bcaab22891
Feat/dockerize frontends (#388)
* feat: unhardcode contract addresses

* fix: linting and tests

* feat: switch contract usage in token app to use unhardcoded addresses

* chore: remove other usage of hard coded contract addresses

* feat: convert contracts to classes, update claim contract to fix circular dependency

* feat: add hard coded contract addresses to contracts page

* fix: misc tidy up

* chore: rename ethers big num conversion func

* fix: remove pending transactions modal

* chore: add single toBigNum function that can accept number string or EthersBignNumber

* chore: delete unused tranche helpers and decimals functions from smart contracts lib

* feat: add faucetable token class

* fix: reset tx state after early exit from approve tx

* feat: re add transaction modal using zustand store

* fix: loader colors for eth wallet

* fix: pass ethereum config to gurantee existence before tx execution

* add docker image for building explorer

* add arg

* env file changes

* add docker file to build env file

* add requirement for env file in explorer

* fix env file syntax

* containers functional

* default to testnet

* make env flag logic consistent in all places

* pre populate env file

* ensure working for all projects

* address PR comment

* generalising env for token

* invert config dependency from ui toolkit

* fix: merge issues

* docs: running containers documentation

* style: lint

* fix: env varibales not being added properly

* chore: fix merge issues

* chore: fix docker file to support new exectutors

* chore: set address on all contracts as a property

* feat: pull token from contract rather than relying on env var

* chore: fix typing

* chore: remove duplicated prop

* chore: don't use chainId

* style: lint

* style: lint

* Merge branch 'master' into feat/dockerize-frontends

* Merge remote-tracking branch 'origin/master' into feat/dockerize-frontends

* test: revert changes to explorer e2e file

* fix: creating client without base causing token to error

* test: fix tests erroring in before hook due to file not being found

* chore: remove node env from configurable flags

Co-authored-by: Matthew Russell <mattrussell36@gmail.com>
2022-06-13 15:39:17 +01:00
..
src Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
.babelrc migrate stuff into new NX 2022-02-23 08:53:57 +00:00
.browserslistrc migrate stuff into new NX 2022-02-23 08:53:57 +00:00
.env Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
.env.capsule Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
.env.devnet Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
.env.mainnet Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
.env.stagnet1 Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
.env.stagnet2 Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
.env.testnet Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
.env.vegacapsule Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
.eslintrc.json colocate querys with libs 2022-03-29 15:52:51 -07:00
index.d.ts Feat/dockerize frontends (#388) 2022-06-13 15:39:17 +01:00
jest.config.js Search implementation (#97) 2022-03-23 09:57:51 +00:00
netlify.toml remove old explorer logic 2022-02-23 08:53:57 +00:00
postcss.config.js add basic tailwind setup 2022-03-04 17:11:56 +00:00
project.json Feat/427: Serve explicit environments (#433) 2022-05-23 10:56:11 +01:00
README.md Feat/427: Serve explicit environments (#433) 2022-05-23 10:56:11 +01:00
tailwind.config.js Fix/411 asset dropdown style (#535) 2022-06-10 16:12:51 -07:00
tsconfig.app.json migrate stuff into new NX 2022-02-23 08:53:57 +00:00
tsconfig.json feat(#175): ui-toolkit links (#453) 2022-05-31 17:30:02 -07:00
tsconfig.spec.json Search implementation (#97) 2022-03-23 09:57:51 +00:00
webpack.config.js Chore/sentry (#163) 2022-03-29 18:29:29 +01:00

Explorer

Features

  • Transactions - Showing all transactions and decoded individual transactions
  • Search - Search for block number or transaction hash
  • Blocks - A list of the blocks on our chain and the transactions within each block
  • Assets - List of all assets on the Vega chain
  • Genesis - The initial Genesis configuration the network was started with
  • Governance - Current and past governance proposals
  • Markets - The markets currently open and expired on the Vega network
  • Network Parameters - The current network parameters
  • Parties - Searching for a specific party and the details for that party
  • Validators - The validator information in Vega and Tendermint

Development

First copy the configuration of the application you are starting:

cp .env.[environment] .env.local

Starting the app:

yarn nx serve explorer

Configuration

Example configurations are provided here:

For convenience, you can boot the app injecting one of the configurations above by running:

yarn nx run explorer:serve --env={env} # e.g. stagnet1

There are a few different configuration options offered for this app:

Flag Purpose
NX_CHAIN_EXPLORER_URL The URL of the chain explorer service for decoding transactions
NX_TENDERMINT_URL The Tendermint REST URL for the Vega consesus engine
NX_TENDERMINT_WEBSOCKET_URL The Tendermint Websocket URL for the Vega consensus engine
NX_VEGA_URL The GraphQl query endpoint of a Vega data node
NX_VEGA_ENV The name of the currently connected vega environment
NX_VEGA_REST The REST URL for the Vega Data Node
NX_EXPLORER_ASSETS Enable the assets page for the explorer
NX_EXPLORER_GENESIS Enable the genesis page for the explorer
NX_EXPLORER_GOVERNANCE Enable the governance page for the explorer
NX_EXPLORER_MARKETS Enable the markets page for the explorer
NX_EXPLORER_NETWORK_PARAMETERS Enable the network parameters page for the explorer
NX_EXPLORER_PARTIES Enable the parties page for the explorer
NX_EXPLORER_VALIDATORS Enable the validators page for the explorer

Testing

To run the minimal set of unit tests, run the following:

yarn nx test explorer

To run the UI automation tests with a mocked API, run:

yarn nx run explorer-e2e:e2e