|
@ -1,24 +1,28 @@ |
|
|
// @flow
|
|
|
// @flow
|
|
|
|
|
|
|
|
|
import React, { PureComponent } from 'react' |
|
|
import React, { PureComponent } from 'react' |
|
|
|
|
|
import { Buffer } from 'buffer' |
|
|
import { createSelector } from 'reselect' |
|
|
import { createSelector } from 'reselect' |
|
|
import { connect } from 'react-redux' |
|
|
import { connect } from 'react-redux' |
|
|
|
|
|
|
|
|
import { accountsSelector } from 'reducers/accounts' |
|
|
import { accountsSelector } from 'reducers/accounts' |
|
|
|
|
|
import { exportSettingsSelector } from 'reducers/settings' |
|
|
import { makeChunks } from '@ledgerhq/live-common/lib/bridgestream/exporter' |
|
|
import { makeChunks } from '@ledgerhq/live-common/lib/bridgestream/exporter' |
|
|
import QRCode from './base/QRCode' |
|
|
import QRCode from './base/QRCode' |
|
|
|
|
|
|
|
|
const mapStateToProps = createSelector(accountsSelector, accounts => ({ |
|
|
const mapStateToProps = createSelector( |
|
|
chunks: makeChunks({ |
|
|
accountsSelector, |
|
|
accounts, |
|
|
exportSettingsSelector, |
|
|
exporterName: 'desktop', |
|
|
(accounts, settings) => ({ |
|
|
exporterVersion: __APP_VERSION__, |
|
|
chunks: makeChunks({ |
|
|
pad: true, |
|
|
accounts, |
|
|
|
|
|
settings, |
|
|
|
|
|
exporterName: 'desktop', |
|
|
|
|
|
exporterVersion: __APP_VERSION__, |
|
|
|
|
|
chunkSize: 120, |
|
|
|
|
|
}), |
|
|
}), |
|
|
}), |
|
|
})) |
|
|
) |
|
|
|
|
|
|
|
|
const LOW_FPS = 2 |
|
|
|
|
|
const HIGH_FPS = 8 |
|
|
|
|
|
|
|
|
|
|
|
class QRCodeExporter extends PureComponent< |
|
|
class QRCodeExporter extends PureComponent< |
|
|
{ |
|
|
{ |
|
@ -36,18 +40,16 @@ class QRCodeExporter extends PureComponent< |
|
|
|
|
|
|
|
|
state = { |
|
|
state = { |
|
|
frame: 0, |
|
|
frame: 0, |
|
|
fps: HIGH_FPS, |
|
|
fps: 5, |
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
componentDidMount() { |
|
|
componentDidMount() { |
|
|
console.log(`BRIDGESTREAM_DATA=${btoa(JSON.stringify(this.props.chunks))}`) // eslint-disable-line
|
|
|
const BRIDGESTREAM_DATA = Buffer.from(JSON.stringify(this.props.chunks)).toString('base64') |
|
|
|
|
|
console.log(`BRIDGESTREAM_DATA=${BRIDGESTREAM_DATA}`) // eslint-disable-line
|
|
|
|
|
|
|
|
|
const nextFrame = ({ frame, fps }, { chunks }) => { |
|
|
const nextFrame = ({ frame }, { chunks }) => { |
|
|
frame = (frame + 1) % chunks.length |
|
|
frame = (frame + 1) % chunks.length |
|
|
return { |
|
|
return { frame } |
|
|
frame, |
|
|
|
|
|
fps: frame === 0 ? (fps === LOW_FPS ? HIGH_FPS : LOW_FPS) : fps, |
|
|
|
|
|
} |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
let lastT |
|
|
let lastT |
|
|