From ae49332876d428b3b2da53147f8ceaeaa7a8b3c5 Mon Sep 17 00:00:00 2001 From: Nickii Miaro Date: Wed, 2 Oct 2024 10:41:49 +0300 Subject: [PATCH] fix: render person-card inside parent container (#3324) --- .../src/components/mgt-person-card/mgt-person-card.ts | 1 + .../components/sub-components/mgt-flyout/mgt-flyout.ts | 9 ++++++++- 2 files changed, 9 insertions(+), 1 deletion(-) diff --git a/packages/mgt-components/src/components/mgt-person-card/mgt-person-card.ts b/packages/mgt-components/src/components/mgt-person-card/mgt-person-card.ts index c7808d206b..6a1958bd0b 100644 --- a/packages/mgt-components/src/components/mgt-person-card/mgt-person-card.ts +++ b/packages/mgt-components/src/components/mgt-person-card/mgt-person-card.ts @@ -529,6 +529,7 @@ export class MgtPersonCard extends MgtTemplatedTaskComponent implements IHistory if (this._windowHeight < 250) { this._smallView = true; + this.fireCustomEvent('smallView', null, true); } const tabLocker = this.lockTabNavigation ? html`
` diff --git a/packages/mgt-components/src/components/sub-components/mgt-flyout/mgt-flyout.ts b/packages/mgt-components/src/components/sub-components/mgt-flyout/mgt-flyout.ts index bc042d0c4b..19c47c3c6c 100644 --- a/packages/mgt-components/src/components/sub-components/mgt-flyout/mgt-flyout.ts +++ b/packages/mgt-components/src/components/sub-components/mgt-flyout/mgt-flyout.ts @@ -134,6 +134,13 @@ export class MgtFlyout extends MgtBaseTaskComponent { this.updateFlyout(); }); }); + + // handling when person-card is rendered in a smaller window + this.addEventListener('smallView', () => { + window.requestAnimationFrame(() => { + this.updateFlyout(); + }); + }); } /** @@ -372,7 +379,7 @@ export class MgtFlyout extends MgtBaseTaskComponent { } } else { if (anchorRect.top + anchorRect.height + flyoutRect.height + this._edgePadding > windowRect.height) { - // it will render offscreen bellow, move it up a bit + // it will render offscreen below, move it up a bit top = windowRect.height - flyoutRect.height - this._edgePadding; } else { top = Math.max(anchorRect.top + anchorRect.height, this._edgePadding);