diff --git a/.env.sample b/.env.sample index 118cdb8d3..18342c28f 100644 --- a/.env.sample +++ b/.env.sample @@ -1,7 +1,7 @@ # ASGARDEX REACT_APP_DEFAULT_NETWORK=mainnet # Chains enabled development mode -REACT_APP_CHAINS_ENABLED=THOR,BNB,BTC,LTC,BCH,ETH +REACT_APP_CHAINS_ENABLED=THOR,BNB,BTC,LTC,BCH,ETH,DOGE,GAIA # Midgard REACT_APP_MIDGARD_TESTNET_URL=https://testnet.midgard.thorchain.info diff --git a/CHANGELOG.md b/CHANGELOG.md index d7d3ca964..6cd81a5f0 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,8 +1,12 @@ -# 0.xx.x (2022-xx-xx) +# 0.16.0 (2022-xx-xx) + +## ADD + +- Support Terra [#2002](https://github.com/thorchain/asgardex-electron/issues/2002), [#2193](https://github.com/thorchain/asgardex-electron/pull/2193), [#2290](https://github.com/thorchain/asgardex-electron/pull/2290) ## Update -- [Pools] Toggle filter buttons to remove clear button +- [Pools] Toggle filter buttons to remove clear button [#2287](https://github.com/thorchain/asgardex-electron/pull/2287) # 0.15.2 (2022-06-06) diff --git a/src/renderer/assets/svg/asset-atom.svg b/src/renderer/assets/svg/asset-atom.svg new file mode 100644 index 000000000..26782420b --- /dev/null +++ b/src/renderer/assets/svg/asset-atom.svg @@ -0,0 +1,85 @@ + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/src/renderer/components/icons/index.ts b/src/renderer/components/icons/index.ts index f6e4e0d1e..6a6ac60d0 100644 --- a/src/renderer/components/icons/index.ts +++ b/src/renderer/components/icons/index.ts @@ -7,6 +7,7 @@ import arrowGreenIcon from '../../assets/svg/asset-arrow-green.svg' import greyArrowIcon from '../../assets/svg/asset-arrow-grey.svg' import arrowTwoIcon from '../../assets/svg/asset-arrow-twoway.svg' import arrowYellowIcon from '../../assets/svg/asset-arrow-yello.svg' +import atomIcon from '../../assets/svg/asset-atom.svg' import bnbRuneIcon from '../../assets/svg/asset-bnb-rune.svg' import bnbIcon from '../../assets/svg/asset-bnb.svg' import btcIcon from '../../assets/svg/asset-btc.svg' @@ -29,6 +30,7 @@ import orbGreenIcon from '../../assets/svg/orb-green.svg' import terraIcon from '../../assets/svg/terra.svg' export { + atomIcon, bnbIcon, btcIcon, dogeIcon, diff --git a/src/renderer/components/uielements/assets/assetData/AssetData.styles.tsx b/src/renderer/components/uielements/assets/assetData/AssetData.styles.tsx index 3af3c84c3..6bceb64e7 100644 --- a/src/renderer/components/uielements/assets/assetData/AssetData.styles.tsx +++ b/src/renderer/components/uielements/assets/assetData/AssetData.styles.tsx @@ -23,7 +23,7 @@ export const AssetIcon = styled(UIAssetIcon)`` export const TickerLabel = styled(UILabel).attrs({ textTransform: 'uppercase', - weight: '600' + weight: 'bold' })` height: 18px; padding: 0px 16px 0px 11px; @@ -39,7 +39,7 @@ export const ChainLabel = styled(TickerLabel)` export const AmountLabel = styled(UILabel).attrs({ textTransform: 'uppercase', - weight: '600' + weight: 'bold' })` font-family: 'MainFontRegular'; padding-left: 10px; diff --git a/src/renderer/components/uielements/assets/assetIcon/AssetIcon.tsx b/src/renderer/components/uielements/assets/assetIcon/AssetIcon.tsx index 3e9d86790..559b51331 100644 --- a/src/renderer/components/uielements/assets/assetIcon/AssetIcon.tsx +++ b/src/renderer/components/uielements/assets/assetIcon/AssetIcon.tsx @@ -22,7 +22,8 @@ import { isRuneBnbAsset, isRuneNativeAsset, isTgtERC20Asset, - isXRuneAsset + isXRuneAsset, + isAtomAsset } from '../../../../helpers/assetHelper' import { isBnbChain, isEthChain } from '../../../../helpers/chainHelper' import { getIntFromName, rainbowStop } from '../../../../helpers/colorHelpers' @@ -37,7 +38,8 @@ import { xRuneIcon, tgtIcon, lunaIcon, - ustIcon + ustIcon, + atomIcon } from '../../../icons' import * as Styled from './AssetIcon.styles' import { Size } from './AssetIcon.types' @@ -96,6 +98,11 @@ export const AssetIcon: React.FC = ({ asset, size = 'normal', className = return dogeIcon } + // Atom + if (isAtomAsset(asset)) { + return atomIcon + } + // LUNA if (isLunaAsset(asset)) { return lunaIcon diff --git a/src/renderer/components/uielements/assets/assetLabel/AssetLabel.styles.ts b/src/renderer/components/uielements/assets/assetLabel/AssetLabel.styles.ts index 851134067..11d804ade 100644 --- a/src/renderer/components/uielements/assets/assetLabel/AssetLabel.styles.ts +++ b/src/renderer/components/uielements/assets/assetLabel/AssetLabel.styles.ts @@ -19,7 +19,7 @@ export const Wrapper = styled(Row).attrs({ export const TickerLabel = styled(UILabel).attrs({ textTransform: 'uppercase', - weight: '600' + weight: 'bold' })` height: 18px; padding: 0px 16px 0px 11px; diff --git a/src/renderer/components/uielements/label/Label.styles.ts b/src/renderer/components/uielements/label/Label.styles.ts index 3bcea49de..f45d5b4d8 100644 --- a/src/renderer/components/uielements/label/Label.styles.ts +++ b/src/renderer/components/uielements/label/Label.styles.ts @@ -11,7 +11,7 @@ export type Props = { size?: Size color?: Color disabled?: boolean - weight?: string + weight?: 'normal' | 'bold' textTransform?: TextTransform nowrap?: boolean onClick?: (_: React.MouseEvent) => void @@ -55,12 +55,12 @@ const colors: Colors = { } export const LabelWrapper = styled.div` - padding: 10px 0; + padding: 0; width: 100%; white-space: ${({ nowrap = false }) => (nowrap ? 'nowrap' : 'normal')}; font-size: ${({ size = 'normal' }) => fontSettings[size].size}; text-transform: ${({ textTransform = 'none' }) => textTransform}; - font-weight: ${({ weight }) => weight}; + font-family: ${({ weight }) => (weight === 'bold' ? 'MainFontBold' : 'MainFontRegular')}; letter-spacing: ${({ size = 'normal' }) => fontSettings[size].spacing}; color: ${({ color }) => colors[color || 'normal']}; opacity: ${({ disabled }) => (disabled ? 0.5 : 1)}; diff --git a/src/renderer/components/wallet/assets/AssetsTableCollapsable.styles.ts b/src/renderer/components/wallet/assets/AssetsTableCollapsable.styles.ts index 7824e3407..8177f2d17 100644 --- a/src/renderer/components/wallet/assets/AssetsTableCollapsable.styles.ts +++ b/src/renderer/components/wallet/assets/AssetsTableCollapsable.styles.ts @@ -58,7 +58,7 @@ export const Label = styled(UILabel)` export const TickerLabel = styled(UILabel).attrs({ textTransform: 'uppercase', - weight: '600' + weight: 'bold' })` padding: 0px; font-size: 16px; diff --git a/src/renderer/helpers/assetHelper.test.ts b/src/renderer/helpers/assetHelper.test.ts index 6a635e040..cc75f3ff9 100644 --- a/src/renderer/helpers/assetHelper.test.ts +++ b/src/renderer/helpers/assetHelper.test.ts @@ -1,3 +1,4 @@ +import { AssetAtom } from '@xchainjs/xchain-cosmos' import { ETHAddress } from '@xchainjs/xchain-ethereum' import { AssetLUNA } from '@xchainjs/xchain-terra' import { @@ -328,6 +329,9 @@ describe('helpers/assetHelper', () => { it('UST', () => { expect(isChainAsset(AssetUST)).toBeFalsy() }) + it('ATOM', () => { + expect(isChainAsset(AssetAtom)).toBeTruthy() + }) }) describe('isUSDAsset', () => { diff --git a/src/renderer/helpers/assetHelper.ts b/src/renderer/helpers/assetHelper.ts index c83928d79..a634b598e 100644 --- a/src/renderer/helpers/assetHelper.ts +++ b/src/renderer/helpers/assetHelper.ts @@ -1,4 +1,5 @@ import { Address } from '@xchainjs/xchain-client' +import { AssetAtom } from '@xchainjs/xchain-cosmos' import { ETHAddress, getTokenAddress } from '@xchainjs/xchain-ethereum' import { AssetLUNA } from '@xchainjs/xchain-terra' import { @@ -133,6 +134,11 @@ export const isLunaAsset = (asset: Asset): boolean => eqAsset.equals(asset, Asse */ export const isUstAsset = (asset: Asset): boolean => eqAsset.equals(asset, AssetUST) +/** + * Check whether an asset is a ATOM asset + */ +export const isAtomAsset = (asset: Asset): boolean => eqAsset.equals(asset, AssetAtom) + /** * Check whether an ERC20 asset is white listed or not */ diff --git a/src/renderer/helpers/chainHelper.ts b/src/renderer/helpers/chainHelper.ts index 32fe7fcf0..4885adec3 100644 --- a/src/renderer/helpers/chainHelper.ts +++ b/src/renderer/helpers/chainHelper.ts @@ -1,3 +1,4 @@ +import { AssetAtom } from '@xchainjs/xchain-cosmos' import { AssetLUNA } from '@xchainjs/xchain-terra' import { Asset, @@ -36,7 +37,7 @@ export const getChainAsset = (chain: Chain): Asset => { case THORChain: return AssetRuneNative case CosmosChain: - throw Error('Cosmos is not supported yet') + return AssetAtom case BCHChain: return AssetBCH case LTCChain: diff --git a/src/renderer/services/chain/address.ts b/src/renderer/services/chain/address.ts index 5273213c6..a5baa0932 100644 --- a/src/renderer/services/chain/address.ts +++ b/src/renderer/services/chain/address.ts @@ -45,7 +45,7 @@ const addressByChain$ = (chain: Chain): WalletAddress$ => { // not supported yet return Rx.of(O.none) case CosmosChain: - // not supported yet + // TODO (@veado) Implement Cosmos return Rx.of(O.none) case BCHChain: return BCH.address$ diff --git a/src/renderer/services/chain/client.ts b/src/renderer/services/chain/client.ts index 46d9a34bb..4baba8c0d 100644 --- a/src/renderer/services/chain/client.ts +++ b/src/renderer/services/chain/client.ts @@ -3,6 +3,7 @@ import { BNBChain, BTCChain, Chain, + CosmosChain, DOGEChain, ETHChain, LTCChain, @@ -43,6 +44,9 @@ export const clientByChain$ = (chain: Chain): XChainClient$ => { return DOGE.client$ case TerraChain: return TERRA.client$ + case CosmosChain: + // TODO (@veado) Implement Cosmos + return Rx.of(O.none) default: return Rx.of(O.none) } diff --git a/src/renderer/services/chain/transaction/common.ts b/src/renderer/services/chain/transaction/common.ts index 0e0674c75..8a995f01c 100644 --- a/src/renderer/services/chain/transaction/common.ts +++ b/src/renderer/services/chain/transaction/common.ts @@ -75,7 +75,7 @@ export const sendTx$ = ({ return THOR.sendTx({ walletType, amount, asset, memo, recipient, walletIndex }) case CosmosChain: - // not available yet + // TODO (@veado) Implement Cosmos return txFailure$(`sendTx$ has not been implemented for Cosmos yet`) case PolkadotChain: @@ -182,6 +182,7 @@ export const txStatusByChain$ = ({ txHash, chain }: { txHash: TxHash; chain: Cha case THORChain: return THOR.txStatus$(txHash, O.none) case CosmosChain: + // TODO (@veado) Implement Cosmos return txStatusFailure$(`txStatusByChain$ has not been implemented for Cosmos`) case PolkadotChain: return txStatusFailure$(`txStatusByChain$ has not been implemented for Polkadot`) diff --git a/src/renderer/services/const.ts b/src/renderer/services/const.ts index 3dc565027..2112bb00a 100644 --- a/src/renderer/services/const.ts +++ b/src/renderer/services/const.ts @@ -14,7 +14,7 @@ export const AVAILABLE_NETWORKS: Network[] = ['testnet', 'stagenet', 'mainnet'] export const ENABLED_CHAINS: Chain[] = envOrDefault( process.env.REACT_APP_CHAINS_ENABLED, - 'THOR,BNB,BTC,LTC,BCH,ETH,DOGE,TERRA' + 'THOR,BNB,BTC,LTC,BCH,ETH,DOGE,TERRA,GAIA' ) .replace(/\s/g, '') .split(',') diff --git a/src/renderer/services/wallet/balances.ts b/src/renderer/services/wallet/balances.ts index 1db3d854f..2668b4550 100644 --- a/src/renderer/services/wallet/balances.ts +++ b/src/renderer/services/wallet/balances.ts @@ -73,6 +73,8 @@ export const createBalancesService = ({ LTC.reloadBalances() DOGE.reloadBalances() TERRA.reloadBalances() + // TODO (@veado) Implement Cosmos + // GAIA.reloadBalances() } // Returns lazy functions to reload balances by given chain @@ -95,6 +97,7 @@ export const createBalancesService = ({ case TerraChain: return TERRA.reloadBalances case CosmosChain: + // TODO (@veado) Implement Cosmos return FP.constVoid case PolkadotChain: return FP.constVoid @@ -175,6 +178,8 @@ export const createBalancesService = ({ balances$: TERRA.balances$(walletType, walletIndex), reloadBalances$: TERRA.reloadBalances$ } + // TODO (@veado) Implement Cosmos + // case CosmosChain: default: return { reloadBalances: FP.constVoid, @@ -580,6 +585,8 @@ export const createBalancesService = ({ LTC: [ltcBalance$, ltcLedgerChainBalance$], DOGE: [dogeChainBalance$, dogeLedgerChainBalance$], TERRA: [terraChainBalance$, terraLedgerChainBalance$] + // TODO (@veado) Implement Cosmos + // GAIA: [cosmosChainBalance$, cosmosLedgerChainBalance$] }) ), // we ignore all `ChainBalances` with state of `initial` balances