@ng-matero/extensions 12.9.2 → 12.10.0
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/bundles/mtxCore.umd.js.map +1 -1
- package/bundles/mtxDatetimepicker.umd.js +5 -0
- package/bundles/mtxDatetimepicker.umd.js.map +1 -1
- package/bundles/mtxGrid.umd.js +24 -21
- package/bundles/mtxGrid.umd.js.map +1 -1
- package/bundles/mtxPopover.umd.js +997 -803
- package/bundles/mtxPopover.umd.js.map +1 -1
- package/bundles/mtxSelect.umd.js +237 -156
- package/bundles/mtxSelect.umd.js.map +1 -1
- package/core/datetime/datetime-formats.d.ts +2 -0
- package/esm2015/core/datetime/datetime-formats.js +1 -1
- package/esm2015/datetimepicker/datetimepicker-input.js +6 -1
- package/esm2015/grid/cell.component.js +7 -4
- package/esm2015/grid/column-menu.component.js +10 -14
- package/esm2015/grid/grid.component.js +10 -6
- package/esm2015/popover/popover-animations.js +10 -13
- package/esm2015/popover/popover-content.js +99 -0
- package/esm2015/popover/popover-interfaces.js +1 -1
- package/esm2015/popover/popover-module.js +7 -5
- package/esm2015/popover/popover-target.js +3 -3
- package/esm2015/popover/popover-trigger.js +210 -172
- package/esm2015/popover/popover-types.js +1 -1
- package/esm2015/popover/popover.js +173 -125
- package/esm2015/popover/public-api.js +2 -1
- package/esm2015/select/option.component.js +4 -6
- package/esm2015/select/select.component.js +111 -31
- package/fesm2015/mtxCore.js.map +1 -1
- package/fesm2015/mtxDatetimepicker.js +5 -0
- package/fesm2015/mtxDatetimepicker.js.map +1 -1
- package/fesm2015/mtxGrid.js +24 -21
- package/fesm2015/mtxGrid.js.map +1 -1
- package/fesm2015/mtxPopover.js +526 -351
- package/fesm2015/mtxPopover.js.map +1 -1
- package/fesm2015/mtxSelect.js +169 -92
- package/fesm2015/mtxSelect.js.map +1 -1
- package/grid/cell.component.d.ts +4 -2
- package/grid/column-menu.component.d.ts +3 -5
- package/grid/grid.component.d.ts +6 -4
- package/grid/mtxGrid.metadata.json +1 -1
- package/package.json +1 -1
- package/popover/mtxPopover.metadata.json +1 -1
- package/popover/popover-animations.d.ts +1 -1
- package/popover/popover-content.d.ts +38 -0
- package/popover/popover-interfaces.d.ts +37 -31
- package/popover/popover-target.d.ts +2 -2
- package/popover/popover-trigger.d.ts +65 -60
- package/popover/popover-types.d.ts +6 -1
- package/popover/popover.d.ts +97 -69
- package/popover/popover.scss +2 -0
- package/popover/public-api.d.ts +1 -0
- package/select/mtxSelect.metadata.json +1 -1
- package/select/option.component.d.ts +7 -6
- package/select/select.component.d.ts +59 -20
|
@@ -1,44 +1,81 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { isFakeMousedownFromScreenReader } from '@angular/cdk/a11y';
|
|
1
|
+
import { FocusMonitor, isFakeMousedownFromScreenReader } from '@angular/cdk/a11y';
|
|
3
2
|
import { Directionality } from '@angular/cdk/bidi';
|
|
3
|
+
import { ENTER, SPACE } from '@angular/cdk/keycodes';
|
|
4
4
|
import { Overlay, OverlayConfig, } from '@angular/cdk/overlay';
|
|
5
5
|
import { TemplatePortal } from '@angular/cdk/portal';
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
6
|
+
import { ChangeDetectorRef, Directive, ElementRef, EventEmitter, Inject, InjectionToken, Input, Optional, Output, ViewContainerRef, } from '@angular/core';
|
|
7
|
+
import { merge, of as observableOf, Subscription } from 'rxjs';
|
|
8
|
+
import { filter, take, takeUntil } from 'rxjs/operators';
|
|
9
|
+
import { MtxPopover } from './popover';
|
|
8
10
|
import { throwMtxPopoverMissingError } from './popover-errors';
|
|
11
|
+
import { MtxPopoverTarget } from './popover-target';
|
|
12
|
+
/** Injection token that determines the scroll handling while the popover is open. */
|
|
13
|
+
export const MTX_POPOVER_SCROLL_STRATEGY = new InjectionToken('mtx-popover-scroll-strategy');
|
|
14
|
+
/** @docs-private */
|
|
15
|
+
export function MTX_POPOVER_SCROLL_STRATEGY_FACTORY(overlay) {
|
|
16
|
+
return () => overlay.scrollStrategies.reposition();
|
|
17
|
+
}
|
|
18
|
+
/** @docs-private */
|
|
19
|
+
export const MTX_POPOVER_SCROLL_STRATEGY_FACTORY_PROVIDER = {
|
|
20
|
+
provide: MTX_POPOVER_SCROLL_STRATEGY,
|
|
21
|
+
deps: [Overlay],
|
|
22
|
+
useFactory: MTX_POPOVER_SCROLL_STRATEGY_FACTORY,
|
|
23
|
+
};
|
|
9
24
|
/**
|
|
10
|
-
* This directive is intended to be used in conjunction with an mtx-popover tag. It is
|
|
25
|
+
* This directive is intended to be used in conjunction with an `mtx-popover` tag. It is
|
|
11
26
|
* responsible for toggling the display of the provided popover instance.
|
|
12
27
|
*/
|
|
13
28
|
export class MtxPopoverTrigger {
|
|
14
|
-
constructor(_overlay, _elementRef, _viewContainerRef, _dir, _changeDetectorRef) {
|
|
29
|
+
constructor(_overlay, _elementRef, _viewContainerRef, scrollStrategy, _dir, _changeDetectorRef, _focusMonitor) {
|
|
15
30
|
this._overlay = _overlay;
|
|
16
31
|
this._elementRef = _elementRef;
|
|
17
32
|
this._viewContainerRef = _viewContainerRef;
|
|
18
33
|
this._dir = _dir;
|
|
19
34
|
this._changeDetectorRef = _changeDetectorRef;
|
|
20
|
-
this.
|
|
21
|
-
this.popoverOpened$ = new Subject();
|
|
22
|
-
this.popoverClosed$ = new Subject();
|
|
35
|
+
this._focusMonitor = _focusMonitor;
|
|
23
36
|
this._overlayRef = null;
|
|
24
37
|
this._popoverOpen = false;
|
|
25
38
|
this._halt = false;
|
|
26
|
-
|
|
39
|
+
this._positionSubscription = Subscription.EMPTY;
|
|
40
|
+
this._popoverCloseSubscription = Subscription.EMPTY;
|
|
41
|
+
this._closingActionsSubscription = Subscription.EMPTY;
|
|
42
|
+
// Tracking input type is necessary so it's possible to only auto-focus
|
|
27
43
|
// the first item of the list when the popover is opened via the keyboard
|
|
28
|
-
this.
|
|
29
|
-
this._onDestroy = new Subject();
|
|
44
|
+
this._openedBy = undefined;
|
|
30
45
|
/** Event emitted when the associated popover is opened. */
|
|
31
46
|
this.popoverOpened = new EventEmitter();
|
|
32
47
|
/** Event emitted when the associated popover is closed. */
|
|
33
48
|
this.popoverClosed = new EventEmitter();
|
|
49
|
+
this._scrollStrategy = scrollStrategy;
|
|
50
|
+
}
|
|
51
|
+
/** References the popover instance that the trigger is associated with. */
|
|
52
|
+
get popover() {
|
|
53
|
+
return this._popover;
|
|
34
54
|
}
|
|
35
|
-
|
|
55
|
+
set popover(popover) {
|
|
56
|
+
if (popover === this._popover) {
|
|
57
|
+
return;
|
|
58
|
+
}
|
|
59
|
+
this._popover = popover;
|
|
60
|
+
this._popoverCloseSubscription.unsubscribe();
|
|
61
|
+
if (popover) {
|
|
62
|
+
this._popoverCloseSubscription = popover.closed.subscribe((reason) => {
|
|
63
|
+
this._destroyPopover();
|
|
64
|
+
});
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
ngAfterContentInit() {
|
|
36
68
|
this._checkPopover();
|
|
37
69
|
this._setCurrentConfig();
|
|
38
|
-
this.popover.closed.subscribe(() => this.closePopover());
|
|
39
70
|
}
|
|
40
71
|
ngOnDestroy() {
|
|
41
|
-
this.
|
|
72
|
+
if (this._overlayRef) {
|
|
73
|
+
this._overlayRef.dispose();
|
|
74
|
+
this._overlayRef = null;
|
|
75
|
+
}
|
|
76
|
+
this._positionSubscription.unsubscribe();
|
|
77
|
+
this._popoverCloseSubscription.unsubscribe();
|
|
78
|
+
this._closingActionsSubscription.unsubscribe();
|
|
42
79
|
}
|
|
43
80
|
_setCurrentConfig() {
|
|
44
81
|
if (this.triggerEvent) {
|
|
@@ -50,12 +87,18 @@ export class MtxPopoverTrigger {
|
|
|
50
87
|
get popoverOpen() {
|
|
51
88
|
return this._popoverOpen;
|
|
52
89
|
}
|
|
53
|
-
|
|
90
|
+
/** The text direction of the containing app. */
|
|
91
|
+
get dir() {
|
|
92
|
+
return this._dir && this._dir.value === 'rtl' ? 'rtl' : 'ltr';
|
|
93
|
+
}
|
|
94
|
+
/** Handles mouse click on the trigger. */
|
|
95
|
+
_handleClick(event) {
|
|
54
96
|
if (this.popover.triggerEvent === 'click') {
|
|
55
97
|
this.togglePopover();
|
|
56
98
|
}
|
|
57
99
|
}
|
|
58
|
-
|
|
100
|
+
/** Handles mouse enter on the trigger. */
|
|
101
|
+
_handleMouseEnter(event) {
|
|
59
102
|
this._halt = false;
|
|
60
103
|
if (this.popover.triggerEvent === 'hover') {
|
|
61
104
|
this._mouseoverTimer = setTimeout(() => {
|
|
@@ -63,7 +106,8 @@ export class MtxPopoverTrigger {
|
|
|
63
106
|
}, this.popover.enterDelay);
|
|
64
107
|
}
|
|
65
108
|
}
|
|
66
|
-
|
|
109
|
+
/** Handles mouse leave on the trigger. */
|
|
110
|
+
_handleMouseLeave(event) {
|
|
67
111
|
if (this.popover.triggerEvent === 'hover') {
|
|
68
112
|
if (this._mouseoverTimer) {
|
|
69
113
|
clearTimeout(this._mouseoverTimer);
|
|
@@ -81,117 +125,120 @@ export class MtxPopoverTrigger {
|
|
|
81
125
|
}
|
|
82
126
|
}
|
|
83
127
|
}
|
|
128
|
+
/** Handles mouse presses on the trigger. */
|
|
129
|
+
_handleMousedown(event) {
|
|
130
|
+
if (!isFakeMousedownFromScreenReader(event)) {
|
|
131
|
+
// Since right or middle button clicks won't trigger the `click` event,
|
|
132
|
+
// we shouldn't consider the popover as opened by mouse in those cases.
|
|
133
|
+
this._openedBy = event.button === 0 ? 'mouse' : undefined;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
/** Handles key presses on the trigger. */
|
|
137
|
+
_handleKeydown(event) {
|
|
138
|
+
const keyCode = event.keyCode;
|
|
139
|
+
// Pressing enter on the trigger will trigger the click handler later.
|
|
140
|
+
if (keyCode === ENTER || keyCode === SPACE) {
|
|
141
|
+
this._openedBy = 'keyboard';
|
|
142
|
+
}
|
|
143
|
+
}
|
|
84
144
|
/** Toggles the popover between the open and closed states. */
|
|
85
145
|
togglePopover() {
|
|
86
146
|
return this._popoverOpen ? this.closePopover() : this.openPopover();
|
|
87
147
|
}
|
|
88
148
|
/** Opens the popover. */
|
|
89
149
|
openPopover() {
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
150
|
+
var _a;
|
|
151
|
+
if (this._popoverOpen || this._halt) {
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
this._checkPopover();
|
|
155
|
+
const overlayRef = this._createOverlay();
|
|
156
|
+
const overlayConfig = overlayRef.getConfig();
|
|
157
|
+
this._setPosition(overlayConfig.positionStrategy);
|
|
158
|
+
if (this.popover.triggerEvent === 'click') {
|
|
159
|
+
overlayConfig.hasBackdrop = (_a = this.popover.hasBackdrop) !== null && _a !== void 0 ? _a : true;
|
|
160
|
+
}
|
|
161
|
+
overlayRef.attach(this._getPortal());
|
|
162
|
+
if (this.popover.lazyContent) {
|
|
163
|
+
this.popover.lazyContent.attach(this.popoverData);
|
|
164
|
+
}
|
|
165
|
+
this._closingActionsSubscription = this._popoverClosingActions().subscribe(() => this.closePopover());
|
|
166
|
+
this._initPopover();
|
|
167
|
+
if (this.popover instanceof MtxPopover) {
|
|
168
|
+
this.popover._startAnimation();
|
|
95
169
|
}
|
|
96
170
|
}
|
|
97
171
|
/** Closes the popover. */
|
|
98
172
|
closePopover() {
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
173
|
+
this.popover.closed.emit();
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Focuses the popover trigger.
|
|
177
|
+
* @param origin Source of the popover trigger's focus.
|
|
178
|
+
*/
|
|
179
|
+
focus(origin, options) {
|
|
180
|
+
if (this._focusMonitor && origin) {
|
|
181
|
+
this._focusMonitor.focusVia(this._elementRef, origin, options);
|
|
182
|
+
}
|
|
183
|
+
else {
|
|
184
|
+
this._elementRef.nativeElement.focus(options);
|
|
102
185
|
}
|
|
103
|
-
this.destroyPopover();
|
|
104
186
|
}
|
|
105
187
|
/** Removes the popover from the DOM. */
|
|
106
|
-
|
|
188
|
+
_destroyPopover(reason) {
|
|
189
|
+
if (!this._overlayRef || !this.popoverOpen) {
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
// Clear the timeout for hover event.
|
|
107
193
|
if (this._mouseoverTimer) {
|
|
108
194
|
clearTimeout(this._mouseoverTimer);
|
|
109
195
|
this._mouseoverTimer = null;
|
|
110
196
|
}
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
/**
|
|
128
|
-
* This method ensures that the popover closes when the overlay backdrop is clicked.
|
|
129
|
-
* We do not use first() here because doing so would not catch clicks from within
|
|
130
|
-
* the popover, and it would fail to unsubscribe properly. Instead, we unsubscribe
|
|
131
|
-
* explicitly when the popover is closed or destroyed.
|
|
132
|
-
*/
|
|
133
|
-
_subscribeToBackdrop() {
|
|
134
|
-
if (this._overlayRef) {
|
|
135
|
-
/** Only subscribe to backdrop if trigger event is click */
|
|
136
|
-
if (this.triggerEvent === 'click' && this.popover.closeOnBackdropClick === true) {
|
|
137
|
-
this._overlayRef
|
|
138
|
-
.backdropClick()
|
|
139
|
-
.pipe(takeUntil(this.popoverClosed$), takeUntil(this._onDestroy))
|
|
140
|
-
.subscribe(() => {
|
|
141
|
-
this.popover._emitCloseEvent();
|
|
197
|
+
const popover = this.popover;
|
|
198
|
+
this._closingActionsSubscription.unsubscribe();
|
|
199
|
+
this._overlayRef.detach();
|
|
200
|
+
this._openedBy = undefined;
|
|
201
|
+
if (popover instanceof MtxPopover) {
|
|
202
|
+
popover._resetAnimation();
|
|
203
|
+
if (popover.lazyContent) {
|
|
204
|
+
// Wait for the exit animation to finish before detaching the content.
|
|
205
|
+
popover._animationDone
|
|
206
|
+
.pipe(filter(event => event.toState === 'void'), take(1),
|
|
207
|
+
// Interrupt if the content got re-attached.
|
|
208
|
+
takeUntil(popover.lazyContent._attached))
|
|
209
|
+
.subscribe({
|
|
210
|
+
next: () => popover.lazyContent.detach(),
|
|
211
|
+
// No matter whether the content got re-attached, reset the popover.
|
|
212
|
+
complete: () => this._setIsPopoverOpen(false),
|
|
142
213
|
});
|
|
143
214
|
}
|
|
215
|
+
else {
|
|
216
|
+
this._setIsPopoverOpen(false);
|
|
217
|
+
}
|
|
144
218
|
}
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
.pipe(takeUntil(this.popoverClosed$), takeUntil(this._onDestroy))
|
|
151
|
-
.subscribe(() => {
|
|
152
|
-
this._setPopoverClosed();
|
|
153
|
-
});
|
|
219
|
+
else {
|
|
220
|
+
this._setIsPopoverOpen(false);
|
|
221
|
+
if (popover.lazyContent) {
|
|
222
|
+
popover.lazyContent.detach();
|
|
223
|
+
}
|
|
154
224
|
}
|
|
155
225
|
}
|
|
156
226
|
/**
|
|
157
|
-
* This method sets the popover state to open
|
|
158
|
-
* the popover was opened via the keyboard.
|
|
227
|
+
* This method sets the popover state to open.
|
|
159
228
|
*/
|
|
160
229
|
_initPopover() {
|
|
161
|
-
this.
|
|
230
|
+
this.popover.direction = this.dir;
|
|
231
|
+
this.popover.setElevation();
|
|
232
|
+
this._setIsPopoverOpen(true);
|
|
162
233
|
}
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
_resetPopover() {
|
|
168
|
-
this._setPopoverClosed();
|
|
169
|
-
// Focus only needs to be reset to the host element if the popover was opened
|
|
170
|
-
// by the keyboard and manually shifted to the first popover item.
|
|
171
|
-
if (!this._openedByMouse) {
|
|
172
|
-
this.focus();
|
|
173
|
-
}
|
|
174
|
-
this._openedByMouse = false;
|
|
175
|
-
}
|
|
176
|
-
/** set state rather than toggle to support triggers sharing a popover */
|
|
177
|
-
_setPopoverOpened() {
|
|
178
|
-
if (!this._popoverOpen) {
|
|
179
|
-
this._popoverOpen = true;
|
|
180
|
-
this.popoverOpened$.next();
|
|
181
|
-
this.popoverOpened.emit();
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
/** set state rather than toggle to support triggers sharing a popover */
|
|
185
|
-
_setPopoverClosed() {
|
|
186
|
-
if (this._popoverOpen) {
|
|
187
|
-
this._popoverOpen = false;
|
|
188
|
-
this.popoverClosed$.next();
|
|
189
|
-
this.popoverClosed.emit();
|
|
190
|
-
}
|
|
234
|
+
// set state rather than toggle to support triggers sharing a popover
|
|
235
|
+
_setIsPopoverOpen(isOpen) {
|
|
236
|
+
this._popoverOpen = isOpen;
|
|
237
|
+
this._popoverOpen ? this.popoverOpened.emit() : this.popoverClosed.emit();
|
|
191
238
|
}
|
|
192
239
|
/**
|
|
193
|
-
*
|
|
194
|
-
*
|
|
240
|
+
* This method checks that a valid instance of MdPopover has been passed into
|
|
241
|
+
* `mtxPopoverTriggerFor`. If not, an exception is thrown.
|
|
195
242
|
*/
|
|
196
243
|
_checkPopover() {
|
|
197
244
|
if (!this.popover) {
|
|
@@ -199,16 +246,20 @@ export class MtxPopoverTrigger {
|
|
|
199
246
|
}
|
|
200
247
|
}
|
|
201
248
|
/**
|
|
202
|
-
*
|
|
203
|
-
*
|
|
249
|
+
* This method creates the overlay from the provided popover's template and saves its
|
|
250
|
+
* OverlayRef so that it can be attached to the DOM when openPopover is called.
|
|
204
251
|
*/
|
|
205
252
|
_createOverlay() {
|
|
206
253
|
if (!this._overlayRef) {
|
|
207
|
-
this._portal = new TemplatePortal(this.popover.templateRef, this._viewContainerRef);
|
|
208
254
|
const config = this._getOverlayConfig();
|
|
209
255
|
this._subscribeToPositions(config.positionStrategy);
|
|
210
256
|
this._overlayRef = this._overlay.create(config);
|
|
211
257
|
}
|
|
258
|
+
else {
|
|
259
|
+
const overlayConfig = this._overlayRef.getConfig();
|
|
260
|
+
const positionStrategy = overlayConfig.positionStrategy;
|
|
261
|
+
positionStrategy.setOrigin(this._getTargetElement());
|
|
262
|
+
}
|
|
212
263
|
return this._overlayRef;
|
|
213
264
|
}
|
|
214
265
|
/**
|
|
@@ -216,32 +267,24 @@ export class MtxPopoverTrigger {
|
|
|
216
267
|
* @returns OverlayConfig
|
|
217
268
|
*/
|
|
218
269
|
_getOverlayConfig() {
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
270
|
+
return new OverlayConfig({
|
|
271
|
+
positionStrategy: this._overlay
|
|
272
|
+
.position()
|
|
273
|
+
.flexibleConnectedTo(this._getTargetElement())
|
|
274
|
+
.withLockedPosition()
|
|
275
|
+
.withGrowAfterOpen()
|
|
276
|
+
.withTransformOriginOn('.mtx-popover-panel'),
|
|
277
|
+
backdropClass: this.popover.backdropClass || 'cdk-overlay-transparent-backdrop',
|
|
278
|
+
panelClass: this.popover.overlayPanelClass,
|
|
279
|
+
scrollStrategy: this._scrollStrategy(),
|
|
280
|
+
direction: this._dir,
|
|
281
|
+
});
|
|
229
282
|
}
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
_getOverlayScrollStrategy(strategy) {
|
|
234
|
-
switch (strategy) {
|
|
235
|
-
case 'noop':
|
|
236
|
-
return this._overlay.scrollStrategies.noop();
|
|
237
|
-
case 'close':
|
|
238
|
-
return this._overlay.scrollStrategies.close();
|
|
239
|
-
case 'block':
|
|
240
|
-
return this._overlay.scrollStrategies.block();
|
|
241
|
-
case 'reposition':
|
|
242
|
-
default:
|
|
243
|
-
return this._overlay.scrollStrategies.reposition();
|
|
283
|
+
_getTargetElement() {
|
|
284
|
+
if (this.targetElement) {
|
|
285
|
+
return this.targetElement.elementRef;
|
|
244
286
|
}
|
|
287
|
+
return this._elementRef;
|
|
245
288
|
}
|
|
246
289
|
/**
|
|
247
290
|
* Listens to changes in the position of the overlay and sets the correct classes
|
|
@@ -265,18 +308,16 @@ export class MtxPopoverTrigger {
|
|
|
265
308
|
: [posX, posY];
|
|
266
309
|
// required for ChangeDetectionStrategy.OnPush
|
|
267
310
|
this._changeDetectorRef.markForCheck();
|
|
268
|
-
this.popover.
|
|
269
|
-
|
|
270
|
-
this.popover.setPositionClasses(pos);
|
|
271
|
-
});
|
|
311
|
+
this.popover.setCurrentStyles(pos);
|
|
312
|
+
this.popover.setPositionClasses(pos);
|
|
272
313
|
});
|
|
273
314
|
}
|
|
274
315
|
/**
|
|
275
|
-
*
|
|
276
|
-
*
|
|
277
|
-
* @
|
|
316
|
+
* Sets the appropriate positions on a position strategy
|
|
317
|
+
* so the overlay connects with the trigger correctly.
|
|
318
|
+
* @param positionStrategy Strategy whose position to update.
|
|
278
319
|
*/
|
|
279
|
-
|
|
320
|
+
_setPosition(positionStrategy) {
|
|
280
321
|
const [originX, origin2ndX, origin3rdX] = this.popover.position[0] === 'before' || this.popover.position[1] === 'after'
|
|
281
322
|
? ['start', 'center', 'end']
|
|
282
323
|
: this.popover.position[0] === 'after' || this.popover.position[1] === 'before'
|
|
@@ -305,16 +346,6 @@ export class MtxPopoverTrigger {
|
|
|
305
346
|
const offsetY = this.popover.yOffset && !isNaN(Number(this.popover.yOffset))
|
|
306
347
|
? Number(this.popover.yOffset)
|
|
307
348
|
: 0;
|
|
308
|
-
/**
|
|
309
|
-
* For overriding position element, when `mtxPopoverTargetAt` has a valid element reference.
|
|
310
|
-
* Useful for sticking popover to parent element and offsetting arrow to trigger element.
|
|
311
|
-
* If undefined defaults to the trigger element reference.
|
|
312
|
-
*/
|
|
313
|
-
let element = this._elementRef;
|
|
314
|
-
if (typeof this.targetElement !== 'undefined') {
|
|
315
|
-
this.popover.containerPositioning = true;
|
|
316
|
-
element = this.targetElement._elementRef;
|
|
317
|
-
}
|
|
318
349
|
let positions = [{ originX, originY, overlayX, overlayY }];
|
|
319
350
|
if (this.popover.position[0] === 'above' || this.popover.position[0] === 'below') {
|
|
320
351
|
positions = [
|
|
@@ -372,36 +403,45 @@ export class MtxPopoverTrigger {
|
|
|
372
403
|
},
|
|
373
404
|
];
|
|
374
405
|
}
|
|
375
|
-
|
|
376
|
-
.position()
|
|
377
|
-
.flexibleConnectedTo(element)
|
|
378
|
-
.withLockedPosition()
|
|
406
|
+
positionStrategy
|
|
379
407
|
.withPositions(positions)
|
|
380
408
|
.withDefaultOffsetX(offsetX)
|
|
381
409
|
.withDefaultOffsetY(offsetY);
|
|
382
410
|
}
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
386
|
-
|
|
387
|
-
|
|
388
|
-
|
|
389
|
-
|
|
390
|
-
if (this._detachmentsSubscription) {
|
|
391
|
-
this._detachmentsSubscription.unsubscribe();
|
|
392
|
-
}
|
|
411
|
+
/** Returns a stream that emits whenever an action that should close the popover occurs. */
|
|
412
|
+
_popoverClosingActions() {
|
|
413
|
+
const backdrop = this.popover.triggerEvent === 'click' && this.popover.closeOnBackdropClick === true
|
|
414
|
+
? this._overlayRef.backdropClick()
|
|
415
|
+
: observableOf();
|
|
416
|
+
const detachments = this._overlayRef.detachments();
|
|
417
|
+
return merge(backdrop, detachments);
|
|
393
418
|
}
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
419
|
+
/** Gets the portal that should be attached to the overlay. */
|
|
420
|
+
_getPortal() {
|
|
421
|
+
// Note that we can avoid this check by keeping the portal on the popover panel.
|
|
422
|
+
// While it would be cleaner, we'd have to introduce another required method on
|
|
423
|
+
// `MtxPopoverPanel`, making it harder to consume.
|
|
424
|
+
if (!this._portal || this._portal.templateRef !== this.popover.templateRef) {
|
|
425
|
+
this._portal = new TemplatePortal(this.popover.templateRef, this._viewContainerRef);
|
|
397
426
|
}
|
|
427
|
+
return this._portal;
|
|
398
428
|
}
|
|
399
429
|
}
|
|
400
430
|
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
|
|
401
431
|
MtxPopoverTrigger.decorators = [
|
|
402
432
|
{ type: Directive, args: [{
|
|
403
|
-
selector: '[mtxPopoverTriggerFor]',
|
|
433
|
+
selector: '[mtx-popover-trigger-for], [mtxPopoverTriggerFor]',
|
|
404
434
|
exportAs: 'mtxPopoverTrigger',
|
|
435
|
+
host: {
|
|
436
|
+
'aria-haspopup': 'true',
|
|
437
|
+
'[attr.aria-expanded]': 'popoverOpen || null',
|
|
438
|
+
'[attr.aria-controls]': 'popoverOpen ? popover.panelId : null',
|
|
439
|
+
'(click)': '_handleClick($event)',
|
|
440
|
+
'(mouseenter)': '_handleMouseEnter($event)',
|
|
441
|
+
'(mouseleave)': '_handleMouseLeave($event)',
|
|
442
|
+
'(mousedown)': '_handleMousedown($event)',
|
|
443
|
+
'(keydown)': '_handleKeydown($event)',
|
|
444
|
+
},
|
|
405
445
|
},] }
|
|
406
446
|
];
|
|
407
447
|
/**
|
|
@@ -415,20 +455,18 @@ MtxPopoverTrigger.ctorParameters = () => [
|
|
|
415
455
|
{ type: Overlay },
|
|
416
456
|
{ type: ElementRef },
|
|
417
457
|
{ type: ViewContainerRef },
|
|
458
|
+
{ type: undefined, decorators: [{ type: Inject, args: [MTX_POPOVER_SCROLL_STRATEGY,] }] },
|
|
418
459
|
{ type: Directionality, decorators: [{ type: Optional }] },
|
|
419
|
-
{ type: ChangeDetectorRef }
|
|
460
|
+
{ type: ChangeDetectorRef },
|
|
461
|
+
{ type: FocusMonitor }
|
|
420
462
|
];
|
|
421
463
|
/** @type {!Object<string, !Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
|
|
422
464
|
MtxPopoverTrigger.propDecorators = {
|
|
423
|
-
ariaHaspopup: [{ type: HostBinding, args: ['attr.aria-haspopup',] }],
|
|
424
465
|
popover: [{ type: Input, args: ['mtxPopoverTriggerFor',] }],
|
|
466
|
+
popoverData: [{ type: Input, args: ['mtxPopoverTriggerData',] }],
|
|
425
467
|
targetElement: [{ type: Input, args: ['mtxPopoverTargetAt',] }],
|
|
426
468
|
triggerEvent: [{ type: Input, args: ['mtxPopoverTriggerOn',] }],
|
|
427
469
|
popoverOpened: [{ type: Output }],
|
|
428
|
-
popoverClosed: [{ type: Output }]
|
|
429
|
-
onClick: [{ type: HostListener, args: ['click', ['$event'],] }],
|
|
430
|
-
onMouseEnter: [{ type: HostListener, args: ['mouseenter', ['$event'],] }],
|
|
431
|
-
onMouseLeave: [{ type: HostListener, args: ['mouseleave', ['$event'],] }],
|
|
432
|
-
_handleMousedown: [{ type: HostListener, args: ['mousedown', ['$event'],] }]
|
|
470
|
+
popoverClosed: [{ type: Output }]
|
|
433
471
|
};
|
|
434
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-trigger.js","sourceRoot":"","sources":["../../../../projects/extensions/popover/popover-trigger.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EAEL,QAAQ,EACR,MAAM,EACN,gBAAgB,EAChB,YAAY,EACZ,WAAW,EACX,iBAAiB,GAClB,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,+BAA+B,EAAE,MAAM,mBAAmB,CAAC;AACpE,OAAO,EAAa,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,EACL,OAAO,EAEP,aAAa,GAMd,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAErD,OAAO,EAAgB,OAAO,EAAE,MAAM,MAAM,CAAC;AAC7C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAS3C,OAAO,EAAE,2BAA2B,EAAE,MAAM,kBAAkB,CAAC;AAE/D;;;GAGG;AAMH,MAAM,OAAO,iBAAiB;IAqC5B,YACU,QAAiB,EAClB,WAAuB,EACtB,iBAAmC,EACvB,IAAoB,EAChC,kBAAqC;QAJrC,aAAQ,GAAR,QAAQ,CAAS;QAClB,gBAAW,GAAX,WAAW,CAAY;QACtB,sBAAiB,GAAjB,iBAAiB,CAAkB;QACvB,SAAI,GAAJ,IAAI,CAAgB;QAChC,uBAAkB,GAAlB,kBAAkB,CAAmB;QAzCZ,iBAAY,GAAG,IAAI,CAAC;QAEvD,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QACrC,mBAAc,GAAG,IAAI,OAAO,EAAQ,CAAC;QAG7B,gBAAW,GAAsB,IAAI,CAAC;QACtC,iBAAY,GAAG,KAAK,CAAC;QACrB,UAAK,GAAG,KAAK,CAAC;QAOtB,uEAAuE;QACvE,yEAAyE;QACjE,mBAAc,GAAG,KAAK,CAAC;QAEvB,eAAU,GAAG,IAAI,OAAO,EAAQ,CAAC;QAWzC,2DAA2D;QACjD,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEnD,2DAA2D;QACjD,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;IAQhD,CAAC;IAEJ,eAAe;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;IAC3D,CAAC;IAED,WAAW;QACT,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,iBAAiB;QACvB,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,CAAC;SAC/C;QAED,IAAI,CAAC,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAClC,CAAC;IAED,mCAAmC;IACnC,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IAGD,OAAO,CAAC,KAAiB;QACvB,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,KAAK,OAAO,EAAE;YACzC,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;IACH,CAAC;IAGD,YAAY,CAAC,KAAiB;QAC5B,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,KAAK,OAAO,EAAE;YACzC,IAAI,CAAC,eAAe,GAAG,UAAU,CAAC,GAAG,EAAE;gBACrC,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;SAC7B;IACH,CAAC;IAGD,YAAY,CAAC,KAAiB;QAC5B,IAAI,IAAI,CAAC,OAAO,CAAC,YAAY,KAAK,OAAO,EAAE;YACzC,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBACnC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;aAC7B;YACD,IAAI,IAAI,CAAC,YAAY,EAAE;gBACrB,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE;wBAC/B,IAAI,CAAC,YAAY,EAAE,CAAC;qBACrB;gBACH,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;aAC7B;iBAAM;gBACL,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;aACnB;SACF;IACH,CAAC;IAED,8DAA8D;IAC9D,aAAa;QACX,OAAO,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;IACtE,CAAC;IAED,yBAAyB;IACzB,WAAW;QACT,IAAI,CAAC,IAAI,CAAC,YAAY,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE;YACrC,IAAI,CAAC,cAAc,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;YAE3C,IAAI,CAAC,oBAAoB,EAAE,CAAC;YAC5B,IAAI,CAAC,uBAAuB,EAAE,CAAC;YAE/B,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;IAED,0BAA0B;IAC1B,YAAY;QACV,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;YAC1B,IAAI,CAAC,aAAa,EAAE,CAAC;SACtB;QAED,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,wCAAwC;IACxC,cAAc;QACZ,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YACnC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;QACD,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;YAC3B,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;YACxB,IAAI,CAAC,qBAAqB,EAAE,CAAC;SAC9B;QAED,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC;QACvB,IAAI,CAAC,UAAU,CAAC,QAAQ,EAAE,CAAC;IAC7B,CAAC;IAED,mCAAmC;IACnC,KAAK;QACH,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;IACzC,CAAC;IAED,gDAAgD;IAChD,IAAI,GAAG;QACL,OAAO,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC;IAChE,CAAC;IAED;;;;;OAKG;IACK,oBAAoB;QAC1B,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,2DAA2D;YAC3D,IAAI,IAAI,CAAC,YAAY,KAAK,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,oBAAoB,KAAK,IAAI,EAAE;gBAC/E,IAAI,CAAC,WAAW;qBACb,aAAa,EAAE;qBACf,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;qBAChE,SAAS,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,OAAO,CAAC,eAAe,EAAE,CAAC;gBACjC,CAAC,CAAC,CAAC;aACN;SACF;IACH,CAAC;IAEO,uBAAuB;QAC7B,IAAI,IAAI,CAAC,WAAW,EAAE;YACpB,IAAI,CAAC,WAAW;iBACb,WAAW,EAAE;iBACb,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;iBAChE,SAAS,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,iBAAiB,EAAE,CAAC;YAC3B,CAAC,CAAC,CAAC;SACN;IACH,CAAC;IAED;;;OAGG;IACK,YAAY;QAClB,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC3B,CAAC;IAED;;;OAGG;IACK,aAAa;QACnB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEzB,6EAA6E;QAC7E,kEAAkE;QAClE,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;YACxB,IAAI,CAAC,KAAK,EAAE,CAAC;SACd;QACD,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAC9B,CAAC;IAED,yEAAyE;IACjE,iBAAiB;QACvB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE;YACtB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC;YAEzB,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,yEAAyE;IACjE,iBAAiB;QACvB,IAAI,IAAI,CAAC,YAAY,EAAE;YACrB,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;YAE1B,IAAI,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;YAC3B,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC;SAC3B;IACH,CAAC;IAED;;;OAGG;IACK,aAAa;QACnB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,2BAA2B,EAAE,CAAC;SAC/B;IACH,CAAC;IAED;;;OAGG;IACK,cAAc;QACpB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE;YACrB,IAAI,CAAC,OAAO,GAAG,IAAI,cAAc,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;YACpF,MAAM,MAAM,GAAG,IAAI,CAAC,iBAAiB,EAAE,CAAC;YACxC,IAAI,CAAC,qBAAqB,CAAC,MAAM,CAAC,gBAAqD,CAAC,CAAC;YACzF,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;SACjD;QAED,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED;;;OAGG;IACK,iBAAiB;QACvB,MAAM,YAAY,GAAG,IAAI,aAAa,EAAE,CAAC;QACzC,YAAY,CAAC,gBAAgB,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAEpD,yDAAyD;QACzD,IAAI,IAAI,CAAC,YAAY,KAAK,OAAO,EAAE;YACjC,YAAY,CAAC,WAAW,GAAG,IAAI,CAAC;YAChC,YAAY,CAAC,aAAa,GAAG,kCAAkC,CAAC;SACjE;QAED,YAAY,CAAC,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC;QACnC,YAAY,CAAC,cAAc,GAAG,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;QAE1F,OAAO,YAAY,CAAC;IACtB,CAAC;IAED;;OAEG;IACK,yBAAyB,CAAC,QAAkC;QAClE,QAAQ,QAAQ,EAAE;YAChB,KAAK,MAAM;gBACT,OAAO,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;YAC/C,KAAK,OAAO;gBACV,OAAO,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;YAChD,KAAK,OAAO;gBACV,OAAO,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;YAChD,KAAK,YAAY,CAAC;YAClB;gBACE,OAAO,IAAI,CAAC,QAAQ,CAAC,gBAAgB,CAAC,UAAU,EAAE,CAAC;SACtD;IACH,CAAC;IAED;;;;OAIG;IACK,qBAAqB,CAAC,QAA2C;QACvE,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAC,eAAe,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE;YACvE,MAAM,IAAI,GACR,MAAM,CAAC,cAAc,CAAC,QAAQ,KAAK,OAAO;gBACxC,CAAC,CAAC,OAAO;gBACT,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,QAAQ,KAAK,KAAK;oBAC1C,CAAC,CAAC,QAAQ;oBACV,CAAC,CAAC,QAAQ,CAAC;YACf,MAAM,IAAI,GACR,MAAM,CAAC,cAAc,CAAC,QAAQ,KAAK,KAAK;gBACtC,CAAC,CAAC,OAAO;gBACT,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,QAAQ,KAAK,QAAQ;oBAC7C,CAAC,CAAC,OAAO;oBACT,CAAC,CAAC,QAAQ,CAAC;YAEf,MAAM,GAAG,GACP,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO;gBAC1E,CAAC,CAAC,CAAC,IAA+B,EAAE,IAAI,CAAC;gBACzC,CAAC,CAAC,CAAC,IAA+B,EAAE,IAAI,CAAC,CAAC;YAE9C,8CAA8C;YAC9C,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;YAEvC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE;gBACzB,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,GAAG,CAAC,CAAC;gBACnC,IAAI,CAAC,OAAO,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;YACvC,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACK,YAAY;QAClB,MAAM,CAAC,OAAO,EAAE,UAAU,EAAE,UAAU,CAAC,GACrC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO;YAC3E,CAAC,CAAC,CAAC,OAAO,EAAE,QAAQ,EAAE,KAAK,CAAC;YAC5B,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ;gBAC/E,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,OAAO,CAAC;gBAC5B,CAAC,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;QAEjC,MAAM,CAAC,OAAO,EAAE,UAAU,EAAE,UAAU,CAAC,GACrC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO;YAC1E,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,EAAE,QAAQ,CAAC;YAC7B,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO;gBAC9E,CAAC,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,KAAK,CAAC;gBAC7B,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;QAElC,MAAM,CAAC,QAAQ,EAAE,gBAAgB,CAAC,GAChC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO;YAC1E,CAAC,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC;YACpB,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ;gBACvC,CAAC,CAAC,CAAC,KAAK,EAAE,OAAO,CAAC;gBAClB,CAAC,CAAC,CAAC,OAAO,EAAE,KAAK,CAAC,CAAC;QAEvB,MAAM,CAAC,QAAQ,EAAE,gBAAgB,CAAC,GAChC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO;YAC3E,CAAC,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC;YACpB,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO;gBACtC,CAAC,CAAC,CAAC,KAAK,EAAE,QAAQ,CAAC;gBACnB,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;QAExB,MAAM,eAAe,GAAG,QAAQ,CAAC;QACjC,MAAM,eAAe,GAAG,QAAQ,CAAC;QAEjC,MAAM,OAAO,GACX,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAC1D,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;YAC3E,CAAC,CAAC,CAAC,CAAC;QACR,MAAM,OAAO,GACX,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YAC1D,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;YAC9B,CAAC,CAAC,CAAC,CAAC;QAER;;;;WAIG;QACH,IAAI,OAAO,GAAG,IAAI,CAAC,WAAW,CAAC;QAC/B,IAAI,OAAO,IAAI,CAAC,aAAa,KAAK,WAAW,EAAE;YAC7C,IAAI,CAAC,OAAO,CAAC,oBAAoB,GAAG,IAAI,CAAC;YACzC,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC;SAC1C;QAED,IAAI,SAAS,GAAwB,CAAC,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,CAAC,CAAC;QAEhF,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO,EAAE;YAChF,SAAS,GAAG;gBACV,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE;gBACjD,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE;gBACzE,EAAE,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAE,OAAO,EAAE;gBACzE;oBACE,OAAO;oBACP,OAAO,EAAE,eAAe;oBACxB,QAAQ;oBACR,QAAQ,EAAE,gBAAgB;oBAC1B,OAAO,EAAE,CAAC,OAAO;iBAClB;gBACD;oBACE,OAAO,EAAE,UAAU;oBACnB,OAAO,EAAE,eAAe;oBACxB,QAAQ,EAAE,UAAU;oBACpB,QAAQ,EAAE,gBAAgB;oBAC1B,OAAO,EAAE,CAAC,OAAO;iBAClB;gBACD;oBACE,OAAO,EAAE,UAAU;oBACnB,OAAO,EAAE,eAAe;oBACxB,QAAQ,EAAE,UAAU;oBACpB,QAAQ,EAAE,gBAAgB;oBAC1B,OAAO,EAAE,CAAC,OAAO;iBAClB;aACF,CAAC;SACH;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAK,OAAO,EAAE;YACjF,SAAS,GAAG;gBACV,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,OAAO,EAAE;gBACjD,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE;gBACzE,EAAE,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,QAAQ,EAAE,QAAQ,EAAE,UAAU,EAAE,OAAO,EAAE;gBACzE;oBACE,OAAO,EAAE,eAAe;oBACxB,OAAO;oBACP,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ;oBACR,OAAO,EAAE,CAAC,OAAO;iBAClB;gBACD;oBACE,OAAO,EAAE,eAAe;oBACxB,OAAO,EAAE,UAAU;oBACnB,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ,EAAE,UAAU;oBACpB,OAAO,EAAE,CAAC,OAAO;iBAClB;gBACD;oBACE,OAAO,EAAE,eAAe;oBACxB,OAAO,EAAE,UAAU;oBACnB,QAAQ,EAAE,gBAAgB;oBAC1B,QAAQ,EAAE,UAAU;oBACpB,OAAO,EAAE,CAAC,OAAO;iBAClB;aACF,CAAC;SACH;QAED,OAAO,IAAI,CAAC,QAAQ;aACjB,QAAQ,EAAE;aACV,mBAAmB,CAAC,OAAO,CAAC;aAC5B,kBAAkB,EAAE;aACpB,aAAa,CAAC,SAAS,CAAC;aACxB,kBAAkB,CAAC,OAAO,CAAC;aAC3B,kBAAkB,CAAC,OAAO,CAAC,CAAC;IACjC,CAAC;IAEO,qBAAqB;QAC3B,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,IAAI,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC;SAC1C;QACD,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC9B,IAAI,CAAC,qBAAqB,CAAC,WAAW,EAAE,CAAC;SAC1C;QACD,IAAI,IAAI,CAAC,wBAAwB,EAAE;YACjC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,CAAC;SAC7C;IACH,CAAC;IAEsC,gBAAgB,CAAC,KAAiB;QACvE,IAAI,KAAK,IAAI,CAAC,+BAA+B,CAAC,KAAK,CAAC,EAAE;YACpD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;SAC5B;IACH,CAAC;;;;YA1dF,SAAS,SAAC;gBACT,QAAQ,EAAE,wBAAwB;gBAClC,QAAQ,EAAE,mBAAmB;aAC9B;;;;;;;;;;YA/BC,OAAO;YAfP,UAAU;YAMV,gBAAgB;YAOE,cAAc,uBA2E7B,QAAQ;YA/EX,iBAAiB;;;;2BAuChB,WAAW,SAAC,oBAAoB;sBAsBhC,KAAK,SAAC,sBAAsB;4BAG5B,KAAK,SAAC,oBAAoB;2BAG1B,KAAK,SAAC,qBAAqB;4BAG3B,MAAM;4BAGN,MAAM;sBAiCN,YAAY,SAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;2BAOhC,YAAY,SAAC,YAAY,EAAE,CAAC,QAAQ,CAAC;2BAUrC,YAAY,SAAC,YAAY,EAAE,CAAC,QAAQ,CAAC;+BA6XrC,YAAY,SAAC,WAAW,EAAE,CAAC,QAAQ,CAAC","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"]}
|
|
472
|
+
//# 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"]}
|