From ea00949b5de3cdab146a86f590b19b5abc5c421a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Piotr=20Szcz=C4=99=C5=9Bniak?= Date: Thu, 14 Sep 2023 14:01:33 +0200 Subject: [PATCH 1/3] Fix for shifting Rect with positioned ancestor. --- packages/ckeditor5-utils/src/dom/rect.ts | 2 +- packages/ckeditor5-utils/tests/dom/position.js | 8 ++++---- 2 files changed, 5 insertions(+), 5 deletions(-) diff --git a/packages/ckeditor5-utils/src/dom/rect.ts b/packages/ckeditor5-utils/src/dom/rect.ts index d82d444e26c..3d867d247ce 100644 --- a/packages/ckeditor5-utils/src/dom/rect.ts +++ b/packages/ckeditor5-utils/src/dom/rect.ts @@ -576,7 +576,7 @@ function getElementOverflow( element: HTMLElement | Range ): string { * (and scrollable) ancestors. */ function shiftRectToCompensatePositionedAncestor( rect: Rect, positionedElementAncestor: HTMLElement ): void { - const ancestorPosition = new Rect( positionedElementAncestor ).toAbsoluteRect(); + const ancestorPosition = new Rect( positionedElementAncestor ); const ancestorBorderWidths = getBorderWidths( positionedElementAncestor ); let moveX = 0; diff --git a/packages/ckeditor5-utils/tests/dom/position.js b/packages/ckeditor5-utils/tests/dom/position.js index e50a96745b0..13d49399abb 100644 --- a/packages/ckeditor5-utils/tests/dom/position.js +++ b/packages/ckeditor5-utils/tests/dom/position.js @@ -261,8 +261,8 @@ describe( 'getOptimalPosition()', () => { parent.appendChild( element ); assertPosition( { element, target, positions: [ attachLeftBottom ] }, { - top: -900, - left: -920, + top: 100, + left: 80, name: 'left-bottom' } ); } ); @@ -307,8 +307,8 @@ describe( 'getOptimalPosition()', () => { parent.scrollTop = 100; assertPosition( { element, target, positions: [ attachLeftBottom ] }, { - top: 200, - left: 280, + top: 1200, + left: 1280, name: 'left-bottom' } ); } ); From e76894734595aee678590f5430ecd19fa4156161 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Piotr=20Szcz=C4=99=C5=9Bniak?= Date: Fri, 15 Sep 2023 12:05:00 +0200 Subject: [PATCH 2/3] Extend function description. [skip ci] --- packages/ckeditor5-utils/src/dom/rect.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/ckeditor5-utils/src/dom/rect.ts b/packages/ckeditor5-utils/src/dom/rect.ts index 3d867d247ce..d45326de96f 100644 --- a/packages/ckeditor5-utils/src/dom/rect.ts +++ b/packages/ckeditor5-utils/src/dom/rect.ts @@ -371,7 +371,7 @@ export default class Rect { } /** - * Calculates absolute `Rect` coordinates. + * Recalculates screen coordinates to coordinates relative to the positioned ancestor offset. */ public toAbsoluteRect(): Rect { const { scrollX, scrollY } = global.window; From bf263d352b4887c18dd8481b003b0661d144f136 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Piotr=20Szcz=C4=99=C5=9Bniak?= Date: Fri, 15 Sep 2023 12:08:16 +0200 Subject: [PATCH 3/3] Extend getVisible function description. [skip ci] --- packages/ckeditor5-utils/src/dom/rect.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/ckeditor5-utils/src/dom/rect.ts b/packages/ckeditor5-utils/src/dom/rect.ts index d45326de96f..046fff1f9bb 100644 --- a/packages/ckeditor5-utils/src/dom/rect.ts +++ b/packages/ckeditor5-utils/src/dom/rect.ts @@ -235,7 +235,7 @@ export default class Rect { } /** - * Returns a new rect, a part of the original rect, which is actually visible to the user, + * Returns a new rect, a part of the original rect, which is actually visible to the user and is relative to the,`body`, * e.g. an original rect cropped by parent element rects which have `overflow` set in CSS * other than `"visible"`. *