aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbrunobar79 <brunobar79@gmail.com>2018-07-25 09:13:17 +0800
committerbrunobar79 <brunobar79@gmail.com>2018-07-25 09:13:17 +0800
commiteeb902dbf0d77a487903c386c11fca5bd9114300 (patch)
tree381e7c1366208d11817e5a325c25ddfa877e6306
parent74fd6d1d1227d7a9e49623b73ee85985d79a1e46 (diff)
downloadtangerine-wallet-browser-eeb902dbf0d77a487903c386c11fca5bd9114300.tar
tangerine-wallet-browser-eeb902dbf0d77a487903c386c11fca5bd9114300.tar.gz
tangerine-wallet-browser-eeb902dbf0d77a487903c386c11fca5bd9114300.tar.bz2
tangerine-wallet-browser-eeb902dbf0d77a487903c386c11fca5bd9114300.tar.lz
tangerine-wallet-browser-eeb902dbf0d77a487903c386c11fca5bd9114300.tar.xz
tangerine-wallet-browser-eeb902dbf0d77a487903c386c11fca5bd9114300.tar.zst
tangerine-wallet-browser-eeb902dbf0d77a487903c386c11fca5bd9114300.zip
decent UI
-rw-r--r--ui/app/components/qr-scanner/qr-scanner.component.js64
1 files changed, 43 insertions, 21 deletions
diff --git a/ui/app/components/qr-scanner/qr-scanner.component.js b/ui/app/components/qr-scanner/qr-scanner.component.js
index cc07e53a2..4cc296441 100644
--- a/ui/app/components/qr-scanner/qr-scanner.component.js
+++ b/ui/app/components/qr-scanner/qr-scanner.component.js
@@ -3,6 +3,7 @@ import PropTypes from 'prop-types'
import {connect} from 'react-redux'
import { hideQrScanner, qrCodeDetected} from '../../actions'
import Instascan from 'instascan'
+import Spinner from '../spinner'
class QrScanner extends Component {
static propTypes = {
@@ -13,50 +14,41 @@ class QrScanner extends Component {
constructor (props) {
super(props)
this.state = {
- msg: 'Place the QR code in front of your camera so we can read it...',
+ ready: false,
+ msg: 'Accesing your camera...',
}
this.scanning = false
}
- parseContent (content) {
- let type = 'unknown'
- let values = {}
-
- // Here we could add more cases
- // To parse other codes (transactions for ex.)
-
- if (content.split('ethereum:').length > 1) {
- type = 'address'
- values = {'address': content.split('ethereum:')[1] }
- }
- return {type, values}
- }
-
componentDidUpdate () {
if (this.props.visible && this.camera && !this.scanning) {
- const scanner = new Instascan.Scanner({
+ this.scanner = new Instascan.Scanner({
video: this.camera,
backgroundScan: false,
continuous: true,
})
- scanner.addListener('scan', (content) => {
- scanner.stop().then(_ => {
+ this.scanner.addListener('scan', (content) => {
+ this.scanner.stop().then(_ => {
const result = this.parseContent(content)
if (result.type !== 'unknown') {
console.log('QR-SCANNER: CODE DETECTED', result)
this.props.qrCodeDetected(result)
this.props.hideQrScanner()
+ this.setState({ ready: false })
} else {
this.setState({msg: 'Error: We couldn\'t identify that QR code'})
}
+ this.scanning = false
})
})
Instascan.Camera.getCameras().then((cameras) => {
if (cameras.length > 0) {
- scanner.start(cameras[0])
+ this.scanner.start(cameras[0])
+ this.setState({ ready: true })
+ this.setState({ msg: 'Place the QR code in front of your camera so we can read it...'})
console.log('QR-SCANNER: started scanning with camera', cameras[0])
} else {
- console.log('QR-SCANNER: no cameras found')
+ this.setState({ msg: 'No camera found :('})
}
}).catch(function (e) {
console.error(e)
@@ -65,6 +57,29 @@ class QrScanner extends Component {
}
}
+ parseContent (content) {
+ let type = 'unknown'
+ let values = {}
+
+ // Here we could add more cases
+ // To parse other codes (transactions for ex.)
+
+ if (content.split('ethereum:').length > 1) {
+ type = 'address'
+ values = {'address': content.split('ethereum:')[1] }
+ }
+ return {type, values}
+ }
+
+
+ stopAndClose = () => {
+ this.scanner.stop().then(_ => {
+ this.scanning = false
+ this.props.hideQrScanner()
+ this.setState({ ready: false })
+ })
+ }
+
render () {
const { visible } = this.props
@@ -92,6 +107,8 @@ class QrScanner extends Component {
<h3 style={{
textAlign: 'center',
marginBottom: '20px',
+ fontSize: '1.5rem',
+ fontWeight: '500',
}}>
Scan QR code
</h3>
@@ -101,17 +118,22 @@ class QrScanner extends Component {
overflow: 'hidden',
width: '100%',
height: '275px',
+ display: 'flex',
+ alignItems: 'center',
+ justifyContent: 'center',
}}>
<video
style={{
width: 'auto',
height: '275px',
marginLeft: '-15%',
+ display: this.state.ready ? 'block' : 'none',
}}
ref={(cam) => {
this.camera = cam
}}
/>
+ { !this.state.ready ? <Spinner color={'#F7C06C'} /> : null}
</div>
<div className={'qr-code-help'} style={{textAlign: 'center', fontSize: '12px', padding: '15px'}}>
{this.state.msg}
@@ -132,7 +154,7 @@ class QrScanner extends Component {
animationName: 'anim_171532470906313',
animationTimingFunction: 'ease-out',
}}
- onClick={_ => this.props.hideQrScanner() }
+ onClick={this.stopAndClose}
/>
</div>
)