@wavemaker/app-ng-runtime 11.9.0-next.27464 → 11.9.0-next.27466

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -77,25 +77,89 @@
77
77
  let activePopover;
78
78
  class PopoverComponent extends base.StylableComponent {
79
79
  static { this.initializeProps = registerProps(); }
80
+ static { this.activePopovers = []; }
80
81
  constructor(inj, app, explicitContext) {
81
82
  super(inj, WIDGET_CONFIG, explicitContext);
82
83
  this.app = app;
83
84
  this.isOpen = false;
84
85
  this.canPopoverOpen = true;
86
+ this.isClosingProgrammatically = false;
85
87
  this.popoverContainerCls = `app-popover-${this.widgetId}`;
86
88
  }
89
+ setupDocumentClickHandler() {
90
+ if (this.documentClickHandler) {
91
+ document.removeEventListener('click', this.documentClickHandler, true);
92
+ }
93
+ this.documentClickHandler = (event) => {
94
+ if (!this.isOpen)
95
+ return;
96
+ const target = event.target;
97
+ const clickedPopoverIndex = PopoverComponent.activePopovers.findIndex(popover => {
98
+ const popoverContainer = document.querySelector(`.${popover.popoverContainerCls}`);
99
+ return popoverContainer?.contains(target);
100
+ });
101
+ if (clickedPopoverIndex === -1) {
102
+ // Click is outside all popovers
103
+ if (this.outsideclick) {
104
+ this.closeAllPopovers();
105
+ }
106
+ }
107
+ else {
108
+ // Click is inside a popover
109
+ this.closeInnerPopovers(clickedPopoverIndex);
110
+ }
111
+ };
112
+ document.addEventListener('click', this.documentClickHandler, true);
113
+ }
114
+ closeAllPopovers() {
115
+ PopoverComponent.activePopovers.forEach(popover => {
116
+ if (popover.outsideclick) {
117
+ popover.isClosingProgrammatically = true;
118
+ popover.close();
119
+ }
120
+ });
121
+ }
122
+ closeInnerPopovers(clickedIndex) {
123
+ for (let i = clickedIndex + 1; i < PopoverComponent.activePopovers.length; i++) {
124
+ const popover = PopoverComponent.activePopovers[i];
125
+ if (popover.outsideclick) {
126
+ popover.isClosingProgrammatically = true;
127
+ popover.close();
128
+ }
129
+ }
130
+ }
131
+ isChildPopover() {
132
+ return !!$(this.nativeElement).closest('.popover').length;
133
+ }
87
134
  // This mehtod is used to show/open the popover. This refers to the same method showPopover.
88
135
  open() {
89
136
  this.showPopover();
137
+ if (!PopoverComponent.activePopovers.includes(this)) {
138
+ PopoverComponent.activePopovers.push(this);
139
+ }
90
140
  }
91
141
  // This mehtod is used to hide/close the popover.
92
142
  close() {
93
- this.isOpen = false;
143
+ if (this.isOpen) {
144
+ this.isClosingProgrammatically = true;
145
+ this.isOpen = false;
146
+ this.bsPopoverDirective.hide();
147
+ const index = PopoverComponent.activePopovers.indexOf(this);
148
+ if (index > -1) {
149
+ PopoverComponent.activePopovers.splice(index, 1);
150
+ }
151
+ }
94
152
  }
95
153
  // Trigger on hiding popover
96
154
  onHidden() {
97
- this.invokeEventCallback('hide', { $event: { type: 'hide' } });
98
- this.isOpen = false;
155
+ if (!this.isChildPopover() || this.isClosingProgrammatically) {
156
+ this.invokeEventCallback('hide', { $event: { type: 'hide' } });
157
+ this.isOpen = false;
158
+ if (activePopover === this) {
159
+ activePopover = null;
160
+ }
161
+ }
162
+ this.isClosingProgrammatically = false;
99
163
  }
100
164
  setFocusToPopoverLink() {
101
165
  setTimeout(() => this.anchorRef.nativeElement.focus(), 10);
@@ -147,12 +211,26 @@
147
211
  $('body > popover-container').wrap('<' + root + '/>');
148
212
  }
149
213
  // Fix for [WMS-25125]: Not closing the existing opened popovers when the autoclose property is DISABLED
150
- if (activePopover && activePopover.isOpen && activePopover.autoclose !== base.AUTOCLOSE_TYPE.DISABLED) {
151
- activePopover.isOpen = false;
214
+ if (!this.isChildPopover()) {
215
+ if (activePopover && activePopover !== this &&
216
+ activePopover.autoclose !== base.AUTOCLOSE_TYPE.DISABLED) {
217
+ activePopover.isClosingProgrammatically = true;
218
+ activePopover.close();
219
+ }
220
+ activePopover = this;
221
+ }
222
+ this.isOpen = true;
223
+ if (!PopoverComponent.activePopovers.includes(this)) {
224
+ PopoverComponent.activePopovers.push(this);
152
225
  }
153
- activePopover = this;
154
- activePopover.isOpen = true;
155
226
  const popoverContainer = document.querySelector(`.${this.popoverContainerCls}`);
227
+ if (popoverContainer) {
228
+ popoverContainer.setAttribute('data-popover-id', this.widgetId);
229
+ // Add click event listener to stop propagation
230
+ popoverContainer.addEventListener('click', (event) => {
231
+ event.stopPropagation();
232
+ });
233
+ }
156
234
  i1.setCSSFromObj(popoverContainer, {
157
235
  height: this.popoverheight,
158
236
  minWidth: this.popoverwidth,
@@ -169,6 +247,9 @@
169
247
  this.anchorRef.nativeElement.onmouseenter = () => clearTimeout(this.closePopoverTimeout);
170
248
  this.anchorRef.nativeElement.onmouseleave = () => this.hidePopover();
171
249
  }
250
+ if (this.outsideclick) {
251
+ this.setupDocumentClickHandler();
252
+ }
172
253
  setTimeout(() => {
173
254
  this.anchorRef.nativeElement.removeAttribute('aria-describedby');
174
255
  });
@@ -235,6 +316,7 @@
235
316
  }
236
317
  }
237
318
  hidePopover() {
319
+ this.isClosingProgrammatically = true;
238
320
  this.closePopoverTimeout = setTimeout(() => this.isOpen = false, 500);
239
321
  }
240
322
  showPopover() {
@@ -288,6 +370,15 @@
288
370
  // Hide the popover container while attaching the next component as part of page reuse strategy.
289
371
  this.bsPopoverDirective.hide();
290
372
  }
373
+ OnDestroy() {
374
+ if (this.documentClickHandler) {
375
+ document.removeEventListener('click', this.documentClickHandler, true);
376
+ }
377
+ const index = PopoverComponent.activePopovers.indexOf(this);
378
+ if (index > -1) {
379
+ PopoverComponent.activePopovers.splice(index, 1);
380
+ }
381
+ }
291
382
  static { this.ɵfac = function PopoverComponent_Factory(t) { return new (t || PopoverComponent)(i0__namespace.ɵɵdirectiveInject(i0__namespace.Injector), i0__namespace.ɵɵdirectiveInject(i1__namespace.App), i0__namespace.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
292
383
  static { this.ɵcmp = /*@__PURE__*/ i0__namespace.ɵɵdefineComponent({ type: PopoverComponent, selectors: [["wm-popover"]], contentQueries: function PopoverComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
293
384
  i0__namespace.ɵɵcontentQuery(dirIndex, i0.TemplateRef, 5);
@@ -24,25 +24,89 @@ const eventsMap = {
24
24
  let activePopover;
25
25
  export class PopoverComponent extends StylableComponent {
26
26
  static { this.initializeProps = registerProps(); }
27
+ static { this.activePopovers = []; }
27
28
  constructor(inj, app, explicitContext) {
28
29
  super(inj, WIDGET_CONFIG, explicitContext);
29
30
  this.app = app;
30
31
  this.isOpen = false;
31
32
  this.canPopoverOpen = true;
33
+ this.isClosingProgrammatically = false;
32
34
  this.popoverContainerCls = `app-popover-${this.widgetId}`;
33
35
  }
36
+ setupDocumentClickHandler() {
37
+ if (this.documentClickHandler) {
38
+ document.removeEventListener('click', this.documentClickHandler, true);
39
+ }
40
+ this.documentClickHandler = (event) => {
41
+ if (!this.isOpen)
42
+ return;
43
+ const target = event.target;
44
+ const clickedPopoverIndex = PopoverComponent.activePopovers.findIndex(popover => {
45
+ const popoverContainer = document.querySelector(`.${popover.popoverContainerCls}`);
46
+ return popoverContainer?.contains(target);
47
+ });
48
+ if (clickedPopoverIndex === -1) {
49
+ // Click is outside all popovers
50
+ if (this.outsideclick) {
51
+ this.closeAllPopovers();
52
+ }
53
+ }
54
+ else {
55
+ // Click is inside a popover
56
+ this.closeInnerPopovers(clickedPopoverIndex);
57
+ }
58
+ };
59
+ document.addEventListener('click', this.documentClickHandler, true);
60
+ }
61
+ closeAllPopovers() {
62
+ PopoverComponent.activePopovers.forEach(popover => {
63
+ if (popover.outsideclick) {
64
+ popover.isClosingProgrammatically = true;
65
+ popover.close();
66
+ }
67
+ });
68
+ }
69
+ closeInnerPopovers(clickedIndex) {
70
+ for (let i = clickedIndex + 1; i < PopoverComponent.activePopovers.length; i++) {
71
+ const popover = PopoverComponent.activePopovers[i];
72
+ if (popover.outsideclick) {
73
+ popover.isClosingProgrammatically = true;
74
+ popover.close();
75
+ }
76
+ }
77
+ }
78
+ isChildPopover() {
79
+ return !!$(this.nativeElement).closest('.popover').length;
80
+ }
34
81
  // This mehtod is used to show/open the popover. This refers to the same method showPopover.
35
82
  open() {
36
83
  this.showPopover();
84
+ if (!PopoverComponent.activePopovers.includes(this)) {
85
+ PopoverComponent.activePopovers.push(this);
86
+ }
37
87
  }
38
88
  // This mehtod is used to hide/close the popover.
39
89
  close() {
40
- this.isOpen = false;
90
+ if (this.isOpen) {
91
+ this.isClosingProgrammatically = true;
92
+ this.isOpen = false;
93
+ this.bsPopoverDirective.hide();
94
+ const index = PopoverComponent.activePopovers.indexOf(this);
95
+ if (index > -1) {
96
+ PopoverComponent.activePopovers.splice(index, 1);
97
+ }
98
+ }
41
99
  }
42
100
  // Trigger on hiding popover
43
101
  onHidden() {
44
- this.invokeEventCallback('hide', { $event: { type: 'hide' } });
45
- this.isOpen = false;
102
+ if (!this.isChildPopover() || this.isClosingProgrammatically) {
103
+ this.invokeEventCallback('hide', { $event: { type: 'hide' } });
104
+ this.isOpen = false;
105
+ if (activePopover === this) {
106
+ activePopover = null;
107
+ }
108
+ }
109
+ this.isClosingProgrammatically = false;
46
110
  }
47
111
  setFocusToPopoverLink() {
48
112
  setTimeout(() => this.anchorRef.nativeElement.focus(), 10);
@@ -94,12 +158,26 @@ export class PopoverComponent extends StylableComponent {
94
158
  $('body > popover-container').wrap('<' + root + '/>');
95
159
  }
96
160
  // Fix for [WMS-25125]: Not closing the existing opened popovers when the autoclose property is DISABLED
97
- if (activePopover && activePopover.isOpen && activePopover.autoclose !== AUTOCLOSE_TYPE.DISABLED) {
98
- activePopover.isOpen = false;
161
+ if (!this.isChildPopover()) {
162
+ if (activePopover && activePopover !== this &&
163
+ activePopover.autoclose !== AUTOCLOSE_TYPE.DISABLED) {
164
+ activePopover.isClosingProgrammatically = true;
165
+ activePopover.close();
166
+ }
167
+ activePopover = this;
168
+ }
169
+ this.isOpen = true;
170
+ if (!PopoverComponent.activePopovers.includes(this)) {
171
+ PopoverComponent.activePopovers.push(this);
99
172
  }
100
- activePopover = this;
101
- activePopover.isOpen = true;
102
173
  const popoverContainer = document.querySelector(`.${this.popoverContainerCls}`);
174
+ if (popoverContainer) {
175
+ popoverContainer.setAttribute('data-popover-id', this.widgetId);
176
+ // Add click event listener to stop propagation
177
+ popoverContainer.addEventListener('click', (event) => {
178
+ event.stopPropagation();
179
+ });
180
+ }
103
181
  setCSSFromObj(popoverContainer, {
104
182
  height: this.popoverheight,
105
183
  minWidth: this.popoverwidth,
@@ -116,6 +194,9 @@ export class PopoverComponent extends StylableComponent {
116
194
  this.anchorRef.nativeElement.onmouseenter = () => clearTimeout(this.closePopoverTimeout);
117
195
  this.anchorRef.nativeElement.onmouseleave = () => this.hidePopover();
118
196
  }
197
+ if (this.outsideclick) {
198
+ this.setupDocumentClickHandler();
199
+ }
119
200
  setTimeout(() => {
120
201
  this.anchorRef.nativeElement.removeAttribute('aria-describedby');
121
202
  });
@@ -182,6 +263,7 @@ export class PopoverComponent extends StylableComponent {
182
263
  }
183
264
  }
184
265
  hidePopover() {
266
+ this.isClosingProgrammatically = true;
185
267
  this.closePopoverTimeout = setTimeout(() => this.isOpen = false, 500);
186
268
  }
187
269
  showPopover() {
@@ -235,6 +317,15 @@ export class PopoverComponent extends StylableComponent {
235
317
  // Hide the popover container while attaching the next component as part of page reuse strategy.
236
318
  this.bsPopoverDirective.hide();
237
319
  }
320
+ OnDestroy() {
321
+ if (this.documentClickHandler) {
322
+ document.removeEventListener('click', this.documentClickHandler, true);
323
+ }
324
+ const index = PopoverComponent.activePopovers.indexOf(this);
325
+ if (index > -1) {
326
+ PopoverComponent.activePopovers.splice(index, 1);
327
+ }
328
+ }
238
329
  static { this.ɵfac = function PopoverComponent_Factory(t) { return new (t || PopoverComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.App), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
239
330
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PopoverComponent, selectors: [["wm-popover"]], contentQueries: function PopoverComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
240
331
  i0.ɵɵcontentQuery(dirIndex, TemplateRef, 5);
@@ -288,4 +379,4 @@ export class PopoverComponent extends StylableComponent {
288
379
  args: ['partial']
289
380
  }] }); })();
290
381
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(PopoverComponent, { className: "PopoverComponent", filePath: "popover.component.ts", lineNumber: 59 }); })();
291
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/navigation/popover/src/popover.component.ts","../../../../../projects/components/widgets/navigation/popover/src/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ContentChild,\n    ElementRef,\n    Inject,\n    Injector,\n    OnInit,\n    Optional,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport {PopoverDirective} from 'ngx-bootstrap/popover';\n\nimport {\n    addClass,\n    adjustContainerPosition,\n    adjustContainerRightEdges,\n    App,\n    findRootContainer,\n    setCSSFromObj\n} from '@wm/core';\nimport {\n    AUTOCLOSE_TYPE,\n    getContainerTargetClass,\n    IWidgetConfig,\n    provideAsWidgetRef,\n    StylableComponent,\n    styler\n} from '@wm/components/base';\n\nimport {registerProps} from './popover.props';\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-popover-wrapper';\nconst WIDGET_CONFIG: IWidgetConfig = {\n    widgetType: 'wm-popover',\n    hostClass: DEFAULT_CLS\n};\n\nconst eventsMap = {\n    click: 'click',\n    hover: 'mouseenter:click',\n    default: 'click mouseenter'\n};\n\nlet activePopover: PopoverComponent;\n\n@Component({\n    selector: 'wm-popover',\n    templateUrl: './popover.component.html',\n    providers: [\n        provideAsWidgetRef(PopoverComponent)\n    ]\n})\n\nexport class PopoverComponent extends StylableComponent implements OnInit, AfterViewInit {\n    static initializeProps = registerProps();\n\n    public event: string;\n    public isOpen = false;\n    private closePopoverTimeout;\n    public readonly popoverContainerCls;\n    public canPopoverOpen = true;\n    private Widgets;\n    private Variables;\n    private Actions;\n\n    public interaction: string;\n    public popoverarrow: boolean;\n    public popoverwidth: string;\n    public popoverheight: string;\n    public contentanimation: string;\n    public contentsource: string;\n    public content: string;\n    public popoverplacement: string;\n    public outsideclick: boolean;\n    public autoclose: string;\n\n    public class: string;\n    public title: string;\n    public tabindex: any;\n    public name: string;\n    public adaptiveposition:boolean;\n    public containerTarget: string;\n    public hint: string;\n    public arialabel: string;\n    public caption: string;\n    public badgevalue: string;\n\n    @ViewChild(PopoverDirective) private bsPopoverDirective;\n    @ViewChild('anchor', { static: true }) anchorRef: ElementRef;\n    @ContentChild(TemplateRef) popoverTemplate;\n    @ContentChild('partial') partialRef;\n\n    constructor(inj: Injector, private app: App, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        this.popoverContainerCls = `app-popover-${this.widgetId}`;\n    }\n\n    // This mehtod is used to show/open the popover. This refers to the same method showPopover.\n    public open() {\n        this.showPopover();\n    }\n\n    // This mehtod is used to hide/close the popover.\n    public close() {\n        this.isOpen = false;\n    }\n\n    // Trigger on hiding popover\n    public onHidden() {\n        this.invokeEventCallback('hide', {$event: {type: 'hide'}});\n        this.isOpen = false;\n    }\n\n    private setFocusToPopoverLink() {\n        setTimeout(() => this.anchorRef.nativeElement.focus(), 10);\n    }\n\n    private adjustPopoverArrowPosition(popoverElem, popoverLeftShift) {\n        this.bsPopoverDirective._popover._ngZone.onStable.subscribe(() => {\n            popoverElem.find('.popover-arrow').css('left', popoverLeftShift + 'px');\n        });\n    }\n\n    private calculatePopoverPostion(element) {\n\n        const popoverElem = $(element);\n        let popoverLeft =  popoverElem.offset().left;\n        const popoverWidth = popoverElem[0].offsetWidth;\n        const viewPortWidth = $(window).width();\n        const parentDimesion = this.anchorRef.nativeElement.getBoundingClientRect();\n        // Adjusting popover position, if it is not visible at left side\n        if (popoverLeft < 0) {\n            adjustContainerPosition(popoverElem, this.nativeElement, this.bsPopoverDirective._popover);\n            const popoverLeftShift = 4;\n            const arrowLeftShift = (parentDimesion.left + (parentDimesion.width / 2)) - popoverLeftShift;\n            this.adjustPopoverArrowPosition(popoverElem, arrowLeftShift);\n        }\n        // Adjusting popover position, if it is not visible at right side\n        if (popoverLeft + popoverWidth > viewPortWidth) {\n            adjustContainerRightEdges(popoverElem, this.nativeElement, this.bsPopoverDirective._popover);\n            setTimeout(() => {\n                popoverLeft = popoverElem.offset().left;\n                const popoverLeftAdjust = (popoverLeft + popoverWidth) - viewPortWidth;\n                const popoverLeftShift =  popoverLeft - popoverLeftAdjust;\n                let arrowLeftShift ;\n                if(popoverLeft<=100){\n                    arrowLeftShift =  (parentDimesion.left + (parentDimesion.width / 2)) - popoverLeft;\n                }else{\n                    arrowLeftShift = (parentDimesion.left + (parentDimesion.width / 2)) - popoverLeftShift;\n                }\n                if(viewPortWidth > 500){\n                    arrowLeftShift += 30;\n                }\n               this.adjustPopoverArrowPosition(popoverElem, arrowLeftShift);\n            });\n        }\n    }\n\n    // Trigger on showing popover\n    public onShown() {\n        const root = findRootContainer(this.$element);\n        // if page styles have to be applied to popover then popover has to be child of page element.\n        if (root) {\n            $('body > popover-container').wrap('<' + root + '/>');\n        }\n        // Fix for [WMS-25125]: Not closing the existing opened popovers when the autoclose property is DISABLED\n        if (activePopover && activePopover.isOpen && activePopover.autoclose !== AUTOCLOSE_TYPE.DISABLED) {\n            activePopover.isOpen = false;\n        }\n\n        activePopover = this;\n        activePopover.isOpen = true;\n\n        const popoverContainer  = document.querySelector(`.${this.popoverContainerCls}`) as HTMLElement;\n        setCSSFromObj(popoverContainer, {\n            height: this.popoverheight,\n            minWidth: this.popoverwidth,\n            width: this.popoverwidth\n        });\n        if (!this.popoverarrow) {\n            addClass(popoverContainer.querySelector('.arrow') as HTMLElement, 'hidden');\n        }\n        if (this.interaction === 'hover' || this.interaction === 'default') {\n\n            // do not use addEventListener here\n            // attaching the event this way will override the existing event handlers\n            popoverContainer.onmouseenter = () => clearTimeout(this.closePopoverTimeout);\n            popoverContainer.onmouseleave = () => this.hidePopover();\n            this.anchorRef.nativeElement.onmouseenter = () => clearTimeout(this.closePopoverTimeout);\n            this.anchorRef.nativeElement.onmouseleave = () => this.hidePopover();\n        }\n        setTimeout(() => {\n            this.anchorRef.nativeElement.removeAttribute('aria-describedby');\n        });\n        const deRegister = this.eventManager.addEventListener(popoverContainer, 'keydown.esc', () => {\n            this.isOpen = false;\n            this.setFocusToPopoverLink();\n            deRegister();\n        });\n        const popoverStartBtn: HTMLElement = popoverContainer.querySelector('.popover-start');\n        const popoverEndBtn: HTMLElement = popoverContainer.querySelector('.popover-end');\n        popoverStartBtn.onkeydown = (event) => {\n            // Check for Shift+Tab key\n            if (event.shiftKey && event.key === 'Tab') {\n                this.bsPopoverDirective.hide();\n                event.preventDefault();\n                this.setFocusToPopoverLink();\n                this.isOpen = false;            }\n        };\n        popoverEndBtn.onkeydown = (event) => {\n            // Check for Tab key\n            if (!event.shiftKey && event.key === 'Tab') {\n                this.bsPopoverDirective.hide();\n                event.preventDefault();\n                this.setFocusToPopoverLink();\n                this.isOpen = false;            }\n        };\n\n        //Whenever autoclose property is set to 'always', adding the onclick listener to the popover container to close the popover.\n        if (this.autoclose === AUTOCLOSE_TYPE.ALWAYS) {\n            popoverContainer.onclick = () => this.close();\n        }\n\n        setTimeout(() => popoverStartBtn.focus(), 50);\n        // Adjusting popover position if the popover placement is top or bottom\n        setTimeout( () => {\n            if (!this.adaptiveposition ) {\n                this.calculatePopoverPostion(popoverContainer);\n            }\n            // triggering onload and onshow events after popover content has rendered\n            this.triggerPopoverEvents();\n        });\n    }\n\n    triggerPopoverEvents() {\n        if (this.contentsource === 'partial') {\n            const cancelSubscription = this.app.subscribe('partialLoaded', (data) => {\n                const parEle = this.partialRef.nativeElement;\n                let partialScope;\n\n                if (parEle) {\n                    partialScope  = parEle.widget;\n                    this.Widgets   = partialScope.Widgets;\n                    this.Variables = partialScope.Variables;\n                    this.Actions   = partialScope.Actions;\n                    this.invokeEventCallback('load');\n                    this.invokeEventCallback('show', {$event: {type: 'show'}});\n                }\n                cancelSubscription();\n            });\n        } else {\n            this.Widgets   = this.viewParent.Widgets;\n            this.Variables = this.viewParent.Variables;\n            this.Actions   = this.viewParent.Actions;\n            this.invokeEventCallback('show', {$event: {type: 'show'}});\n        }\n    }\n\n    private hidePopover() {\n        this.closePopoverTimeout = setTimeout(() => this.isOpen = false, 500);\n    }\n\n    private showPopover() {\n        this.bsPopoverDirective.show();\n    }\n\n    onPopoverAnchorKeydown($event) {\n        // if there is no content available, the popover should not open through enter key. So checking whether the canPopoverOpen flag is true or not.\n        if (!this.canPopoverOpen) {\n           return;\n        }\n        if ($event.key === 'Enter') {\n            $event.stopPropagation();\n            $event.preventDefault();\n            this.showPopover();\n        }\n    }\n\n    onPropertyChange(key: string, nv: any, ov?: any) {\n        if (key === 'class' || key === 'tabindex') {\n            return;\n        }\n        if (key === 'contentsource') {\n            // if there is no partial content available, the popover should not open\n            if (this.contentsource === 'partial' && !this.content) {\n                this.canPopoverOpen = false;\n            }\n        }\n        if (key === 'content' && nv) {\n            this.canPopoverOpen = true;\n        }\n        if (key === 'autoclose') {\n            this.outsideclick = (nv === AUTOCLOSE_TYPE.OUTSIDECLICK || nv === AUTOCLOSE_TYPE.ALWAYS) ? true : false;\n        }\n        super.onPropertyChange(key, nv, ov);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this.event = eventsMap[this.interaction];\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        styler(this.anchorRef.nativeElement, this);\n        this.containerTarget = getContainerTargetClass(this.nativeElement);\n        // let parentElemPopover = $(this.nativeElement).parents();\n        // if (parentElemPopover.closest('[wmTable]').length ||\n        //     parentElemPopover.closest('[wmtabs]').length ||\n        //     parentElemPopover.closest('modal-container').length) {\n        //     this.adaptiveposition = false;\n        // }\n    }\n\n    ngOnDetach() {\n        // Hide the popover container while attaching the next component as part of page reuse strategy.\n        this.bsPopoverDirective.hide();\n    }\n}\n","<a [popover]=\"popoverTemplate\"\n    [popoverContext]=\"context\"\n    [popoverTitle]=\"title\"\n    [placement]=\"popoverplacement\"\n    [outsideClick]=\"outsideclick\"\n    [triggers]=\"event\"\n    (onShown)=\"onShown()\"\n    (onHidden)=\"onHidden()\"\n    containerClass=\"app-popover animated {{contentanimation}} {{popoverContainerCls}}\"\n    [container]=\"containerTarget || '.wm-app'\"\n    [isOpen]=\"isOpen\"\n    [tabindex]=\"tabindex\"\n    [name]=\"name\"\n    [class]=\"class\"\n    [ngClass]=\"{'disable-popover': !canPopoverOpen}\"\n    [adaptivePosition]=\"adaptiveposition\"\n   boundariesElement=\"window\"\n   [attr.aria-label]=\"arialabel || (badgevalue ? caption + ' ' + badgevalue : caption) || 'Popover menu'\"\n    [attr.aria-expanded]=\"isOpen\"\n    role=\"button\"\n    #anchor\n    name.bind=\"name\"\n    wmAnchor\n    animation.bind=\"animation\"\n    badgevalue.bind=\"badgevalue\"\n    caption.bind=\"caption\"\n    encodeurl.bind=\"encodeurl\"\n    hint.bind=\"hint\"\n    hyperlink.bind=\"hyperlink\"\n    iconurl.bind=\"iconurl\"\n    iconwidth.bind=\"iconwidth\"\n    iconheight.bind=\"iconheight\"\n    iconmargin.bind=\"iconmargin\"\n    iconclass.bind=\"iconclass\"\n    iconposition.bind=\"iconposition\"\n    shortcutkey.bind=\"shortcutkey\"\n    tabindex.bind=\"tabindex\"\n    (keydown)=\"onPopoverAnchorKeydown($event)\">\n</a>\n"]}
382
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.component.js","sourceRoot":"","sources":["../../../../../projects/components/widgets/navigation/popover/src/popover.component.ts","../../../../../projects/components/widgets/navigation/popover/src/popover.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    Component,\n    ContentChild,\n    ElementRef,\n    Inject,\n    Injector,\n    OnInit,\n    Optional,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport {PopoverDirective} from 'ngx-bootstrap/popover';\n\nimport {\n    addClass,\n    adjustContainerPosition,\n    adjustContainerRightEdges,\n    App,\n    findRootContainer,\n    setCSSFromObj\n} from '@wm/core';\nimport {\n    AUTOCLOSE_TYPE,\n    getContainerTargetClass,\n    IWidgetConfig,\n    provideAsWidgetRef,\n    StylableComponent,\n    styler\n} from '@wm/components/base';\n\nimport {registerProps} from './popover.props';\n\ndeclare const $;\n\nconst DEFAULT_CLS = 'app-popover-wrapper';\nconst WIDGET_CONFIG: IWidgetConfig = {\n    widgetType: 'wm-popover',\n    hostClass: DEFAULT_CLS\n};\n\nconst eventsMap = {\n    click: 'click',\n    hover: 'mouseenter:click',\n    default: 'click mouseenter'\n};\n\nlet activePopover: PopoverComponent;\n\n@Component({\n    selector: 'wm-popover',\n    templateUrl: './popover.component.html',\n    providers: [\n        provideAsWidgetRef(PopoverComponent)\n    ]\n})\n\nexport class PopoverComponent extends StylableComponent implements OnInit, AfterViewInit {\n    static initializeProps = registerProps();\n\n    public event: string;\n    public isOpen = false;\n    private closePopoverTimeout;\n    public readonly popoverContainerCls;\n    public canPopoverOpen = true;\n    private Widgets;\n    private Variables;\n    private Actions;\n\n    public interaction: string;\n    public popoverarrow: boolean;\n    public popoverwidth: string;\n    public popoverheight: string;\n    public contentanimation: string;\n    public contentsource: string;\n    public content: string;\n    public popoverplacement: string;\n    public outsideclick: boolean;\n    public autoclose: string;\n\n    public class: string;\n    public title: string;\n    public tabindex: any;\n    public name: string;\n    public adaptiveposition:boolean;\n    public containerTarget: string;\n    public hint: string;\n    public arialabel: string;\n    public caption: string;\n    public badgevalue: string;\n    private documentClickHandler: (e: MouseEvent) => void;\n    private isClosingProgrammatically = false;\n    private static activePopovers: PopoverComponent[] = [];\n\n    @ViewChild(PopoverDirective) private bsPopoverDirective;\n    @ViewChild('anchor', { static: true }) anchorRef: ElementRef;\n    @ContentChild(TemplateRef) popoverTemplate;\n    @ContentChild('partial') partialRef;\n\n    constructor(inj: Injector, private app: App, @Inject('EXPLICIT_CONTEXT') @Optional() explicitContext: any) {\n        super(inj, WIDGET_CONFIG, explicitContext);\n        this.popoverContainerCls = `app-popover-${this.widgetId}`;\n    }\n\n    private setupDocumentClickHandler() {\n        if (this.documentClickHandler) {\n            document.removeEventListener('click', this.documentClickHandler, true);\n        }\n\n        this.documentClickHandler = (event: MouseEvent) => {\n            if (!this.isOpen) return;\n\n            const target = event.target as HTMLElement;\n            const clickedPopoverIndex = PopoverComponent.activePopovers.findIndex(popover => {\n                const popoverContainer = document.querySelector(`.${popover.popoverContainerCls}`);\n                return popoverContainer?.contains(target);\n            });\n\n            if (clickedPopoverIndex === -1) {\n                // Click is outside all popovers\n                if (this.outsideclick) {\n                    this.closeAllPopovers();\n                }\n            } else {\n                // Click is inside a popover\n                this.closeInnerPopovers(clickedPopoverIndex);\n            }\n        };\n\n        document.addEventListener('click', this.documentClickHandler, true);\n    }\n\n    private closeAllPopovers() {\n        PopoverComponent.activePopovers.forEach(popover => {\n            if (popover.outsideclick) {\n                popover.isClosingProgrammatically = true;\n                popover.close();\n            }\n        });\n    }\n\n    private closeInnerPopovers(clickedIndex: number) {\n        for (let i = clickedIndex + 1; i < PopoverComponent.activePopovers.length; i++) {\n            const popover = PopoverComponent.activePopovers[i];\n            if (popover.outsideclick) {\n                popover.isClosingProgrammatically = true;\n                popover.close();\n            }\n        }\n    }\n\n    private isChildPopover(): boolean {\n        return !!$(this.nativeElement).closest('.popover').length;\n    }\n    // This mehtod is used to show/open the popover. This refers to the same method showPopover.\n    public open() {\n        this.showPopover();\n        if (!PopoverComponent.activePopovers.includes(this)) {\n            PopoverComponent.activePopovers.push(this);\n        }\n    }\n\n    // This mehtod is used to hide/close the popover.\n    public close() {\n        if (this.isOpen) {\n            this.isClosingProgrammatically = true;\n            this.isOpen = false;\n            this.bsPopoverDirective.hide();\n            const index = PopoverComponent.activePopovers.indexOf(this);\n            if (index > -1) {\n                PopoverComponent.activePopovers.splice(index, 1);\n            }\n        }\n    }\n\n    // Trigger on hiding popover\n    public onHidden() {\n        if (!this.isChildPopover() || this.isClosingProgrammatically) {\n            this.invokeEventCallback('hide', {$event: {type: 'hide'}});\n            this.isOpen = false;\n            if (activePopover === this) {\n                activePopover = null;\n            }\n        }\n        this.isClosingProgrammatically = false;\n    }\n\n    private setFocusToPopoverLink() {\n        setTimeout(() => this.anchorRef.nativeElement.focus(), 10);\n    }\n\n    private adjustPopoverArrowPosition(popoverElem, popoverLeftShift) {\n        this.bsPopoverDirective._popover._ngZone.onStable.subscribe(() => {\n            popoverElem.find('.popover-arrow').css('left', popoverLeftShift + 'px');\n        });\n    }\n\n    private calculatePopoverPostion(element) {\n\n        const popoverElem = $(element);\n        let popoverLeft =  popoverElem.offset().left;\n        const popoverWidth = popoverElem[0].offsetWidth;\n        const viewPortWidth = $(window).width();\n        const parentDimesion = this.anchorRef.nativeElement.getBoundingClientRect();\n        // Adjusting popover position, if it is not visible at left side\n        if (popoverLeft < 0) {\n            adjustContainerPosition(popoverElem, this.nativeElement, this.bsPopoverDirective._popover);\n            const popoverLeftShift = 4;\n            const arrowLeftShift = (parentDimesion.left + (parentDimesion.width / 2)) - popoverLeftShift;\n            this.adjustPopoverArrowPosition(popoverElem, arrowLeftShift);\n        }\n        // Adjusting popover position, if it is not visible at right side\n        if (popoverLeft + popoverWidth > viewPortWidth) {\n            adjustContainerRightEdges(popoverElem, this.nativeElement, this.bsPopoverDirective._popover);\n            setTimeout(() => {\n                popoverLeft = popoverElem.offset().left;\n                const popoverLeftAdjust = (popoverLeft + popoverWidth) - viewPortWidth;\n                const popoverLeftShift =  popoverLeft - popoverLeftAdjust;\n                let arrowLeftShift ;\n                if(popoverLeft<=100){\n                    arrowLeftShift =  (parentDimesion.left + (parentDimesion.width / 2)) - popoverLeft;\n                }else{\n                    arrowLeftShift = (parentDimesion.left + (parentDimesion.width / 2)) - popoverLeftShift;\n                }\n                if(viewPortWidth > 500){\n                    arrowLeftShift += 30;\n                }\n               this.adjustPopoverArrowPosition(popoverElem, arrowLeftShift);\n            });\n        }\n    }\n\n    // Trigger on showing popover\n    public onShown() {\n        const root = findRootContainer(this.$element);\n        // if page styles have to be applied to popover then popover has to be child of page element.\n        if (root) {\n            $('body > popover-container').wrap('<' + root + '/>');\n        }\n        // Fix for [WMS-25125]: Not closing the existing opened popovers when the autoclose property is DISABLED\n        if (!this.isChildPopover()) {\n            if (activePopover && activePopover !== this && \n                activePopover.autoclose !== AUTOCLOSE_TYPE.DISABLED) {\n                activePopover.isClosingProgrammatically = true;\n                activePopover.close();\n            }\n            activePopover = this;\n        }\n\n        this.isOpen = true;\n        if (!PopoverComponent.activePopovers.includes(this)) {\n            PopoverComponent.activePopovers.push(this);\n        }\n        const popoverContainer  = document.querySelector(`.${this.popoverContainerCls}`) as HTMLElement;\n        if (popoverContainer) {\n            popoverContainer.setAttribute('data-popover-id', this.widgetId);\n            \n            // Add click event listener to stop propagation\n            popoverContainer.addEventListener('click', (event: Event) => {\n                event.stopPropagation();\n            });\n        }\n        setCSSFromObj(popoverContainer, {\n            height: this.popoverheight,\n            minWidth: this.popoverwidth,\n            width: this.popoverwidth\n        });\n        if (!this.popoverarrow) {\n            addClass(popoverContainer.querySelector('.arrow') as HTMLElement, 'hidden');\n        }\n        if (this.interaction === 'hover' || this.interaction === 'default') {\n\n            // do not use addEventListener here\n            // attaching the event this way will override the existing event handlers\n            popoverContainer.onmouseenter = () => clearTimeout(this.closePopoverTimeout);\n            popoverContainer.onmouseleave = () => this.hidePopover();\n            this.anchorRef.nativeElement.onmouseenter = () => clearTimeout(this.closePopoverTimeout);\n            this.anchorRef.nativeElement.onmouseleave = () => this.hidePopover();\n        }\n        if (this.outsideclick) {\n            this.setupDocumentClickHandler();\n        }\n        setTimeout(() => {\n            this.anchorRef.nativeElement.removeAttribute('aria-describedby');\n        });\n        const deRegister = this.eventManager.addEventListener(popoverContainer, 'keydown.esc', () => {\n            this.isOpen = false;\n            this.setFocusToPopoverLink();\n            deRegister();\n        });\n        const popoverStartBtn: HTMLElement = popoverContainer.querySelector('.popover-start');\n        const popoverEndBtn: HTMLElement = popoverContainer.querySelector('.popover-end');\n        popoverStartBtn.onkeydown = (event) => {\n            // Check for Shift+Tab key\n            if (event.shiftKey && event.key === 'Tab') {\n                this.bsPopoverDirective.hide();\n                event.preventDefault();\n                this.setFocusToPopoverLink();\n                this.isOpen = false;            }\n        };\n        popoverEndBtn.onkeydown = (event) => {\n            // Check for Tab key\n            if (!event.shiftKey && event.key === 'Tab') {\n                this.bsPopoverDirective.hide();\n                event.preventDefault();\n                this.setFocusToPopoverLink();\n                this.isOpen = false;            }\n        };\n\n        //Whenever autoclose property is set to 'always', adding the onclick listener to the popover container to close the popover.\n        if (this.autoclose === AUTOCLOSE_TYPE.ALWAYS) {\n            popoverContainer.onclick = () => this.close();\n        }\n\n        setTimeout(() => popoverStartBtn.focus(), 50);\n        // Adjusting popover position if the popover placement is top or bottom\n        setTimeout( () => {\n            if (!this.adaptiveposition ) {\n                this.calculatePopoverPostion(popoverContainer);\n            }\n            // triggering onload and onshow events after popover content has rendered\n            this.triggerPopoverEvents();\n        });\n    }\n\n    triggerPopoverEvents() {\n        if (this.contentsource === 'partial') {\n            const cancelSubscription = this.app.subscribe('partialLoaded', (data) => {\n                const parEle = this.partialRef.nativeElement;\n                let partialScope;\n\n                if (parEle) {\n                    partialScope  = parEle.widget;\n                    this.Widgets   = partialScope.Widgets;\n                    this.Variables = partialScope.Variables;\n                    this.Actions   = partialScope.Actions;\n                    this.invokeEventCallback('load');\n                    this.invokeEventCallback('show', {$event: {type: 'show'}});\n                }\n                cancelSubscription();\n            });\n        } else {\n            this.Widgets   = this.viewParent.Widgets;\n            this.Variables = this.viewParent.Variables;\n            this.Actions   = this.viewParent.Actions;\n            this.invokeEventCallback('show', {$event: {type: 'show'}});\n        }\n    }\n\n    private hidePopover() {\n        this.isClosingProgrammatically = true;\n        this.closePopoverTimeout = setTimeout(() => this.isOpen = false, 500);\n    }\n\n    private showPopover() {\n        this.bsPopoverDirective.show();\n    }\n\n    onPopoverAnchorKeydown($event) {\n        // if there is no content available, the popover should not open through enter key. So checking whether the canPopoverOpen flag is true or not.\n        if (!this.canPopoverOpen) {\n           return;\n        }\n        if ($event.key === 'Enter') {\n            $event.stopPropagation();\n            $event.preventDefault();\n            this.showPopover();\n        }\n    }\n\n    onPropertyChange(key: string, nv: any, ov?: any) {\n        if (key === 'class' || key === 'tabindex') {\n            return;\n        }\n        if (key === 'contentsource') {\n            // if there is no partial content available, the popover should not open\n            if (this.contentsource === 'partial' && !this.content) {\n                this.canPopoverOpen = false;\n            }\n        }\n        if (key === 'content' && nv) {\n            this.canPopoverOpen = true;\n        }\n        if (key === 'autoclose') {\n            this.outsideclick = (nv === AUTOCLOSE_TYPE.OUTSIDECLICK || nv === AUTOCLOSE_TYPE.ALWAYS) ? true : false;\n        }\n        super.onPropertyChange(key, nv, ov);\n    }\n\n    ngOnInit() {\n        super.ngOnInit();\n        this.event = eventsMap[this.interaction];\n    }\n\n    ngAfterViewInit() {\n        super.ngAfterViewInit();\n        styler(this.anchorRef.nativeElement, this);\n        this.containerTarget = getContainerTargetClass(this.nativeElement);\n        // let parentElemPopover = $(this.nativeElement).parents();\n        // if (parentElemPopover.closest('[wmTable]').length ||\n        //     parentElemPopover.closest('[wmtabs]').length ||\n        //     parentElemPopover.closest('modal-container').length) {\n        //     this.adaptiveposition = false;\n        // }\n    }\n\n    ngOnDetach() {\n        // Hide the popover container while attaching the next component as part of page reuse strategy.\n        this.bsPopoverDirective.hide();\n    }\n\n    OnDestroy() {\n        if (this.documentClickHandler) {\n            document.removeEventListener('click', this.documentClickHandler, true);\n        }\n        const index = PopoverComponent.activePopovers.indexOf(this);\n        if (index > -1) {\n            PopoverComponent.activePopovers.splice(index, 1);\n        }\n    }\n}\n","<a [popover]=\"popoverTemplate\"\n    [popoverContext]=\"context\"\n    [popoverTitle]=\"title\"\n    [placement]=\"popoverplacement\"\n    [outsideClick]=\"outsideclick\"\n    [triggers]=\"event\"\n    (onShown)=\"onShown()\"\n    (onHidden)=\"onHidden()\"\n    containerClass=\"app-popover animated {{contentanimation}} {{popoverContainerCls}}\"\n    [container]=\"containerTarget || '.wm-app'\"\n    [isOpen]=\"isOpen\"\n    [tabindex]=\"tabindex\"\n    [name]=\"name\"\n    [class]=\"class\"\n    [ngClass]=\"{'disable-popover': !canPopoverOpen}\"\n    [adaptivePosition]=\"adaptiveposition\"\n   boundariesElement=\"window\"\n   [attr.aria-label]=\"arialabel || (badgevalue ? caption + ' ' + badgevalue : caption) || 'Popover menu'\"\n    [attr.aria-expanded]=\"isOpen\"\n    role=\"button\"\n    #anchor\n    name.bind=\"name\"\n    wmAnchor\n    animation.bind=\"animation\"\n    badgevalue.bind=\"badgevalue\"\n    caption.bind=\"caption\"\n    encodeurl.bind=\"encodeurl\"\n    hint.bind=\"hint\"\n    hyperlink.bind=\"hyperlink\"\n    iconurl.bind=\"iconurl\"\n    iconwidth.bind=\"iconwidth\"\n    iconheight.bind=\"iconheight\"\n    iconmargin.bind=\"iconmargin\"\n    iconclass.bind=\"iconclass\"\n    iconposition.bind=\"iconposition\"\n    shortcutkey.bind=\"shortcutkey\"\n    tabindex.bind=\"tabindex\"\n    (keydown)=\"onPopoverAnchorKeydown($event)\">\n</a>\n"]}
@@ -60,25 +60,89 @@ const eventsMap = {
60
60
  let activePopover;
61
61
  class PopoverComponent extends StylableComponent {
62
62
  static { this.initializeProps = registerProps(); }
63
+ static { this.activePopovers = []; }
63
64
  constructor(inj, app, explicitContext) {
64
65
  super(inj, WIDGET_CONFIG, explicitContext);
65
66
  this.app = app;
66
67
  this.isOpen = false;
67
68
  this.canPopoverOpen = true;
69
+ this.isClosingProgrammatically = false;
68
70
  this.popoverContainerCls = `app-popover-${this.widgetId}`;
69
71
  }
72
+ setupDocumentClickHandler() {
73
+ if (this.documentClickHandler) {
74
+ document.removeEventListener('click', this.documentClickHandler, true);
75
+ }
76
+ this.documentClickHandler = (event) => {
77
+ if (!this.isOpen)
78
+ return;
79
+ const target = event.target;
80
+ const clickedPopoverIndex = PopoverComponent.activePopovers.findIndex(popover => {
81
+ const popoverContainer = document.querySelector(`.${popover.popoverContainerCls}`);
82
+ return popoverContainer?.contains(target);
83
+ });
84
+ if (clickedPopoverIndex === -1) {
85
+ // Click is outside all popovers
86
+ if (this.outsideclick) {
87
+ this.closeAllPopovers();
88
+ }
89
+ }
90
+ else {
91
+ // Click is inside a popover
92
+ this.closeInnerPopovers(clickedPopoverIndex);
93
+ }
94
+ };
95
+ document.addEventListener('click', this.documentClickHandler, true);
96
+ }
97
+ closeAllPopovers() {
98
+ PopoverComponent.activePopovers.forEach(popover => {
99
+ if (popover.outsideclick) {
100
+ popover.isClosingProgrammatically = true;
101
+ popover.close();
102
+ }
103
+ });
104
+ }
105
+ closeInnerPopovers(clickedIndex) {
106
+ for (let i = clickedIndex + 1; i < PopoverComponent.activePopovers.length; i++) {
107
+ const popover = PopoverComponent.activePopovers[i];
108
+ if (popover.outsideclick) {
109
+ popover.isClosingProgrammatically = true;
110
+ popover.close();
111
+ }
112
+ }
113
+ }
114
+ isChildPopover() {
115
+ return !!$(this.nativeElement).closest('.popover').length;
116
+ }
70
117
  // This mehtod is used to show/open the popover. This refers to the same method showPopover.
71
118
  open() {
72
119
  this.showPopover();
120
+ if (!PopoverComponent.activePopovers.includes(this)) {
121
+ PopoverComponent.activePopovers.push(this);
122
+ }
73
123
  }
74
124
  // This mehtod is used to hide/close the popover.
75
125
  close() {
76
- this.isOpen = false;
126
+ if (this.isOpen) {
127
+ this.isClosingProgrammatically = true;
128
+ this.isOpen = false;
129
+ this.bsPopoverDirective.hide();
130
+ const index = PopoverComponent.activePopovers.indexOf(this);
131
+ if (index > -1) {
132
+ PopoverComponent.activePopovers.splice(index, 1);
133
+ }
134
+ }
77
135
  }
78
136
  // Trigger on hiding popover
79
137
  onHidden() {
80
- this.invokeEventCallback('hide', { $event: { type: 'hide' } });
81
- this.isOpen = false;
138
+ if (!this.isChildPopover() || this.isClosingProgrammatically) {
139
+ this.invokeEventCallback('hide', { $event: { type: 'hide' } });
140
+ this.isOpen = false;
141
+ if (activePopover === this) {
142
+ activePopover = null;
143
+ }
144
+ }
145
+ this.isClosingProgrammatically = false;
82
146
  }
83
147
  setFocusToPopoverLink() {
84
148
  setTimeout(() => this.anchorRef.nativeElement.focus(), 10);
@@ -130,12 +194,26 @@ class PopoverComponent extends StylableComponent {
130
194
  $('body > popover-container').wrap('<' + root + '/>');
131
195
  }
132
196
  // Fix for [WMS-25125]: Not closing the existing opened popovers when the autoclose property is DISABLED
133
- if (activePopover && activePopover.isOpen && activePopover.autoclose !== AUTOCLOSE_TYPE.DISABLED) {
134
- activePopover.isOpen = false;
197
+ if (!this.isChildPopover()) {
198
+ if (activePopover && activePopover !== this &&
199
+ activePopover.autoclose !== AUTOCLOSE_TYPE.DISABLED) {
200
+ activePopover.isClosingProgrammatically = true;
201
+ activePopover.close();
202
+ }
203
+ activePopover = this;
204
+ }
205
+ this.isOpen = true;
206
+ if (!PopoverComponent.activePopovers.includes(this)) {
207
+ PopoverComponent.activePopovers.push(this);
135
208
  }
136
- activePopover = this;
137
- activePopover.isOpen = true;
138
209
  const popoverContainer = document.querySelector(`.${this.popoverContainerCls}`);
210
+ if (popoverContainer) {
211
+ popoverContainer.setAttribute('data-popover-id', this.widgetId);
212
+ // Add click event listener to stop propagation
213
+ popoverContainer.addEventListener('click', (event) => {
214
+ event.stopPropagation();
215
+ });
216
+ }
139
217
  setCSSFromObj(popoverContainer, {
140
218
  height: this.popoverheight,
141
219
  minWidth: this.popoverwidth,
@@ -152,6 +230,9 @@ class PopoverComponent extends StylableComponent {
152
230
  this.anchorRef.nativeElement.onmouseenter = () => clearTimeout(this.closePopoverTimeout);
153
231
  this.anchorRef.nativeElement.onmouseleave = () => this.hidePopover();
154
232
  }
233
+ if (this.outsideclick) {
234
+ this.setupDocumentClickHandler();
235
+ }
155
236
  setTimeout(() => {
156
237
  this.anchorRef.nativeElement.removeAttribute('aria-describedby');
157
238
  });
@@ -218,6 +299,7 @@ class PopoverComponent extends StylableComponent {
218
299
  }
219
300
  }
220
301
  hidePopover() {
302
+ this.isClosingProgrammatically = true;
221
303
  this.closePopoverTimeout = setTimeout(() => this.isOpen = false, 500);
222
304
  }
223
305
  showPopover() {
@@ -271,6 +353,15 @@ class PopoverComponent extends StylableComponent {
271
353
  // Hide the popover container while attaching the next component as part of page reuse strategy.
272
354
  this.bsPopoverDirective.hide();
273
355
  }
356
+ OnDestroy() {
357
+ if (this.documentClickHandler) {
358
+ document.removeEventListener('click', this.documentClickHandler, true);
359
+ }
360
+ const index = PopoverComponent.activePopovers.indexOf(this);
361
+ if (index > -1) {
362
+ PopoverComponent.activePopovers.splice(index, 1);
363
+ }
364
+ }
274
365
  static { this.ɵfac = function PopoverComponent_Factory(t) { return new (t || PopoverComponent)(i0.ɵɵdirectiveInject(i0.Injector), i0.ɵɵdirectiveInject(i1.App), i0.ɵɵdirectiveInject('EXPLICIT_CONTEXT', 8)); }; }
275
366
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: PopoverComponent, selectors: [["wm-popover"]], contentQueries: function PopoverComponent_ContentQueries(rf, ctx, dirIndex) { if (rf & 1) {
276
367
  i0.ɵɵcontentQuery(dirIndex, TemplateRef, 5);