mirror of
https://github.com/S2-/pwgen.git
synced 2025-08-02 17:00:03 +02:00
Compare commits
12 Commits
Author | SHA1 | Date | |
---|---|---|---|
06cfa9d0da | |||
fa5ba83db2 | |||
5c37f822db | |||
a53d60474d | |||
4d7fefccfc | |||
0d6278cd82 | |||
fee9b6b20a | |||
5959bc4cbe | |||
93c4955d1d | |||
3a64948533 | |||
a0d5b54b5d | |||
396236254a |
12
README.md
Normal file
12
README.md
Normal file
@@ -0,0 +1,12 @@
|
||||
# pwgen reloaded
|
||||
|
||||
## What it does
|
||||
|
||||
A firefox addon that generates a password and copies it to the clipboard
|
||||
|
||||

|
||||
|
||||
## install
|
||||
|
||||
On amo!
|
||||
[https://addons.mozilla.org/firefox/addon/pwgen-reloaded/](https://addons.mozilla.org/firefox/addon/pwgen-reloaded/)
|
Binary file not shown.
Before Width: | Height: | Size: 68 KiB After Width: | Height: | Size: 29 KiB |
@@ -1,5 +0,0 @@
|
||||
# pwgen
|
||||
|
||||
## What it does ##
|
||||
|
||||
Simply generate a password and copy it to the clipboard
|
@@ -2,7 +2,7 @@
|
||||
"description": "Just a toolbar button that generates a password and copies it to your clipboard.",
|
||||
"manifest_version": 2,
|
||||
"name": "pwgen reloaded",
|
||||
"version": "1.1.8",
|
||||
"version": "1.1.12",
|
||||
"homepage_url": "https://github.com/S2-/pwgen",
|
||||
"icons": {
|
||||
"48": "icons/lock-48.png"
|
||||
|
@@ -21,6 +21,30 @@ input[type="number"] {
|
||||
font-size: inherit;
|
||||
padding: 5px 10px;
|
||||
}
|
||||
|
||||
input[type="checkbox"] {
|
||||
margin-bottom: -7px;
|
||||
}
|
||||
|
||||
.copied {
|
||||
/*height: 100%;*/
|
||||
width: 100%;
|
||||
background-color: #FFF8DC;
|
||||
position: absolute;
|
||||
margin: -25px;
|
||||
margin-top: -5px;
|
||||
padding: 5px;
|
||||
text-align: center;
|
||||
}
|
||||
|
||||
.fadein {
|
||||
visibility: visible;
|
||||
opacity: 1;
|
||||
transition: opacity 1s linear;
|
||||
}
|
||||
|
||||
.fadeout {
|
||||
visibility: hidden;
|
||||
opacity: 0;
|
||||
transition: visibility 0s 1s, opacity 1s linear;
|
||||
}
|
||||
|
@@ -10,10 +10,14 @@
|
||||
</head>
|
||||
|
||||
<body>
|
||||
<div class="copied" style="display: none;">password copied to clipboard</div>
|
||||
|
||||
<form>
|
||||
|
||||
<div>
|
||||
<label for"length">length <input type="number" id="length" value="14" min="0" name="length"></label>
|
||||
<label>length</label>
|
||||
<label for"length-min">min <input type="number" id="length-min" value="14" min="0" name="length-min" style="width: 50px;"></label>
|
||||
<label for"length-max">max <input type="number" id="length-max" value="18" min="0" name="length-max" style="width: 50px;"></label>
|
||||
</div>
|
||||
|
||||
<div>
|
||||
|
@@ -14,9 +14,14 @@ function randPassword(length, includeSpecial) {
|
||||
return randPwd;
|
||||
}
|
||||
|
||||
function generateLength() {
|
||||
return Math.floor(Math.random() * getParams().lengthMax - getParams().lengthMin + 1) + getParams().lengthMin;
|
||||
}
|
||||
|
||||
function getParams() {
|
||||
return {
|
||||
length: parseInt(document.getElementById('length').value),
|
||||
lengthMin: parseInt(document.getElementById('length-min').value),
|
||||
lengthMax: parseInt(document.getElementById('length-max').value),
|
||||
special: document.getElementById('special').checked,
|
||||
directcopy: document.getElementById('directcopy').checked
|
||||
}
|
||||
@@ -24,7 +29,8 @@ function getParams() {
|
||||
|
||||
function loadOptions() {
|
||||
return browser.storage.local.get({
|
||||
length: 14,
|
||||
lengthMin: 14,
|
||||
lengthMax: 17,
|
||||
special: true,
|
||||
directcopy: false
|
||||
});
|
||||
@@ -34,20 +40,38 @@ function saveOptions(options) {
|
||||
return browser.storage.local.set(options);
|
||||
}
|
||||
|
||||
function copypasstoclippboard() {
|
||||
function copypasstoclippboard(cb) {
|
||||
setTimeout(function() {
|
||||
var copyText = document.getElementById('pw');
|
||||
copyText.select();
|
||||
document.execCommand('copy');
|
||||
if (typeof(cb) === 'function') {
|
||||
cb();
|
||||
}
|
||||
fade(document.getElementsByClassName('copied')[0]);
|
||||
}, 200);
|
||||
}
|
||||
|
||||
function fade(element) {
|
||||
var clone = element.cloneNode(true);
|
||||
clone.style.display = 'block';
|
||||
element.parentNode.insertBefore(clone, element.nextSibling);
|
||||
|
||||
setTimeout(() => {
|
||||
clone.className += ' fadeout';
|
||||
}, 500);
|
||||
|
||||
setTimeout(() => {
|
||||
clone.remove();
|
||||
}, 1600);
|
||||
}
|
||||
|
||||
document.addEventListener('DOMContentLoaded', function() {
|
||||
|
||||
document.getElementById('new').addEventListener('click', (ev) => {
|
||||
ev.preventDefault();
|
||||
var params = getParams();
|
||||
document.getElementById('pw').value = randPassword(params.length, params.special);
|
||||
document.getElementById('pw').value = randPassword(generateLength(), params.special);
|
||||
});
|
||||
|
||||
document.getElementById('copy').addEventListener('click', (ev) => {
|
||||
@@ -63,10 +87,11 @@ document.addEventListener('DOMContentLoaded', function() {
|
||||
}
|
||||
|
||||
loadOptions().then((options) => {
|
||||
document.getElementById('length').value = options.length;
|
||||
document.getElementById('length-min').value = options.lengthMin;
|
||||
document.getElementById('length-max').value = options.lengthMax;
|
||||
document.getElementById('special').checked = options.special;
|
||||
document.getElementById('directcopy').checked = options.directcopy;
|
||||
document.getElementById('pw').value = randPassword(getParams().length, getParams().special);
|
||||
document.getElementById('pw').value = randPassword(generateLength(), getParams().special);
|
||||
|
||||
if (options.directcopy) {
|
||||
copypasstoclippboard();
|
||||
@@ -74,4 +99,3 @@ document.addEventListener('DOMContentLoaded', function() {
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
|
Reference in New Issue
Block a user