X-Git-Url: https://git.immae.eu/?p=perso%2FImmae%2FProjets%2FCryptomonnaies%2FBIP39.git;a=blobdiff_plain;f=src%2Fjs%2Findex.js;h=ff35755383b2ab5e26330dafb85d26dbe1c24fe7;hp=36af5782a2f511f9798b134f57c12600b087ce82;hb=7733ac322b60127fa8d845f90e7605625996c9d1;hpb=139becaf2cc22c99e2813098c1411164c9baef26 diff --git a/src/js/index.js b/src/js/index.js index 36af578..ff35755 100644 --- a/src/js/index.js +++ b/src/js/index.js @@ -40,6 +40,7 @@ DOM.entropyWordIndexes = DOM.entropyContainer.find(".word-indexes"); DOM.entropyChecksum = DOM.entropyContainer.find(".checksum"); DOM.entropyMnemonicLength = DOM.entropyContainer.find(".mnemonic-length"); + DOM.entropyWeakEntropyOverrideWarning = DOM.entropyContainer.find(".weak-entropy-override-warning"); DOM.entropyFilterWarning = DOM.entropyContainer.find(".filter-warning"); DOM.phrase = $(".phrase"); DOM.passphrase = $(".passphrase"); @@ -76,6 +77,8 @@ DOM.bip49accountXprv = $("#bip49 .account-xprv"); DOM.bip49accountXpub = $("#bip49 .account-xpub"); DOM.bip49change = $("#bip49 .change"); + DOM.bip84unavailable = $("#bip84 .unavailable"); + DOM.bip84available = $("#bip84 .available"); DOM.bip84path = $("#bip84-path"); DOM.bip84purpose = $("#bip84 .purpose"); DOM.bip84coin = $("#bip84 .coin"); @@ -88,9 +91,10 @@ DOM.bip141path = $("#bip141-path"); DOM.bip141semantics = $(".bip141-semantics"); DOM.generatedStrength = $(".generate-container .strength"); + DOM.generatedStrengthWarning = $(".generate-container .warning"); DOM.hardenedAddresses = $(".hardened-addresses"); - DOM.useBitpayAddressesContainer = $(".use-bitpay-addresses-container"); - DOM.useBitpayAddresses = $(".use-bitpay-addresses"); + DOM.bitcoinCashAddressTypeContainer = $(".bch-addr-type-container"); + DOM.bitcoinCashAddressType = $("[name=bch-addr-type]") DOM.useBip38 = $(".use-bip38"); DOM.bip38Password = $(".bip38-password"); DOM.addresses = $(".addresses"); @@ -114,6 +118,7 @@ function init() { // Events + DOM.generatedStrength.on("change", generatedStrengthChanged); DOM.network.on("change", networkChanged); DOM.bip32Client.on("change", bip32ClientChanged); DOM.useEntropy.on("change", setEntropyVisibility); @@ -144,7 +149,7 @@ DOM.privateKeyToggle.on("click", togglePrivateKeys); DOM.csvTab.on("click", updateCsv); DOM.languages.on("click", languageChanged); - DOM.useBitpayAddresses.on("change", useBitpayAddressesChange); + DOM.bitcoinCashAddressType.on("change", bitcoinCashAddressTypeChange); setQrEvents(DOM.showQrEls); disableForms(); hidePending(); @@ -155,21 +160,25 @@ // Event handlers + function generatedStrengthChanged() { + var strength = parseInt(DOM.generatedStrength.val()); + if (strength < 12) { + DOM.generatedStrengthWarning.removeClass("hidden"); + } + else { + DOM.generatedStrengthWarning.addClass("hidden"); + } + } + function networkChanged(e) { clearDerivedKeys(); clearAddressesList(); DOM.litecoinLtubContainer.addClass("hidden"); - DOM.useBitpayAddressesContainer.addClass("hidden"); + DOM.bitcoinCashAddressTypeContainer.addClass("hidden"); var networkIndex = e.target.value; var network = networks[networkIndex]; network.onSelect(); - if (network.segwitAvailable) { - adjustNetworkForSegwit(); - showSegwitAvailable(); - } - else { - showSegwitUnavailable(); - } + adjustNetworkForSegwit(); if (seed != null) { phraseChanged(); } @@ -359,8 +368,11 @@ showPending(); // Don't show segwit if it's selected but network doesn't support it if (segwitSelected() && !networkHasSegwit()) { + showSegwitUnavailable(); + hidePending(); return; } + showSegwitAvailable(); // Get the derivation path var derivationPath = getDerivationPath(); var errorText = findDerivationPathErrors(derivationPath); @@ -411,8 +423,7 @@ }, 50); } - function useBitpayAddressesChange() { - setBitcoinCashNetworkValues(); + function bitcoinCashAddressTypeChange() { phraseChanged(); } @@ -801,7 +812,7 @@ var keyPair = key.keyPair; var useUncompressed = useBip38; if (useUncompressed) { - keyPair = new bitcoinjs.bitcoin.ECPair(keyPair.d, null, { compressed: false }); + keyPair = new bitcoinjs.bitcoin.ECPair(keyPair.d, null, { network: network, compressed: false }); } // get address var address = keyPair.getAddress().toString(); @@ -809,7 +820,7 @@ var hasPrivkey = !key.isNeutered(); var privkey = "NA"; if (hasPrivkey) { - privkey = keyPair.toWIF(network); + privkey = keyPair.toWIF(); // BIP38 encode private key if required if (useBip38) { privkey = bitcoinjsBip38.encrypt(keyPair.d.toBuffer(), false, bip38password, function(p) { @@ -839,6 +850,16 @@ privkey = convertRipplePriv(privkey); address = convertRippleAdrr(address); } + // Bitcoin Cash address format may vary + if (networks[DOM.network.val()].name == "BCH - Bitcoin Cash") { + var bchAddrType = DOM.bitcoinCashAddressType.filter(":checked").val(); + if (bchAddrType == "cashaddr") { + address = bchaddr.toCashAddress(address); + } + else if (bchAddrType == "bitpay") { + address = bchaddr.toBitpayAddress(address); + } + } // Segwit addresses are different if (isSegwit) { if (!segwitAvailable) { @@ -1142,7 +1163,7 @@ function wordArrayToPhrase(words) { var phrase = words.join(" "); var language = getLanguageFromPhrase(phrase); - if (language == "japanese" || language == "korean") { + if (language == "japanese") { phrase = words.join("\u3000"); } return phrase; @@ -1178,6 +1199,17 @@ mnemonicLength = parseInt(mnemonicLength); var numberOfBits = 32 * mnemonicLength / 3; bits = bits.substring(0, numberOfBits); + // show warning for weak entropy override + if (mnemonicLength / 3 * 32 > entropy.binaryStr.length) { + DOM.entropyWeakEntropyOverrideWarning.removeClass("hidden"); + } + else { + DOM.entropyWeakEntropyOverrideWarning.addClass("hidden"); + } + } + else { + // hide warning for weak entropy override + DOM.entropyWeakEntropyOverrideWarning.addClass("hidden"); } // Discard trailing entropy var bitsToUse = Math.floor(bits.length / 32) * 32; @@ -1358,7 +1390,20 @@ } function networkHasSegwit() { - return networks[DOM.network.val()].segwitAvailable; + var n = network; + if ("baseNetwork" in network) { + n = bitcoinjs.bitcoin.networks[network.baseNetwork]; + } + // check if only p2wpkh params are required + if (p2wpkhSelected()) { + return "p2wpkh" in n; + } + // check if only p2wpkh-in-p2sh params are required + else if (p2wpkhInP2shSelected()) { + return "p2wpkhInP2sh" in n; + } + // require both if it's unclear which params are required + return "p2wpkh" in n && "p2wpkhInP2sh" in n; } function bip49TabSelected() { @@ -1382,6 +1427,8 @@ function showSegwitAvailable() { DOM.bip49unavailable.addClass("hidden"); DOM.bip49available.removeClass("hidden"); + DOM.bip84unavailable.addClass("hidden"); + DOM.bip84available.removeClass("hidden"); DOM.bip141unavailable.addClass("hidden"); DOM.bip141available.removeClass("hidden"); } @@ -1389,23 +1436,12 @@ function showSegwitUnavailable() { DOM.bip49available.addClass("hidden"); DOM.bip49unavailable.removeClass("hidden"); + DOM.bip84available.addClass("hidden"); + DOM.bip84unavailable.removeClass("hidden"); DOM.bip141available.addClass("hidden"); DOM.bip141unavailable.removeClass("hidden"); } - function useBitpayAddresses() { - return !(DOM.useBitpayAddresses.prop("checked")); - } - - function setBitcoinCashNetworkValues() { - if (useBitpayAddresses()) { - network = bitcoinjs.bitcoin.networks.bitcoin; - } - else { - network = bitcoinjs.bitcoin.networks.bitcoinCashBitbpay; - } - } - function adjustNetworkForSegwit() { // If segwit is selected the xpub/xprv prefixes need to be adjusted // to avoid accidentally importing BIP49 xpub to BIP44 watch only @@ -1514,34 +1550,92 @@ } var networks = [ + { + name: "AC - Asiacoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.asiacoin; + setHdCoin(51); + }, + }, + { + name: "ACC - Adcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.adcoin; + setHdCoin(161); + }, + }, + { + name: "AUR - Auroracoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.auroracoin; + setHdCoin(85); + }, + }, { name: "AXE - Axe", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.axe; - setHdCoin(0); + setHdCoin(4242); + }, + }, + { + name: "BCA - Bitcoin Atom", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.atom; + setHdCoin(185); }, }, { name: "BCH - Bitcoin Cash", - segwitAvailable: false, onSelect: function() { - DOM.useBitpayAddressesContainer.removeClass("hidden"); - setBitcoinCashNetworkValues(); + DOM.bitcoinCashAddressTypeContainer.removeClass("hidden"); setHdCoin(145); }, }, + { + name: "BEET - Beetlecoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.beetlecoin; + setHdCoin(800); + }, + }, + { + name: "BELA - Belacoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.belacoin; + setHdCoin(73); + }, + }, { name: "BLK - BlackCoin", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.blackcoin; setHdCoin(10); }, }, + { + name: "BRIT - Britcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.britcoin; + setHdCoin(70); + }, + }, + { + name: "BSD - Bitsend", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.bitsend; + setHdCoin(91); + }, + }, + { + name: "BTA - Bata", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.bata; + setHdCoin(89); + }, + }, { name: "BTC - Bitcoin", - segwitAvailable: true, onSelect: function() { network = bitcoinjs.bitcoin.networks.bitcoin; setHdCoin(0); @@ -1549,31 +1643,83 @@ }, { name: "BTC - Bitcoin Testnet", - segwitAvailable: true, onSelect: function() { network = bitcoinjs.bitcoin.networks.testnet; setHdCoin(1); }, }, + { + name: "BTCP - Bitcoin Private", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.bitcoinprivate; + setHdCoin(183); + }, + }, + { + name: "BTCZ - Bitcoinz", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.bitcoinz; + setHdCoin(177); + }, + }, { name: "BTG - Bitcoin Gold", - segwitAvailable: true, onSelect: function() { network = bitcoinjs.bitcoin.networks.bgold; - setHdCoin(0); + setHdCoin(156); + }, + }, + { + name: "BTX - Bitcore", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.bitcore; + setHdCoin(160); + }, + }, + { + name: "CCN - Cannacoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.cannacoin; + setHdCoin(19); + }, + }, + { + name: "CDN - Canadaecoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.canadaecoin; + setHdCoin(34); }, }, { name: "CLAM - Clams", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.clam; setHdCoin(23); }, }, + { + name: "CLUB - Clubcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.clubcoin; + setHdCoin(79); + }, + }, + { + name: "CMP - Compcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.compcoin; + setHdCoin(71); + }, + }, + { + name: "CRAVE - Crave", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.crave; + setHdCoin(186); + }, + }, { name: "CRW - Crown", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.crown; setHdCoin(72); @@ -1581,7 +1727,6 @@ }, { name: "DASH - Dash", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.dash; setHdCoin(5); @@ -1589,55 +1734,188 @@ }, { name: "DASH - Dash Testnet", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.dashtn; setHdCoin(1); }, }, + { + name: "DFC - Defcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.defcoin; + setHdCoin(1337); + }, + }, + { + name: "DGB - Digibyte", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.digibyte; + setHdCoin(20); + }, + }, + { + name: "DGC - Digitalcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.digitalcoin; + setHdCoin(18); + }, + }, + { + name: "DMD - Diamond", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.diamond; + setHdCoin(152); + }, + }, { name: "DNR - Denarius", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.denarius; - setHdCoin(0); + setHdCoin(116); }, }, { name: "DOGE - Dogecoin", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.dogecoin; setHdCoin(3); }, }, + { + name: "ECN - Ecoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.ecoin; + setHdCoin(115); + }, + }, + { + name: "EDRC - Edrcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.edrcoin; + setHdCoin(56); + }, + }, + { + name: "EFL - Egulden", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.egulden; + setHdCoin(78); + }, + }, + { + name: "EMC2 - Einsteinium", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.einsteinium; + setHdCoin(41); + }, + }, + { + name: "ERC - Europecoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.europecoin; + setHdCoin(151); + }, + }, { name: "ETH - Ethereum", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.bitcoin; setHdCoin(60); }, }, + { + name: "EXCL - Exclusivecoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.exclusivecoin; + setHdCoin(190); + }, + }, { name: "FJC - Fujicoin", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.fujicoin; setHdCoin(75); }, }, + { + name: "FLASH - Flashcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.flashcoin; + setHdCoin(120); + }, + }, + { + name: "FRST - Firstcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.firstcoin; + setHdCoin(167); + }, + }, + { + name: "FTC - Feathercoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.feathercoin; + setHdCoin(8); + }, + }, { name: "GAME - GameCredits", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.game; setHdCoin(101); }, }, + { + name: "GBX - Gobyte", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.gobyte; + setHdCoin(176); + }, + }, + { + name: "GCR - GCRCoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.gcr; + setHdCoin(79); + }, + }, + { + name: "GRC - Gridcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.gridcoin; + setHdCoin(84); + }, + }, + { + name: "HNC - Helleniccoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.helleniccoin; + setHdCoin(168); + }, + }, + { + name: "INSN - Insane", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.insane; + setHdCoin(68); + }, + }, + { + name: "IOP - Iop", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.iop; + setHdCoin(66); + }, + }, + { + name: "IXC - Ixcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.ixcoin; + setHdCoin(86); + }, + }, { name: "JBS - Jumbucks", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.jumbucks; setHdCoin(26); @@ -1651,50 +1929,178 @@ setHdCoin(141); }, }, + { + name: "KOBO - Kobocoin", + bip49available: false, + onSelect: function() { + network = bitcoinjs.bitcoin.networks.kobocoin; + setHdCoin(196); + }, + }, + { + name: "LBC - Library Credits", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.lbry; + setHdCoin(140); + }, + }, + { + name: "LCC - Litecoincash", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.litecoincash; + setHdCoin(192); + }, + }, + { + name: "LDCN - Landcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.landcoin; + setHdCoin(63); + }, + }, + { + name: "LINX - Linx", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.linx; + setHdCoin(114); + }, + }, { name: "LTC - Litecoin", - segwitAvailable: true, onSelect: function() { network = bitcoinjs.bitcoin.networks.litecoin; setHdCoin(2); DOM.litecoinLtubContainer.removeClass("hidden"); }, }, + { + name: "LYNX - Lynx", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.lynx; + setHdCoin(191); + }, + }, { name: "MAZA - Maza", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.maza; setHdCoin(13); }, }, + { + name: "MNX - Minexcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.minexcoin; + setHdCoin(182); + }, + }, { name: "MONA - Monacoin", - segwitAvailable: true, onSelect: function() { network = bitcoinjs.bitcoin.networks.monacoin, setHdCoin(22); }, }, + { + name: "NAV - Navcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.navcoin; + setHdCoin(130); + }, + }, + { + name: "NEBL - Neblio", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.neblio; + setHdCoin(146); + }, + }, + { + name: "NEOS - Neoscoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.neoscoin; + setHdCoin(25); + }, + }, + { + name: "NLG - Gulden", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.gulden; + setHdCoin(87); + }, + }, { name: "NMC - Namecoin", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.namecoin; setHdCoin(7); }, }, + { + name: "NRG - Energi", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.energi; + setHdCoin(204); + }, + }, + { + name: "NRO - Neurocoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.neurocoin; + setHdCoin(110); + }, + }, + { + name: "NSR - Nushares", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.nushares; + setHdCoin(11); + }, + }, + { + name: "NYC - Newyorkc", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.newyorkc; + setHdCoin(179); + }, + }, + { + name: "NVC - Novacoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.novacoin; + setHdCoin(50); + }, + }, + { + name: "OK - Okcash", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.okcash; + setHdCoin(69); + }, + }, + { + name: "OMNI - Omnicore", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.omnicore; + setHdCoin(200); + }, + }, { name: "ONX - Onixcoin", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.onixcoin; setHdCoin(174); }, }, + { + name: "PINK - Pinkcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.pinkcoin; + setHdCoin(117); + }, + }, { name: "PIVX - PIVX", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.pivx; setHdCoin(119); @@ -1702,23 +2108,69 @@ }, { name: "PIVX - PIVX Testnet", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.pivxtestnet; setHdCoin(1); }, }, + { + name: "POSW - POSWcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.poswcoin; + setHdCoin(47); + }, + }, + { + name: "POT - Potcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.potcoin; + setHdCoin(81); + }, + }, { name: "PPC - Peercoin", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.peercoin; setHdCoin(6); }, }, + { + name: "PSB - Pesobit", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.pesobit; + setHdCoin(62); + }, + }, + { + name: "PUT - Putincoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.putincoin; + setHdCoin(122); + }, + }, + { + name: "RBY - Rubycoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.rubycoin; + setHdCoin(16); + }, + }, + { + name: "RDD - Reddcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.reddoin; + setHdCoin(4); + }, + }, + { + name: "RVR - RevolutionVR", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.revolutionvr; + setHdCoin(129); + }, + }, { name: "SDC - ShadowCash", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.shadow; setHdCoin(35); @@ -1726,7 +2178,6 @@ }, { name: "SDC - ShadowCash Testnet", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.shadowtn; setHdCoin(1); @@ -1734,7 +2185,6 @@ }, { name: "SLM - Slimcoin", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.slimcoin; setHdCoin(63); @@ -1742,23 +2192,83 @@ }, { name: "SLM - Slimcoin Testnet", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.slimcointn; setHdCoin(111); }, }, + { + name: "SLR - Solarcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.solarcoin; + setHdCoin(58); + }, + }, + { + name: "SMLY - Smileycoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.smileycoin; + setHdCoin(59); + }, + }, + { + name: "STRAT - Stratis", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.stratis; + setHdCoin(105); + }, + }, + { + name: "SYS - Syscoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.syscoin; + setHdCoin(57); + }, + }, + { + name: "THC - Hempcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.hempcoin; + setHdCoin(113); + }, + }, + { + name: "TOA - Toa", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.toa; + setHdCoin(159); + }, + }, + { + name: "USC - Ultimatesecurecash", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.ultimatesecurecash; + setHdCoin(112); + }, + }, { name: "USNBT - NuBits", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.nubits; setHdCoin(12); }, }, + { + name: "UNO - Unobtanium", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.unobtanium; + setHdCoin(92); + }, + }, + { + name: "VASH - Vpncoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.vpncoin; + setHdCoin(33); + }, + }, { name: "VIA - Viacoin", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.viacoin; setHdCoin(14); @@ -1766,15 +2276,41 @@ }, { name: "VIA - Viacoin Testnet", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.viacointestnet; setHdCoin(1); }, }, + { + name: "VIVO - Vivo", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.vivo; + setHdCoin(166); + }, + }, + { + name: "VTC - Vertcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.vertcoin; + setHdCoin(28); + }, + }, + { + name: "WC - Wincoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.wincoin; + setHdCoin(181); + }, + }, + { + name: "XBC - Bitcoinplus", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.bitcoinplus; + setHdCoin(65); + }, + }, { name: "XMY - Myriadcoin", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.myriadcoin; setHdCoin(90); @@ -1782,12 +2318,67 @@ }, { name: "XRP - Ripple", - segwitAvailable: false, onSelect: function() { network = bitcoinjs.bitcoin.networks.bitcoin; setHdCoin(144); }, }, + { + name: "XVC - Vcash", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.vcash; + setHdCoin(127); + }, + }, + { + name: "XVG - Verge", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.verge; + setHdCoin(77); + }, + }, + { + name: "XWC - Whitecoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.whitecoin; + setHdCoin(155); + }, + }, + { + name: "XZC - Zcoin", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.zcoin; + setHdCoin(136); + }, + }, + { + name: "ZCL - Zclassic", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.zclassic; + setHdCoin(147); + }, + }, + { + name: "ZEC - Zcash", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.zcash; + setHdCoin(133); + }, + }, + { + name: "XUEZ - Xuez", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.xuez; + setHdCoin(225); + }, + }, + { + name: "ZEN - Zencash", + onSelect: function() { + network = bitcoinjs.bitcoin.networks.zencash; + setHdCoin(121); + }, + }, ] var clients = [