@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,169 +1,187 @@
|
|
|
1
|
-
import { Component, EventEmitter, Input, Output, TemplateRef, ViewChild, ViewEncapsulation, ChangeDetectionStrategy, HostBinding, Optional, } from '@angular/core';
|
|
2
1
|
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
3
|
-
import { ESCAPE } from '@angular/cdk/keycodes';
|
|
4
|
-
import {
|
|
2
|
+
import { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';
|
|
3
|
+
import { ChangeDetectionStrategy, Component, ContentChild, EventEmitter, Inject, InjectionToken, Input, Output, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
|
|
4
|
+
import { Subject } from 'rxjs';
|
|
5
5
|
import { transformPopover } from './popover-animations';
|
|
6
|
+
import { MTX_POPOVER_CONTENT } from './popover-content';
|
|
7
|
+
import { throwMtxPopoverInvalidPositionEnd, throwMtxPopoverInvalidPositionStart, } from './popover-errors';
|
|
6
8
|
import * as i0 from "@angular/core";
|
|
7
|
-
import * as i1 from "@angular/
|
|
8
|
-
import * as i2 from "@angular/
|
|
9
|
-
|
|
9
|
+
import * as i1 from "@angular/common";
|
|
10
|
+
import * as i2 from "@angular/cdk/a11y";
|
|
11
|
+
/** Injection token to be used to override the default options for `mtx-popover`. */
|
|
12
|
+
export const MTX_POPOVER_DEFAULT_OPTIONS = new InjectionToken('mtx-popover-default-options', {
|
|
13
|
+
providedIn: 'root',
|
|
14
|
+
factory: MTX_POPOVER_DEFAULT_OPTIONS_FACTORY,
|
|
15
|
+
});
|
|
16
|
+
/** @docs-private */
|
|
17
|
+
export function MTX_POPOVER_DEFAULT_OPTIONS_FACTORY() {
|
|
18
|
+
return {
|
|
19
|
+
backdropClass: 'cdk-overlay-transparent-backdrop',
|
|
20
|
+
};
|
|
21
|
+
}
|
|
22
|
+
let popoverPanelUid = 0;
|
|
10
23
|
export class MtxPopover {
|
|
11
|
-
constructor(
|
|
12
|
-
this._dir = _dir;
|
|
24
|
+
constructor(_elementRef, _ngZone, _defaultOptions) {
|
|
13
25
|
this._elementRef = _elementRef;
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
|
|
17
|
-
this.
|
|
18
|
-
this.
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
23
|
-
this.
|
|
24
|
-
this.
|
|
25
|
-
this.
|
|
26
|
-
this.
|
|
27
|
-
this.
|
|
28
|
-
this.
|
|
29
|
-
this.
|
|
30
|
-
this.
|
|
31
|
-
this.
|
|
32
|
-
this.
|
|
33
|
-
/** Config object to be passed into the popover's ngClass */
|
|
26
|
+
this._ngZone = _ngZone;
|
|
27
|
+
this._defaultOptions = _defaultOptions;
|
|
28
|
+
this._triggerEvent = this._defaultOptions.triggerEvent ?? 'hover';
|
|
29
|
+
this._enterDelay = this._defaultOptions.enterDelay ?? 100;
|
|
30
|
+
this._leaveDelay = this._defaultOptions.leaveDelay ?? 100;
|
|
31
|
+
this._position = this._defaultOptions.position ?? ['below', 'after'];
|
|
32
|
+
this._panelOffsetX = this._defaultOptions.xOffset ?? 0;
|
|
33
|
+
this._panelOffsetY = this._defaultOptions.yOffset ?? 0;
|
|
34
|
+
this._arrowWidth = this._defaultOptions.arrowWidth ?? 16;
|
|
35
|
+
this._arrowHeight = this._defaultOptions.arrowHeight ?? 16;
|
|
36
|
+
this._arrowOffsetX = this._defaultOptions.arrowOffsetX ?? 20;
|
|
37
|
+
this._arrowOffsetY = this._defaultOptions.arrowOffsetY ?? 20;
|
|
38
|
+
this._closeOnPanelClick = this._defaultOptions.closeOnPanelClick ?? false;
|
|
39
|
+
this._closeOnBackdropClick = this._defaultOptions.closeOnBackdropClick ?? true;
|
|
40
|
+
this._focusTrapEnabled = this._defaultOptions.focusTrapEnabled ?? false;
|
|
41
|
+
this._focusTrapAutoCaptureEnabled = this._defaultOptions.focusTrapAutoCaptureEnabled ?? false;
|
|
42
|
+
this._hasBackdrop = this._defaultOptions.hasBackdrop;
|
|
43
|
+
this._elevation = this._defaultOptions.elevation ?? 8;
|
|
44
|
+
this._elevationPrefix = 'mat-elevation-z';
|
|
45
|
+
/** Config object to be passed into the popover's ngClass. */
|
|
34
46
|
this._classList = {};
|
|
35
|
-
/**
|
|
36
|
-
this.
|
|
47
|
+
/** Current state of the panel animation. */
|
|
48
|
+
this._panelAnimationState = 'void';
|
|
49
|
+
/** Emits whenever an animation on the popover completes. */
|
|
50
|
+
this._animationDone = new Subject();
|
|
51
|
+
/** Whether the popover is animating. */
|
|
52
|
+
this._isAnimating = false;
|
|
37
53
|
/** Closing disabled on popover */
|
|
38
54
|
this.closeDisabled = false;
|
|
39
|
-
/**
|
|
40
|
-
this.
|
|
55
|
+
/** Class or list of classes to be added to the overlay panel. */
|
|
56
|
+
this.overlayPanelClass = this._defaultOptions.overlayPanelClass || '';
|
|
57
|
+
/** Class to be added to the backdrop element. */
|
|
58
|
+
this.backdropClass = this._defaultOptions.backdropClass;
|
|
41
59
|
/** Event emitted when the popover is closed. */
|
|
42
60
|
this.closed = new EventEmitter();
|
|
43
|
-
this.
|
|
44
|
-
}
|
|
45
|
-
/** Position of the popover. */
|
|
46
|
-
get position() {
|
|
47
|
-
return this._position;
|
|
61
|
+
this.panelId = `mtx-popover-panel-${popoverPanelUid++}`;
|
|
48
62
|
}
|
|
49
|
-
|
|
50
|
-
if (!['before', 'after', 'above', 'below'].includes(value[0])) {
|
|
51
|
-
throwMtxPopoverInvalidPositionStart();
|
|
52
|
-
}
|
|
53
|
-
if (!['before', 'after', 'above', 'below', 'center'].includes(value[1])) {
|
|
54
|
-
throwMtxPopoverInvalidPositionEnd();
|
|
55
|
-
}
|
|
56
|
-
this._position = value;
|
|
57
|
-
this.setPositionClasses();
|
|
58
|
-
}
|
|
59
|
-
/** Popover trigger event */
|
|
63
|
+
/** Popover's trigger event. */
|
|
60
64
|
get triggerEvent() {
|
|
61
65
|
return this._triggerEvent;
|
|
62
66
|
}
|
|
63
67
|
set triggerEvent(value) {
|
|
64
68
|
this._triggerEvent = value;
|
|
65
69
|
}
|
|
66
|
-
/** Popover
|
|
67
|
-
get scrollStrategy() {
|
|
68
|
-
return this._scrollStrategy;
|
|
69
|
-
}
|
|
70
|
-
set scrollStrategy(value) {
|
|
71
|
-
this._scrollStrategy = value;
|
|
72
|
-
}
|
|
73
|
-
/** Popover enter delay */
|
|
70
|
+
/** Popover's enter delay. */
|
|
74
71
|
get enterDelay() {
|
|
75
72
|
return this._enterDelay;
|
|
76
73
|
}
|
|
77
74
|
set enterDelay(value) {
|
|
78
75
|
this._enterDelay = value;
|
|
79
76
|
}
|
|
80
|
-
/** Popover leave delay */
|
|
77
|
+
/** Popover's leave delay. */
|
|
81
78
|
get leaveDelay() {
|
|
82
79
|
return this._leaveDelay;
|
|
83
80
|
}
|
|
84
81
|
set leaveDelay(value) {
|
|
85
82
|
this._leaveDelay = value;
|
|
86
83
|
}
|
|
87
|
-
/** Popover
|
|
84
|
+
/** Popover's position. */
|
|
85
|
+
get position() {
|
|
86
|
+
return this._position;
|
|
87
|
+
}
|
|
88
|
+
set position(value) {
|
|
89
|
+
if (!['before', 'after', 'above', 'below'].includes(value[0])) {
|
|
90
|
+
throwMtxPopoverInvalidPositionStart();
|
|
91
|
+
}
|
|
92
|
+
if (!['before', 'after', 'above', 'below', 'center'].includes(value[1])) {
|
|
93
|
+
throwMtxPopoverInvalidPositionEnd();
|
|
94
|
+
}
|
|
95
|
+
this._position = value;
|
|
96
|
+
this.setPositionClasses();
|
|
97
|
+
}
|
|
98
|
+
/** Popover-panel's X offset. */
|
|
88
99
|
get xOffset() {
|
|
89
100
|
return this._panelOffsetX;
|
|
90
101
|
}
|
|
91
102
|
set xOffset(value) {
|
|
92
103
|
this._panelOffsetX = value;
|
|
93
104
|
}
|
|
94
|
-
/** Popover
|
|
105
|
+
/** Popover-panel's Y offset. */
|
|
95
106
|
get yOffset() {
|
|
96
107
|
return this._panelOffsetY;
|
|
97
108
|
}
|
|
98
109
|
set yOffset(value) {
|
|
99
110
|
this._panelOffsetY = value;
|
|
100
111
|
}
|
|
101
|
-
/** Popover
|
|
102
|
-
get arrowOffsetX() {
|
|
103
|
-
return this._arrowOffsetX;
|
|
104
|
-
}
|
|
105
|
-
set arrowOffsetX(value) {
|
|
106
|
-
this._arrowOffsetX = value;
|
|
107
|
-
}
|
|
108
|
-
/** Popover arrow offset y */
|
|
109
|
-
get arrowOffsetY() {
|
|
110
|
-
return this._arrowOffsetY;
|
|
111
|
-
}
|
|
112
|
-
set arrowOffsetY(value) {
|
|
113
|
-
this._arrowOffsetY = value;
|
|
114
|
-
}
|
|
115
|
-
/** Popover arrow width */
|
|
112
|
+
/** Popover-arrow's width. */
|
|
116
113
|
get arrowWidth() {
|
|
117
114
|
return this._arrowWidth;
|
|
118
115
|
}
|
|
119
116
|
set arrowWidth(value) {
|
|
120
117
|
this._arrowWidth = value;
|
|
121
118
|
}
|
|
122
|
-
/** Popover
|
|
119
|
+
/** Popover-arrow's height. */
|
|
123
120
|
get arrowHeight() {
|
|
124
121
|
return this._arrowHeight;
|
|
125
122
|
}
|
|
126
123
|
set arrowHeight(value) {
|
|
127
124
|
this._arrowHeight = value;
|
|
128
125
|
}
|
|
129
|
-
/** Popover
|
|
126
|
+
/** Popover-arrow's X offset. */
|
|
127
|
+
get arrowOffsetX() {
|
|
128
|
+
return this._arrowOffsetX;
|
|
129
|
+
}
|
|
130
|
+
set arrowOffsetX(value) {
|
|
131
|
+
this._arrowOffsetX = value;
|
|
132
|
+
}
|
|
133
|
+
/** Popover-arrow's Y offset. */
|
|
134
|
+
get arrowOffsetY() {
|
|
135
|
+
return this._arrowOffsetY;
|
|
136
|
+
}
|
|
137
|
+
set arrowOffsetY(value) {
|
|
138
|
+
this._arrowOffsetY = value;
|
|
139
|
+
}
|
|
140
|
+
/** Whether popover can be closed when click the popover-panel. */
|
|
130
141
|
get closeOnPanelClick() {
|
|
131
142
|
return this._closeOnPanelClick;
|
|
132
143
|
}
|
|
133
144
|
set closeOnPanelClick(value) {
|
|
134
145
|
this._closeOnPanelClick = coerceBooleanProperty(value);
|
|
135
146
|
}
|
|
136
|
-
/**
|
|
147
|
+
/** Whether popover can be closed when click the backdrop. */
|
|
137
148
|
get closeOnBackdropClick() {
|
|
138
149
|
return this._closeOnBackdropClick;
|
|
139
150
|
}
|
|
140
151
|
set closeOnBackdropClick(value) {
|
|
141
152
|
this._closeOnBackdropClick = coerceBooleanProperty(value);
|
|
142
153
|
}
|
|
143
|
-
/**
|
|
144
|
-
get disableAnimation() {
|
|
145
|
-
return this._disableAnimation;
|
|
146
|
-
}
|
|
147
|
-
set disableAnimation(value) {
|
|
148
|
-
this._disableAnimation = coerceBooleanProperty(value);
|
|
149
|
-
}
|
|
150
|
-
/** Popover focus trap using cdkTrapFocus */
|
|
154
|
+
/** Whether enable focus trap using `cdkTrapFocus`. */
|
|
151
155
|
get focusTrapEnabled() {
|
|
152
156
|
return this._focusTrapEnabled;
|
|
153
157
|
}
|
|
154
158
|
set focusTrapEnabled(value) {
|
|
155
159
|
this._focusTrapEnabled = coerceBooleanProperty(value);
|
|
156
160
|
}
|
|
157
|
-
/**
|
|
161
|
+
/** Whether enable focus trap auto capture using `cdkTrapFocusAutoCapture`. */
|
|
158
162
|
get focusTrapAutoCaptureEnabled() {
|
|
159
163
|
return this._focusTrapAutoCaptureEnabled;
|
|
160
164
|
}
|
|
161
165
|
set focusTrapAutoCaptureEnabled(value) {
|
|
162
166
|
this._focusTrapAutoCaptureEnabled = coerceBooleanProperty(value);
|
|
163
167
|
}
|
|
168
|
+
/** Whether the popover has a backdrop. It will always be false if the trigger event is hover. */
|
|
169
|
+
get hasBackdrop() {
|
|
170
|
+
return this._hasBackdrop;
|
|
171
|
+
}
|
|
172
|
+
set hasBackdrop(value) {
|
|
173
|
+
this._hasBackdrop = coerceBooleanProperty(value);
|
|
174
|
+
}
|
|
175
|
+
/** Popover-panel's elevation (0~24). */
|
|
176
|
+
get elevation() {
|
|
177
|
+
return Math.max(0, Math.min(Math.round(this._elevation), 24));
|
|
178
|
+
}
|
|
179
|
+
set elevation(value) {
|
|
180
|
+
this._elevation = value;
|
|
181
|
+
}
|
|
164
182
|
/**
|
|
165
183
|
* This method takes classes set on the host md-popover element and applies them on the
|
|
166
|
-
* popover template that displays in the overlay container.
|
|
184
|
+
* popover template that displays in the overlay container. Otherwise, it's difficult
|
|
167
185
|
* to style the containing popover from outside the component.
|
|
168
186
|
* @param classes list of class names
|
|
169
187
|
*/
|
|
@@ -179,7 +197,7 @@ export class MtxPopover {
|
|
|
179
197
|
}
|
|
180
198
|
/**
|
|
181
199
|
* This method takes classes set on the host md-popover element and applies them on the
|
|
182
|
-
* popover template that displays in the overlay container.
|
|
200
|
+
* popover template that displays in the overlay container. Otherwise, it's difficult
|
|
183
201
|
* to style the containing popover from outside the component.
|
|
184
202
|
* @deprecated Use `panelClass` instead.
|
|
185
203
|
* @breaking-change 8.0.0
|
|
@@ -190,47 +208,46 @@ export class MtxPopover {
|
|
|
190
208
|
set classList(classes) {
|
|
191
209
|
this.panelClass = classes;
|
|
192
210
|
}
|
|
211
|
+
ngOnInit() {
|
|
212
|
+
this.setPositionClasses();
|
|
213
|
+
}
|
|
193
214
|
ngOnDestroy() {
|
|
194
|
-
this._emitCloseEvent();
|
|
195
215
|
this.closed.complete();
|
|
196
216
|
}
|
|
197
217
|
/** Handle a keyboard event from the popover, delegating to the appropriate action. */
|
|
198
218
|
_handleKeydown(event) {
|
|
199
|
-
|
|
219
|
+
const keyCode = event.keyCode;
|
|
220
|
+
switch (keyCode) {
|
|
200
221
|
case ESCAPE:
|
|
201
|
-
|
|
202
|
-
|
|
222
|
+
if (!hasModifierKey(event)) {
|
|
223
|
+
event.preventDefault();
|
|
224
|
+
this.closed.emit('keydown');
|
|
225
|
+
}
|
|
226
|
+
break;
|
|
203
227
|
}
|
|
204
228
|
}
|
|
205
|
-
/**
|
|
206
|
-
|
|
207
|
-
* trigger will close the popover.
|
|
208
|
-
*/
|
|
209
|
-
_emitCloseEvent() {
|
|
210
|
-
this.closed.emit();
|
|
211
|
-
}
|
|
212
|
-
/** Close popover on click if closeOnPanelClick is true */
|
|
213
|
-
onClick() {
|
|
229
|
+
/** Close popover on click if `closeOnPanelClick` is true. */
|
|
230
|
+
_handleClick() {
|
|
214
231
|
if (this.closeOnPanelClick) {
|
|
215
|
-
this.
|
|
232
|
+
this.closed.emit('click');
|
|
216
233
|
}
|
|
217
234
|
}
|
|
218
|
-
/** Disables close of popover when leaving trigger element and mouse over the popover */
|
|
219
|
-
|
|
235
|
+
/** Disables close of popover when leaving trigger element and mouse over the popover. */
|
|
236
|
+
_handleMouseOver() {
|
|
220
237
|
if (this.triggerEvent === 'hover') {
|
|
221
238
|
this.closeDisabled = true;
|
|
222
239
|
}
|
|
223
240
|
}
|
|
224
|
-
/** Enables close of popover when mouse leaving popover element */
|
|
225
|
-
|
|
241
|
+
/** Enables close of popover when mouse leaving popover element. */
|
|
242
|
+
_handleMouseLeave() {
|
|
226
243
|
if (this.triggerEvent === 'hover') {
|
|
227
244
|
setTimeout(() => {
|
|
228
245
|
this.closeDisabled = false;
|
|
229
|
-
this.
|
|
246
|
+
this.closed.emit();
|
|
230
247
|
}, this.leaveDelay);
|
|
231
248
|
}
|
|
232
249
|
}
|
|
233
|
-
/** Sets the current styles for the popover to allow for dynamically changing settings */
|
|
250
|
+
/** Sets the current styles for the popover to allow for dynamically changing settings. */
|
|
234
251
|
setCurrentStyles(pos = this.position) {
|
|
235
252
|
const left = pos[1] === 'after'
|
|
236
253
|
? `${this.arrowOffsetX - this.arrowWidth / 2}px`
|
|
@@ -244,16 +261,13 @@ export class MtxPopover {
|
|
|
244
261
|
? `calc(50% - ${this.arrowHeight / 2}px)`
|
|
245
262
|
: '';
|
|
246
263
|
const top = pos[1] === 'below' ? `${this.arrowOffsetY - this.arrowHeight / 2}px` : '';
|
|
247
|
-
this.
|
|
264
|
+
this.arrowStyles =
|
|
248
265
|
pos[0] === 'above' || pos[0] === 'below'
|
|
249
266
|
? {
|
|
250
|
-
left: this.
|
|
251
|
-
right: this.
|
|
267
|
+
left: this.direction === 'ltr' ? left : right,
|
|
268
|
+
right: this.direction === 'ltr' ? right : left,
|
|
252
269
|
}
|
|
253
|
-
: {
|
|
254
|
-
top,
|
|
255
|
-
bottom,
|
|
256
|
-
};
|
|
270
|
+
: { top, bottom };
|
|
257
271
|
}
|
|
258
272
|
/**
|
|
259
273
|
* It's necessary to set position-based classes to ensure the popover panel animation
|
|
@@ -273,49 +287,85 @@ export class MtxPopover {
|
|
|
273
287
|
this._classList['mtx-popover-below-center'] = pos[0] === 'below' && pos[1] === 'center';
|
|
274
288
|
this._classList['mtx-popover-below-after'] = pos[0] === 'below' && pos[1] === 'after';
|
|
275
289
|
}
|
|
290
|
+
/** Sets the popover-panel's elevation. */
|
|
291
|
+
setElevation() {
|
|
292
|
+
const newElevation = `${this._elevationPrefix}${this.elevation}`;
|
|
293
|
+
if (this._previousElevation) {
|
|
294
|
+
this._classList[this._previousElevation] = false;
|
|
295
|
+
}
|
|
296
|
+
this._classList[newElevation] = true;
|
|
297
|
+
this._previousElevation = newElevation;
|
|
298
|
+
}
|
|
299
|
+
/** Starts the enter animation. */
|
|
300
|
+
_startAnimation() {
|
|
301
|
+
// @breaking-change 8.0.0 Combine with _resetAnimation.
|
|
302
|
+
this._panelAnimationState = 'enter';
|
|
303
|
+
}
|
|
304
|
+
/** Resets the panel animation to its initial state. */
|
|
305
|
+
_resetAnimation() {
|
|
306
|
+
// @breaking-change 8.0.0 Combine with _startAnimation.
|
|
307
|
+
this._panelAnimationState = 'void';
|
|
308
|
+
}
|
|
309
|
+
/** Callback that is invoked when the panel animation completes. */
|
|
310
|
+
_onAnimationDone(event) {
|
|
311
|
+
this._animationDone.next(event);
|
|
312
|
+
this._isAnimating = false;
|
|
313
|
+
}
|
|
314
|
+
_onAnimationStart(event) {
|
|
315
|
+
this._isAnimating = true;
|
|
316
|
+
}
|
|
276
317
|
}
|
|
277
|
-
/** @nocollapse */ MtxPopover.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: MtxPopover, deps: [{ token:
|
|
278
|
-
/** @nocollapse */ MtxPopover.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: MtxPopover, selector: "mtx-popover", inputs: {
|
|
318
|
+
/** @nocollapse */ MtxPopover.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: MtxPopover, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }, { token: MTX_POPOVER_DEFAULT_OPTIONS }], target: i0.ɵɵFactoryTarget.Component });
|
|
319
|
+
/** @nocollapse */ MtxPopover.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.2.0", type: MtxPopover, selector: "mtx-popover", inputs: { backdropClass: "backdropClass", ariaLabel: ["aria-label", "ariaLabel"], ariaLabelledby: ["aria-labelledby", "ariaLabelledby"], ariaDescribedby: ["aria-describedby", "ariaDescribedby"], triggerEvent: "triggerEvent", enterDelay: "enterDelay", leaveDelay: "leaveDelay", position: "position", xOffset: "xOffset", yOffset: "yOffset", arrowWidth: "arrowWidth", arrowHeight: "arrowHeight", arrowOffsetX: "arrowOffsetX", arrowOffsetY: "arrowOffsetY", closeOnPanelClick: "closeOnPanelClick", closeOnBackdropClick: "closeOnBackdropClick", focusTrapEnabled: "focusTrapEnabled", focusTrapAutoCaptureEnabled: "focusTrapAutoCaptureEnabled", hasBackdrop: "hasBackdrop", elevation: "elevation", panelClass: ["class", "panelClass"], classList: "classList" }, outputs: { closed: "closed" }, queries: [{ propertyName: "lazyContent", first: true, predicate: MTX_POPOVER_CONTENT, descendants: true }], viewQueries: [{ propertyName: "templateRef", first: true, predicate: TemplateRef, descendants: true }], exportAs: ["mtxPopover"], ngImport: i0, template: "<ng-template>\r\n <div class=\"mtx-popover-panel\"\r\n [id]=\"panelId\"\r\n [ngClass]=\"_classList\"\r\n (keydown)=\"_handleKeydown($event)\"\r\n (click)=\"_handleClick()\"\r\n (mouseover)=\"_handleMouseOver()\"\r\n (mouseleave)=\"_handleMouseLeave()\"\r\n [@transformPopover]=\"_panelAnimationState\"\r\n (@transformPopover.start)=\"_onAnimationStart($event)\"\r\n (@transformPopover.done)=\"_onAnimationDone($event)\"\r\n tabindex=\"-1\"\r\n role=\"dialog\"\r\n [attr.aria-label]=\"ariaLabel || null\"\r\n [attr.aria-labelledby]=\"ariaLabelledby || null\"\r\n [attr.aria-describedby]=\"ariaDescribedby || null\"\r\n [cdkTrapFocus]=\"focusTrapEnabled\"\r\n [cdkTrapFocusAutoCapture]=\"focusTrapAutoCaptureEnabled\">\r\n <div class=\"mtx-popover-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"mtx-popover-direction-arrow\" [ngStyle]=\"arrowStyles\"></div>\r\n </div>\r\n</ng-template>\r\n", styles: [".mtx-popover-panel{position:relative;max-height:calc(100vh - 48px);padding:8px;border-radius:4px;font-size:16px;outline:0}.mtx-popover-panel[class*=mtx-popover-below]{margin-top:calc(.5em + 2px)}.mtx-popover-panel[class*=mtx-popover-above]{margin-bottom:calc(.5em + 2px)}.mtx-popover-panel[class*=mtx-popover-before]{margin-right:calc(.5em + 2px)}[dir=rtl] .mtx-popover-panel[class*=mtx-popover-before]{margin-right:auto;margin-left:calc(.5em + 2px)}.mtx-popover-panel[class*=mtx-popover-after]{margin-left:calc(.5em + 2px)}[dir=rtl] .mtx-popover-panel[class*=mtx-popover-after]{margin-left:auto;margin-right:calc(.5em + 2px)}.mtx-popover-direction-arrow{position:absolute}.mtx-popover-direction-arrow:before,.mtx-popover-direction-arrow:after{position:absolute;display:inline-block;content:\"\";border-width:.5em;border-style:solid}.mtx-popover-direction-arrow:after{border-width:calc(.5em - 1px)}[class*=mtx-popover-below] .mtx-popover-direction-arrow,[class*=mtx-popover-above] .mtx-popover-direction-arrow{width:1em}[class*=mtx-popover-below] .mtx-popover-direction-arrow:after,[class*=mtx-popover-above] .mtx-popover-direction-arrow:after{left:1px}[dir=rtl] [class*=mtx-popover-below] .mtx-popover-direction-arrow:after,[dir=rtl] [class*=mtx-popover-above] .mtx-popover-direction-arrow:after{right:1px;left:auto}[class*=mtx-popover-below] .mtx-popover-direction-arrow{top:0}[class*=mtx-popover-below] .mtx-popover-direction-arrow:before,[class*=mtx-popover-below] .mtx-popover-direction-arrow:after{bottom:0;border-top-width:0}[class*=mtx-popover-above] .mtx-popover-direction-arrow{bottom:0}[class*=mtx-popover-above] .mtx-popover-direction-arrow:before,[class*=mtx-popover-above] .mtx-popover-direction-arrow:after{top:0;border-bottom-width:0}[class*=mtx-popover-before] .mtx-popover-direction-arrow,[class*=mtx-popover-after] .mtx-popover-direction-arrow{height:1em}[class*=mtx-popover-before] .mtx-popover-direction-arrow:after,[class*=mtx-popover-after] .mtx-popover-direction-arrow:after{top:1px}[class*=mtx-popover-before] .mtx-popover-direction-arrow{right:0}[class*=mtx-popover-before] .mtx-popover-direction-arrow:before,[class*=mtx-popover-before] .mtx-popover-direction-arrow:after{left:0;border-right-width:0}[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow{right:auto;left:0}[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow:before,[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow:after{left:auto;right:0;border-left-width:0}[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow:before{border-right-width:.5em}[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow:after{border-right-width:calc(.5em - 1px)}[class*=mtx-popover-after] .mtx-popover-direction-arrow{left:0}[class*=mtx-popover-after] .mtx-popover-direction-arrow:before,[class*=mtx-popover-after] .mtx-popover-direction-arrow:after{right:0;border-left-width:0}[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow{left:auto;right:0}[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow:before,[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow:after{right:auto;left:0;border-right-width:0}[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow:before{border-left-width:.5em}[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow:after{border-left-width:calc(.5em - 1px)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i2.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }], animations: [transformPopover], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
279
320
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: MtxPopover, decorators: [{
|
|
280
321
|
type: Component,
|
|
281
|
-
args: [{ selector: 'mtx-popover', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, animations: [transformPopover], exportAs: 'mtxPopover', template: "<ng-template>\r\n <div class=\"mtx-popover-panel
|
|
282
|
-
}], ctorParameters: function () { return [{ type:
|
|
283
|
-
type:
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
args: ['attr.role']
|
|
287
|
-
}], position: [{
|
|
322
|
+
args: [{ selector: 'mtx-popover', changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, animations: [transformPopover], exportAs: 'mtxPopover', template: "<ng-template>\r\n <div class=\"mtx-popover-panel\"\r\n [id]=\"panelId\"\r\n [ngClass]=\"_classList\"\r\n (keydown)=\"_handleKeydown($event)\"\r\n (click)=\"_handleClick()\"\r\n (mouseover)=\"_handleMouseOver()\"\r\n (mouseleave)=\"_handleMouseLeave()\"\r\n [@transformPopover]=\"_panelAnimationState\"\r\n (@transformPopover.start)=\"_onAnimationStart($event)\"\r\n (@transformPopover.done)=\"_onAnimationDone($event)\"\r\n tabindex=\"-1\"\r\n role=\"dialog\"\r\n [attr.aria-label]=\"ariaLabel || null\"\r\n [attr.aria-labelledby]=\"ariaLabelledby || null\"\r\n [attr.aria-describedby]=\"ariaDescribedby || null\"\r\n [cdkTrapFocus]=\"focusTrapEnabled\"\r\n [cdkTrapFocusAutoCapture]=\"focusTrapAutoCaptureEnabled\">\r\n <div class=\"mtx-popover-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div class=\"mtx-popover-direction-arrow\" [ngStyle]=\"arrowStyles\"></div>\r\n </div>\r\n</ng-template>\r\n", styles: [".mtx-popover-panel{position:relative;max-height:calc(100vh - 48px);padding:8px;border-radius:4px;font-size:16px;outline:0}.mtx-popover-panel[class*=mtx-popover-below]{margin-top:calc(.5em + 2px)}.mtx-popover-panel[class*=mtx-popover-above]{margin-bottom:calc(.5em + 2px)}.mtx-popover-panel[class*=mtx-popover-before]{margin-right:calc(.5em + 2px)}[dir=rtl] .mtx-popover-panel[class*=mtx-popover-before]{margin-right:auto;margin-left:calc(.5em + 2px)}.mtx-popover-panel[class*=mtx-popover-after]{margin-left:calc(.5em + 2px)}[dir=rtl] .mtx-popover-panel[class*=mtx-popover-after]{margin-left:auto;margin-right:calc(.5em + 2px)}.mtx-popover-direction-arrow{position:absolute}.mtx-popover-direction-arrow:before,.mtx-popover-direction-arrow:after{position:absolute;display:inline-block;content:\"\";border-width:.5em;border-style:solid}.mtx-popover-direction-arrow:after{border-width:calc(.5em - 1px)}[class*=mtx-popover-below] .mtx-popover-direction-arrow,[class*=mtx-popover-above] .mtx-popover-direction-arrow{width:1em}[class*=mtx-popover-below] .mtx-popover-direction-arrow:after,[class*=mtx-popover-above] .mtx-popover-direction-arrow:after{left:1px}[dir=rtl] [class*=mtx-popover-below] .mtx-popover-direction-arrow:after,[dir=rtl] [class*=mtx-popover-above] .mtx-popover-direction-arrow:after{right:1px;left:auto}[class*=mtx-popover-below] .mtx-popover-direction-arrow{top:0}[class*=mtx-popover-below] .mtx-popover-direction-arrow:before,[class*=mtx-popover-below] .mtx-popover-direction-arrow:after{bottom:0;border-top-width:0}[class*=mtx-popover-above] .mtx-popover-direction-arrow{bottom:0}[class*=mtx-popover-above] .mtx-popover-direction-arrow:before,[class*=mtx-popover-above] .mtx-popover-direction-arrow:after{top:0;border-bottom-width:0}[class*=mtx-popover-before] .mtx-popover-direction-arrow,[class*=mtx-popover-after] .mtx-popover-direction-arrow{height:1em}[class*=mtx-popover-before] .mtx-popover-direction-arrow:after,[class*=mtx-popover-after] .mtx-popover-direction-arrow:after{top:1px}[class*=mtx-popover-before] .mtx-popover-direction-arrow{right:0}[class*=mtx-popover-before] .mtx-popover-direction-arrow:before,[class*=mtx-popover-before] .mtx-popover-direction-arrow:after{left:0;border-right-width:0}[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow{right:auto;left:0}[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow:before,[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow:after{left:auto;right:0;border-left-width:0}[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow:before{border-right-width:.5em}[dir=rtl] [class*=mtx-popover-before] .mtx-popover-direction-arrow:after{border-right-width:calc(.5em - 1px)}[class*=mtx-popover-after] .mtx-popover-direction-arrow{left:0}[class*=mtx-popover-after] .mtx-popover-direction-arrow:before,[class*=mtx-popover-after] .mtx-popover-direction-arrow:after{right:0;border-left-width:0}[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow{left:auto;right:0}[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow:before,[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow:after{right:auto;left:0;border-right-width:0}[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow:before{border-left-width:.5em}[dir=rtl] [class*=mtx-popover-after] .mtx-popover-direction-arrow:after{border-left-width:calc(.5em - 1px)}\n"] }]
|
|
323
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }, { type: undefined, decorators: [{
|
|
324
|
+
type: Inject,
|
|
325
|
+
args: [MTX_POPOVER_DEFAULT_OPTIONS]
|
|
326
|
+
}] }]; }, propDecorators: { backdropClass: [{
|
|
288
327
|
type: Input
|
|
328
|
+
}], ariaLabel: [{
|
|
329
|
+
type: Input,
|
|
330
|
+
args: ['aria-label']
|
|
331
|
+
}], ariaLabelledby: [{
|
|
332
|
+
type: Input,
|
|
333
|
+
args: ['aria-labelledby']
|
|
334
|
+
}], ariaDescribedby: [{
|
|
335
|
+
type: Input,
|
|
336
|
+
args: ['aria-describedby']
|
|
289
337
|
}], triggerEvent: [{
|
|
290
338
|
type: Input
|
|
291
|
-
}], scrollStrategy: [{
|
|
292
|
-
type: Input
|
|
293
339
|
}], enterDelay: [{
|
|
294
340
|
type: Input
|
|
295
341
|
}], leaveDelay: [{
|
|
296
342
|
type: Input
|
|
343
|
+
}], position: [{
|
|
344
|
+
type: Input
|
|
297
345
|
}], xOffset: [{
|
|
298
346
|
type: Input
|
|
299
347
|
}], yOffset: [{
|
|
300
348
|
type: Input
|
|
301
|
-
}], arrowOffsetX: [{
|
|
302
|
-
type: Input
|
|
303
|
-
}], arrowOffsetY: [{
|
|
304
|
-
type: Input
|
|
305
349
|
}], arrowWidth: [{
|
|
306
350
|
type: Input
|
|
307
351
|
}], arrowHeight: [{
|
|
308
352
|
type: Input
|
|
353
|
+
}], arrowOffsetX: [{
|
|
354
|
+
type: Input
|
|
355
|
+
}], arrowOffsetY: [{
|
|
356
|
+
type: Input
|
|
309
357
|
}], closeOnPanelClick: [{
|
|
310
358
|
type: Input
|
|
311
359
|
}], closeOnBackdropClick: [{
|
|
312
360
|
type: Input
|
|
313
|
-
}], disableAnimation: [{
|
|
314
|
-
type: Input
|
|
315
361
|
}], focusTrapEnabled: [{
|
|
316
362
|
type: Input
|
|
317
363
|
}], focusTrapAutoCaptureEnabled: [{
|
|
318
364
|
type: Input
|
|
365
|
+
}], hasBackdrop: [{
|
|
366
|
+
type: Input
|
|
367
|
+
}], elevation: [{
|
|
368
|
+
type: Input
|
|
319
369
|
}], panelClass: [{
|
|
320
370
|
type: Input,
|
|
321
371
|
args: ['class']
|
|
@@ -326,5 +376,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
326
376
|
}], templateRef: [{
|
|
327
377
|
type: ViewChild,
|
|
328
378
|
args: [TemplateRef]
|
|
379
|
+
}], lazyContent: [{
|
|
380
|
+
type: ContentChild,
|
|
381
|
+
args: [MTX_POPOVER_CONTENT]
|
|
329
382
|
}] } });
|
|
330
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.js","sourceRoot":"","sources":["../../../../projects/extensions/popover/popover.ts","../../../../projects/extensions/popover/popover.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n  ElementRef,\n  ChangeDetectionStrategy,\n  HostBinding,\n  NgZone,\n  Optional,\n} from '@angular/core';\nimport { AnimationEvent } from '@angular/animations';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { ESCAPE } from '@angular/cdk/keycodes';\nimport { Directionality } from '@angular/cdk/bidi';\n\nimport {\n  MtxPopoverTriggerEvent,\n  MtxPopoverScrollStrategy,\n  MtxPopoverPosition,\n} from './popover-types';\nimport {\n  throwMtxPopoverInvalidPositionStart,\n  throwMtxPopoverInvalidPositionEnd,\n} from './popover-errors';\nimport { MtxPopoverPanel } from './popover-interfaces';\nimport { transformPopover } from './popover-animations';\n\n@Component({\n  selector: 'mtx-popover',\n  templateUrl: './popover.html',\n  styleUrls: ['./popover.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  animations: [transformPopover],\n  exportAs: 'mtxPopover',\n})\nexport class MtxPopover implements MtxPopoverPanel, OnDestroy {\n  @HostBinding('attr.role') role = 'dialog';\n\n  // Settings for popover, view setters and getters for more detail\n  private _position: MtxPopoverPosition = ['below', 'after'];\n  private _triggerEvent: MtxPopoverTriggerEvent = 'hover';\n  private _scrollStrategy: MtxPopoverScrollStrategy = 'reposition';\n  private _enterDelay = 100;\n  private _leaveDelay = 100;\n  private _panelOffsetX = 0;\n  private _panelOffsetY = 0;\n  private _closeOnPanelClick = false;\n  private _closeOnBackdropClick = true;\n  private _disableAnimation = false;\n  private _focusTrapEnabled = false;\n  private _focusTrapAutoCaptureEnabled = false;\n  private _arrowOffsetX = 20;\n  private _arrowOffsetY = 20;\n  private _arrowWidth = 16;\n  private _arrowHeight = 16;\n\n  /** Config object to be passed into the popover's ngClass */\n  _classList: { [key: string]: boolean } = {};\n\n  /** Whether popover's `targetElement` is defined */\n  public containerPositioning = false;\n\n  /** Closing disabled on popover */\n  public closeDisabled = false;\n\n  /** Config object to be passed into the popover's arrow ngStyle */\n  public popoverPanelStyles!: Record<string, unknown>;\n\n  /** Config object to be passed into the popover's arrow ngStyle */\n  public popoverArrowStyles!: Record<string, unknown>;\n\n  /** Config object to be passed into the popover's content ngStyle */\n  public popoverContentStyles!: Record<string, unknown>;\n\n  /** Emits the current animation state whenever it changes. */\n  _onAnimationStateChange = new EventEmitter<AnimationEvent>();\n\n  /** Position of the popover. */\n  @Input()\n  get position() {\n    return this._position;\n  }\n  set position(value: MtxPopoverPosition) {\n    if (!['before', 'after', 'above', 'below'].includes(value[0])) {\n      throwMtxPopoverInvalidPositionStart();\n    }\n    if (!['before', 'after', 'above', 'below', 'center'].includes(value[1])) {\n      throwMtxPopoverInvalidPositionEnd();\n    }\n    this._position = value;\n    this.setPositionClasses();\n  }\n\n  /** Popover trigger event */\n  @Input()\n  get triggerEvent(): MtxPopoverTriggerEvent {\n    return this._triggerEvent;\n  }\n  set triggerEvent(value: MtxPopoverTriggerEvent) {\n    this._triggerEvent = value;\n  }\n\n  /** Popover scroll strategy */\n  @Input()\n  get scrollStrategy(): MtxPopoverScrollStrategy {\n    return this._scrollStrategy;\n  }\n  set scrollStrategy(value: MtxPopoverScrollStrategy) {\n    this._scrollStrategy = value;\n  }\n\n  /** Popover enter delay */\n  @Input()\n  get enterDelay(): number {\n    return this._enterDelay;\n  }\n  set enterDelay(value: number) {\n    this._enterDelay = value;\n  }\n\n  /** Popover leave delay */\n  @Input()\n  get leaveDelay(): number {\n    return this._leaveDelay;\n  }\n  set leaveDelay(value: number) {\n    this._leaveDelay = value;\n  }\n\n  /** Popover target offset x */\n  @Input()\n  get xOffset(): number {\n    return this._panelOffsetX;\n  }\n  set xOffset(value: number) {\n    this._panelOffsetX = value;\n  }\n\n  /** Popover target offset y */\n  @Input()\n  get yOffset(): number {\n    return this._panelOffsetY;\n  }\n  set yOffset(value: number) {\n    this._panelOffsetY = value;\n  }\n\n  /** Popover arrow offset x */\n  @Input()\n  get arrowOffsetX(): number {\n    return this._arrowOffsetX;\n  }\n  set arrowOffsetX(value: number) {\n    this._arrowOffsetX = value;\n  }\n\n  /** Popover arrow offset y */\n  @Input()\n  get arrowOffsetY(): number {\n    return this._arrowOffsetY;\n  }\n  set arrowOffsetY(value: number) {\n    this._arrowOffsetY = value;\n  }\n\n  /** Popover arrow width */\n  @Input()\n  get arrowWidth(): number {\n    return this._arrowWidth;\n  }\n  set arrowWidth(value: number) {\n    this._arrowWidth = value;\n  }\n\n  /** Popover arrow height */\n  @Input()\n  get arrowHeight(): number {\n    return this._arrowHeight;\n  }\n  set arrowHeight(value: number) {\n    this._arrowHeight = value;\n  }\n\n  /** Popover close on container click */\n  @Input()\n  get closeOnPanelClick(): boolean {\n    return this._closeOnPanelClick;\n  }\n  set closeOnPanelClick(value: boolean) {\n    this._closeOnPanelClick = coerceBooleanProperty(value);\n  }\n\n  /** Popover close on backdrop click */\n  @Input()\n  get closeOnBackdropClick(): boolean {\n    return this._closeOnBackdropClick;\n  }\n  set closeOnBackdropClick(value: boolean) {\n    this._closeOnBackdropClick = coerceBooleanProperty(value);\n  }\n\n  /** Disable animations of popover and all child elements */\n  @Input()\n  get disableAnimation(): boolean {\n    return this._disableAnimation;\n  }\n  set disableAnimation(value: boolean) {\n    this._disableAnimation = coerceBooleanProperty(value);\n  }\n\n  /** Popover focus trap using cdkTrapFocus */\n  @Input()\n  get focusTrapEnabled(): boolean {\n    return this._focusTrapEnabled;\n  }\n  set focusTrapEnabled(value: boolean) {\n    this._focusTrapEnabled = coerceBooleanProperty(value);\n  }\n\n  /** Popover focus trap auto capture using cdkTrapFocusAutoCapture */\n  @Input()\n  get focusTrapAutoCaptureEnabled(): boolean {\n    return this._focusTrapAutoCaptureEnabled;\n  }\n  set focusTrapAutoCaptureEnabled(value: boolean) {\n    this._focusTrapAutoCaptureEnabled = coerceBooleanProperty(value);\n  }\n\n  /**\n   * This method takes classes set on the host md-popover element and applies them on the\n   * popover template that displays in the overlay container.  Otherwise, it's difficult\n   * to style the containing popover from outside the component.\n   * @param classes list of class names\n   */\n  @Input('class')\n  set panelClass(classes: string) {\n    if (classes && classes.length) {\n      this._classList = classes.split(' ').reduce((obj: any, className: string) => {\n        obj[className] = true;\n        return obj;\n      }, {});\n\n      this._elementRef.nativeElement.className = '';\n      this.setPositionClasses();\n    }\n  }\n\n  /**\n   * This method takes classes set on the host md-popover element and applies them on the\n   * popover template that displays in the overlay container.  Otherwise, it's difficult\n   * to style the containing popover from outside the component.\n   * @deprecated Use `panelClass` instead.\n   * @breaking-change 8.0.0\n   */\n  @Input()\n  get classList(): string {\n    return this.panelClass;\n  }\n  set classList(classes: string) {\n    this.panelClass = classes;\n  }\n\n  /** Event emitted when the popover is closed. */\n  @Output() closed = new EventEmitter<void>();\n\n  @ViewChild(TemplateRef) templateRef!: TemplateRef<any>;\n\n  constructor(\n    @Optional() private _dir: Directionality,\n    private _elementRef: ElementRef,\n    public zone: NgZone\n  ) {\n    this.setPositionClasses();\n  }\n\n  ngOnDestroy() {\n    this._emitCloseEvent();\n    this.closed.complete();\n  }\n\n  /** Handle a keyboard event from the popover, delegating to the appropriate action. */\n  _handleKeydown(event: KeyboardEvent) {\n    switch (event.keyCode) {\n      case ESCAPE:\n        this._emitCloseEvent();\n        return;\n    }\n  }\n\n  /**\n   * This emits a close event to which the trigger is subscribed. When emitted, the\n   * trigger will close the popover.\n   */\n  _emitCloseEvent(): void {\n    this.closed.emit();\n  }\n\n  /** Close popover on click if closeOnPanelClick is true */\n  onClick() {\n    if (this.closeOnPanelClick) {\n      this._emitCloseEvent();\n    }\n  }\n\n  /** Disables close of popover when leaving trigger element and mouse over the popover */\n  onMouseOver() {\n    if (this.triggerEvent === 'hover') {\n      this.closeDisabled = true;\n    }\n  }\n\n  /** Enables close of popover when mouse leaving popover element */\n  onMouseLeave() {\n    if (this.triggerEvent === 'hover') {\n      setTimeout(() => {\n        this.closeDisabled = false;\n        this._emitCloseEvent();\n      }, this.leaveDelay);\n    }\n  }\n\n  /** Sets the current styles for the popover to allow for dynamically changing settings */\n  setCurrentStyles(pos = this.position) {\n    const left =\n      pos[1] === 'after'\n        ? `${this.arrowOffsetX - this.arrowWidth / 2}px`\n        : pos[1] === 'center'\n        ? `calc(50% - ${this.arrowWidth / 2}px)`\n        : '';\n    const right = pos[1] === 'before' ? `${this.arrowOffsetX - this.arrowWidth / 2}px` : '';\n\n    const bottom =\n      pos[1] === 'above'\n        ? `${this.arrowOffsetY - this.arrowHeight / 2}px`\n        : pos[1] === 'center'\n        ? `calc(50% - ${this.arrowHeight / 2}px)`\n        : '';\n    const top = pos[1] === 'below' ? `${this.arrowOffsetY - this.arrowHeight / 2}px` : '';\n\n    this.popoverArrowStyles =\n      pos[0] === 'above' || pos[0] === 'below'\n        ? {\n            left: this._dir.value === 'ltr' ? left : right,\n            right: this._dir.value === 'ltr' ? right : left,\n          }\n        : {\n            top,\n            bottom,\n          };\n  }\n\n  /**\n   * It's necessary to set position-based classes to ensure the popover panel animation\n   * folds out from the correct direction.\n   */\n  setPositionClasses(pos = this.position): void {\n    this._classList['mtx-popover-before-above'] = pos[0] === 'before' && pos[1] === 'above';\n    this._classList['mtx-popover-before-center'] = pos[0] === 'before' && pos[1] === 'center';\n    this._classList['mtx-popover-before-below'] = pos[0] === 'before' && pos[1] === 'below';\n    this._classList['mtx-popover-after-above'] = pos[0] === 'after' && pos[1] === 'above';\n    this._classList['mtx-popover-after-center'] = pos[0] === 'after' && pos[1] === 'center';\n    this._classList['mtx-popover-after-below'] = pos[0] === 'after' && pos[1] === 'below';\n    this._classList['mtx-popover-above-before'] = pos[0] === 'above' && pos[1] === 'before';\n    this._classList['mtx-popover-above-center'] = pos[0] === 'above' && pos[1] === 'center';\n    this._classList['mtx-popover-above-after'] = pos[0] === 'above' && pos[1] === 'after';\n    this._classList['mtx-popover-below-before'] = pos[0] === 'below' && pos[1] === 'before';\n    this._classList['mtx-popover-below-center'] = pos[0] === 'below' && pos[1] === 'center';\n    this._classList['mtx-popover-below-after'] = pos[0] === 'below' && pos[1] === 'after';\n  }\n\n  static ngAcceptInputType_closeOnPanelClick: BooleanInput;\n  static ngAcceptInputType_closeOnBackdropClick: BooleanInput;\n  static ngAcceptInputType_disableAnimation: BooleanInput;\n  static ngAcceptInputType_focusTrapEnabled: BooleanInput;\n  static ngAcceptInputType_focusTrapAutoCaptureEnabled: BooleanInput;\n}\n","<ng-template>\r\n  <div class=\"mtx-popover-panel mat-elevation-z8\" role=\"dialog\"\r\n       [ngClass]=\"_classList\"\r\n       [ngStyle]=\"popoverPanelStyles\"\r\n       (keydown)=\"_handleKeydown($event)\"\r\n       (click)=\"onClick()\"\r\n       (mouseover)=\"onMouseOver()\"\r\n       (mouseleave)=\"onMouseLeave()\"\r\n       [@.disabled]=\"disableAnimation\"\r\n       [@transformPopover]=\"'enter'\">\r\n    <div class=\"mtx-popover-direction-arrow\" [ngStyle]=\"popoverArrowStyles\"></div>\r\n    <div class=\"mtx-popover-content\"\r\n         [ngStyle]=\"popoverContentStyles\"\r\n         [cdkTrapFocus]=\"focusTrapEnabled\"\r\n         [cdkTrapFocusAutoCapture]=\"focusTrapAutoCaptureEnabled\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n  </div>\r\n</ng-template>\r\n"]}
|
|
383
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.js","sourceRoot":"","sources":["../../../../projects/extensions/popover/popover.ts","../../../../projects/extensions/popover/popover.html"],"names":[],"mappings":"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","sourcesContent":["import { AnimationEvent } from '@angular/animations';\nimport { Direction } from '@angular/cdk/bidi';\nimport { BooleanInput, coerceBooleanProperty } from '@angular/cdk/coercion';\nimport { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  Inject,\n  InjectionToken,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Output,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { Subject } from 'rxjs';\nimport { transformPopover } from './popover-animations';\nimport { MtxPopoverContent, MTX_POPOVER_CONTENT } from './popover-content';\nimport {\n  throwMtxPopoverInvalidPositionEnd,\n  throwMtxPopoverInvalidPositionStart,\n} from './popover-errors';\nimport { MtxPopoverDefaultOptions, MtxPopoverPanel } from './popover-interfaces';\nimport { MtxPopoverPosition, MtxPopoverTriggerEvent, PopoverCloseReason } from './popover-types';\n\n/** Injection token to be used to override the default options for `mtx-popover`. */\nexport const MTX_POPOVER_DEFAULT_OPTIONS = new InjectionToken<MtxPopoverDefaultOptions>(\n  'mtx-popover-default-options',\n  {\n    providedIn: 'root',\n    factory: MTX_POPOVER_DEFAULT_OPTIONS_FACTORY,\n  }\n);\n\n/** @docs-private */\nexport function MTX_POPOVER_DEFAULT_OPTIONS_FACTORY(): MtxPopoverDefaultOptions {\n  return {\n    backdropClass: 'cdk-overlay-transparent-backdrop',\n  };\n}\n\nlet popoverPanelUid = 0;\n\n@Component({\n  selector: 'mtx-popover',\n  templateUrl: './popover.html',\n  styleUrls: ['./popover.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  animations: [transformPopover],\n  exportAs: 'mtxPopover',\n})\nexport class MtxPopover implements MtxPopoverPanel, OnInit, OnDestroy {\n  private _triggerEvent = this._defaultOptions.triggerEvent ?? 'hover';\n  private _enterDelay = this._defaultOptions.enterDelay ?? 100;\n  private _leaveDelay = this._defaultOptions.leaveDelay ?? 100;\n  private _position = this._defaultOptions.position ?? ['below', 'after'];\n  private _panelOffsetX = this._defaultOptions.xOffset ?? 0;\n  private _panelOffsetY = this._defaultOptions.yOffset ?? 0;\n  private _arrowWidth = this._defaultOptions.arrowWidth ?? 16;\n  private _arrowHeight = this._defaultOptions.arrowHeight ?? 16;\n  private _arrowOffsetX = this._defaultOptions.arrowOffsetX ?? 20;\n  private _arrowOffsetY = this._defaultOptions.arrowOffsetY ?? 20;\n  private _closeOnPanelClick = this._defaultOptions.closeOnPanelClick ?? false;\n  private _closeOnBackdropClick = this._defaultOptions.closeOnBackdropClick ?? true;\n  private _focusTrapEnabled = this._defaultOptions.focusTrapEnabled ?? false;\n  private _focusTrapAutoCaptureEnabled = this._defaultOptions.focusTrapAutoCaptureEnabled ?? false;\n  private _hasBackdrop = this._defaultOptions.hasBackdrop;\n  private _elevation = this._defaultOptions.elevation ?? 8;\n\n  private _previousElevation?: string;\n  private _elevationPrefix = 'mat-elevation-z';\n\n  /** Config object to be passed into the popover's ngClass. */\n  _classList: { [key: string]: boolean } = {};\n\n  /** Current state of the panel animation. */\n  _panelAnimationState: 'void' | 'enter' = 'void';\n\n  /** Emits whenever an animation on the popover completes. */\n  readonly _animationDone = new Subject<AnimationEvent>();\n\n  /** Whether the popover is animating. */\n  _isAnimating = false;\n\n  /** Closing disabled on popover */\n  closeDisabled = false;\n\n  /** Config object to be passed into the popover's arrow ngStyle */\n  arrowStyles?: Record<string, unknown>;\n\n  /** Layout direction of the popover. */\n  direction?: Direction;\n\n  /** Class or list of classes to be added to the overlay panel. */\n  overlayPanelClass: string | string[] = this._defaultOptions.overlayPanelClass || '';\n\n  /** Class to be added to the backdrop element. */\n  @Input() backdropClass = this._defaultOptions.backdropClass;\n\n  /** aria-label for the popover panel. */\n  @Input('aria-label') ariaLabel?: string;\n\n  /** aria-labelledby for the popover panel. */\n  @Input('aria-labelledby') ariaLabelledby?: string;\n\n  /** aria-describedby for the popover panel. */\n  @Input('aria-describedby') ariaDescribedby?: string;\n\n  /** Popover's trigger event. */\n  @Input()\n  get triggerEvent(): MtxPopoverTriggerEvent {\n    return this._triggerEvent;\n  }\n  set triggerEvent(value: MtxPopoverTriggerEvent) {\n    this._triggerEvent = value;\n  }\n\n  /** Popover's enter delay. */\n  @Input()\n  get enterDelay(): number {\n    return this._enterDelay;\n  }\n  set enterDelay(value: number) {\n    this._enterDelay = value;\n  }\n\n  /** Popover's leave delay. */\n  @Input()\n  get leaveDelay(): number {\n    return this._leaveDelay;\n  }\n  set leaveDelay(value: number) {\n    this._leaveDelay = value;\n  }\n\n  /** Popover's position. */\n  @Input()\n  get position() {\n    return this._position;\n  }\n  set position(value: MtxPopoverPosition) {\n    if (!['before', 'after', 'above', 'below'].includes(value[0])) {\n      throwMtxPopoverInvalidPositionStart();\n    }\n    if (!['before', 'after', 'above', 'below', 'center'].includes(value[1])) {\n      throwMtxPopoverInvalidPositionEnd();\n    }\n    this._position = value;\n    this.setPositionClasses();\n  }\n\n  /** Popover-panel's X offset. */\n  @Input()\n  get xOffset(): number {\n    return this._panelOffsetX;\n  }\n  set xOffset(value: number) {\n    this._panelOffsetX = value;\n  }\n\n  /** Popover-panel's Y offset. */\n  @Input()\n  get yOffset(): number {\n    return this._panelOffsetY;\n  }\n  set yOffset(value: number) {\n    this._panelOffsetY = value;\n  }\n\n  /** Popover-arrow's width. */\n  @Input()\n  get arrowWidth(): number {\n    return this._arrowWidth;\n  }\n  set arrowWidth(value: number) {\n    this._arrowWidth = value;\n  }\n\n  /** Popover-arrow's height. */\n  @Input()\n  get arrowHeight(): number {\n    return this._arrowHeight;\n  }\n  set arrowHeight(value: number) {\n    this._arrowHeight = value;\n  }\n\n  /** Popover-arrow's X offset. */\n  @Input()\n  get arrowOffsetX(): number {\n    return this._arrowOffsetX;\n  }\n  set arrowOffsetX(value: number) {\n    this._arrowOffsetX = value;\n  }\n\n  /** Popover-arrow's Y offset. */\n  @Input()\n  get arrowOffsetY(): number {\n    return this._arrowOffsetY;\n  }\n  set arrowOffsetY(value: number) {\n    this._arrowOffsetY = value;\n  }\n\n  /** Whether popover can be closed when click the popover-panel. */\n  @Input()\n  get closeOnPanelClick(): boolean {\n    return this._closeOnPanelClick;\n  }\n  set closeOnPanelClick(value: boolean) {\n    this._closeOnPanelClick = coerceBooleanProperty(value);\n  }\n\n  /** Whether popover can be closed when click the backdrop. */\n  @Input()\n  get closeOnBackdropClick(): boolean {\n    return this._closeOnBackdropClick;\n  }\n  set closeOnBackdropClick(value: boolean) {\n    this._closeOnBackdropClick = coerceBooleanProperty(value);\n  }\n\n  /** Whether enable focus trap using `cdkTrapFocus`. */\n  @Input()\n  get focusTrapEnabled(): boolean {\n    return this._focusTrapEnabled;\n  }\n  set focusTrapEnabled(value: boolean) {\n    this._focusTrapEnabled = coerceBooleanProperty(value);\n  }\n\n  /** Whether enable focus trap auto capture using `cdkTrapFocusAutoCapture`. */\n  @Input()\n  get focusTrapAutoCaptureEnabled(): boolean {\n    return this._focusTrapAutoCaptureEnabled;\n  }\n  set focusTrapAutoCaptureEnabled(value: boolean) {\n    this._focusTrapAutoCaptureEnabled = coerceBooleanProperty(value);\n  }\n\n  /** Whether the popover has a backdrop. It will always be false if the trigger event is hover. */\n  @Input()\n  get hasBackdrop(): boolean | undefined {\n    return this._hasBackdrop;\n  }\n  set hasBackdrop(value: boolean | undefined) {\n    this._hasBackdrop = coerceBooleanProperty(value);\n  }\n\n  /** Popover-panel's elevation (0~24). */\n  @Input()\n  get elevation(): number {\n    return Math.max(0, Math.min(Math.round(this._elevation), 24));\n  }\n  set elevation(value: number) {\n    this._elevation = value;\n  }\n\n  /**\n   * This method takes classes set on the host md-popover element and applies them on the\n   * popover template that displays in the overlay container. Otherwise, it's difficult\n   * to style the containing popover from outside the component.\n   * @param classes list of class names\n   */\n  @Input('class')\n  set panelClass(classes: string) {\n    if (classes && classes.length) {\n      this._classList = classes.split(' ').reduce((obj: any, className: string) => {\n        obj[className] = true;\n        return obj;\n      }, {});\n\n      this._elementRef.nativeElement.className = '';\n      this.setPositionClasses();\n    }\n  }\n\n  /**\n   * This method takes classes set on the host md-popover element and applies them on the\n   * popover template that displays in the overlay container. Otherwise, it's difficult\n   * to style the containing popover from outside the component.\n   * @deprecated Use `panelClass` instead.\n   * @breaking-change 8.0.0\n   */\n  @Input()\n  get classList(): string {\n    return this.panelClass;\n  }\n  set classList(classes: string) {\n    this.panelClass = classes;\n  }\n\n  /** Event emitted when the popover is closed. */\n  @Output() closed = new EventEmitter<PopoverCloseReason>();\n\n  /** @docs-private */\n  @ViewChild(TemplateRef) templateRef!: TemplateRef<any>;\n\n  /**\n   * Popover content that will be rendered lazily.\n   * @docs-private\n   */\n  @ContentChild(MTX_POPOVER_CONTENT) lazyContent?: MtxPopoverContent;\n\n  readonly panelId = `mtx-popover-panel-${popoverPanelUid++}`;\n\n  constructor(\n    private _elementRef: ElementRef,\n    private _ngZone: NgZone,\n    @Inject(MTX_POPOVER_DEFAULT_OPTIONS) private _defaultOptions: MtxPopoverDefaultOptions\n  ) {}\n\n  ngOnInit() {\n    this.setPositionClasses();\n  }\n\n  ngOnDestroy() {\n    this.closed.complete();\n  }\n\n  /** Handle a keyboard event from the popover, delegating to the appropriate action. */\n  _handleKeydown(event: KeyboardEvent) {\n    const keyCode = event.keyCode;\n\n    switch (keyCode) {\n      case ESCAPE:\n        if (!hasModifierKey(event)) {\n          event.preventDefault();\n          this.closed.emit('keydown');\n        }\n        break;\n    }\n  }\n\n  /** Close popover on click if `closeOnPanelClick` is true. */\n  _handleClick() {\n    if (this.closeOnPanelClick) {\n      this.closed.emit('click');\n    }\n  }\n\n  /** Disables close of popover when leaving trigger element and mouse over the popover. */\n  _handleMouseOver() {\n    if (this.triggerEvent === 'hover') {\n      this.closeDisabled = true;\n    }\n  }\n\n  /** Enables close of popover when mouse leaving popover element. */\n  _handleMouseLeave() {\n    if (this.triggerEvent === 'hover') {\n      setTimeout(() => {\n        this.closeDisabled = false;\n        this.closed.emit();\n      }, this.leaveDelay);\n    }\n  }\n\n  /** Sets the current styles for the popover to allow for dynamically changing settings. */\n  setCurrentStyles(pos = this.position) {\n    const left =\n      pos[1] === 'after'\n        ? `${this.arrowOffsetX - this.arrowWidth / 2}px`\n        : pos[1] === 'center'\n        ? `calc(50% - ${this.arrowWidth / 2}px)`\n        : '';\n    const right = pos[1] === 'before' ? `${this.arrowOffsetX - this.arrowWidth / 2}px` : '';\n\n    const bottom =\n      pos[1] === 'above'\n        ? `${this.arrowOffsetY - this.arrowHeight / 2}px`\n        : pos[1] === 'center'\n        ? `calc(50% - ${this.arrowHeight / 2}px)`\n        : '';\n    const top = pos[1] === 'below' ? `${this.arrowOffsetY - this.arrowHeight / 2}px` : '';\n\n    this.arrowStyles =\n      pos[0] === 'above' || pos[0] === 'below'\n        ? {\n            left: this.direction === 'ltr' ? left : right,\n            right: this.direction === 'ltr' ? right : left,\n          }\n        : { top, bottom };\n  }\n\n  /**\n   * It's necessary to set position-based classes to ensure the popover panel animation\n   * folds out from the correct direction.\n   */\n  setPositionClasses(pos = this.position): void {\n    this._classList['mtx-popover-before-above'] = pos[0] === 'before' && pos[1] === 'above';\n    this._classList['mtx-popover-before-center'] = pos[0] === 'before' && pos[1] === 'center';\n    this._classList['mtx-popover-before-below'] = pos[0] === 'before' && pos[1] === 'below';\n    this._classList['mtx-popover-after-above'] = pos[0] === 'after' && pos[1] === 'above';\n    this._classList['mtx-popover-after-center'] = pos[0] === 'after' && pos[1] === 'center';\n    this._classList['mtx-popover-after-below'] = pos[0] === 'after' && pos[1] === 'below';\n    this._classList['mtx-popover-above-before'] = pos[0] === 'above' && pos[1] === 'before';\n    this._classList['mtx-popover-above-center'] = pos[0] === 'above' && pos[1] === 'center';\n    this._classList['mtx-popover-above-after'] = pos[0] === 'above' && pos[1] === 'after';\n    this._classList['mtx-popover-below-before'] = pos[0] === 'below' && pos[1] === 'before';\n    this._classList['mtx-popover-below-center'] = pos[0] === 'below' && pos[1] === 'center';\n    this._classList['mtx-popover-below-after'] = pos[0] === 'below' && pos[1] === 'after';\n  }\n\n  /** Sets the popover-panel's elevation. */\n  setElevation(): void {\n    const newElevation = `${this._elevationPrefix}${this.elevation}`;\n\n    if (this._previousElevation) {\n      this._classList[this._previousElevation] = false;\n    }\n\n    this._classList[newElevation] = true;\n    this._previousElevation = newElevation;\n  }\n\n  /** Starts the enter animation. */\n  _startAnimation() {\n    // @breaking-change 8.0.0 Combine with _resetAnimation.\n    this._panelAnimationState = 'enter';\n  }\n\n  /** Resets the panel animation to its initial state. */\n  _resetAnimation() {\n    // @breaking-change 8.0.0 Combine with _startAnimation.\n    this._panelAnimationState = 'void';\n  }\n\n  /** Callback that is invoked when the panel animation completes. */\n  _onAnimationDone(event: AnimationEvent) {\n    this._animationDone.next(event);\n    this._isAnimating = false;\n  }\n\n  _onAnimationStart(event: AnimationEvent) {\n    this._isAnimating = true;\n  }\n\n  static ngAcceptInputType_closeOnPanelClick: BooleanInput;\n  static ngAcceptInputType_closeOnBackdropClick: BooleanInput;\n  static ngAcceptInputType_focusTrapEnabled: BooleanInput;\n  static ngAcceptInputType_focusTrapAutoCaptureEnabled: BooleanInput;\n  static ngAcceptInputType_hasBackdrop: BooleanInput;\n}\n","<ng-template>\r\n  <div class=\"mtx-popover-panel\"\r\n       [id]=\"panelId\"\r\n       [ngClass]=\"_classList\"\r\n       (keydown)=\"_handleKeydown($event)\"\r\n       (click)=\"_handleClick()\"\r\n       (mouseover)=\"_handleMouseOver()\"\r\n       (mouseleave)=\"_handleMouseLeave()\"\r\n       [@transformPopover]=\"_panelAnimationState\"\r\n       (@transformPopover.start)=\"_onAnimationStart($event)\"\r\n       (@transformPopover.done)=\"_onAnimationDone($event)\"\r\n       tabindex=\"-1\"\r\n       role=\"dialog\"\r\n       [attr.aria-label]=\"ariaLabel || null\"\r\n       [attr.aria-labelledby]=\"ariaLabelledby || null\"\r\n       [attr.aria-describedby]=\"ariaDescribedby || null\"\r\n       [cdkTrapFocus]=\"focusTrapEnabled\"\r\n       [cdkTrapFocusAutoCapture]=\"focusTrapAutoCaptureEnabled\">\r\n    <div class=\"mtx-popover-content\">\r\n      <ng-content></ng-content>\r\n    </div>\r\n    <div class=\"mtx-popover-direction-arrow\" [ngStyle]=\"arrowStyles\"></div>\r\n  </div>\r\n</ng-template>\r\n"]}
|