mirror of
https://github.com/bitwarden/browser
synced 2025-12-17 08:43:33 +00:00
handle autofill for pages with no forms, but still has fields
This commit is contained in:
@@ -17,14 +17,15 @@ function initAutofill() {
|
|||||||
metadata: {}
|
metadata: {}
|
||||||
};
|
};
|
||||||
|
|
||||||
var passwordFields = [];
|
var passwordFields = [],
|
||||||
|
passwordForms = [];
|
||||||
|
|
||||||
for (var i = 0; i < pageDetails.fields.length; i++) {
|
for (var i = 0; i < pageDetails.fields.length; i++) {
|
||||||
if (pageDetails.fields[i].type === 'password') {
|
if (pageDetails.fields[i].type === 'password') {
|
||||||
passwordFields.push(pageDetails.fields[i]);
|
passwordFields.push(pageDetails.fields[i]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var passwordForms = [];
|
|
||||||
for (var formKey in pageDetails.forms) {
|
for (var formKey in pageDetails.forms) {
|
||||||
for (var j = 0; j < passwordFields.length; j++) {
|
for (var j = 0; j < passwordFields.length; j++) {
|
||||||
if (formKey === passwordFields[j].form) {
|
if (formKey === passwordFields[j].form) {
|
||||||
@@ -34,11 +35,11 @@ function initAutofill() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!passwordForms.length) {
|
var password = null,
|
||||||
return null;
|
username = null,
|
||||||
}
|
loginForm = null;
|
||||||
|
|
||||||
var loginForm = null;
|
if (passwordForms.length) {
|
||||||
if (passwordForms.length > 1) {
|
if (passwordForms.length > 1) {
|
||||||
// More than one form with a password field is on the page.
|
// More than one form with a password field is on the page.
|
||||||
// This usually occurs when a website has a login and signup form on the same page.
|
// This usually occurs when a website has a login and signup form on the same page.
|
||||||
@@ -82,7 +83,6 @@ function initAutofill() {
|
|||||||
loginForm = passwordForms[0];
|
loginForm = passwordForms[0];
|
||||||
}
|
}
|
||||||
|
|
||||||
var password = null;
|
|
||||||
for (i = 0; i < pageDetails.fields.length; i++) {
|
for (i = 0; i < pageDetails.fields.length; i++) {
|
||||||
var f = pageDetails.fields[i];
|
var f = pageDetails.fields[i];
|
||||||
if (f.form === loginForm.opid && f.type === 'password') {
|
if (f.form === loginForm.opid && f.type === 'password') {
|
||||||
@@ -91,7 +91,6 @@ function initAutofill() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
var username = null;
|
|
||||||
for (i = 0; i < pageDetails.fields.length; i++) {
|
for (i = 0; i < pageDetails.fields.length; i++) {
|
||||||
f = pageDetails.fields[i];
|
f = pageDetails.fields[i];
|
||||||
if (f.form === loginForm.opid && (f.type === 'text' || f.type === 'email')
|
if (f.form === loginForm.opid && (f.type === 'text' || f.type === 'email')
|
||||||
@@ -100,16 +99,25 @@ function initAutofill() {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (loginForm.htmlAction) {
|
||||||
|
fillScript.autosubmit = { focusOpid: password.opid };
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (passwordFields.length == 1) {
|
||||||
|
password = passwordFields[0];
|
||||||
|
if (password.elementNumber > 0) {
|
||||||
|
username = pageDetails.fields[password.elementNumber - 1];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (username) {
|
if (username) {
|
||||||
fillScript.script.push(['click_on_opid', username.opid]);
|
fillScript.script.push(['click_on_opid', username.opid]);
|
||||||
fillScript.script.push(['fill_by_opid', username.opid, fillUsername]);
|
fillScript.script.push(['fill_by_opid', username.opid, fillUsername]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (password) {
|
||||||
fillScript.script.push(['click_on_opid', password.opid]);
|
fillScript.script.push(['click_on_opid', password.opid]);
|
||||||
fillScript.script.push(['fill_by_opid', password.opid, fillPassword]);
|
fillScript.script.push(['fill_by_opid', password.opid, fillPassword]);
|
||||||
|
|
||||||
if (loginForm.htmlAction) {
|
|
||||||
fillScript.autosubmit = { focusOpid: password.opid };
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return fillScript;
|
return fillScript;
|
||||||
|
|||||||
Reference in New Issue
Block a user