-
Notifications
You must be signed in to change notification settings - Fork 357
LLC:countervalues
First of all, wrap your app component with Countervalues
provider and provide trackingPairs as a prop.
import {
Countervalues,
useTrackingPairForAccounts
} from "@ledgerhq/live-countervalues-react"
function App() {
// get these in the client side
const accounts = ...
const trackingPairs = useTrackingPairForAccounts(accounts, countervalueCurrency)
return (
<Countervalues
userSettings={{
autofillGaps: true,
trackingPairs
}}
// use this prop to restore local countervalues cache
savedState={CounterValuesStateRaw}
>
<MainApp />
</Countervalues>
)
}
*Currently in Ledger Live, accounts
and countervalueCurrency
are managed by two different implementations on desktop and mobile side. Therefore, useTrackingPairForAccounts
still has to accept these as arguments. In the future we may want to move all the logic inside live-common to provide even simpler API.
useCalculate hook inside a React component or a custom hook.
import { useCalculate } from "@ledgerhq/live-countervalues-react"
// inside component or custom hook
const countervalue = useCalculate({
from: Currency,
to: Currency,
value: number,
disableRounding: boolean,
date: Date,
});
import { useCountervaluesExport } from "@ledgerhq/live-countervalues-react"
// inside component or custom hook
const rawState = useCountervaluesExport()
function save() {...}
useCallback(() => {
save(rawState)
// it's probably overkill to list rawState object as a dependency since its reference would change all the time, but you get the idea.
}, [rawState])
For example, when the app window goes to background it may be ideal to stop polling to save some network traffics. Or you may want to wipe all the current state and re-poll all the state. For those situations, useCountervaluesPolling
hook comes in handy. You can also utilize pending
flag to see if polling is in progress.
import { useCountervaluesPolling } from "@ledgerhq/live-countervalues-react"
// inside component or custom hook
const { wipe, poll, start, stop, pending, error } = useCountervaluesPolling();
- useSendAmount
- to calculate countervalue based on the amount user inputs
- useCalculateCountervalueCallback
- it returns callback calculate function based on currency provided as its argument
- useBalanceHistoryWithCountervalue
- used to show chart in Account page inside Ledger Live
- usePortfolio
- used to dispaly portfolio chart
- useCurrencyPortfolio
- used to dispaly portfolio chart for specific currency
- useDistribution
- used in Asset distribution screen
In most of cases, it's enough to use hooks which are exported from @ledgerhq/live-countervalues-react
.
But core (@ledgerhq/live-countervalues/logic
) module comes in handy when you want to use these logic outside React component or inside some callback functions.
@ledgerhq/live-countervalues/helpers
also exports some useful functions.
The CLI implements tools to test the countervalues.
The easiest way to get it is to install it with NPM. As it's still experimental, make sure to often update it to latest version we have worked on:
npm i -g ledger-live@countervalues
This is a super set of ledger-live sync
that is showing you a Portfolio version of your accounts, similarly to Ledger Live's Portfolio.
SUMMARY OF PORTFOLIO: 65 accounts, total of USD 80.70 ::: on a month period: 138% (USD 46.82)
USD 110.75 ┤ ╭╮
USD 102.87 ┤ ││
USD 94.99 ┤ ││
USD 87.10 ┤ ││
USD 79.22 ┤ ││ ╭─╮╭──────╮╭
USD 71.34 ┤ ││ ╭───────╯ ╰╯ ││
USD 63.46 ┤ │╰─────╯ ││
USD 55.58 ┤ │ ││
USD 47.69 ┤ │ ││
USD 39.81 ┤ │ ││
USD 31.93 ┼──╯ ╰╯
It takes the same parameter of sync
but it also takes
--countervalue <String> : ticker of a currency
-p, --period <String> : year | month | week
Example:
ledger-live portfolio -c eth --xpub xpub6BemYiVNp19a1XgWqLcpWd1pBDZTgzPEcVvhR15cpXPVQjuEnrU7fa3TUatX2NbRWNkqx51jmyukisqGokHq5dyK5uYcbwQBF7nJyAdpYZy
This allows to test directly the countervalues.
Running the command without parameter will simply fetch the latest month of daily BTC-USD rates.
It can take more parameters however:
❯ ledger-live countervalues --countervalue EUR -c ETH -c BTC -f asciichart
Ethereum to Euro
EUR 198.28 ┼ ╭─────╮╭
EUR 178.45 ┤ ╭╮ ╭──────╯ ││
EUR 158.62 ┼──╮ ╭─╯╰──╯ ││
EUR 138.80 ┤ ╰─────╯ ││
EUR 118.97 ┤ ││
EUR 99.14 ┤ ││
EUR 79.31 ┤ ││
EUR 59.48 ┤ ││
EUR 39.66 ┤ ││
EUR 19.83 ┤ ││
EUR 0.00 ┤ ╰╯
Bitcoin to Euro
EUR 8,426.00 ┼ ╭╮╭───╮╭
EUR 7,583.40 ┤ ╭─╯╰╯ ││
EUR 6,740.80 ┼──╮ ╭╮ ╭───╮ ╭────╯ ││
EUR 5,898.20 ┤ ╰─╯╰──╯ ╰─╯ ││
EUR 5,055.60 ┤ ││
EUR 4,213.00 ┤ ││
EUR 3,370.40 ┤ ││
EUR 2,527.80 ┤ ││
EUR 1,685.20 ┤ ││
EUR 842.60 ┤ ││
EUR 0.00 ┤ ╰╯
We can also do more tests like fetching rates of TOP 10 of coins:
❯ ledger-live countervalues --marketcap --size 10 --format stats
BTC to USD availability=93%
ETH to USD availability=93%
XRP to USD availability=97%
USDT to USD availability=97%
BCH to USD availability=97%
LTC to USD availability=97%
BNB to USD availability=97%
EOS to USD availability=97%
XTZ to USD availability=97%
XLM to USD availability=97%
Total availability: 96%
If you want a lot of more verbosity, you can run with
VERBOSE=1
DEBUG_HTTP_RESPONSE=1
- Ledger Live Desktop
- Ledger Live Mobile
-
Ledger Live Common
- Introduction
- Currency Models
- Currency Bridge
- Account
- Account Bridge
- apps
- appsCheckAllAppVersions
- ledger-live bot
- Canonical Ways to Investigate Bugs
- Coin Integration Introduction
- Countervalues
- Packages Duplicates
- Derivation
- Developing with CLI
- Developing
- Gist Firmware Update
- Gist Transaction
- Hardware Wallet Logic
- Socket
- Assorted tips
- Integration Tests
- Process
- Monorepository Migration Guide
- Issues, Workaround and Tricks
- Common CI Troubleshooting
- Create staging builds using the CI
- Deprecated