@ng-matero/extensions 14.2.2 → 14.3.1
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.
- package/core/datetime/datetime-formats.d.ts +2 -0
- package/esm2020/core/datetime/datetime-formats.mjs +1 -1
- package/esm2020/datetimepicker/datetimepicker-input.mjs +6 -1
- package/esm2020/grid/column-menu.component.mjs +11 -17
- package/esm2020/grid/grid.component.mjs +3 -3
- package/esm2020/popover/popover-animations.mjs +10 -13
- package/esm2020/popover/popover-content.mjs +90 -0
- package/esm2020/popover/popover-interfaces.mjs +1 -1
- package/esm2020/popover/popover-module.mjs +9 -7
- package/esm2020/popover/popover-target.mjs +3 -3
- package/esm2020/popover/popover-trigger.mjs +214 -184
- package/esm2020/popover/popover-types.mjs +1 -1
- package/esm2020/popover/popover.mjs +186 -133
- package/esm2020/popover/public-api.mjs +2 -1
- package/fesm2015/mtxCore.mjs.map +1 -1
- package/fesm2015/mtxDatetimepicker.mjs +5 -0
- package/fesm2015/mtxDatetimepicker.mjs.map +1 -1
- package/fesm2015/mtxGrid.mjs +12 -18
- package/fesm2015/mtxGrid.mjs.map +1 -1
- package/fesm2015/mtxPopover.mjs +518 -352
- package/fesm2015/mtxPopover.mjs.map +1 -1
- package/fesm2020/mtxCore.mjs.map +1 -1
- package/fesm2020/mtxDatetimepicker.mjs +5 -0
- package/fesm2020/mtxDatetimepicker.mjs.map +1 -1
- package/fesm2020/mtxGrid.mjs +12 -18
- package/fesm2020/mtxGrid.mjs.map +1 -1
- package/fesm2020/mtxPopover.mjs +512 -350
- package/fesm2020/mtxPopover.mjs.map +1 -1
- package/grid/column-menu.component.d.ts +4 -6
- package/package.json +1 -1
- package/popover/popover-animations.d.ts +1 -1
- package/popover/popover-content.d.ts +43 -0
- package/popover/popover-interfaces.d.ts +37 -31
- package/popover/popover-module.d.ts +4 -3
- package/popover/popover-target.d.ts +2 -2
- package/popover/popover-trigger.d.ts +67 -62
- package/popover/popover-types.d.ts +6 -1
- package/popover/popover.d.ts +99 -70
- package/popover/popover.scss +2 -0
- package/popover/public-api.d.ts +1 -0
|
@@ -1,46 +1,83 @@
|
|
|
1
|
-
import { Directive, EventEmitter, Input, Optional, Output, HostListener, HostBinding, } from '@angular/core';
|
|
2
1
|
import { isFakeMousedownFromScreenReader } from '@angular/cdk/a11y';
|
|
3
|
-
import {
|
|
2
|
+
import { ENTER, SPACE } from '@angular/cdk/keycodes';
|
|
3
|
+
import { Overlay, OverlayConfig, } from '@angular/cdk/overlay';
|
|
4
4
|
import { TemplatePortal } from '@angular/cdk/portal';
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
5
|
+
import { Directive, EventEmitter, Inject, InjectionToken, Input, Optional, Output, } from '@angular/core';
|
|
6
|
+
import { merge, of as observableOf, Subscription } from 'rxjs';
|
|
7
|
+
import { filter, take, takeUntil } from 'rxjs/operators';
|
|
8
|
+
import { MtxPopover } from './popover';
|
|
7
9
|
import { throwMtxPopoverMissingError } from './popover-errors';
|
|
8
10
|
import * as i0 from "@angular/core";
|
|
9
11
|
import * as i1 from "@angular/cdk/overlay";
|
|
10
12
|
import * as i2 from "@angular/cdk/bidi";
|
|
13
|
+
import * as i3 from "@angular/cdk/a11y";
|
|
14
|
+
/** Injection token that determines the scroll handling while the popover is open. */
|
|
15
|
+
export const MTX_POPOVER_SCROLL_STRATEGY = new InjectionToken('mtx-popover-scroll-strategy');
|
|
16
|
+
/** @docs-private */
|
|
17
|
+
export function MTX_POPOVER_SCROLL_STRATEGY_FACTORY(overlay) {
|
|
18
|
+
return () => overlay.scrollStrategies.reposition();
|
|
19
|
+
}
|
|
20
|
+
/** @docs-private */
|
|
21
|
+
export const MTX_POPOVER_SCROLL_STRATEGY_FACTORY_PROVIDER = {
|
|
22
|
+
provide: MTX_POPOVER_SCROLL_STRATEGY,
|
|
23
|
+
deps: [Overlay],
|
|
24
|
+
useFactory: MTX_POPOVER_SCROLL_STRATEGY_FACTORY,
|
|
25
|
+
};
|
|
11
26
|
/**
|
|
12
|
-
* This directive is intended to be used in conjunction with an mtx-popover tag. It is
|
|
27
|
+
* This directive is intended to be used in conjunction with an `mtx-popover` tag. It is
|
|
13
28
|
* responsible for toggling the display of the provided popover instance.
|
|
14
29
|
*/
|
|
15
30
|
export class MtxPopoverTrigger {
|
|
16
|
-
constructor(_overlay, _elementRef, _viewContainerRef, _dir, _changeDetectorRef) {
|
|
31
|
+
constructor(_overlay, _elementRef, _viewContainerRef, scrollStrategy, _dir, _changeDetectorRef, _focusMonitor) {
|
|
17
32
|
this._overlay = _overlay;
|
|
18
33
|
this._elementRef = _elementRef;
|
|
19
34
|
this._viewContainerRef = _viewContainerRef;
|
|
20
35
|
this._dir = _dir;
|
|
21
36
|
this._changeDetectorRef = _changeDetectorRef;
|
|
22
|
-
this.
|
|
23
|
-
this.popoverOpened$ = new Subject();
|
|
24
|
-
this.popoverClosed$ = new Subject();
|
|
37
|
+
this._focusMonitor = _focusMonitor;
|
|
25
38
|
this._overlayRef = null;
|
|
26
39
|
this._popoverOpen = false;
|
|
27
40
|
this._halt = false;
|
|
28
|
-
|
|
41
|
+
this._positionSubscription = Subscription.EMPTY;
|
|
42
|
+
this._popoverCloseSubscription = Subscription.EMPTY;
|
|
43
|
+
this._closingActionsSubscription = Subscription.EMPTY;
|
|
44
|
+
// Tracking input type is necessary so it's possible to only auto-focus
|
|
29
45
|
// the first item of the list when the popover is opened via the keyboard
|
|
30
|
-
this.
|
|
31
|
-
this._onDestroy = new Subject();
|
|
46
|
+
this._openedBy = undefined;
|
|
32
47
|
/** Event emitted when the associated popover is opened. */
|
|
33
48
|
this.popoverOpened = new EventEmitter();
|
|
34
49
|
/** Event emitted when the associated popover is closed. */
|
|
35
50
|
this.popoverClosed = new EventEmitter();
|
|
51
|
+
this._scrollStrategy = scrollStrategy;
|
|
52
|
+
}
|
|
53
|
+
/** References the popover instance that the trigger is associated with. */
|
|
54
|
+
get popover() {
|
|
55
|
+
return this._popover;
|
|
36
56
|
}
|
|
37
|
-
|
|
57
|
+
set popover(popover) {
|
|
58
|
+
if (popover === this._popover) {
|
|
59
|
+
return;
|
|
60
|
+
}
|
|
61
|
+
this._popover = popover;
|
|
62
|
+
this._popoverCloseSubscription.unsubscribe();
|
|
63
|
+
if (popover) {
|
|
64
|
+
this._popoverCloseSubscription = popover.closed.subscribe((reason) => {
|
|
65
|
+
this._destroyPopover();
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
ngAfterContentInit() {
|
|
38
70
|
this._checkPopover();
|
|
39
71
|
this._setCurrentConfig();
|
|
40
|
-
this.popover.closed.subscribe(() => this.closePopover());
|
|
41
72
|
}
|
|
42
73
|
ngOnDestroy() {
|
|
43
|
-
this.
|
|
74
|
+
if (this._overlayRef) {
|
|
75
|
+
this._overlayRef.dispose();
|
|
76
|
+
this._overlayRef = null;
|
|
77
|
+
}
|
|
78
|
+
this._positionSubscription.unsubscribe();
|
|
79
|
+
this._popoverCloseSubscription.unsubscribe();
|
|
80
|
+
this._closingActionsSubscription.unsubscribe();
|
|
44
81
|
}
|
|
45
82
|
_setCurrentConfig() {
|
|
46
83
|
if (this.triggerEvent) {
|
|
@@ -52,12 +89,18 @@ export class MtxPopoverTrigger {
|
|
|
52
89
|
get popoverOpen() {
|
|
53
90
|
return this._popoverOpen;
|
|
54
91
|
}
|
|
55
|
-
|
|
92
|
+
/** The text direction of the containing app. */
|
|
93
|
+
get dir() {
|
|
94
|
+
return this._dir && this._dir.value === 'rtl' ? 'rtl' : 'ltr';
|
|
95
|
+
}
|
|
96
|
+
/** Handles mouse click on the trigger. */
|
|
97
|
+
_handleClick(event) {
|
|
56
98
|
if (this.popover.triggerEvent === 'click') {
|
|
57
99
|
this.togglePopover();
|
|
58
100
|
}
|
|
59
101
|
}
|
|
60
|
-
|
|
102
|
+
/** Handles mouse enter on the trigger. */
|
|
103
|
+
_handleMouseEnter(event) {
|
|
61
104
|
this._halt = false;
|
|
62
105
|
if (this.popover.triggerEvent === 'hover') {
|
|
63
106
|
this._mouseoverTimer = setTimeout(() => {
|
|
@@ -65,7 +108,8 @@ export class MtxPopoverTrigger {
|
|
|
65
108
|
}, this.popover.enterDelay);
|
|
66
109
|
}
|
|
67
110
|
}
|
|
68
|
-
|
|
111
|
+
/** Handles mouse leave on the trigger. */
|
|
112
|
+
_handleMouseLeave(event) {
|
|
69
113
|
if (this.popover.triggerEvent === 'hover') {
|
|
70
114
|
if (this._mouseoverTimer) {
|
|
71
115
|
clearTimeout(this._mouseoverTimer);
|
|
@@ -83,117 +127,119 @@ export class MtxPopoverTrigger {
|
|
|
83
127
|
}
|
|
84
128
|
}
|
|
85
129
|
}
|
|
130
|
+
/** Handles mouse presses on the trigger. */
|
|
131
|
+
_handleMousedown(event) {
|
|
132
|
+
if (!isFakeMousedownFromScreenReader(event)) {
|
|
133
|
+
// Since right or middle button clicks won't trigger the `click` event,
|
|
134
|
+
// we shouldn't consider the popover as opened by mouse in those cases.
|
|
135
|
+
this._openedBy = event.button === 0 ? 'mouse' : undefined;
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
/** Handles key presses on the trigger. */
|
|
139
|
+
_handleKeydown(event) {
|
|
140
|
+
const keyCode = event.keyCode;
|
|
141
|
+
// Pressing enter on the trigger will trigger the click handler later.
|
|
142
|
+
if (keyCode === ENTER || keyCode === SPACE) {
|
|
143
|
+
this._openedBy = 'keyboard';
|
|
144
|
+
}
|
|
145
|
+
}
|
|
86
146
|
/** Toggles the popover between the open and closed states. */
|
|
87
147
|
togglePopover() {
|
|
88
148
|
return this._popoverOpen ? this.closePopover() : this.openPopover();
|
|
89
149
|
}
|
|
90
150
|
/** Opens the popover. */
|
|
91
151
|
openPopover() {
|
|
92
|
-
if (
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
152
|
+
if (this._popoverOpen || this._halt) {
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
this._checkPopover();
|
|
156
|
+
const overlayRef = this._createOverlay();
|
|
157
|
+
const overlayConfig = overlayRef.getConfig();
|
|
158
|
+
this._setPosition(overlayConfig.positionStrategy);
|
|
159
|
+
if (this.popover.triggerEvent === 'click') {
|
|
160
|
+
overlayConfig.hasBackdrop = this.popover.hasBackdrop ?? true;
|
|
161
|
+
}
|
|
162
|
+
overlayRef.attach(this._getPortal());
|
|
163
|
+
if (this.popover.lazyContent) {
|
|
164
|
+
this.popover.lazyContent.attach(this.popoverData);
|
|
165
|
+
}
|
|
166
|
+
this._closingActionsSubscription = this._popoverClosingActions().subscribe(() => this.closePopover());
|
|
167
|
+
this._initPopover();
|
|
168
|
+
if (this.popover instanceof MtxPopover) {
|
|
169
|
+
this.popover._startAnimation();
|
|
97
170
|
}
|
|
98
171
|
}
|
|
99
172
|
/** Closes the popover. */
|
|
100
173
|
closePopover() {
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
174
|
+
this.popover.closed.emit();
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Focuses the popover trigger.
|
|
178
|
+
* @param origin Source of the popover trigger's focus.
|
|
179
|
+
*/
|
|
180
|
+
focus(origin, options) {
|
|
181
|
+
if (this._focusMonitor && origin) {
|
|
182
|
+
this._focusMonitor.focusVia(this._elementRef, origin, options);
|
|
183
|
+
}
|
|
184
|
+
else {
|
|
185
|
+
this._elementRef.nativeElement.focus(options);
|
|
104
186
|
}
|
|
105
|
-
this.destroyPopover();
|
|
106
187
|
}
|
|
107
188
|
/** Removes the popover from the DOM. */
|
|
108
|
-
|
|
189
|
+
_destroyPopover(reason) {
|
|
190
|
+
if (!this._overlayRef || !this.popoverOpen) {
|
|
191
|
+
return;
|
|
192
|
+
}
|
|
193
|
+
// Clear the timeout for hover event.
|
|
109
194
|
if (this._mouseoverTimer) {
|
|
110
195
|
clearTimeout(this._mouseoverTimer);
|
|
111
196
|
this._mouseoverTimer = null;
|
|
112
197
|
}
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
/**
|
|
130
|
-
* This method ensures that the popover closes when the overlay backdrop is clicked.
|
|
131
|
-
* We do not use first() here because doing so would not catch clicks from within
|
|
132
|
-
* the popover, and it would fail to unsubscribe properly. Instead, we unsubscribe
|
|
133
|
-
* explicitly when the popover is closed or destroyed.
|
|
134
|
-
*/
|
|
135
|
-
_subscribeToBackdrop() {
|
|
136
|
-
if (this._overlayRef) {
|
|
137
|
-
/** Only subscribe to backdrop if trigger event is click */
|
|
138
|
-
if (this.triggerEvent === 'click' && this.popover.closeOnBackdropClick === true) {
|
|
139
|
-
this._overlayRef
|
|
140
|
-
.backdropClick()
|
|
141
|
-
.pipe(takeUntil(this.popoverClosed$), takeUntil(this._onDestroy))
|
|
142
|
-
.subscribe(() => {
|
|
143
|
-
this.popover._emitCloseEvent();
|
|
198
|
+
const popover = this.popover;
|
|
199
|
+
this._closingActionsSubscription.unsubscribe();
|
|
200
|
+
this._overlayRef.detach();
|
|
201
|
+
this._openedBy = undefined;
|
|
202
|
+
if (popover instanceof MtxPopover) {
|
|
203
|
+
popover._resetAnimation();
|
|
204
|
+
if (popover.lazyContent) {
|
|
205
|
+
// Wait for the exit animation to finish before detaching the content.
|
|
206
|
+
popover._animationDone
|
|
207
|
+
.pipe(filter(event => event.toState === 'void'), take(1),
|
|
208
|
+
// Interrupt if the content got re-attached.
|
|
209
|
+
takeUntil(popover.lazyContent._attached))
|
|
210
|
+
.subscribe({
|
|
211
|
+
next: () => popover.lazyContent.detach(),
|
|
212
|
+
// No matter whether the content got re-attached, reset the popover.
|
|
213
|
+
complete: () => this._setIsPopoverOpen(false),
|
|
144
214
|
});
|
|
145
215
|
}
|
|
216
|
+
else {
|
|
217
|
+
this._setIsPopoverOpen(false);
|
|
218
|
+
}
|
|
146
219
|
}
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
.pipe(takeUntil(this.popoverClosed$), takeUntil(this._onDestroy))
|
|
153
|
-
.subscribe(() => {
|
|
154
|
-
this._setPopoverClosed();
|
|
155
|
-
});
|
|
220
|
+
else {
|
|
221
|
+
this._setIsPopoverOpen(false);
|
|
222
|
+
if (popover.lazyContent) {
|
|
223
|
+
popover.lazyContent.detach();
|
|
224
|
+
}
|
|
156
225
|
}
|
|
157
226
|
}
|
|
158
227
|
/**
|
|
159
|
-
* This method sets the popover state to open
|
|
160
|
-
* the popover was opened via the keyboard.
|
|
228
|
+
* This method sets the popover state to open.
|
|
161
229
|
*/
|
|
162
230
|
_initPopover() {
|
|
163
|
-
this.
|
|
231
|
+
this.popover.direction = this.dir;
|
|
232
|
+
this.popover.setElevation();
|
|
233
|
+
this._setIsPopoverOpen(true);
|
|
164
234
|
}
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
_resetPopover() {
|
|
170
|
-
this._setPopoverClosed();
|
|
171
|
-
// Focus only needs to be reset to the host element if the popover was opened
|
|
172
|
-
// by the keyboard and manually shifted to the first popover item.
|
|
173
|
-
if (!this._openedByMouse) {
|
|
174
|
-
this.focus();
|
|
175
|
-
}
|
|
176
|
-
this._openedByMouse = false;
|
|
177
|
-
}
|
|
178
|
-
/** set state rather than toggle to support triggers sharing a popover */
|
|
179
|
-
_setPopoverOpened() {
|
|
180
|
-
if (!this._popoverOpen) {
|
|
181
|
-
this._popoverOpen = true;
|
|
182
|
-
this.popoverOpened$.next();
|
|
183
|
-
this.popoverOpened.emit();
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
/** set state rather than toggle to support triggers sharing a popover */
|
|
187
|
-
_setPopoverClosed() {
|
|
188
|
-
if (this._popoverOpen) {
|
|
189
|
-
this._popoverOpen = false;
|
|
190
|
-
this.popoverClosed$.next();
|
|
191
|
-
this.popoverClosed.emit();
|
|
192
|
-
}
|
|
235
|
+
// set state rather than toggle to support triggers sharing a popover
|
|
236
|
+
_setIsPopoverOpen(isOpen) {
|
|
237
|
+
this._popoverOpen = isOpen;
|
|
238
|
+
this._popoverOpen ? this.popoverOpened.emit() : this.popoverClosed.emit();
|
|
193
239
|
}
|
|
194
240
|
/**
|
|
195
|
-
*
|
|
196
|
-
*
|
|
241
|
+
* This method checks that a valid instance of MdPopover has been passed into
|
|
242
|
+
* `mtxPopoverTriggerFor`. If not, an exception is thrown.
|
|
197
243
|
*/
|
|
198
244
|
_checkPopover() {
|
|
199
245
|
if (!this.popover) {
|
|
@@ -201,16 +247,20 @@ export class MtxPopoverTrigger {
|
|
|
201
247
|
}
|
|
202
248
|
}
|
|
203
249
|
/**
|
|
204
|
-
*
|
|
205
|
-
*
|
|
250
|
+
* This method creates the overlay from the provided popover's template and saves its
|
|
251
|
+
* OverlayRef so that it can be attached to the DOM when openPopover is called.
|
|
206
252
|
*/
|
|
207
253
|
_createOverlay() {
|
|
208
254
|
if (!this._overlayRef) {
|
|
209
|
-
this._portal = new TemplatePortal(this.popover.templateRef, this._viewContainerRef);
|
|
210
255
|
const config = this._getOverlayConfig();
|
|
211
256
|
this._subscribeToPositions(config.positionStrategy);
|
|
212
257
|
this._overlayRef = this._overlay.create(config);
|
|
213
258
|
}
|
|
259
|
+
else {
|
|
260
|
+
const overlayConfig = this._overlayRef.getConfig();
|
|
261
|
+
const positionStrategy = overlayConfig.positionStrategy;
|
|
262
|
+
positionStrategy.setOrigin(this._getTargetElement());
|
|
263
|
+
}
|
|
214
264
|
return this._overlayRef;
|
|
215
265
|
}
|
|
216
266
|
/**
|
|
@@ -218,32 +268,24 @@ export class MtxPopoverTrigger {
|
|
|
218
268
|
* @returns OverlayConfig
|
|
219
269
|
*/
|
|
220
270
|
_getOverlayConfig() {
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
271
|
+
return new OverlayConfig({
|
|
272
|
+
positionStrategy: this._overlay
|
|
273
|
+
.position()
|
|
274
|
+
.flexibleConnectedTo(this._getTargetElement())
|
|
275
|
+
.withLockedPosition()
|
|
276
|
+
.withGrowAfterOpen()
|
|
277
|
+
.withTransformOriginOn('.mtx-popover-panel'),
|
|
278
|
+
backdropClass: this.popover.backdropClass || 'cdk-overlay-transparent-backdrop',
|
|
279
|
+
panelClass: this.popover.overlayPanelClass,
|
|
280
|
+
scrollStrategy: this._scrollStrategy(),
|
|
281
|
+
direction: this._dir,
|
|
282
|
+
});
|
|
231
283
|
}
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
_getOverlayScrollStrategy(strategy) {
|
|
236
|
-
switch (strategy) {
|
|
237
|
-
case 'noop':
|
|
238
|
-
return this._overlay.scrollStrategies.noop();
|
|
239
|
-
case 'close':
|
|
240
|
-
return this._overlay.scrollStrategies.close();
|
|
241
|
-
case 'block':
|
|
242
|
-
return this._overlay.scrollStrategies.block();
|
|
243
|
-
case 'reposition':
|
|
244
|
-
default:
|
|
245
|
-
return this._overlay.scrollStrategies.reposition();
|
|
284
|
+
_getTargetElement() {
|
|
285
|
+
if (this.targetElement) {
|
|
286
|
+
return this.targetElement.elementRef;
|
|
246
287
|
}
|
|
288
|
+
return this._elementRef;
|
|
247
289
|
}
|
|
248
290
|
/**
|
|
249
291
|
* Listens to changes in the position of the overlay and sets the correct classes
|
|
@@ -267,18 +309,16 @@ export class MtxPopoverTrigger {
|
|
|
267
309
|
: [posX, posY];
|
|
268
310
|
// required for ChangeDetectionStrategy.OnPush
|
|
269
311
|
this._changeDetectorRef.markForCheck();
|
|
270
|
-
this.popover.
|
|
271
|
-
|
|
272
|
-
this.popover.setPositionClasses(pos);
|
|
273
|
-
});
|
|
312
|
+
this.popover.setCurrentStyles(pos);
|
|
313
|
+
this.popover.setPositionClasses(pos);
|
|
274
314
|
});
|
|
275
315
|
}
|
|
276
316
|
/**
|
|
277
|
-
*
|
|
278
|
-
*
|
|
279
|
-
* @
|
|
317
|
+
* Sets the appropriate positions on a position strategy
|
|
318
|
+
* so the overlay connects with the trigger correctly.
|
|
319
|
+
* @param positionStrategy Strategy whose position to update.
|
|
280
320
|
*/
|
|
281
|
-
|
|
321
|
+
_setPosition(positionStrategy) {
|
|
282
322
|
const [originX, origin2ndX, origin3rdX] = this.popover.position[0] === 'before' || this.popover.position[1] === 'after'
|
|
283
323
|
? ['start', 'center', 'end']
|
|
284
324
|
: this.popover.position[0] === 'after' || this.popover.position[1] === 'before'
|
|
@@ -307,16 +347,6 @@ export class MtxPopoverTrigger {
|
|
|
307
347
|
const offsetY = this.popover.yOffset && !isNaN(Number(this.popover.yOffset))
|
|
308
348
|
? Number(this.popover.yOffset)
|
|
309
349
|
: 0;
|
|
310
|
-
/**
|
|
311
|
-
* For overriding position element, when `mtxPopoverTargetAt` has a valid element reference.
|
|
312
|
-
* Useful for sticking popover to parent element and offsetting arrow to trigger element.
|
|
313
|
-
* If undefined defaults to the trigger element reference.
|
|
314
|
-
*/
|
|
315
|
-
let element = this._elementRef;
|
|
316
|
-
if (typeof this.targetElement !== 'undefined') {
|
|
317
|
-
this.popover.containerPositioning = true;
|
|
318
|
-
element = this.targetElement._elementRef;
|
|
319
|
-
}
|
|
320
350
|
let positions = [{ originX, originY, overlayX, overlayY }];
|
|
321
351
|
if (this.popover.position[0] === 'above' || this.popover.position[0] === 'below') {
|
|
322
352
|
positions = [
|
|
@@ -374,47 +404,59 @@ export class MtxPopoverTrigger {
|
|
|
374
404
|
},
|
|
375
405
|
];
|
|
376
406
|
}
|
|
377
|
-
|
|
378
|
-
.position()
|
|
379
|
-
.flexibleConnectedTo(element)
|
|
380
|
-
.withLockedPosition()
|
|
407
|
+
positionStrategy
|
|
381
408
|
.withPositions(positions)
|
|
382
409
|
.withDefaultOffsetX(offsetX)
|
|
383
410
|
.withDefaultOffsetY(offsetY);
|
|
384
411
|
}
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
if (this._detachmentsSubscription) {
|
|
393
|
-
this._detachmentsSubscription.unsubscribe();
|
|
394
|
-
}
|
|
412
|
+
/** Returns a stream that emits whenever an action that should close the popover occurs. */
|
|
413
|
+
_popoverClosingActions() {
|
|
414
|
+
const backdrop = this.popover.triggerEvent === 'click' && this.popover.closeOnBackdropClick === true
|
|
415
|
+
? this._overlayRef.backdropClick()
|
|
416
|
+
: observableOf();
|
|
417
|
+
const detachments = this._overlayRef.detachments();
|
|
418
|
+
return merge(backdrop, detachments);
|
|
395
419
|
}
|
|
396
|
-
|
|
397
|
-
|
|
398
|
-
|
|
420
|
+
/** Gets the portal that should be attached to the overlay. */
|
|
421
|
+
_getPortal() {
|
|
422
|
+
// Note that we can avoid this check by keeping the portal on the popover panel.
|
|
423
|
+
// While it would be cleaner, we'd have to introduce another required method on
|
|
424
|
+
// `MtxPopoverPanel`, making it harder to consume.
|
|
425
|
+
if (!this._portal || this._portal.templateRef !== this.popover.templateRef) {
|
|
426
|
+
this._portal = new TemplatePortal(this.popover.templateRef, this._viewContainerRef);
|
|
399
427
|
}
|
|
428
|
+
return this._portal;
|
|
400
429
|
}
|
|
401
430
|
}
|
|
402
|
-
/** @nocollapse */ MtxPopoverTrigger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: MtxPopoverTrigger, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: i2.Directionality, optional: true }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
403
|
-
/** @nocollapse */ MtxPopoverTrigger.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: MtxPopoverTrigger, selector: "[mtxPopoverTriggerFor]", inputs: { popover: ["mtxPopoverTriggerFor", "popover"], targetElement: ["mtxPopoverTargetAt", "targetElement"], triggerEvent: ["mtxPopoverTriggerOn", "triggerEvent"] }, outputs: { popoverOpened: "popoverOpened", popoverClosed: "popoverClosed" }, host: { listeners: { "click": "
|
|
431
|
+
/** @nocollapse */ MtxPopoverTrigger.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: MtxPopoverTrigger, deps: [{ token: i1.Overlay }, { token: i0.ElementRef }, { token: i0.ViewContainerRef }, { token: MTX_POPOVER_SCROLL_STRATEGY }, { token: i2.Directionality, optional: true }, { token: i0.ChangeDetectorRef }, { token: i3.FocusMonitor }], target: i0.ɵɵFactoryTarget.Directive });
|
|
432
|
+
/** @nocollapse */ MtxPopoverTrigger.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: MtxPopoverTrigger, selector: "[mtx-popover-trigger-for], [mtxPopoverTriggerFor]", inputs: { popover: ["mtxPopoverTriggerFor", "popover"], popoverData: ["mtxPopoverTriggerData", "popoverData"], targetElement: ["mtxPopoverTargetAt", "targetElement"], triggerEvent: ["mtxPopoverTriggerOn", "triggerEvent"] }, outputs: { popoverOpened: "popoverOpened", popoverClosed: "popoverClosed" }, host: { attributes: { "aria-haspopup": "true" }, listeners: { "click": "_handleClick($event)", "mouseenter": "_handleMouseEnter($event)", "mouseleave": "_handleMouseLeave($event)", "mousedown": "_handleMousedown($event)", "keydown": "_handleKeydown($event)" }, properties: { "attr.aria-expanded": "popoverOpen || null", "attr.aria-controls": "popoverOpen ? popover.panelId : null" } }, exportAs: ["mtxPopoverTrigger"], ngImport: i0 });
|
|
404
433
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: MtxPopoverTrigger, decorators: [{
|
|
405
434
|
type: Directive,
|
|
406
435
|
args: [{
|
|
407
|
-
selector: '[mtxPopoverTriggerFor]',
|
|
436
|
+
selector: '[mtx-popover-trigger-for], [mtxPopoverTriggerFor]',
|
|
408
437
|
exportAs: 'mtxPopoverTrigger',
|
|
438
|
+
host: {
|
|
439
|
+
'aria-haspopup': 'true',
|
|
440
|
+
'[attr.aria-expanded]': 'popoverOpen || null',
|
|
441
|
+
'[attr.aria-controls]': 'popoverOpen ? popover.panelId : null',
|
|
442
|
+
'(click)': '_handleClick($event)',
|
|
443
|
+
'(mouseenter)': '_handleMouseEnter($event)',
|
|
444
|
+
'(mouseleave)': '_handleMouseLeave($event)',
|
|
445
|
+
'(mousedown)': '_handleMousedown($event)',
|
|
446
|
+
'(keydown)': '_handleKeydown($event)',
|
|
447
|
+
},
|
|
409
448
|
}]
|
|
410
|
-
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type:
|
|
449
|
+
}], ctorParameters: function () { return [{ type: i1.Overlay }, { type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: undefined, decorators: [{
|
|
450
|
+
type: Inject,
|
|
451
|
+
args: [MTX_POPOVER_SCROLL_STRATEGY]
|
|
452
|
+
}] }, { type: i2.Directionality, decorators: [{
|
|
411
453
|
type: Optional
|
|
412
|
-
}] }, { type: i0.ChangeDetectorRef }]; }, propDecorators: {
|
|
413
|
-
type: HostBinding,
|
|
414
|
-
args: ['attr.aria-haspopup']
|
|
415
|
-
}], popover: [{
|
|
454
|
+
}] }, { type: i0.ChangeDetectorRef }, { type: i3.FocusMonitor }]; }, propDecorators: { popover: [{
|
|
416
455
|
type: Input,
|
|
417
456
|
args: ['mtxPopoverTriggerFor']
|
|
457
|
+
}], popoverData: [{
|
|
458
|
+
type: Input,
|
|
459
|
+
args: ['mtxPopoverTriggerData']
|
|
418
460
|
}], targetElement: [{
|
|
419
461
|
type: Input,
|
|
420
462
|
args: ['mtxPopoverTargetAt']
|
|
@@ -425,17 +467,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
425
467
|
type: Output
|
|
426
468
|
}], popoverClosed: [{
|
|
427
469
|
type: Output
|
|
428
|
-
}], onClick: [{
|
|
429
|
-
type: HostListener,
|
|
430
|
-
args: ['click', ['$event']]
|
|
431
|
-
}], onMouseEnter: [{
|
|
432
|
-
type: HostListener,
|
|
433
|
-
args: ['mouseenter', ['$event']]
|
|
434
|
-
}], onMouseLeave: [{
|
|
435
|
-
type: HostListener,
|
|
436
|
-
args: ['mouseleave', ['$event']]
|
|
437
|
-
}], _handleMousedown: [{
|
|
438
|
-
type: HostListener,
|
|
439
|
-
args: ['mousedown', ['$event']]
|
|
440
470
|
}] } });
|
|
441
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-trigger.js","sourceRoot":"","sources":["../../../../projects/extensions/popover/popover-trigger.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  ViewContainerRef,\n  HostListener,\n  HostBinding,\n  ChangeDetectorRef,\n} from '@angular/core';\n\nimport { isFakeMousedownFromScreenReader } from '@angular/cdk/a11y';\nimport { Direction, Directionality } from '@angular/cdk/bidi';\nimport {\n  Overlay,\n  OverlayRef,\n  OverlayConfig,\n  HorizontalConnectionPos,\n  VerticalConnectionPos,\n  FlexibleConnectedPositionStrategy,\n  ScrollStrategy,\n  ConnectedPosition,\n} from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\n\nimport { Subscription, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { MtxPopoverPanel, MtxTarget } from './popover-interfaces';\nimport {\n  MtxPopoverTriggerEvent,\n  MtxPopoverScrollStrategy,\n  MtxPopoverPosition,\n  MtxPopoverPositionStart,\n} from './popover-types';\nimport { throwMtxPopoverMissingError } from './popover-errors';\n\n/**\n * This directive is intended to be used in conjunction with an mtx-popover tag. It is\n * responsible for toggling the display of the provided popover instance.\n */\n\n@Directive({\n  selector: '[mtxPopoverTriggerFor]',\n  exportAs: 'mtxPopoverTrigger',\n})\nexport class MtxPopoverTrigger implements AfterViewInit, OnDestroy {\n  @HostBinding('attr.aria-haspopup') ariaHaspopup = true;\n\n  popoverOpened$ = new Subject<void>();\n  popoverClosed$ = new Subject<void>();\n\n  private _portal!: TemplatePortal<any>;\n  private _overlayRef: OverlayRef | null = null;\n  private _popoverOpen = false;\n  private _halt = false;\n  private _backdropSubscription!: Subscription;\n  private _positionSubscription!: Subscription;\n  private _detachmentsSubscription!: Subscription;\n\n  private _mouseoverTimer: any;\n\n  // tracking input type is necessary so it's possible to only auto-focus\n  // the first item of the list when the popover is opened via the keyboard\n  private _openedByMouse = false;\n\n  private _onDestroy = new Subject<void>();\n\n  /** References the popover instance that the trigger is associated with. */\n  @Input('mtxPopoverTriggerFor') popover!: MtxPopoverPanel;\n\n  /** References the popover target instance that the trigger is associated with. */\n  @Input('mtxPopoverTargetAt') targetElement!: MtxTarget;\n\n  /** Popover trigger event */\n  @Input('mtxPopoverTriggerOn') triggerEvent!: MtxPopoverTriggerEvent;\n\n  /** Event emitted when the associated popover is opened. */\n  @Output() popoverOpened = new EventEmitter<void>();\n\n  /** Event emitted when the associated popover is closed. */\n  @Output() popoverClosed = new EventEmitter<void>();\n\n  constructor(\n    private _overlay: Overlay,\n    public _elementRef: ElementRef,\n    private _viewContainerRef: ViewContainerRef,\n    @Optional() private _dir: Directionality,\n    private _changeDetectorRef: ChangeDetectorRef\n  ) {}\n\n  ngAfterViewInit() {\n    this._checkPopover();\n    this._setCurrentConfig();\n    this.popover.closed.subscribe(() => this.closePopover());\n  }\n\n  ngOnDestroy() {\n    this.destroyPopover();\n  }\n\n  private _setCurrentConfig() {\n    if (this.triggerEvent) {\n      this.popover.triggerEvent = this.triggerEvent;\n    }\n\n    this.popover.setCurrentStyles();\n  }\n\n  /** Whether the popover is open. */\n  get popoverOpen(): boolean {\n    return this._popoverOpen;\n  }\n\n  @HostListener('click', ['$event'])\n  onClick(event: MouseEvent): void {\n    if (this.popover.triggerEvent === 'click') {\n      this.togglePopover();\n    }\n  }\n\n  @HostListener('mouseenter', ['$event'])\n  onMouseEnter(event: MouseEvent): void {\n    this._halt = false;\n    if (this.popover.triggerEvent === 'hover') {\n      this._mouseoverTimer = setTimeout(() => {\n        this.openPopover();\n      }, this.popover.enterDelay);\n    }\n  }\n\n  @HostListener('mouseleave', ['$event'])\n  onMouseLeave(event: MouseEvent): void {\n    if (this.popover.triggerEvent === 'hover') {\n      if (this._mouseoverTimer) {\n        clearTimeout(this._mouseoverTimer);\n        this._mouseoverTimer = null;\n      }\n      if (this._popoverOpen) {\n        setTimeout(() => {\n          if (!this.popover.closeDisabled) {\n            this.closePopover();\n          }\n        }, this.popover.leaveDelay);\n      } else {\n        this._halt = true;\n      }\n    }\n  }\n\n  /** Toggles the popover between the open and closed states. */\n  togglePopover(): void {\n    return this._popoverOpen ? this.closePopover() : this.openPopover();\n  }\n\n  /** Opens the popover. */\n  openPopover(): void {\n    if (!this._popoverOpen && !this._halt) {\n      this._createOverlay().attach(this._portal);\n\n      this._subscribeToBackdrop();\n      this._subscribeToDetachments();\n\n      this._initPopover();\n    }\n  }\n\n  /** Closes the popover. */\n  closePopover(): void {\n    if (this._overlayRef) {\n      this._overlayRef.detach();\n      this._resetPopover();\n    }\n\n    this.destroyPopover();\n  }\n\n  /** Removes the popover from the DOM. */\n  destroyPopover(): void {\n    if (this._mouseoverTimer) {\n      clearTimeout(this._mouseoverTimer);\n      this._mouseoverTimer = null;\n    }\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n      this._cleanUpSubscriptions();\n    }\n\n    this._onDestroy.next();\n    this._onDestroy.complete();\n  }\n\n  /** Focuses the popover trigger. */\n  focus() {\n    this._elementRef.nativeElement.focus();\n  }\n\n  /** The text direction of the containing app. */\n  get dir(): Direction {\n    return this._dir && this._dir.value === 'rtl' ? 'rtl' : 'ltr';\n  }\n\n  /**\n   * This method ensures that the popover closes when the overlay backdrop is clicked.\n   * We do not use first() here because doing so would not catch clicks from within\n   * the popover, and it would fail to unsubscribe properly. Instead, we unsubscribe\n   * explicitly when the popover is closed or destroyed.\n   */\n  private _subscribeToBackdrop(): void {\n    if (this._overlayRef) {\n      /** Only subscribe to backdrop if trigger event is click */\n      if (this.triggerEvent === 'click' && this.popover.closeOnBackdropClick === true) {\n        this._overlayRef\n          .backdropClick()\n          .pipe(takeUntil(this.popoverClosed$), takeUntil(this._onDestroy))\n          .subscribe(() => {\n            this.popover._emitCloseEvent();\n          });\n      }\n    }\n  }\n\n  private _subscribeToDetachments(): void {\n    if (this._overlayRef) {\n      this._overlayRef\n        .detachments()\n        .pipe(takeUntil(this.popoverClosed$), takeUntil(this._onDestroy))\n        .subscribe(() => {\n          this._setPopoverClosed();\n        });\n    }\n  }\n\n  /**\n   * This method sets the popover state to open and focuses the first item if\n   * the popover was opened via the keyboard.\n   */\n  private _initPopover(): void {\n    this._setPopoverOpened();\n  }\n\n  /**\n   * This method resets the popover when it's closed, most importantly restoring\n   * focus to the popover trigger if the popover was opened via the keyboard.\n   */\n  private _resetPopover(): void {\n    this._setPopoverClosed();\n\n    // Focus only needs to be reset to the host element if the popover was opened\n    // by the keyboard and manually shifted to the first popover item.\n    if (!this._openedByMouse) {\n      this.focus();\n    }\n    this._openedByMouse = false;\n  }\n\n  /** set state rather than toggle to support triggers sharing a popover */\n  private _setPopoverOpened(): void {\n    if (!this._popoverOpen) {\n      this._popoverOpen = true;\n\n      this.popoverOpened$.next();\n      this.popoverOpened.emit();\n    }\n  }\n\n  /** set state rather than toggle to support triggers sharing a popover */\n  private _setPopoverClosed(): void {\n    if (this._popoverOpen) {\n      this._popoverOpen = false;\n\n      this.popoverClosed$.next();\n      this.popoverClosed.emit();\n    }\n  }\n\n  /**\n   *  This method checks that a valid instance of MdPopover has been passed into\n   *  mdPopoverTriggerFor. If not, an exception is thrown.\n   */\n  private _checkPopover() {\n    if (!this.popover) {\n      throwMtxPopoverMissingError();\n    }\n  }\n\n  /**\n   *  This method creates the overlay from the provided popover's template and saves its\n   *  OverlayRef so that it can be attached to the DOM when openPopover is called.\n   */\n  private _createOverlay(): OverlayRef {\n    if (!this._overlayRef) {\n      this._portal = new TemplatePortal(this.popover.templateRef, this._viewContainerRef);\n      const config = this._getOverlayConfig();\n      this._subscribeToPositions(config.positionStrategy as FlexibleConnectedPositionStrategy);\n      this._overlayRef = this._overlay.create(config);\n    }\n\n    return this._overlayRef;\n  }\n\n  /**\n   * This method builds the configuration object needed to create the overlay, the OverlayConfig.\n   * @returns OverlayConfig\n   */\n  private _getOverlayConfig(): OverlayConfig {\n    const overlayState = new OverlayConfig();\n    overlayState.positionStrategy = this._getPosition();\n\n    /** Display overlay backdrop if trigger event is click */\n    if (this.triggerEvent === 'click') {\n      overlayState.hasBackdrop = true;\n      overlayState.backdropClass = 'cdk-overlay-transparent-backdrop';\n    }\n\n    overlayState.direction = this._dir;\n    overlayState.scrollStrategy = this._getOverlayScrollStrategy(this.popover.scrollStrategy);\n\n    return overlayState;\n  }\n\n  /**\n   * This method returns the scroll strategy used by the cdk/overlay.\n   */\n  private _getOverlayScrollStrategy(strategy: MtxPopoverScrollStrategy): ScrollStrategy {\n    switch (strategy) {\n      case 'noop':\n        return this._overlay.scrollStrategies.noop();\n      case 'close':\n        return this._overlay.scrollStrategies.close();\n      case 'block':\n        return this._overlay.scrollStrategies.block();\n      case 'reposition':\n      default:\n        return this._overlay.scrollStrategies.reposition();\n    }\n  }\n\n  /**\n   * Listens to changes in the position of the overlay and sets the correct classes\n   * on the popover based on the new position. This ensures the animation origin is always\n   * correct, even if a fallback position is used for the overlay.\n   */\n  private _subscribeToPositions(position: FlexibleConnectedPositionStrategy): void {\n    this._positionSubscription = position.positionChanges.subscribe(change => {\n      const posX =\n        change.connectionPair.overlayX === 'start'\n          ? 'after'\n          : change.connectionPair.overlayX === 'end'\n          ? 'before'\n          : 'center';\n      const posY =\n        change.connectionPair.overlayY === 'top'\n          ? 'below'\n          : change.connectionPair.overlayY === 'bottom'\n          ? 'above'\n          : 'center';\n\n      const pos: MtxPopoverPosition =\n        this.popover.position[0] === 'above' || this.popover.position[0] === 'below'\n          ? [posY as MtxPopoverPositionStart, posX]\n          : [posX as MtxPopoverPositionStart, posY];\n\n      // required for ChangeDetectionStrategy.OnPush\n      this._changeDetectorRef.markForCheck();\n\n      this.popover.zone.run(() => {\n        this.popover.setCurrentStyles(pos);\n        this.popover.setPositionClasses(pos);\n      });\n    });\n  }\n\n  /**\n   * This method builds the position strategy for the overlay, so the popover is properly connected\n   * to the trigger.\n   * @returns ConnectedPositionStrategy\n   */\n  private _getPosition(): FlexibleConnectedPositionStrategy {\n    const [originX, origin2ndX, origin3rdX]: HorizontalConnectionPos[] =\n      this.popover.position[0] === 'before' || this.popover.position[1] === 'after'\n        ? ['start', 'center', 'end']\n        : this.popover.position[0] === 'after' || this.popover.position[1] === 'before'\n        ? ['end', 'center', 'start']\n        : ['center', 'start', 'end'];\n\n    const [originY, origin2ndY, origin3rdY]: VerticalConnectionPos[] =\n      this.popover.position[0] === 'above' || this.popover.position[1] === 'below'\n        ? ['top', 'center', 'bottom']\n        : this.popover.position[0] === 'below' || this.popover.position[1] === 'above'\n        ? ['bottom', 'center', 'top']\n        : ['center', 'top', 'bottom'];\n\n    const [overlayX, overlayFallbackX]: HorizontalConnectionPos[] =\n      this.popover.position[0] === 'below' || this.popover.position[0] === 'above'\n        ? [originX, originX]\n        : this.popover.position[0] === 'before'\n        ? ['end', 'start']\n        : ['start', 'end'];\n\n    const [overlayY, overlayFallbackY]: VerticalConnectionPos[] =\n      this.popover.position[0] === 'before' || this.popover.position[0] === 'after'\n        ? [originY, originY]\n        : this.popover.position[0] === 'below'\n        ? ['top', 'bottom']\n        : ['bottom', 'top'];\n\n    const originFallbackX = overlayX;\n    const originFallbackY = overlayY;\n\n    const offsetX =\n      this.popover.xOffset && !isNaN(Number(this.popover.xOffset))\n        ? Number(this.dir === 'ltr' ? this.popover.xOffset : -this.popover.xOffset)\n        : 0;\n    const offsetY =\n      this.popover.yOffset && !isNaN(Number(this.popover.yOffset))\n        ? Number(this.popover.yOffset)\n        : 0;\n\n    /**\n     * For overriding position element, when `mtxPopoverTargetAt` has a valid element reference.\n     * Useful for sticking popover to parent element and offsetting arrow to trigger element.\n     * If undefined defaults to the trigger element reference.\n     */\n    let element = this._elementRef;\n    if (typeof this.targetElement !== 'undefined') {\n      this.popover.containerPositioning = true;\n      element = this.targetElement._elementRef;\n    }\n\n    let positions: ConnectedPosition[] = [{ originX, originY, overlayX, overlayY }];\n\n    if (this.popover.position[0] === 'above' || this.popover.position[0] === 'below') {\n      positions = [\n        { originX, originY, overlayX, overlayY, offsetY },\n        { originX: origin2ndX, originY, overlayX: origin2ndX, overlayY, offsetY },\n        { originX: origin3rdX, originY, overlayX: origin3rdX, overlayY, offsetY },\n        {\n          originX,\n          originY: originFallbackY,\n          overlayX,\n          overlayY: overlayFallbackY,\n          offsetY: -offsetY,\n        },\n        {\n          originX: origin2ndX,\n          originY: originFallbackY,\n          overlayX: origin2ndX,\n          overlayY: overlayFallbackY,\n          offsetY: -offsetY,\n        },\n        {\n          originX: origin3rdX,\n          originY: originFallbackY,\n          overlayX: origin3rdX,\n          overlayY: overlayFallbackY,\n          offsetY: -offsetY,\n        },\n      ];\n    }\n\n    if (this.popover.position[0] === 'before' || this.popover.position[0] === 'after') {\n      positions = [\n        { originX, originY, overlayX, overlayY, offsetX },\n        { originX, originY: origin2ndY, overlayX, overlayY: origin2ndY, offsetX },\n        { originX, originY: origin3rdY, overlayX, overlayY: origin3rdY, offsetX },\n        {\n          originX: originFallbackX,\n          originY,\n          overlayX: overlayFallbackX,\n          overlayY,\n          offsetX: -offsetX,\n        },\n        {\n          originX: originFallbackX,\n          originY: origin2ndY,\n          overlayX: overlayFallbackX,\n          overlayY: origin2ndY,\n          offsetX: -offsetX,\n        },\n        {\n          originX: originFallbackX,\n          originY: origin3rdY,\n          overlayX: overlayFallbackX,\n          overlayY: origin3rdY,\n          offsetX: -offsetX,\n        },\n      ];\n    }\n\n    return this._overlay\n      .position()\n      .flexibleConnectedTo(element)\n      .withLockedPosition()\n      .withPositions(positions)\n      .withDefaultOffsetX(offsetX)\n      .withDefaultOffsetY(offsetY);\n  }\n\n  private _cleanUpSubscriptions(): void {\n    if (this._backdropSubscription) {\n      this._backdropSubscription.unsubscribe();\n    }\n    if (this._positionSubscription) {\n      this._positionSubscription.unsubscribe();\n    }\n    if (this._detachmentsSubscription) {\n      this._detachmentsSubscription.unsubscribe();\n    }\n  }\n\n  @HostListener('mousedown', ['$event']) _handleMousedown(event: MouseEvent): void {\n    if (event && !isFakeMousedownFromScreenReader(event)) {\n      this._openedByMouse = true;\n    }\n  }\n}\n"]}
|
|
471
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-trigger.js","sourceRoot":"","sources":["../../../../projects/extensions/popover/popover-trigger.ts"],"names":[],"mappings":"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","sourcesContent":["import { FocusMonitor, FocusOrigin, isFakeMousedownFromScreenReader } from '@angular/cdk/a11y';\nimport { Direction, Directionality } from '@angular/cdk/bidi';\nimport { ENTER, SPACE } from '@angular/cdk/keycodes';\nimport {\n  ConnectedPosition,\n  FlexibleConnectedPositionStrategy,\n  HorizontalConnectionPos,\n  Overlay,\n  OverlayConfig,\n  OverlayRef,\n  ScrollStrategy,\n  VerticalConnectionPos,\n} from '@angular/cdk/overlay';\nimport { TemplatePortal } from '@angular/cdk/portal';\nimport {\n  AfterContentInit,\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  OnDestroy,\n  Optional,\n  Output,\n  ViewContainerRef,\n} from '@angular/core';\nimport { merge, of as observableOf, Subscription } from 'rxjs';\nimport { filter, take, takeUntil } from 'rxjs/operators';\nimport { MtxPopover } from './popover';\nimport { throwMtxPopoverMissingError } from './popover-errors';\nimport { MtxPopoverPanel } from './popover-interfaces';\nimport { MtxPopoverTarget } from './popover-target';\nimport {\n  MtxPopoverPosition,\n  MtxPopoverPositionStart,\n  MtxPopoverTriggerEvent,\n  PopoverCloseReason,\n} from './popover-types';\n\n/** Injection token that determines the scroll handling while the popover is open. */\nexport const MTX_POPOVER_SCROLL_STRATEGY = new InjectionToken<() => ScrollStrategy>(\n  'mtx-popover-scroll-strategy'\n);\n\n/** @docs-private */\nexport function MTX_POPOVER_SCROLL_STRATEGY_FACTORY(overlay: Overlay): () => ScrollStrategy {\n  return () => overlay.scrollStrategies.reposition();\n}\n\n/** @docs-private */\nexport const MTX_POPOVER_SCROLL_STRATEGY_FACTORY_PROVIDER = {\n  provide: MTX_POPOVER_SCROLL_STRATEGY,\n  deps: [Overlay],\n  useFactory: MTX_POPOVER_SCROLL_STRATEGY_FACTORY,\n};\n\n/**\n * This directive is intended to be used in conjunction with an `mtx-popover` tag. It is\n * responsible for toggling the display of the provided popover instance.\n */\n@Directive({\n  selector: '[mtx-popover-trigger-for], [mtxPopoverTriggerFor]',\n  exportAs: 'mtxPopoverTrigger',\n  host: {\n    'aria-haspopup': 'true',\n    '[attr.aria-expanded]': 'popoverOpen || null',\n    '[attr.aria-controls]': 'popoverOpen ? popover.panelId : null',\n    '(click)': '_handleClick($event)',\n    '(mouseenter)': '_handleMouseEnter($event)',\n    '(mouseleave)': '_handleMouseLeave($event)',\n    '(mousedown)': '_handleMousedown($event)',\n    '(keydown)': '_handleKeydown($event)',\n  },\n})\nexport class MtxPopoverTrigger implements AfterContentInit, OnDestroy {\n  private _portal?: TemplatePortal;\n  private _overlayRef: OverlayRef | null = null;\n  private _popoverOpen = false;\n  private _halt = false;\n  private _positionSubscription = Subscription.EMPTY;\n  private _popoverCloseSubscription = Subscription.EMPTY;\n  private _closingActionsSubscription = Subscription.EMPTY;\n  private _scrollStrategy!: () => ScrollStrategy;\n  private _mouseoverTimer: any;\n\n  // Tracking input type is necessary so it's possible to only auto-focus\n  // the first item of the list when the popover is opened via the keyboard\n  _openedBy: Exclude<FocusOrigin, 'program' | null> | undefined = undefined;\n\n  /** References the popover instance that the trigger is associated with. */\n  @Input('mtxPopoverTriggerFor')\n  get popover() {\n    return this._popover;\n  }\n  set popover(popover: MtxPopoverPanel) {\n    if (popover === this._popover) {\n      return;\n    }\n\n    this._popover = popover;\n    this._popoverCloseSubscription.unsubscribe();\n\n    if (popover) {\n      this._popoverCloseSubscription = popover.closed.subscribe((reason: PopoverCloseReason) => {\n        this._destroyPopover();\n      });\n    }\n  }\n  private _popover!: MtxPopoverPanel;\n\n  /** Data to be passed along to any lazily-rendered content. */\n  @Input('mtxPopoverTriggerData') popoverData: any;\n\n  /** References the popover target instance that the trigger is associated with. */\n  @Input('mtxPopoverTargetAt') targetElement?: MtxPopoverTarget;\n\n  /** Popover trigger event */\n  @Input('mtxPopoverTriggerOn') triggerEvent?: MtxPopoverTriggerEvent;\n\n  /** Event emitted when the associated popover is opened. */\n  @Output() popoverOpened = new EventEmitter<void>();\n\n  /** Event emitted when the associated popover is closed. */\n  @Output() popoverClosed = new EventEmitter<void>();\n\n  constructor(\n    private _overlay: Overlay,\n    private _elementRef: ElementRef<HTMLElement>,\n    private _viewContainerRef: ViewContainerRef,\n    @Inject(MTX_POPOVER_SCROLL_STRATEGY) scrollStrategy: any,\n    @Optional() private _dir: Directionality,\n    private _changeDetectorRef: ChangeDetectorRef,\n    private _focusMonitor?: FocusMonitor\n  ) {\n    this._scrollStrategy = scrollStrategy;\n  }\n\n  ngAfterContentInit() {\n    this._checkPopover();\n    this._setCurrentConfig();\n  }\n\n  ngOnDestroy() {\n    if (this._overlayRef) {\n      this._overlayRef.dispose();\n      this._overlayRef = null;\n    }\n\n    this._positionSubscription.unsubscribe();\n    this._popoverCloseSubscription.unsubscribe();\n    this._closingActionsSubscription.unsubscribe();\n  }\n\n  private _setCurrentConfig() {\n    if (this.triggerEvent) {\n      this.popover.triggerEvent = this.triggerEvent;\n    }\n\n    this.popover.setCurrentStyles();\n  }\n\n  /** Whether the popover is open. */\n  get popoverOpen(): boolean {\n    return this._popoverOpen;\n  }\n\n  /** The text direction of the containing app. */\n  get dir(): Direction {\n    return this._dir && this._dir.value === 'rtl' ? 'rtl' : 'ltr';\n  }\n\n  /** Handles mouse click on the trigger. */\n  _handleClick(event: MouseEvent): void {\n    if (this.popover.triggerEvent === 'click') {\n      this.togglePopover();\n    }\n  }\n\n  /** Handles mouse enter on the trigger. */\n  _handleMouseEnter(event: MouseEvent): void {\n    this._halt = false;\n\n    if (this.popover.triggerEvent === 'hover') {\n      this._mouseoverTimer = setTimeout(() => {\n        this.openPopover();\n      }, this.popover.enterDelay);\n    }\n  }\n\n  /** Handles mouse leave on the trigger. */\n  _handleMouseLeave(event: MouseEvent): void {\n    if (this.popover.triggerEvent === 'hover') {\n      if (this._mouseoverTimer) {\n        clearTimeout(this._mouseoverTimer);\n        this._mouseoverTimer = null;\n      }\n\n      if (this._popoverOpen) {\n        setTimeout(() => {\n          if (!this.popover.closeDisabled) {\n            this.closePopover();\n          }\n        }, this.popover.leaveDelay);\n      } else {\n        this._halt = true;\n      }\n    }\n  }\n\n  /** Handles mouse presses on the trigger. */\n  _handleMousedown(event: MouseEvent): void {\n    if (!isFakeMousedownFromScreenReader(event)) {\n      // Since right or middle button clicks won't trigger the `click` event,\n      // we shouldn't consider the popover as opened by mouse in those cases.\n      this._openedBy = event.button === 0 ? 'mouse' : undefined;\n    }\n  }\n\n  /** Handles key presses on the trigger. */\n  _handleKeydown(event: KeyboardEvent): void {\n    const keyCode = event.keyCode;\n\n    // Pressing enter on the trigger will trigger the click handler later.\n    if (keyCode === ENTER || keyCode === SPACE) {\n      this._openedBy = 'keyboard';\n    }\n  }\n\n  /** Toggles the popover between the open and closed states. */\n  togglePopover(): void {\n    return this._popoverOpen ? this.closePopover() : this.openPopover();\n  }\n\n  /** Opens the popover. */\n  openPopover(): void {\n    if (this._popoverOpen || this._halt) {\n      return;\n    }\n\n    this._checkPopover();\n\n    const overlayRef = this._createOverlay();\n    const overlayConfig = overlayRef.getConfig();\n\n    this._setPosition(overlayConfig.positionStrategy as FlexibleConnectedPositionStrategy);\n    if (this.popover.triggerEvent === 'click') {\n      overlayConfig.hasBackdrop = this.popover.hasBackdrop ?? true;\n    }\n    overlayRef.attach(this._getPortal());\n\n    if (this.popover.lazyContent) {\n      this.popover.lazyContent.attach(this.popoverData);\n    }\n\n    this._closingActionsSubscription = this._popoverClosingActions().subscribe(() =>\n      this.closePopover()\n    );\n    this._initPopover();\n\n    if (this.popover instanceof MtxPopover) {\n      this.popover._startAnimation();\n    }\n  }\n\n  /** Closes the popover. */\n  closePopover(): void {\n    this.popover.closed.emit();\n  }\n\n  /**\n   * Focuses the popover trigger.\n   * @param origin Source of the popover trigger's focus.\n   */\n  focus(origin?: FocusOrigin, options?: FocusOptions) {\n    if (this._focusMonitor && origin) {\n      this._focusMonitor.focusVia(this._elementRef, origin, options);\n    } else {\n      this._elementRef.nativeElement.focus(options);\n    }\n  }\n\n  /** Removes the popover from the DOM. */\n  private _destroyPopover(reason: PopoverCloseReason) {\n    if (!this._overlayRef || !this.popoverOpen) {\n      return;\n    }\n\n    // Clear the timeout for hover event.\n    if (this._mouseoverTimer) {\n      clearTimeout(this._mouseoverTimer);\n      this._mouseoverTimer = null;\n    }\n\n    const popover = this.popover;\n    this._closingActionsSubscription.unsubscribe();\n    this._overlayRef.detach();\n\n    this._openedBy = undefined;\n\n    if (popover instanceof MtxPopover) {\n      popover._resetAnimation();\n\n      if (popover.lazyContent) {\n        // Wait for the exit animation to finish before detaching the content.\n        popover._animationDone\n          .pipe(\n            filter(event => event.toState === 'void'),\n            take(1),\n            // Interrupt if the content got re-attached.\n            takeUntil(popover.lazyContent._attached)\n          )\n          .subscribe({\n            next: () => popover.lazyContent!.detach(),\n            // No matter whether the content got re-attached, reset the popover.\n            complete: () => this._setIsPopoverOpen(false),\n          });\n      } else {\n        this._setIsPopoverOpen(false);\n      }\n    } else {\n      this._setIsPopoverOpen(false);\n\n      if (popover.lazyContent) {\n        popover.lazyContent.detach();\n      }\n    }\n  }\n\n  /**\n   * This method sets the popover state to open.\n   */\n  private _initPopover(): void {\n    this.popover.direction = this.dir;\n    this.popover.setElevation();\n    this._setIsPopoverOpen(true);\n  }\n\n  // set state rather than toggle to support triggers sharing a popover\n  private _setIsPopoverOpen(isOpen: boolean): void {\n    this._popoverOpen = isOpen;\n    this._popoverOpen ? this.popoverOpened.emit() : this.popoverClosed.emit();\n  }\n\n  /**\n   * This method checks that a valid instance of MdPopover has been passed into\n   * `mtxPopoverTriggerFor`. If not, an exception is thrown.\n   */\n  private _checkPopover() {\n    if (!this.popover) {\n      throwMtxPopoverMissingError();\n    }\n  }\n\n  /**\n   * This method creates the overlay from the provided popover's template and saves its\n   * OverlayRef so that it can be attached to the DOM when openPopover is called.\n   */\n  private _createOverlay(): OverlayRef {\n    if (!this._overlayRef) {\n      const config = this._getOverlayConfig();\n      this._subscribeToPositions(config.positionStrategy as FlexibleConnectedPositionStrategy);\n      this._overlayRef = this._overlay.create(config);\n    } else {\n      const overlayConfig = this._overlayRef.getConfig();\n      const positionStrategy = overlayConfig.positionStrategy as FlexibleConnectedPositionStrategy;\n      positionStrategy.setOrigin(this._getTargetElement());\n    }\n\n    return this._overlayRef;\n  }\n\n  /**\n   * This method builds the configuration object needed to create the overlay, the OverlayConfig.\n   * @returns OverlayConfig\n   */\n  private _getOverlayConfig(): OverlayConfig {\n    return new OverlayConfig({\n      positionStrategy: this._overlay\n        .position()\n        .flexibleConnectedTo(this._getTargetElement())\n        .withLockedPosition()\n        .withGrowAfterOpen()\n        .withTransformOriginOn('.mtx-popover-panel'),\n      backdropClass: this.popover.backdropClass || 'cdk-overlay-transparent-backdrop',\n      panelClass: this.popover.overlayPanelClass,\n      scrollStrategy: this._scrollStrategy(),\n      direction: this._dir,\n    });\n  }\n\n  private _getTargetElement(): ElementRef<HTMLElement> {\n    if (this.targetElement) {\n      return this.targetElement.elementRef;\n    }\n\n    return this._elementRef;\n  }\n\n  /**\n   * Listens to changes in the position of the overlay and sets the correct classes\n   * on the popover based on the new position. This ensures the animation origin is always\n   * correct, even if a fallback position is used for the overlay.\n   */\n  private _subscribeToPositions(position: FlexibleConnectedPositionStrategy): void {\n    this._positionSubscription = position.positionChanges.subscribe(change => {\n      const posX =\n        change.connectionPair.overlayX === 'start'\n          ? 'after'\n          : change.connectionPair.overlayX === 'end'\n          ? 'before'\n          : 'center';\n      const posY =\n        change.connectionPair.overlayY === 'top'\n          ? 'below'\n          : change.connectionPair.overlayY === 'bottom'\n          ? 'above'\n          : 'center';\n\n      const pos: MtxPopoverPosition =\n        this.popover.position[0] === 'above' || this.popover.position[0] === 'below'\n          ? [posY as MtxPopoverPositionStart, posX]\n          : [posX as MtxPopoverPositionStart, posY];\n\n      // required for ChangeDetectionStrategy.OnPush\n      this._changeDetectorRef.markForCheck();\n\n      this.popover.setCurrentStyles(pos);\n      this.popover.setPositionClasses(pos);\n    });\n  }\n\n  /**\n   * Sets the appropriate positions on a position strategy\n   * so the overlay connects with the trigger correctly.\n   * @param positionStrategy Strategy whose position to update.\n   */\n  private _setPosition(positionStrategy: FlexibleConnectedPositionStrategy) {\n    const [originX, origin2ndX, origin3rdX]: HorizontalConnectionPos[] =\n      this.popover.position[0] === 'before' || this.popover.position[1] === 'after'\n        ? ['start', 'center', 'end']\n        : this.popover.position[0] === 'after' || this.popover.position[1] === 'before'\n        ? ['end', 'center', 'start']\n        : ['center', 'start', 'end'];\n\n    const [originY, origin2ndY, origin3rdY]: VerticalConnectionPos[] =\n      this.popover.position[0] === 'above' || this.popover.position[1] === 'below'\n        ? ['top', 'center', 'bottom']\n        : this.popover.position[0] === 'below' || this.popover.position[1] === 'above'\n        ? ['bottom', 'center', 'top']\n        : ['center', 'top', 'bottom'];\n\n    const [overlayX, overlayFallbackX]: HorizontalConnectionPos[] =\n      this.popover.position[0] === 'below' || this.popover.position[0] === 'above'\n        ? [originX, originX]\n        : this.popover.position[0] === 'before'\n        ? ['end', 'start']\n        : ['start', 'end'];\n\n    const [overlayY, overlayFallbackY]: VerticalConnectionPos[] =\n      this.popover.position[0] === 'before' || this.popover.position[0] === 'after'\n        ? [originY, originY]\n        : this.popover.position[0] === 'below'\n        ? ['top', 'bottom']\n        : ['bottom', 'top'];\n\n    const originFallbackX = overlayX;\n    const originFallbackY = overlayY;\n\n    const offsetX =\n      this.popover.xOffset && !isNaN(Number(this.popover.xOffset))\n        ? Number(this.dir === 'ltr' ? this.popover.xOffset : -this.popover.xOffset)\n        : 0;\n    const offsetY =\n      this.popover.yOffset && !isNaN(Number(this.popover.yOffset))\n        ? Number(this.popover.yOffset)\n        : 0;\n\n    let positions: ConnectedPosition[] = [{ originX, originY, overlayX, overlayY }];\n\n    if (this.popover.position[0] === 'above' || this.popover.position[0] === 'below') {\n      positions = [\n        { originX, originY, overlayX, overlayY, offsetY },\n        { originX: origin2ndX, originY, overlayX: origin2ndX, overlayY, offsetY },\n        { originX: origin3rdX, originY, overlayX: origin3rdX, overlayY, offsetY },\n        {\n          originX,\n          originY: originFallbackY,\n          overlayX,\n          overlayY: overlayFallbackY,\n          offsetY: -offsetY,\n        },\n        {\n          originX: origin2ndX,\n          originY: originFallbackY,\n          overlayX: origin2ndX,\n          overlayY: overlayFallbackY,\n          offsetY: -offsetY,\n        },\n        {\n          originX: origin3rdX,\n          originY: originFallbackY,\n          overlayX: origin3rdX,\n          overlayY: overlayFallbackY,\n          offsetY: -offsetY,\n        },\n      ];\n    }\n\n    if (this.popover.position[0] === 'before' || this.popover.position[0] === 'after') {\n      positions = [\n        { originX, originY, overlayX, overlayY, offsetX },\n        { originX, originY: origin2ndY, overlayX, overlayY: origin2ndY, offsetX },\n        { originX, originY: origin3rdY, overlayX, overlayY: origin3rdY, offsetX },\n        {\n          originX: originFallbackX,\n          originY,\n          overlayX: overlayFallbackX,\n          overlayY,\n          offsetX: -offsetX,\n        },\n        {\n          originX: originFallbackX,\n          originY: origin2ndY,\n          overlayX: overlayFallbackX,\n          overlayY: origin2ndY,\n          offsetX: -offsetX,\n        },\n        {\n          originX: originFallbackX,\n          originY: origin3rdY,\n          overlayX: overlayFallbackX,\n          overlayY: origin3rdY,\n          offsetX: -offsetX,\n        },\n      ];\n    }\n\n    positionStrategy\n      .withPositions(positions)\n      .withDefaultOffsetX(offsetX)\n      .withDefaultOffsetY(offsetY);\n  }\n\n  /** Returns a stream that emits whenever an action that should close the popover occurs. */\n  private _popoverClosingActions() {\n    const backdrop =\n      this.popover.triggerEvent === 'click' && this.popover.closeOnBackdropClick === true\n        ? this._overlayRef!.backdropClick()\n        : observableOf();\n    const detachments = this._overlayRef!.detachments();\n    return merge(backdrop, detachments);\n  }\n\n  /** Gets the portal that should be attached to the overlay. */\n  private _getPortal(): TemplatePortal {\n    // Note that we can avoid this check by keeping the portal on the popover panel.\n    // While it would be cleaner, we'd have to introduce another required method on\n    // `MtxPopoverPanel`, making it harder to consume.\n    if (!this._portal || this._portal.templateRef !== this.popover.templateRef) {\n      this._portal = new TemplatePortal(this.popover.templateRef, this._viewContainerRef);\n    }\n\n    return this._portal;\n  }\n}\n"]}
|