aboutsummaryrefslogtreecommitdiffstats
path: root/app/scripts/controllers/recent-blocks.js
diff options
context:
space:
mode:
authorFrankie <frankie.diamond@gmail.com>2017-12-22 03:37:37 +0800
committerGitHub <noreply@github.com>2017-12-22 03:37:37 +0800
commit9940ea71dfb2b1e478f134e7cd82fce0e134f071 (patch)
treef8494687303bd29c67a2090a30371a7bbb78a578 /app/scripts/controllers/recent-blocks.js
parentcc7e85c078c0bd3ac69f4f2c2de07da8f4fb4d23 (diff)
parentd3f5ad874e4bf90cda4e440f9b0635c6ac416382 (diff)
downloadtangerine-wallet-browser-9940ea71dfb2b1e478f134e7cd82fce0e134f071.tar
tangerine-wallet-browser-9940ea71dfb2b1e478f134e7cd82fce0e134f071.tar.gz
tangerine-wallet-browser-9940ea71dfb2b1e478f134e7cd82fce0e134f071.tar.bz2
tangerine-wallet-browser-9940ea71dfb2b1e478f134e7cd82fce0e134f071.tar.lz
tangerine-wallet-browser-9940ea71dfb2b1e478f134e7cd82fce0e134f071.tar.xz
tangerine-wallet-browser-9940ea71dfb2b1e478f134e7cd82fce0e134f071.tar.zst
tangerine-wallet-browser-9940ea71dfb2b1e478f134e7cd82fce0e134f071.zip
Merge branch 'master' into tx-param-vaalidation
Diffstat (limited to 'app/scripts/controllers/recent-blocks.js')
-rw-r--r--app/scripts/controllers/recent-blocks.js44
1 files changed, 44 insertions, 0 deletions
diff --git a/app/scripts/controllers/recent-blocks.js b/app/scripts/controllers/recent-blocks.js
new file mode 100644
index 000000000..4a906261e
--- /dev/null
+++ b/app/scripts/controllers/recent-blocks.js
@@ -0,0 +1,44 @@
+const ObservableStore = require('obs-store')
+const extend = require('xtend')
+
+class RecentBlocksController {
+
+ constructor (opts = {}) {
+ const { blockTracker } = opts
+ this.blockTracker = blockTracker
+ this.historyLength = opts.historyLength || 40
+
+ const initState = extend({
+ recentBlocks: [],
+ }, opts.initState)
+ this.store = new ObservableStore(initState)
+
+ this.blockTracker.on('block', this.processBlock.bind(this))
+ }
+
+ resetState () {
+ this.store.updateState({
+ recentBlocks: [],
+ })
+ }
+
+ processBlock (newBlock) {
+ const block = extend(newBlock, {
+ gasPrices: newBlock.transactions.map((tx) => {
+ return tx.gasPrice
+ }),
+ })
+ delete block.transactions
+
+ const state = this.store.getState()
+ state.recentBlocks.push(block)
+
+ while (state.recentBlocks.length > this.historyLength) {
+ state.recentBlocks.shift()
+ }
+
+ this.store.updateState(state)
+ }
+}
+
+module.exports = RecentBlocksController