You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
48 lines
1.3 KiB
48 lines
1.3 KiB
import React, { Component } from 'react'
|
|
import PropTypes from 'prop-types'
|
|
import Isvg from 'react-inlinesvg'
|
|
import zapLogo from 'icons/zap_logo.svg'
|
|
import styles from './Syncing.scss'
|
|
|
|
class Syncing extends Component {
|
|
componentWillMount() {
|
|
this.props.fetchBlockHeight()
|
|
}
|
|
|
|
render() {
|
|
const { syncPercentage } = this.props
|
|
|
|
return (
|
|
<div className={styles.container}>
|
|
<div className={styles.titleBar} />
|
|
|
|
<div className={styles.content}>
|
|
<header>
|
|
<Isvg className={styles.bitcoinLogo} src={zapLogo} />
|
|
</header>
|
|
<section className={styles.progressContainer}>
|
|
<h1>Syncing to the blockchain...</h1>
|
|
<div className={styles.progressBar}>
|
|
<div
|
|
className={styles.progress}
|
|
style={{ width: Number.isNaN(syncPercentage) ? 0 : `${syncPercentage}%` }}
|
|
/>
|
|
</div>
|
|
<h4>
|
|
{Number.isNaN(parseInt(syncPercentage, 10)) || syncPercentage.toString().length === 0
|
|
? ''
|
|
: `${syncPercentage}%`}
|
|
</h4>
|
|
</section>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|
|
}
|
|
|
|
Syncing.propTypes = {
|
|
fetchBlockHeight: PropTypes.func.isRequired,
|
|
syncPercentage: PropTypes.oneOfType([PropTypes.number, PropTypes.string]).isRequired
|
|
}
|
|
|
|
export default Syncing
|
|
|