|
| 1 | +// Variables to access HTML |
| 2 | +let content = document.querySelector("[password-display]"); |
| 3 | +const copyMsg = document.querySelector("[datacopy-msg]"); |
| 4 | +const copyButton = document.querySelector("[copy-button]"); |
| 5 | + |
| 6 | +let passwordNo = document.querySelector("[pass-len]"); |
| 7 | +let slideTag = document.querySelector("[slider]"); |
| 8 | + |
| 9 | +let uppercase = document.querySelector("#uppercase"); |
| 10 | +let lowerCase = document.querySelector("#lowercase"); |
| 11 | +let numberInput = document.querySelector("#number"); |
| 12 | +let symbol = document.querySelector("#symbol"); |
| 13 | + |
| 14 | +let indicator = document.querySelector("[strength-indicator]"); |
| 15 | + |
| 16 | +const generate = document.querySelector("#generate"); |
| 17 | + |
| 18 | + |
| 19 | + |
| 20 | + |
| 21 | +let passWord = ""; |
| 22 | +let passWordLen = 10; // Default |
| 23 | +let color = '#b4b4b4'; |
| 24 | + |
| 25 | +handleSlider(); // Call for first time after reload page |
| 26 | +function handleSlider(){ |
| 27 | + slideTag.value = passWordLen; |
| 28 | + passwordNo.textContent = passWordLen; |
| 29 | +} |
| 30 | + |
| 31 | +slideTag.addEventListener('input', (event)=>{ |
| 32 | + passWordLen = event.target.value; |
| 33 | + handleSlider(); |
| 34 | +}) |
| 35 | + |
| 36 | +indicatorfun(color); //call |
| 37 | +indicatorfun(color); |
| 38 | +function indicatorfun(color){ |
| 39 | + indicator.style.backgroundColor = color; |
| 40 | + indicator.style.boxShadow = "100px 200px 2px color"; |
| 41 | + |
| 42 | +} |
| 43 | + |
| 44 | +// Universal formula to get any random no. [min, max} |
| 45 | +function getRandomInt(min, max){ |
| 46 | + return Math.floor( Math.random()*(max-min) ) + min ; |
| 47 | +} |
| 48 | + |
| 49 | +function getRandomNumber(){ |
| 50 | + return getRandomInt(0, 9); |
| 51 | +} |
| 52 | + |
| 53 | +function getRandomLowerCase(){ |
| 54 | + return String.fromCharCode(getRandomInt(97, 123)); |
| 55 | +} |
| 56 | + |
| 57 | +function getRandomUpperCase(){ |
| 58 | + return String.fromCharCode(getRandomInt(65, 91)); |
| 59 | +} |
| 60 | + |
| 61 | +const symbolArr = "\|<`(>,.?{~!@#[+-=^&*)/$%_}]"; |
| 62 | +function getRandomSymbol(){ |
| 63 | + return symbolArr.charAt((getRandomInt(0, symbolArr.length))); |
| 64 | +} |
| 65 | + |
| 66 | +// Calculation of strength of a password and calls for indicator |
| 67 | +function calcStrength(){ |
| 68 | + let upperVar = uppercase.checked; |
| 69 | + let lowerVar = lowerCase.checked; |
| 70 | + let numberVar = number.checked; |
| 71 | + let symbolVar = symbol.checked; |
| 72 | + |
| 73 | + // Own Logic |
| 74 | + if(upperVar && lowerVar && numberVar && symbolVar){ |
| 75 | + indicatorfun('#3cb371'); |
| 76 | + }else if((upperVar && lowerVar && numberVar) || (upperVar && lowerVar && symbolVar) || (upperVar && numberVar && symbolVar)){ |
| 77 | + indicatorfun('#3cb371') |
| 78 | + }else if((upperVar && lowerVar && !numberVar && !symbolVar) || (upperVar && !lowerVar && !numberVar && symbolVar) || (!upperVar && !lowerVar && numberVar && symbolVar) || (!upperVar && lowerVar && numberVar && !symbolVar)){ |
| 79 | + indicatorfun('#ffa500'); |
| 80 | + }else{ |
| 81 | + indicatorfun('#ff0000'); |
| 82 | + } |
| 83 | +} |
| 84 | + |
| 85 | + |
| 86 | +// Clipboard API fetched function. [WriteText] |
| 87 | +async function copyToClipboard(){ |
| 88 | + try{ |
| 89 | + await navigator.clipboard.writeText(content.textContent); |
| 90 | + copyMsg.textContent = "Copied"; |
| 91 | + } |
| 92 | + catch(e){ |
| 93 | + copyMsg.textContent = "Failed to copy"; |
| 94 | + } |
| 95 | + copyMsg.classList.remove("hidden"); |
| 96 | + // For disappering |
| 97 | + setTimeout(()=>{ |
| 98 | + copyMsg.classList.add("hidden"); |
| 99 | + }, 2000); |
| 100 | +} |
| 101 | + |
| 102 | +copyButton.addEventListener('click', (event) =>{ |
| 103 | + if(content.value) copyToClipboard(); // only is password is generated |
| 104 | +}); |
| 105 | + |
| 106 | + |
| 107 | +// For final output + suffle array - [Protection algo] |
| 108 | +// function suffleArr(array){ |
| 109 | +// let pass = ""; |
| 110 | +// for(let i = array.length-1; i>0; i--){ |
| 111 | +// let randomInd = getRandomInt(0,array.length); |
| 112 | +// let temp = array[randomInd]; |
| 113 | +// array[randomInd] = array[i]; |
| 114 | +// array[i] = temp; |
| 115 | +// pass = array[i] + pass ; |
| 116 | +// } |
| 117 | +// return pass; |
| 118 | +// } |
| 119 | + |
| 120 | + |
| 121 | +// Actual Brain |
| 122 | +function generatePassword(){ |
| 123 | + let arr = []; |
| 124 | + passWord = ""; |
| 125 | + if(uppercase.checked){ |
| 126 | + passWord+= getRandomUpperCase(); |
| 127 | + arr.push(getRandomUpperCase); |
| 128 | + } |
| 129 | + if(lowerCase.checked){ |
| 130 | + passWord+= getRandomLowerCase(); |
| 131 | + arr.push(getRandomLowerCase); |
| 132 | + } |
| 133 | + if(numberInput.checked){ |
| 134 | + passWord+= getRandomNumber(); |
| 135 | + arr.push(getRandomNumber); |
| 136 | + } |
| 137 | + if(symbol.checked){ |
| 138 | + passWord+= getRandomSymbol(); |
| 139 | + arr.push(getRandomSymbol); |
| 140 | + } |
| 141 | + // If any check box is not checked. |
| 142 | + if(passWord.length<=0) { |
| 143 | + content.placeholder = "Choose atleast one box"; |
| 144 | + return ; |
| 145 | + } |
| 146 | + |
| 147 | + for(let i=passWord.length; i<passWordLen; i++){ |
| 148 | + let fun = arr[getRandomInt(0, arr.length)](); |
| 149 | + passWord+= fun; |
| 150 | + } |
| 151 | + //passWord = suffleArr(Array.from(passWord)); |
| 152 | + content.value = passWord; |
| 153 | + calcStrength(); |
| 154 | +} |
| 155 | + |
| 156 | +generate.addEventListener('click', generatePassword); |
0 commit comments