Skip to content

Commit

Permalink
fix(cdk/overlay): fix overlay margin in isBoundedByLeftViewportEdge (…
Browse files Browse the repository at this point in the history
…'left-ward') mode (#28233)

(cherry picked from commit 8f60b62)
  • Loading branch information
kryshac authored and crisbeto committed Feb 26, 2024
1 parent 537ed41 commit 94eafc1
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -2000,6 +2000,31 @@ describe('FlexibleConnectedPositionStrategy', () => {
expect(Math.floor(overlayRect.top)).toBe(viewportMargin);
});

it('should calculate the right offset correctly with a viewport margin', async () => {
const viewportMargin = 5;
const right = 20;

originElement.style.right = `${right}px`;
originElement.style.top = `200px`;

positionStrategy
.withFlexibleDimensions()
.withPush(false)
.withViewportMargin(viewportMargin)
.withPositions([
{
originX: 'end',
originY: 'top',
overlayX: 'end',
overlayY: 'bottom',
},
]);

attachOverlay({positionStrategy});

expect(overlayRef.hostElement.style.right).toBe(`${right}px`);
});

it('should center flexible overlay with push on a scrolled page', () => {
const veryLargeElement = document.createElement('div');

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -815,7 +815,7 @@ export class FlexibleConnectedPositionStrategy implements PositionStrategy {
let width: number, left: number, right: number;

if (isBoundedByLeftViewportEdge) {
right = viewport.width - origin.x + this._viewportMargin;
right = viewport.width - origin.x + this._viewportMargin * 2;
width = origin.x - this._viewportMargin;
} else if (isBoundedByRightViewportEdge) {
left = origin.x;
Expand Down

0 comments on commit 94eafc1

Please sign in to comment.