@terra-money/use-station
v4.8.1
Published
**useStation** is React hooks to fetch and process data from [fcd](https://github.com/terra-project/fcd).
Downloads
144
Readme
useStation
useStation is React hooks to fetch and process data from fcd.
If developers install this project from npm and use it, they can easily build a web-app like Terra Station with React.
Getting Started
Install to your React project using npm:
npm install @terra-money/use-station
Declare your domain like below to solve CORS problem:
https://local.terra.money
Basic sample:
import React, { useMemo } from 'react'
import ReactDOM from 'react-dom'
import { useConfigState, ConfigProvider } from '@terra-money/use-station'
import { useDashboard, DashboardUI } from '@terra-money/use-station'
const Dashboard = () => {
const { error, loading, ui } = useDashboard()
const render = ({ prices: { title, display } }: DashboardUI) => {
const { value, unit } = display
return (
<article>
<h1>{title}</h1>
<p>{[value, unit].join(' ')}</p>
</article>
)
}
return (
<div>
{error ? error.message : loading ? 'Loading...' : ui && render(ui)}
</div>
)
}
const chain = {
name: 'mainnet',
chainID: 'columbus-4',
lcd: 'https://lcd.terra.dev',
fcd: 'https://fcd.terra.dev',
ws: 'wss://fcd.terra.dev'
}
const App = () => {
const config = useConfigState({ chain })
return (
<ConfigProvider value={config}>
{config.chain.current.key && config.lang.current && <Dashboard />}
</ConfigProvider>
)
}
ReactDOM.render(<App />, document.getElementById('root'))
Available Scripts
This project was bootstrapped with tsdx.
In the project directory, you can run:
npm start
or yarn start
Runs the project in development/watch mode.
npm run build
or yarn build
Bundles the package to the dist folder.
npm test
or yarn test
Runs the test watcher (Jest) in an interactive mode.
npm run lint
or yarn lint
Runs Eslint with Prettier on .ts and .tsx files.