import 'babel-polyfill'; import whenDomReady from 'when-dom-ready'; import dogeSeed from '../'; import noUiSlider from 'nouislider'; const bitsToWords = { 128: 12, 160: 15, 192: 18, 224: 21, 256: 24 }; const main = async () => { await whenDomReady(); const seedText = document.querySelector('.seed-text'); const regenerateSeedButton = document.querySelector('.regenerate-seed'); const bitSlider = noUiSlider.create(document.querySelector('.bit-slider'), { range: {min: 128, max: 256}, step: 32, start: 256, pips: { mode: 'steps', density: 1, format: {to: bits => bitsToWords[bits]}, filter: (value, step) => step === 0 ? -1 : 1 } }); const generateSeed = () => { const bits = Number(bitSlider.get()); const seedPhraseWords = dogeSeed(bits).split(' '); const wrappedSeedPhrase = seedPhraseWords.map(word => `${word}`).join(' '); const wordCount = seedPhraseWords.length; seedText.dataset.wordCount = wordCount; seedText.innerHTML = wrappedSeedPhrase; }; regenerateSeedButton.addEventListener('click', generateSeed); bitSlider.on('update', generateSeed); generateSeed(); }; main();