Bug 1363650 - (intersection-observer) Use content area as the intersection rectangle for custom root with overflow clip. r=mattwoodrow

--HG--
extra : rebase_source : f5f559903d704159a062d99fa43360a6222a3ee7
This commit is contained in:
Tobias Schneider 2017-06-21 10:40:44 -07:00
Родитель 622cba0919
Коммит 73616729d7
4 изменённых файлов: 11 добавлений и 10 удалений

Просмотреть файл

@ -268,17 +268,21 @@ DOMIntersectionObserver::Update(nsIDocument* aDocument, DOMHighResTimeStamp time
root = mRoot;
rootFrame = root->GetPrimaryFrame();
if (rootFrame) {
nsRect rootRectRelativeToRootFrame;
if (rootFrame->IsScrollFrame()) {
// rootRectRelativeToRootFrame should be the content rect of rootFrame, not including the scrollbars.
nsIScrollableFrame* scrollFrame = do_QueryFrame(rootFrame);
rootRect = nsLayoutUtils::TransformFrameRectToAncestor(
rootFrame,
rootFrame->GetContentRectRelativeToSelf(),
scrollFrame->GetScrolledFrame());
rootRectRelativeToRootFrame = scrollFrame->GetScrollPortRect();
} else {
rootRect = nsLayoutUtils::GetAllInFlowRectsUnion(rootFrame,
nsLayoutUtils::GetContainingBlockForClientRect(rootFrame),
nsLayoutUtils::RECTS_ACCOUNT_FOR_TRANSFORMS);
// rootRectRelativeToRootFrame should be the border rect of rootFrame.
rootRectRelativeToRootFrame = rootFrame->GetRectRelativeToSelf();
}
nsIFrame* containingBlock =
nsLayoutUtils::GetContainingBlockForClientRect(rootFrame);
rootRect =
nsLayoutUtils::TransformFrameRectToAncestor(rootFrame,
rootRectRelativeToRootFrame,
containingBlock);
}
} else {
nsCOMPtr<nsIPresShell> presShell = aDocument->GetShell();

Просмотреть файл

@ -1,3 +1,2 @@
[containing-block.html]
type: testharness
disabled: https://bugzilla.mozilla.org/show_bug.cgi?id=1363650

Просмотреть файл

@ -1,3 +1,2 @@
[remove-element.html]
type: testharness
disabled: https://bugzilla.mozilla.org/show_bug.cgi?id=1363650

Просмотреть файл

@ -1,3 +1,2 @@
[same-document-root.html]
type: testharness
disabled: https://bugzilla.mozilla.org/show_bug.cgi?id=1363650