From 4d776680af15035a974e6244b517ebd6812917b7 Mon Sep 17 00:00:00 2001 From: Maurits Date: Wed, 1 May 2024 11:16:10 +0200 Subject: [PATCH] propagate click event to popover item activation callback --- .../popover-item-default/popover-item-default.ts | 12 +++++++----- src/components/utils/popover/popover-abstract.ts | 2 +- 2 files changed, 8 insertions(+), 6 deletions(-) diff --git a/src/components/utils/popover/components/popover-item/popover-item-default/popover-item-default.ts b/src/components/utils/popover/components/popover-item/popover-item-default/popover-item-default.ts index 71cdb7b37..d3a00fe64 100644 --- a/src/components/utils/popover/components/popover-item/popover-item-default/popover-item-default.ts +++ b/src/components/utils/popover/components/popover-item/popover-item-default/popover-item-default.ts @@ -103,15 +103,16 @@ export class PopoverItemDefault extends PopoverItem { /** * Called on popover item click + * @param event - click event */ - public handleClick(): void { + public handleClick(event: Event): void { if (this.isConfirmationStateEnabled && this.confirmationState !== null) { - this.activateOrEnableConfirmationMode(this.confirmationState); + this.activateOrEnableConfirmationMode(this.confirmationState, event); return; } - this.activateOrEnableConfirmationMode(this.params); + this.activateOrEnableConfirmationMode(this.params, event); } /** @@ -281,11 +282,12 @@ export class PopoverItemDefault extends PopoverItem { * Executes item's onActivate callback if the item has no confirmation configured * * @param item - item to activate or bring to confirmation mode + * @param event - pointer event that triggered item activation */ - private activateOrEnableConfirmationMode(item: PopoverItemDefaultParams): void { + private activateOrEnableConfirmationMode(item: PopoverItemDefaultParams, event?: PointerEvent): void { if (item.confirmation === undefined) { try { - item.onActivate?.(item); + item.onActivate?.(item, event); this.disableConfirmationMode(); } catch { this.animateError(); diff --git a/src/components/utils/popover/popover-abstract.ts b/src/components/utils/popover/popover-abstract.ts index 0191dcd64..917cebec0 100644 --- a/src/components/utils/popover/popover-abstract.ts +++ b/src/components/utils/popover/popover-abstract.ts @@ -261,7 +261,7 @@ export abstract class PopoverAbstract /** Cleanup other items state */ this.itemsInteractive.filter(x => x !== item).forEach(x => x.reset()); - item.handleClick(); + item.handleClick(event); this.toggleItemActivenessIfNeeded(item);