Client select has 'custom derivation path' option

* Specific clients cause derivation path input to be readonly
* Rename ambiguous variable client-phrase to bip32-client
This commit is contained in:
Ian Coleman
2017-02-19 11:49:51 +11:00
parent a2e3e81989
commit 29bf60f53b
2 changed files with 20 additions and 14 deletions

View File

@@ -368,9 +368,10 @@
</p>
</div>
<div class="form-group">
<label for="client-phrase" class="col-sm-2 control-label" data-translate>Client</label>
<label for="bip32-client" class="col-sm-2 control-label" data-translate>Client</label>
<div class="col-sm-10">
<select id="client-phrase" class="client form-control">
<select id="bip32-client" class="client form-control">
<option value="custom">Custom derivation path</option>
<!-- populated by javascript -->
</select>
</div>

View File

@@ -23,9 +23,8 @@
var DOM = {};
DOM.network = $(".network");
DOM.client = $(".client");
DOM.bip32Client = $("#bip32-client");
DOM.phraseNetwork = $("#network-phrase");
DOM.phraseClient = $("#client-phrase");
DOM.useEntropy = $(".use-entropy");
DOM.entropyContainer = $(".entropy-container");
DOM.entropy = $(".entropy");
@@ -79,7 +78,7 @@
function init() {
// Events
DOM.network.on("change", networkChanged);
DOM.client.on("change", clientChanged);
DOM.bip32Client.on("change", bip32ClientChanged);
DOM.useEntropy.on("change", setEntropyVisibility);
DOM.entropy.on("input", delayedEntropyChanged);
DOM.entropyMnemonicLength.on("change", entropyChanged);
@@ -120,15 +119,21 @@
rootKeyChanged();
}
}
function clientChanged(e) {
var clientIndex = e.target.value;
clients[clientIndex].onSelect();
if (seed != null) {
phraseChanged();
function bip32ClientChanged(e) {
var clientIndex = DOM.bip32Client.val();
if (clientIndex == "custom") {
DOM.bip32path.prop("readonly", false);
}
else {
rootKeyChanged();
DOM.bip32path.prop("readonly", true);
clients[clientIndex].onSelect();
if (seed != null) {
phraseChanged();
}
else {
rootKeyChanged();
}
}
}
@@ -725,14 +730,14 @@
DOM.phraseNetwork.append(option);
}
}
function populateClientSelect() {
for (var i=0; i<clients.length; i++) {
var client = clients[i];
var option = $("<option>");
option.attr("value", i);
option.text(client.name);
DOM.phraseClient.append(option);
DOM.bip32Client.append(option);
}
}