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 zapLogoDark from 'icons/zap_logo_black.svg' import copyIcon from 'icons/copy.svg' import { showNotification } from 'lib/utils/notifications' import { FormattedMessage, injectIntl } from 'react-intl' import messages from './messages' import styles from './Syncing.scss' class Syncing extends Component { state = { timer: null, syncMessageDetail: null, syncMessageExtraDetail: null } componentWillMount() { const { syncStatus, intl } = 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: intl.formatMessage({ ...messages.grab_coffee }) }) } }, 10000) this.setState({ timer }) } componentWillUnmount() { const { timer } = this.state clearInterval(timer) } render() { const { hasSynced, syncStatus, syncPercentage, address, blockHeight, lndBlockHeight, lndCfilterHeight, intl, theme } = this.props let { syncMessageDetail, syncMessageExtraDetail } = this.state const copyClicked = () => { copy(address) showNotification('Noice', 'Successfully copied to clipboard') } let syncMessage if (syncStatus === 'waiting') { syncMessage = intl.formatMessage({ ...messages.waiting_for_peers }) } else if (syncStatus === 'in-progress') { if (typeof syncPercentage === 'undefined' || syncPercentage <= 0) { syncMessage = intl.formatMessage({ ...messages.preparing }) syncMessageDetail = null } else if (syncPercentage) { syncMessage = `${syncPercentage}%` syncMessageDetail = intl.formatMessage( { ...messages.block_progress }, { currentBlock: lndBlockHeight.toLocaleString(), totalBlocks: blockHeight.toLocaleString() } ) syncMessageExtraDetail = intl.formatMessage( { ...messages.filter_progress }, { currentFilter: lndCfilterHeight.toLocaleString(), totalFilters: blockHeight.toLocaleString() } ) } } if (typeof hasSynced === 'undefined') { return null } return (