DOM.privateKeyToggle = $(".private-key-toggle");
var derivationPath = DOM.bip44path.val();
- var currentPhrase = DOM.phrase.val();
- var currentPassphrase = DOM.passphrase.val();
function init() {
// Events
- DOM.phrase.on("keyup", delayedPhraseChanged);
- DOM.passphrase.on("keyup", delayedPhraseChanged);
+ DOM.phrase.on("input", delayedPhraseChanged);
+ DOM.passphrase.on("input", delayedPhraseChanged);
DOM.generate.on("click", generateClicked);
DOM.more.on("click", showMore);
- DOM.bip32path.on("keyup", bip32Changed);
- DOM.bip44purpose.on("keyup", bip44Changed);
- DOM.bip44coin.on("keyup", bip44Changed);
- DOM.bip44account.on("keyup", bip44Changed);
- DOM.bip44change.on("keyup", bip44Changed);
+ DOM.bip32path.on("input", bip32Changed);
+ DOM.bip44purpose.on("input", bip44Changed);
+ DOM.bip44coin.on("input", bip44Changed);
+ DOM.bip44account.on("input", bip44Changed);
+ DOM.bip44change.on("input", bip44Changed);
DOM.tab.on("click", tabClicked);
DOM.indexToggle.on("click", toggleIndexes);
DOM.addressToggle.on("click", toggleAddresses);
// Event handlers
function delayedPhraseChanged() {
- if (!hasChanged()) {
- return;
- }
hideValidationError();
showPending();
if (phraseChangeTimeoutEvent != null) {
calcBip32Seed(phrase, passphrase, derivationPath);
displayBip32Info();
hidePending();
- // Set current state so we only update as needed
- currentPhrase = phrase;
- currentPassphrase = passphrase;
}
function generateClicked() {
}
function derivationChanged() {
- hideValidationError();
- showPending();
- setTimeout(phraseChanged, 50);
+ delayedPhraseChanged();
}
function bip32Changed() {
function calcBip32Seed(phrase, passphrase, path) {
var seed = mnemonic.toSeed(phrase, passphrase);
- var seedHash = Bitcoin.crypto.sha256(seed).toString("hex");
- bip32RootKey = Bitcoin.HDNode.fromSeedHex(seedHash, network);
+ bip32RootKey = Bitcoin.HDNode.fromSeedHex(seed, network);
bip32ExtendedKey = bip32RootKey;
// Derive the key from the path
var pathBits = path.split("/");
function findPhraseErrors(phrase) {
// TODO make this right
// Preprocess the words
+ phrase = mnemonic.normalizeString(phrase);
var parts = phrase.split(" ");
var proper = [];
for (var i=0; i<parts.length; i++) {
var index = i+ start;
var key = bip32ExtendedKey.derive(index);
var address = key.getAddress().toString();
- var privkey = key.privKey.toWIF();
+ var privkey = key.privKey.toWIF(network);
addAddressToList(index, address, privkey);
}
}
.hide();
}
- function hasChanged() {
- var phraseChanged = DOM.phrase.val() != currentPhrase;
- var passphraseChanged = DOM.passphrase.val() != currentPassphrase;
- return phraseChanged || passphraseChanged;
- }
-
init();
})();