diff --git a/public/views/backup.html b/public/views/backup.html
index 0e3dd024a..e7990c779 100644
--- a/public/views/backup.html
+++ b/public/views/backup.html
@@ -116,13 +116,16 @@
Please tap the words in order to confirm your backup phrase is correctly written.
-
-
+
+
+
+
-
-
-
-
+
+
+
diff --git a/src/js/controllers/backup.js b/src/js/controllers/backup.js
index 04f22b503..cb81c905a 100644
--- a/src/js/controllers/backup.js
+++ b/src/js/controllers/backup.js
@@ -1,11 +1,11 @@
'use strict';
angular.module('copayApp.controllers').controller('backupController',
- function($rootScope, $scope, $timeout, $document, $log, $state, $compile, go, lodash, profileService, gettext, bwcService, bwsError, walletService) {
+ function($rootScope, $scope, $timeout, $log, lodash, profileService, gettext, bwcService, bwsError, walletService) {
var self = this;
var fc = profileService.focusedClient;
- var customWords = [];
+ self.customWords = [];
self.walletName = fc.credentials.walletName;
var handleEncryptedWallet = function(client, cb) {
@@ -16,19 +16,6 @@ angular.module('copayApp.controllers').controller('backupController',
});
};
- function init() {
- $scope.passphrase = '';
- resetAllButtons();
- customWords = [];
- self.step = 1;
- self.deleted = false;
- self.credentialsEncrypted = false;
- self.selectComplete = false;
- self.backupError = false;
- }
-
- init();
-
if (fc.credentials && !fc.credentials.mnemonicEncrypted && !fc.credentials.mnemonic)
self.deleted = true;
@@ -40,6 +27,19 @@ angular.module('copayApp.controllers').controller('backupController',
initWords();
}
+ init();
+
+ function init() {
+ $scope.passphrase = '';
+ self.shuffledMnemonicWords = shuffledWords(self.mnemonicWords);
+ self.customWords = [];
+ self.step = 1;
+ self.deleted = false;
+ self.credentialsEncrypted = false;
+ self.selectComplete = false;
+ self.backupError = false;
+ };
+
self.goToStep = function(n) {
self.step = n;
if (self.step == 1)
@@ -49,18 +49,29 @@ angular.module('copayApp.controllers').controller('backupController',
if (self.step == 4) {
confirm();
}
- }
+ };
function initWords() {
var words = fc.getMnemonic();
self.xPrivKey = fc.credentials.xPrivKey;
walletService.lock(fc);
self.mnemonicWords = words.split(/[\u3000\s]+/);
- self.shuffledMnemonicWords = lodash.sortBy(self.mnemonicWords);;
+ self.shuffledMnemonicWords = shuffledWords(self.mnemonicWords);
self.mnemonicHasPassphrase = fc.mnemonicHasPassphrase();
self.useIdeograms = words.indexOf("\u3000") >= 0;
};
+ function shuffledWords(words) {
+ var sort = lodash.sortBy(words);
+
+ return lodash.map(sort, function(w) {
+ return {
+ word: w,
+ selected: false
+ };
+ });
+ };
+
self.toggle = function() {
self.error = "";
@@ -98,64 +109,37 @@ angular.module('copayApp.controllers').controller('backupController',
});
}
}
- }
+ };
- function resetAllButtons() {
- $document.getElementById('addWord').innerHTML = '';
- var nodes = $document.getElementById("buttons").getElementsByTagName('button');
- lodash.each(nodes, function(n) {
- $document.getElementById(n.id).disabled = false;
- });
- }
-
- self.enableButton = function(word) {
- $document.getElementById(word).disabled = false;
- lodash.remove(customWords, function(v) {
- return v == word;
- });
- }
-
- self.disableButton = function(index, word) {
- var element = {
- index: index,
- word: word
+ $scope.addButton = function(index, item) {
+ var newWord = {
+ word: item.word,
+ prevIndex: index
};
- $document.getElementById(index + word).disabled = true;
- customWords.push(element);
- self.addButton(index, word);
- }
-
- self.addButton = function(index, word) {
- var btnhtml = '
';
- var temp = $compile(btnhtml)($scope);
- angular.element($document.getElementById('addWord')).append(temp);
+ self.customWords.push(newWord);
+ self.shuffledMnemonicWords[index].selected = true;
self.shouldContinue();
- }
+ };
- self.removeButton = function(event) {
- var id = (event.target.id);
- $document.getElementById(id).remove();
- self.enableButton(id.substring(1));
- lodash.remove(customWords, function(d) {
- return d.index == id.substring(1, 3);
- });
+ $scope.removeButton = function(index, item) {
+ self.customWords.splice(index, 1);
+ self.shuffledMnemonicWords[item.prevIndex].selected = false;
self.shouldContinue();
- }
+ };
self.shouldContinue = function() {
- if (customWords.length == 12)
+ if (self.customWords.length == 12)
self.selectComplete = true;
else
self.selectComplete = false;
- }
+ };
function confirm() {
self.backupError = false;
var walletClient = bwcService.getClient();
var separator = self.useIdeograms ? '\u3000' : ' ';
- var customSentence = lodash.pluck(customWords, 'word').join(separator);
+ var customSentence = lodash.pluck(self.customWords, 'word').join(separator);
var passphrase = $scope.passphrase || '';
try {
@@ -173,7 +157,7 @@ angular.module('copayApp.controllers').controller('backupController',
}
$rootScope.$emit('Local/BackupDone');
- }
+ };
function backupError(err) {
$log.debug('Failed to verify backup: ', err);