1
0
mirror of https://github.com/oceanprotocol/commons.git synced 2023-03-15 18:03:00 +01:00

Merge pull request #158 from oceanprotocol/fix/hashes

Submarine links and Pacific support
This commit is contained in:
Matthias Kretschmann 2019-06-14 13:15:47 +02:00 committed by GitHub
commit f699fa8db6
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
12 changed files with 101 additions and 43 deletions

View File

@ -54,6 +54,6 @@
}
.spinner {
composes: spinner, small from '../Spinner.module.scss';
composes: spinner, small from '../../atoms/Spinner.module.scss';
margin-right: $spacer;
}

View File

@ -2,7 +2,7 @@ import React, { Fragment } from 'react'
import { VersionNumbersState as VersionTableProps } from '.'
import styles from './VersionTable.module.scss'
import slugify from '@sindresorhus/slugify'
import Spinner from '../Spinner'
import Spinner from '../../atoms/Spinner'
const VersionTableContracts = ({
contracts,
@ -14,27 +14,60 @@ const VersionTableContracts = ({
<table>
<tbody>
{contracts &&
Object.keys(contracts).map(key => (
Object.keys(contracts).map(key => {
const submarineLink = `https://submarine${
network === 'duero'
? '.duero'
: network === 'pacific'
? '.pacific'
: ''
}.dev-ocean.com/address/${contracts[key]}`
return (
<tr key={key}>
<td>
<span className={styles.label}>{key}</span>
</td>
<td>
<a
href={`https://submarine${network === 'duero' &&
'.duero'}.dev-ocean.com/address/${
contracts[key]
}`}
>
<a href={submarineLink}>
<code>{contracts[key]}</code>
</a>
</td>
</tr>
))}
)
})}
</tbody>
</table>
)
const VersionNumber = ({
isLoading,
software,
version,
network
}: {
isLoading: boolean
software: string
version: string
network: string
}) =>
isLoading ? (
<Spinner small className={styles.spinner} />
) : version ? (
<>
<a
href={`https://github.com/oceanprotocol/${slugify(
software
)}/releases/tag/v${version}`}
>
<code>v{version}</code>
</a>
{network && `(${network})`}
</>
) : (
<span>Could not get version</span>
)
const VersionTable = ({ data }: { data: VersionTableProps }) => (
<div className={styles.tableWrap}>
<table className={styles.table}>
@ -55,16 +88,12 @@ const VersionTable = ({ data }: { data: VersionTableProps }) => (
</a>
</td>
<td>
{value.isLoading ? (
<Spinner small className={styles.spinner} />
) : value.version ? (
<>
<code>v{value.version}</code>
{value.network && `(${value.network})`}
</>
) : (
'Could not get version'
)}
<VersionNumber
isLoading={value.isLoading}
software={value.software}
version={value.version}
network={value.network}
/>
</td>
</tr>
{key === 'keeperContracts' && data.brizo.contracts && (

View File

@ -5,7 +5,7 @@ import { ReactComponent as AiCommons } from '../../img/aicommons.svg'
import styles from './Footer.module.scss'
import meta from '../../data/meta.json'
import VersionNumbers from '../atoms/VersionNumbers'
import VersionNumbers from '../molecules/VersionNumbers'
const Footer = () => (
<footer className={styles.footer}>

View File

@ -153,13 +153,16 @@ export default class UserProvider extends PureComponent<{}, UserProviderState> {
await window.web3.eth.net.getId((err, netId) => {
if (err) return
const isPacific = netId === 0xcea11
const isNile = netId === 8995
const isDuero = netId === 2199
const isSpree = netId === 8996
isOceanNetwork = isNile || isDuero || isSpree
isOceanNetwork = isPacific || isNile || isDuero || isSpree
const network = isNile
const network = isPacific
? 'Pacific'
: isNile
? 'Nile'
: isDuero
? 'Duero'
@ -255,10 +258,11 @@ export default class UserProvider extends PureComponent<{}, UserProviderState> {
if (isWeb3) {
const network = await ocean.keeper.getNetworkName()
const isPacific = network === 'Pacific'
const isNile = network === 'Nile'
const isDuero = network === 'Duero'
const isSpree = network === 'Spree'
const isOceanNetwork = isNile || isDuero || isSpree
const isOceanNetwork = isPacific || isNile || isDuero || isSpree
network !== this.state.network &&
this.setState({ isOceanNetwork, network })

View File

@ -1,7 +1,7 @@
import React, { Component } from 'react'
import Route from '../components/templates/Route'
import Content from '../components/atoms/Content'
import VersionNumbers from '../components/atoms/VersionNumbers'
import VersionNumbers from '../components/molecules/VersionNumbers'
class About extends Component {
public render() {

View File

@ -25,6 +25,13 @@
overflow-wrap: break-word;
display: inline;
}
a:hover,
a:focus {
code {
color: inherit;
}
}
}
.error {

View File

@ -16,6 +16,8 @@ interface FaucetState {
}
export default class Faucet extends PureComponent<{}, FaucetState> {
public static contextType = User
public state = {
isLoading: false,
success: undefined,
@ -59,15 +61,31 @@ export default class Faucet extends PureComponent<{}, FaucetState> {
})
}
private Success = () => (
private Success = () => {
const { network } = this.context
const { trxHash } = this.state
const submarineLink = `https://submarine${
network === 'Duero'
? '.duero'
: network === 'Pacific'
? '.pacific'
: ''
}.dev-ocean.com/tx/${trxHash}`
return (
<div className={styles.success}>
<strong>{this.state.success}</strong>
<p>
<strong>Your Transaction Hash</strong>
<code>{this.state.trxHash}</code>
<a href={submarineLink}>
<code>{trxHash}</code>
</a>
</p>
</div>
)
}
private Error = () => (
<div className={styles.error}>