mirror of
https://github.com/servo/servo.git
synced 2025-06-26 01:54:33 +01:00
34 lines
1.5 KiB
JavaScript
34 lines
1.5 KiB
JavaScript
/**
|
|
* The function positions a new div to exactly the bounding client rect without
|
|
* using sticky position. If it's directly under the sticky element it could be
|
|
* obscured and not show up when compared to the ref. */
|
|
function createIndicatorForStickyElements(sticky_divs) {
|
|
if (sticky_divs.length == 0)
|
|
throw "No sticky div was found in the test case.";
|
|
|
|
sticky_divs.forEach((sticky_div) => {
|
|
if (getComputedStyle(sticky_div).position != "sticky")
|
|
throw "Provided sticky element does not have position: sticky";
|
|
});
|
|
|
|
document.fonts.ready.then(() => {
|
|
sticky_divs.forEach((sticky_div) => {
|
|
// The relative position indicator will be able to share the same containing
|
|
// block to match the position with the same offset from in flow position
|
|
// (offsetTop/offsetLeft)
|
|
let position_div = document.createElement("div");
|
|
position_div.style.left = sticky_div.offsetLeft + "px";
|
|
position_div.style.top = sticky_div.offsetTop + "px";
|
|
// The absolute position is to ensure that the position_div adds zero size
|
|
// to in flow layout
|
|
position_div.style.position = "absolute"
|
|
let indicator_div = document.createElement("div");
|
|
indicator_div.style.width = sticky_div.offsetWidth + "px";
|
|
indicator_div.style.height = sticky_div.offsetHeight + "px";
|
|
indicator_div.style.backgroundColor = "blue";
|
|
indicator_div.style.position = "relative";
|
|
position_div.appendChild(indicator_div);
|
|
sticky_div.parentNode.insertBefore(position_div, sticky_div);
|
|
});
|
|
});
|
|
}
|