import React, { Component } from 'react' import PropTypes from 'prop-types' import QRCode from 'qrcode.react' import copy from 'copy-to-clipboard' import Isvg from 'react-inlinesvg' import zapLogo from 'icons/zap_logo.svg' import copyIcon from 'icons/copy.svg' import { showNotification } from 'notifications' import styles from './Syncing.scss' class Syncing extends Component { state = { timer: null, syncMessageDetail: null } componentWillMount() { const { syncStatus } = this.props // If we are still waiting for peers after some time, advise te user it could take a wile. let timer = setTimeout(() => { if (syncStatus === 'waiting') { this.setState({ syncMessageDetail: 'It looks like this could take some time - you might want to grab a coffee or try again later!' }) } }, 10000) this.setState({ timer }) } componentWillUnmount() { const { timer } = this.state clearInterval(timer) } render() { const { hasSynced, syncStatus, syncPercentage, address, blockHeight, lndBlockHeight } = this.props let { syncMessageDetail } = this.state const copyClicked = () => { copy(address) showNotification('Noice', 'Successfully copied to clipboard') } let syncMessage if (syncStatus === 'waiting') { syncMessage = 'Waiting for peers...' } else if (typeof syncPercentage === 'undefined' || syncPercentage <= 0) { syncMessage = 'Preparing...' syncMessageDetail = null } else if (syncPercentage > 0 && syncPercentage < 99) { syncMessage = `${syncPercentage}%` syncMessageDetail = `${lndBlockHeight.toLocaleString()} of ${blockHeight.toLocaleString()}` } else if (syncPercentage >= 99) { syncMessage = 'Finalizing...' syncMessageDetail = null } if (typeof hasSynced === 'undefined') { return null } return (
Please wait a while whilst we fetch all of your latest data from the blockchain.
Might as well fund your wallet while you're waiting to sync.