Mend CHANGE.log

feature/default_network_editable
Frankie 9 years ago
commit 03e9ff6e42
  1. 5
      CHANGELOG.md
  2. BIN
      app/images/ethereum-network.jpg
  3. BIN
      app/images/morden-test-network.jpg
  4. BIN
      app/images/no-connection.jpg
  5. BIN
      app/images/unknown-private-network.jpg
  6. 2
      app/manifest.json
  7. 31
      test/unit/lib/icon-factory-test.js
  8. 17
      ui/app/components/identicon.js
  9. 52
      ui/lib/icon-factory.js

@ -1,7 +1,12 @@
# Changelog # Changelog
## Current Master ## Current Master
- Style up the info page - Style up the info page
- Cache identicon images to optimize for long lists of transactions.
## 2.3.0 2016-06-06
- Show network status in title bar - Show network status in title bar
- Added seed word recovery to config screen. - Added seed word recovery to config screen.
- Clicking network status indicator now reveals a provider menu. - Clicking network status indicator now reveals a provider menu.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 11 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 6.8 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 3.9 KiB

@ -1,7 +1,7 @@
{ {
"name": "__MSG_appName__", "name": "__MSG_appName__",
"short_name": "Metamask", "short_name": "Metamask",
"version": "2.2.0", "version": "2.3.0",
"manifest_version": 2, "manifest_version": 2,
"description": "__MSG_appDescription__", "description": "__MSG_appDescription__",
"icons": { "icons": {

@ -0,0 +1,31 @@
const assert = require('assert')
const sinon = require('sinon')
const path = require('path')
const IconFactoryGen = require(path.join(__dirname, '..', '..', '..', 'ui', 'lib', 'icon-factory.js'))
describe('icon-factory', function() {
let iconFactory, address, diameter
beforeEach(function() {
iconFactory = IconFactoryGen((d,n) => 'stubicon')
address = '0x012345671234567890'
diameter = 50
})
it('should return a data-uri string for any address and diameter', function() {
const output = iconFactory.iconForAddress(address, diameter)
assert.ok(output.indexOf('data:image/svg') === 0)
assert.equal(output, iconFactory.cache[address][diameter])
})
it('should default to cache first', function() {
const testOutput = 'foo'
const mockSizeCache = {}
mockSizeCache[diameter] = testOutput
iconFactory.cache[address] = mockSizeCache
const output = iconFactory.iconForAddress(address, diameter)
assert.equal(output, testOutput)
})
})

@ -1,8 +1,10 @@
const Component = require('react').Component const Component = require('react').Component
const h = require('react-hyperscript') const h = require('react-hyperscript')
const inherits = require('util').inherits const inherits = require('util').inherits
const jazzicon = require('jazzicon')
const findDOMNode = require('react-dom').findDOMNode const findDOMNode = require('react-dom').findDOMNode
const jazzicon = require('jazzicon')
const iconFactoryGen = require('../../lib/icon-factory')
const iconFactory = iconFactoryGen(jazzicon)
module.exports = IdenticonComponent module.exports = IdenticonComponent
@ -35,21 +37,14 @@ IdenticonComponent.prototype.componentDidMount = function(){
var address = state.address var address = state.address
if (!address) return if (!address) return
var numericRepresentation = jsNumberForAddress(address)
var container = findDOMNode(this) var container = findDOMNode(this)
// jazzicon with hack to fix inline svg error
var diameter = state.diameter || this.defaultDiameter var diameter = state.diameter || this.defaultDiameter
var identicon = jazzicon(diameter, numericRepresentation) var dataUri = iconFactory.iconForAddress(address, diameter)
var identiconSrc = identicon.innerHTML
var dataUri = 'data:image/svg+xml;charset=utf-8,'+encodeURIComponent(identiconSrc)
var img = document.createElement('img') var img = document.createElement('img')
img.src = dataUri img.src = dataUri
container.appendChild(img) container.appendChild(img)
} }
function jsNumberForAddress(address) {
var addr = address.slice(2, 10)
var seed = parseInt(addr, 16)
return seed
}

@ -0,0 +1,52 @@
var iconFactory
module.exports = function(jazzicon) {
if (!iconFactory) {
iconFactory = new IconFactory(jazzicon)
}
return iconFactory
}
function IconFactory(jazzicon) {
this.jazzicon = jazzicon
this.cache = {}
}
IconFactory.prototype.iconForAddress = function(address, diameter) {
if (this.isCached(address, diameter)) {
return this.cache[address][diameter]
}
const dataUri = this.generateNewUri(address, diameter)
this.cacheIcon(address, diameter, dataUri)
return dataUri
}
IconFactory.prototype.generateNewUri = function(address, diameter) {
var numericRepresentation = jsNumberForAddress(address)
var identicon = this.jazzicon(diameter, numericRepresentation)
var identiconSrc = identicon.innerHTML
var dataUri = 'data:image/svg+xml;charset=utf-8,'+encodeURIComponent(identiconSrc)
return dataUri
}
IconFactory.prototype.cacheIcon = function(address, diameter, icon) {
if (!(address in this.cache)) {
var sizeCache = {}
sizeCache[diameter] = icon
return this.cache[address] = sizeCache
} else {
return this.cache[address][diameter] = icon
}
}
IconFactory.prototype.isCached = function(address, diameter) {
return address in this.cache && diameter in this.cache[address]
}
function jsNumberForAddress(address) {
var addr = address.slice(2, 10)
var seed = parseInt(addr, 16)
return seed
}
Loading…
Cancel
Save