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();
// Get location of frame and add it to element
// TODO How to generate a 0 object without this
// Get location of frame if it exists and add it to element
let frame_offset_rect = null;
if (frame === null) {
// Dummy object with zero offset
@ -206,9 +205,9 @@ window._qutebrowser.webelem = (function() {
// Recurse into frames and add them
for (let i = 0; i < subelem_frames.length; i++) {
if (iframe_same_domain(subelem_frames[i])) {
const subelems = subelem_frames[i].document.
querySelectorAll(selector);
const frame = subelem_frames[i];
const subelems = frame.document.
querySelectorAll(selector);
for (let elem_num = 0; elem_num < subelems.length; ++elem_num) {
if (!only_visible || is_visible(subelems[elem_num])) {
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
function run_frames(func) {
for (let i = 0; i < window.frames.length; ++i) {
if (iframe_same_domain(window.frames[i])) {
const frame = window.frames[i];
if (iframe_same_domain(frame)) {
const result = func(frame);
if (result) {
return result;
@ -242,10 +241,7 @@ window._qutebrowser.webelem = (function() {
const serialized_elem = run_frames((frame) => {
const element = frame.window.document.getElementById(id);
if (element) {
return serialize_elem(element, frame);
}
return null;
});
if (serialized_elem) {
@ -255,12 +251,12 @@ window._qutebrowser.webelem = (function() {
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
function replace_elem_frame(elem, func) {
function call_if_frame(elem, func) {
for (let i = 0; i < window.frames.length; ++i) {
if (iframe_same_domain(window.frames[i])) {
const frame = window.frames[i];
if (iframe_same_domain(frame)) {
if (frame.frameElement === elem) {
return func(frame);
}
@ -279,7 +275,7 @@ window._qutebrowser.webelem = (function() {
}
// 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));
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
const frame_elem = replace_elem_frame(elem,
const frame_elem = call_if_frame(elem,
(frame) => {
// Subtract offsets due to being in an iframe
const frame_offset_rect =
@ -323,11 +319,7 @@ window._qutebrowser.webelem = (function() {
}
return null;
});
if (serialized_frame_elem) {
return serialized_frame_elem;
}
return null;
};
funcs.set_value = (id, value) => {