Simplify and clean up frame logic

This commit is contained in:
Jay Kamat 2017-12-15 15:16:18 -05:00
parent 5c5f992821
commit 2898c416aa
No known key found for this signature in database
GPG Key ID: 5D2E399600F4F7B5

View File

@ -105,8 +105,7 @@ window._qutebrowser.webelem = (function() {
const client_rects = elem.getClientRects(); const client_rects = elem.getClientRects();
// Get location of frame and add it to element // Get location of frame if it exists and add it to element
// TODO How to generate a 0 object without this
let frame_offset_rect = null; let frame_offset_rect = null;
if (frame === null) { if (frame === null) {
// Dummy object with zero offset // Dummy object with zero offset
@ -206,9 +205,9 @@ window._qutebrowser.webelem = (function() {
// Recurse into frames and add them // Recurse into frames and add them
for (let i = 0; i < subelem_frames.length; i++) { for (let i = 0; i < subelem_frames.length; i++) {
if (iframe_same_domain(subelem_frames[i])) { if (iframe_same_domain(subelem_frames[i])) {
const subelems = subelem_frames[i].document.
querySelectorAll(selector);
const frame = subelem_frames[i]; const frame = subelem_frames[i];
const subelems = frame.document.
querySelectorAll(selector);
for (let elem_num = 0; elem_num < subelems.length; ++elem_num) { for (let elem_num = 0; elem_num < subelems.length; ++elem_num) {
if (!only_visible || is_visible(subelems[elem_num])) { if (!only_visible || is_visible(subelems[elem_num])) {
out.push(serialize_elem(subelems[elem_num], frame)); out.push(serialize_elem(subelems[elem_num], frame));
@ -223,8 +222,8 @@ window._qutebrowser.webelem = (function() {
// Runs a function in a frame until the result is not null, then return // Runs a function in a frame until the result is not null, then return
function run_frames(func) { function run_frames(func) {
for (let i = 0; i < window.frames.length; ++i) { for (let i = 0; i < window.frames.length; ++i) {
if (iframe_same_domain(window.frames[i])) { const frame = window.frames[i];
const frame = window.frames[i]; if (iframe_same_domain(frame)) {
const result = func(frame); const result = func(frame);
if (result) { if (result) {
return result; return result;
@ -242,10 +241,7 @@ window._qutebrowser.webelem = (function() {
const serialized_elem = run_frames((frame) => { const serialized_elem = run_frames((frame) => {
const element = frame.window.document.getElementById(id); const element = frame.window.document.getElementById(id);
if (element) { return serialize_elem(element, frame);
return serialize_elem(element, frame);
}
return null;
}); });
if (serialized_elem) { if (serialized_elem) {
@ -255,12 +251,12 @@ window._qutebrowser.webelem = (function() {
return null; return null;
}; };
// Check if elem is an iframe, and if so, run func on it. // Check if elem is an iframe, and if so, return the result of func on it.
// If no iframes match, return null // If no iframes match, return null
function replace_elem_frame(elem, func) { function call_if_frame(elem, func) {
for (let i = 0; i < window.frames.length; ++i) { for (let i = 0; i < window.frames.length; ++i) {
if (iframe_same_domain(window.frames[i])) { const frame = window.frames[i];
const frame = window.frames[i]; if (iframe_same_domain(frame)) {
if (frame.frameElement === elem) { if (frame.frameElement === elem) {
return func(frame); return func(frame);
} }
@ -279,7 +275,7 @@ window._qutebrowser.webelem = (function() {
} }
// Check if we got an iframe, and if so, recurse inside of it // Check if we got an iframe, and if so, recurse inside of it
const frame_elem = replace_elem_frame(elem, const frame_elem = call_if_frame(elem,
(frame) => serialize_elem(frame.document.activeElement, frame)); (frame) => serialize_elem(frame.document.activeElement, frame));
if (frame_elem === null) { if (frame_elem === null) {
@ -293,7 +289,7 @@ window._qutebrowser.webelem = (function() {
// Check if we got an iframe, and if so, recurse inside of it // Check if we got an iframe, and if so, recurse inside of it
const frame_elem = replace_elem_frame(elem, const frame_elem = call_if_frame(elem,
(frame) => { (frame) => {
// Subtract offsets due to being in an iframe // Subtract offsets due to being in an iframe
const frame_offset_rect = const frame_offset_rect =
@ -323,11 +319,7 @@ window._qutebrowser.webelem = (function() {
} }
return null; return null;
}); });
return serialized_frame_elem;
if (serialized_frame_elem) {
return serialized_frame_elem;
}
return null;
}; };
funcs.set_value = (id, value) => { funcs.set_value = (id, value) => {