@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.
Files changed (53) hide show
  1. package/bundles/mtxCore.umd.js.map +1 -1
  2. package/bundles/mtxDatetimepicker.umd.js +5 -0
  3. package/bundles/mtxDatetimepicker.umd.js.map +1 -1
  4. package/bundles/mtxGrid.umd.js +24 -21
  5. package/bundles/mtxGrid.umd.js.map +1 -1
  6. package/bundles/mtxPopover.umd.js +997 -803
  7. package/bundles/mtxPopover.umd.js.map +1 -1
  8. package/bundles/mtxSelect.umd.js +237 -156
  9. package/bundles/mtxSelect.umd.js.map +1 -1
  10. package/core/datetime/datetime-formats.d.ts +2 -0
  11. package/esm2015/core/datetime/datetime-formats.js +1 -1
  12. package/esm2015/datetimepicker/datetimepicker-input.js +6 -1
  13. package/esm2015/grid/cell.component.js +7 -4
  14. package/esm2015/grid/column-menu.component.js +10 -14
  15. package/esm2015/grid/grid.component.js +10 -6
  16. package/esm2015/popover/popover-animations.js +10 -13
  17. package/esm2015/popover/popover-content.js +99 -0
  18. package/esm2015/popover/popover-interfaces.js +1 -1
  19. package/esm2015/popover/popover-module.js +7 -5
  20. package/esm2015/popover/popover-target.js +3 -3
  21. package/esm2015/popover/popover-trigger.js +210 -172
  22. package/esm2015/popover/popover-types.js +1 -1
  23. package/esm2015/popover/popover.js +173 -125
  24. package/esm2015/popover/public-api.js +2 -1
  25. package/esm2015/select/option.component.js +4 -6
  26. package/esm2015/select/select.component.js +111 -31
  27. package/fesm2015/mtxCore.js.map +1 -1
  28. package/fesm2015/mtxDatetimepicker.js +5 -0
  29. package/fesm2015/mtxDatetimepicker.js.map +1 -1
  30. package/fesm2015/mtxGrid.js +24 -21
  31. package/fesm2015/mtxGrid.js.map +1 -1
  32. package/fesm2015/mtxPopover.js +526 -351
  33. package/fesm2015/mtxPopover.js.map +1 -1
  34. package/fesm2015/mtxSelect.js +169 -92
  35. package/fesm2015/mtxSelect.js.map +1 -1
  36. package/grid/cell.component.d.ts +4 -2
  37. package/grid/column-menu.component.d.ts +3 -5
  38. package/grid/grid.component.d.ts +6 -4
  39. package/grid/mtxGrid.metadata.json +1 -1
  40. package/package.json +1 -1
  41. package/popover/mtxPopover.metadata.json +1 -1
  42. package/popover/popover-animations.d.ts +1 -1
  43. package/popover/popover-content.d.ts +38 -0
  44. package/popover/popover-interfaces.d.ts +37 -31
  45. package/popover/popover-target.d.ts +2 -2
  46. package/popover/popover-trigger.d.ts +65 -60
  47. package/popover/popover-types.d.ts +6 -1
  48. package/popover/popover.d.ts +97 -69
  49. package/popover/popover.scss +2 -0
  50. package/popover/public-api.d.ts +1 -0
  51. package/select/mtxSelect.metadata.json +1 -1
  52. package/select/option.component.d.ts +7 -6
  53. package/select/select.component.d.ts +59 -20
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci10eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2V4dGVuc2lvbnMvcG9wb3Zlci9wb3BvdmVyLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBNdHhQb3BvdmVyUG9zaXRpb25TdGFydCA9ICdhYm92ZScgfCAnYmVsb3cnIHwgJ2JlZm9yZScgfCAnYWZ0ZXInO1xuXG5leHBvcnQgdHlwZSBNdHhQb3BvdmVyUG9zaXRpb25FbmQgPSBNdHhQb3BvdmVyUG9zaXRpb25TdGFydCB8ICdjZW50ZXInO1xuXG5leHBvcnQgdHlwZSBNdHhQb3BvdmVyUG9zaXRpb24gPSBbTXR4UG9wb3ZlclBvc2l0aW9uU3RhcnQsIE10eFBvcG92ZXJQb3NpdGlvbkVuZF07XG5cbmV4cG9ydCB0eXBlIE10eFBvcG92ZXJUcmlnZ2VyRXZlbnQgPSAnY2xpY2snIHwgJ2hvdmVyJyB8ICdub25lJztcblxuZXhwb3J0IHR5cGUgTXR4UG9wb3ZlclNjcm9sbFN0cmF0ZWd5ID0gJ25vb3AnIHwgJ2Nsb3NlJyB8ICdibG9jaycgfCAncmVwb3NpdGlvbic7XG4iXX0=
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci10eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2V4dGVuc2lvbnMvcG9wb3Zlci9wb3BvdmVyLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyIvKiogRmlyc3QgdmFsdWUgb2YgcG9wb3ZlcidzIHBvc2l0aW9uLiAqL1xuZXhwb3J0IHR5cGUgTXR4UG9wb3ZlclBvc2l0aW9uU3RhcnQgPSAnYWJvdmUnIHwgJ2JlbG93JyB8ICdiZWZvcmUnIHwgJ2FmdGVyJztcblxuLyoqIFNlY29uZCB2YWx1ZSBvZiBwb3BvdmVyJ3MgcG9zaXRpb24uICovXG5leHBvcnQgdHlwZSBNdHhQb3BvdmVyUG9zaXRpb25FbmQgPSBNdHhQb3BvdmVyUG9zaXRpb25TdGFydCB8ICdjZW50ZXInO1xuXG4vKiogUG9wb3ZlcidzIHBvc2l0aW9uLiAqL1xuZXhwb3J0IHR5cGUgTXR4UG9wb3ZlclBvc2l0aW9uID0gW010eFBvcG92ZXJQb3NpdGlvblN0YXJ0LCBNdHhQb3BvdmVyUG9zaXRpb25FbmRdO1xuXG4vKiogUG9wb3ZlcidzIHRyaWdnZXIgZXZlbnQuICovXG5leHBvcnQgdHlwZSBNdHhQb3BvdmVyVHJpZ2dlckV2ZW50ID0gJ2NsaWNrJyB8ICdob3ZlcicgfCAnbm9uZSc7XG5cbi8qKiBSZWFzb24gd2h5IHRoZSBwb3BvdmVyIHdhcyBjbG9zZWQuICovXG5leHBvcnQgdHlwZSBQb3BvdmVyQ2xvc2VSZWFzb24gPSB2b2lkIHwgJ2NsaWNrJyB8ICdrZXlkb3duJyB8ICd0YWInO1xuIl19
@@ -1,166 +1,187 @@
1
- import { Component, EventEmitter, Input, Output, TemplateRef, ViewChild, ViewEncapsulation, ElementRef, ChangeDetectionStrategy, HostBinding, NgZone, Optional, } from '@angular/core';
2
1
  import { coerceBooleanProperty } from '@angular/cdk/coercion';
3
- import { ESCAPE } from '@angular/cdk/keycodes';
4
- import { Directionality } from '@angular/cdk/bidi';
5
- import { throwMtxPopoverInvalidPositionStart, throwMtxPopoverInvalidPositionEnd, } from './popover-errors';
2
+ import { ESCAPE, hasModifierKey } from '@angular/cdk/keycodes';
3
+ import { ChangeDetectionStrategy, Component, ContentChild, ElementRef, EventEmitter, Inject, InjectionToken, Input, NgZone, Output, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core';
4
+ import { Subject } from 'rxjs';
6
5
  import { transformPopover } from './popover-animations';
6
+ import { MtxPopoverContent, MTX_POPOVER_CONTENT } from './popover-content';
7
+ import { throwMtxPopoverInvalidPositionEnd, throwMtxPopoverInvalidPositionStart, } from './popover-errors';
8
+ /** Injection token to be used to override the default options for `mtx-popover`. */
9
+ export const MTX_POPOVER_DEFAULT_OPTIONS = new InjectionToken('mtx-popover-default-options', {
10
+ providedIn: 'root',
11
+ factory: MTX_POPOVER_DEFAULT_OPTIONS_FACTORY,
12
+ });
13
+ /** @docs-private */
14
+ export function MTX_POPOVER_DEFAULT_OPTIONS_FACTORY() {
15
+ return {
16
+ backdropClass: 'cdk-overlay-transparent-backdrop',
17
+ };
18
+ }
19
+ let popoverPanelUid = 0;
7
20
  export class MtxPopover {
8
- constructor(_dir, _elementRef, zone) {
9
- this._dir = _dir;
21
+ constructor(_elementRef, _ngZone, _defaultOptions) {
22
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
10
23
  this._elementRef = _elementRef;
11
- this.zone = zone;
12
- this.role = 'dialog';
13
- /** Settings for popover, view setters and getters for more detail */
14
- this._position = ['below', 'after'];
15
- this._triggerEvent = 'hover';
16
- this._scrollStrategy = 'reposition';
17
- this._enterDelay = 100;
18
- this._leaveDelay = 100;
19
- this._panelOffsetX = 0;
20
- this._panelOffsetY = 0;
21
- this._closeOnPanelClick = false;
22
- this._closeOnBackdropClick = true;
23
- this._disableAnimation = false;
24
- this._focusTrapEnabled = true;
25
- this._focusTrapAutoCaptureEnabled = true;
26
- this._arrowOffsetX = 20;
27
- this._arrowOffsetY = 20;
28
- this._arrowWidth = 16;
29
- this._arrowHeight = 16;
30
- /** Config object to be passed into the popover's ngClass */
24
+ this._ngZone = _ngZone;
25
+ this._defaultOptions = _defaultOptions;
26
+ this._triggerEvent = (_a = this._defaultOptions.triggerEvent) !== null && _a !== void 0 ? _a : 'hover';
27
+ this._enterDelay = (_b = this._defaultOptions.enterDelay) !== null && _b !== void 0 ? _b : 100;
28
+ this._leaveDelay = (_c = this._defaultOptions.leaveDelay) !== null && _c !== void 0 ? _c : 100;
29
+ this._position = (_d = this._defaultOptions.position) !== null && _d !== void 0 ? _d : ['below', 'after'];
30
+ this._panelOffsetX = (_e = this._defaultOptions.xOffset) !== null && _e !== void 0 ? _e : 0;
31
+ this._panelOffsetY = (_f = this._defaultOptions.yOffset) !== null && _f !== void 0 ? _f : 0;
32
+ this._arrowWidth = (_g = this._defaultOptions.arrowWidth) !== null && _g !== void 0 ? _g : 16;
33
+ this._arrowHeight = (_h = this._defaultOptions.arrowHeight) !== null && _h !== void 0 ? _h : 16;
34
+ this._arrowOffsetX = (_j = this._defaultOptions.arrowOffsetX) !== null && _j !== void 0 ? _j : 20;
35
+ this._arrowOffsetY = (_k = this._defaultOptions.arrowOffsetY) !== null && _k !== void 0 ? _k : 20;
36
+ this._closeOnPanelClick = (_l = this._defaultOptions.closeOnPanelClick) !== null && _l !== void 0 ? _l : false;
37
+ this._closeOnBackdropClick = (_m = this._defaultOptions.closeOnBackdropClick) !== null && _m !== void 0 ? _m : true;
38
+ this._focusTrapEnabled = (_o = this._defaultOptions.focusTrapEnabled) !== null && _o !== void 0 ? _o : false;
39
+ this._focusTrapAutoCaptureEnabled = (_p = this._defaultOptions.focusTrapAutoCaptureEnabled) !== null && _p !== void 0 ? _p : false;
40
+ this._hasBackdrop = this._defaultOptions.hasBackdrop;
41
+ this._elevation = (_q = this._defaultOptions.elevation) !== null && _q !== void 0 ? _q : 8;
42
+ this._elevationPrefix = 'mat-elevation-z';
43
+ /** Config object to be passed into the popover's ngClass. */
31
44
  this._classList = {};
32
- /** Whether popover's `targetElement` is defined */
33
- this.containerPositioning = false;
45
+ /** Current state of the panel animation. */
46
+ this._panelAnimationState = 'void';
47
+ /** Emits whenever an animation on the popover completes. */
48
+ this._animationDone = new Subject();
49
+ /** Whether the popover is animating. */
50
+ this._isAnimating = false;
34
51
  /** Closing disabled on popover */
35
52
  this.closeDisabled = false;
36
- /** Emits the current animation state whenever it changes. */
37
- this._onAnimationStateChange = new EventEmitter();
53
+ /** Config object to be passed into the popover's arrow ngStyle */
54
+ this.arrowStyles = null;
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;
38
59
  /** Event emitted when the popover is closed. */
39
60
  this.closed = new EventEmitter();
40
- this.setPositionClasses();
41
- }
42
- /** Position of the popover. */
43
- get position() {
44
- return this._position;
45
- }
46
- set position(value) {
47
- if (!['before', 'after', 'above', 'below'].includes(value[0])) {
48
- throwMtxPopoverInvalidPositionStart();
49
- }
50
- if (!['before', 'after', 'above', 'below', 'center'].includes(value[1])) {
51
- throwMtxPopoverInvalidPositionEnd();
52
- }
53
- this._position = value;
54
- this.setPositionClasses();
61
+ this.panelId = `mtx-popover-panel-${popoverPanelUid++}`;
55
62
  }
56
- /** Popover trigger event */
63
+ /** Popover's trigger event. */
57
64
  get triggerEvent() {
58
65
  return this._triggerEvent;
59
66
  }
60
67
  set triggerEvent(value) {
61
68
  this._triggerEvent = value;
62
69
  }
63
- /** Popover scroll strategy */
64
- get scrollStrategy() {
65
- return this._scrollStrategy;
66
- }
67
- set scrollStrategy(value) {
68
- this._scrollStrategy = value;
69
- }
70
- /** Popover enter delay */
70
+ /** Popover's enter delay. */
71
71
  get enterDelay() {
72
72
  return this._enterDelay;
73
73
  }
74
74
  set enterDelay(value) {
75
75
  this._enterDelay = value;
76
76
  }
77
- /** Popover leave delay */
77
+ /** Popover's leave delay. */
78
78
  get leaveDelay() {
79
79
  return this._leaveDelay;
80
80
  }
81
81
  set leaveDelay(value) {
82
82
  this._leaveDelay = value;
83
83
  }
84
- /** Popover target offset x */
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. */
85
99
  get xOffset() {
86
100
  return this._panelOffsetX;
87
101
  }
88
102
  set xOffset(value) {
89
103
  this._panelOffsetX = value;
90
104
  }
91
- /** Popover target offset y */
105
+ /** Popover-panel's Y offset. */
92
106
  get yOffset() {
93
107
  return this._panelOffsetY;
94
108
  }
95
109
  set yOffset(value) {
96
110
  this._panelOffsetY = value;
97
111
  }
98
- /** Popover arrow offset x */
99
- get arrowOffsetX() {
100
- return this._arrowOffsetX;
101
- }
102
- set arrowOffsetX(value) {
103
- this._arrowOffsetX = value;
104
- }
105
- /** Popover arrow offset y */
106
- get arrowOffsetY() {
107
- return this._arrowOffsetY;
108
- }
109
- set arrowOffsetY(value) {
110
- this._arrowOffsetY = value;
111
- }
112
- /** Popover arrow width */
112
+ /** Popover-arrow's width. */
113
113
  get arrowWidth() {
114
114
  return this._arrowWidth;
115
115
  }
116
116
  set arrowWidth(value) {
117
117
  this._arrowWidth = value;
118
118
  }
119
- /** Popover arrow height */
119
+ /** Popover-arrow's height. */
120
120
  get arrowHeight() {
121
121
  return this._arrowHeight;
122
122
  }
123
123
  set arrowHeight(value) {
124
124
  this._arrowHeight = value;
125
125
  }
126
- /** Popover close on container click */
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. */
127
141
  get closeOnPanelClick() {
128
142
  return this._closeOnPanelClick;
129
143
  }
130
144
  set closeOnPanelClick(value) {
131
145
  this._closeOnPanelClick = coerceBooleanProperty(value);
132
146
  }
133
- /** Popover close on backdrop click */
147
+ /** Whether popover can be closed when click the backdrop. */
134
148
  get closeOnBackdropClick() {
135
149
  return this._closeOnBackdropClick;
136
150
  }
137
151
  set closeOnBackdropClick(value) {
138
152
  this._closeOnBackdropClick = coerceBooleanProperty(value);
139
153
  }
140
- /** Disable animations of popover and all child elements */
141
- get disableAnimation() {
142
- return this._disableAnimation;
143
- }
144
- set disableAnimation(value) {
145
- this._disableAnimation = coerceBooleanProperty(value);
146
- }
147
- /** Popover focus trap using cdkTrapFocus */
154
+ /** Whether enable focus trap using `cdkTrapFocus`. */
148
155
  get focusTrapEnabled() {
149
156
  return this._focusTrapEnabled;
150
157
  }
151
158
  set focusTrapEnabled(value) {
152
159
  this._focusTrapEnabled = coerceBooleanProperty(value);
153
160
  }
154
- /** Popover focus trap auto capture using cdkTrapFocusAutoCapture */
161
+ /** Whether enable focus trap auto capture using `cdkTrapFocusAutoCapture`. */
155
162
  get focusTrapAutoCaptureEnabled() {
156
163
  return this._focusTrapAutoCaptureEnabled;
157
164
  }
158
165
  set focusTrapAutoCaptureEnabled(value) {
159
166
  this._focusTrapAutoCaptureEnabled = coerceBooleanProperty(value);
160
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
+ }
161
182
  /**
162
183
  * This method takes classes set on the host md-popover element and applies them on the
163
- * popover template that displays in the overlay container. Otherwise, it's difficult
184
+ * popover template that displays in the overlay container. Otherwise, it's difficult
164
185
  * to style the containing popover from outside the component.
165
186
  * @param classes list of class names
166
187
  */
@@ -176,7 +197,7 @@ export class MtxPopover {
176
197
  }
177
198
  /**
178
199
  * This method takes classes set on the host md-popover element and applies them on the
179
- * popover template that displays in the overlay container. Otherwise, it's difficult
200
+ * popover template that displays in the overlay container. Otherwise, it's difficult
180
201
  * to style the containing popover from outside the component.
181
202
  * @deprecated Use `panelClass` instead.
182
203
  * @breaking-change 8.0.0
@@ -187,47 +208,46 @@ export class MtxPopover {
187
208
  set classList(classes) {
188
209
  this.panelClass = classes;
189
210
  }
211
+ ngOnInit() {
212
+ this.setPositionClasses();
213
+ }
190
214
  ngOnDestroy() {
191
- this._emitCloseEvent();
192
215
  this.closed.complete();
193
216
  }
194
217
  /** Handle a keyboard event from the popover, delegating to the appropriate action. */
195
218
  _handleKeydown(event) {
196
- switch (event.keyCode) {
219
+ const keyCode = event.keyCode;
220
+ switch (keyCode) {
197
221
  case ESCAPE:
198
- this._emitCloseEvent();
199
- return;
222
+ if (!hasModifierKey(event)) {
223
+ event.preventDefault();
224
+ this.closed.emit('keydown');
225
+ }
226
+ break;
200
227
  }
201
228
  }
202
- /**
203
- * This emits a close event to which the trigger is subscribed. When emitted, the
204
- * trigger will close the popover.
205
- */
206
- _emitCloseEvent() {
207
- this.closed.emit();
208
- }
209
- /** Close popover on click if closeOnPanelClick is true */
210
- onClick() {
229
+ /** Close popover on click if `closeOnPanelClick` is true. */
230
+ _handleClick() {
211
231
  if (this.closeOnPanelClick) {
212
- this._emitCloseEvent();
232
+ this.closed.emit('click');
213
233
  }
214
234
  }
215
- /** Disables close of popover when leaving trigger element and mouse over the popover */
216
- onMouseOver() {
235
+ /** Disables close of popover when leaving trigger element and mouse over the popover. */
236
+ _handleMouseOver() {
217
237
  if (this.triggerEvent === 'hover') {
218
238
  this.closeDisabled = true;
219
239
  }
220
240
  }
221
- /** Enables close of popover when mouse leaving popover element */
222
- onMouseLeave() {
241
+ /** Enables close of popover when mouse leaving popover element. */
242
+ _handleMouseLeave() {
223
243
  if (this.triggerEvent === 'hover') {
224
244
  setTimeout(() => {
225
245
  this.closeDisabled = false;
226
- this._emitCloseEvent();
246
+ this.closed.emit();
227
247
  }, this.leaveDelay);
228
248
  }
229
249
  }
230
- /** 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. */
231
251
  setCurrentStyles(pos = this.position) {
232
252
  const left = pos[1] === 'after'
233
253
  ? `${this.arrowOffsetX - this.arrowWidth / 2}px`
@@ -241,16 +261,13 @@ export class MtxPopover {
241
261
  ? `calc(50% - ${this.arrowHeight / 2}px)`
242
262
  : '';
243
263
  const top = pos[1] === 'below' ? `${this.arrowOffsetY - this.arrowHeight / 2}px` : '';
244
- this.popoverArrowStyles =
264
+ this.arrowStyles =
245
265
  pos[0] === 'above' || pos[0] === 'below'
246
266
  ? {
247
- left: this._dir.value === 'ltr' ? left : right,
248
- right: this._dir.value === 'ltr' ? right : left,
267
+ left: this.direction === 'ltr' ? left : right,
268
+ right: this.direction === 'ltr' ? right : left,
249
269
  }
250
- : {
251
- top,
252
- bottom,
253
- };
270
+ : { top, bottom };
254
271
  }
255
272
  /**
256
273
  * It's necessary to set position-based classes to ensure the popover panel animation
@@ -270,17 +287,44 @@ export class MtxPopover {
270
287
  this._classList['mtx-popover-below-center'] = pos[0] === 'below' && pos[1] === 'center';
271
288
  this._classList['mtx-popover-below-after'] = pos[0] === 'below' && pos[1] === 'after';
272
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
+ }
273
317
  }
274
318
  /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
275
319
  MtxPopover.decorators = [
276
320
  { type: Component, args: [{
277
321
  selector: 'mtx-popover',
278
- template: "<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",
322
+ 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",
279
323
  changeDetection: ChangeDetectionStrategy.OnPush,
280
324
  encapsulation: ViewEncapsulation.None,
281
325
  animations: [transformPopover],
282
326
  exportAs: 'mtxPopover',
283
- styles: [".mtx-popover-panel{max-height:calc(100vh - 48px);padding:8px;border-radius:4px;font-size:16px}.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"]
327
+ 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"]
284
328
  },] }
285
329
  ];
286
330
  /**
@@ -291,32 +335,36 @@ MtxPopover.decorators = [
291
335
  * @nocollapse
292
336
  */
293
337
  MtxPopover.ctorParameters = () => [
294
- { type: Directionality, decorators: [{ type: Optional }] },
295
338
  { type: ElementRef },
296
- { type: NgZone }
339
+ { type: NgZone },
340
+ { type: undefined, decorators: [{ type: Inject, args: [MTX_POPOVER_DEFAULT_OPTIONS,] }] }
297
341
  ];
298
342
  /** @type {!Object<string, !Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
299
343
  MtxPopover.propDecorators = {
300
- role: [{ type: HostBinding, args: ['attr.role',] }],
301
- position: [{ type: Input }],
344
+ backdropClass: [{ type: Input }],
345
+ ariaLabel: [{ type: Input, args: ['aria-label',] }],
346
+ ariaLabelledby: [{ type: Input, args: ['aria-labelledby',] }],
347
+ ariaDescribedby: [{ type: Input, args: ['aria-describedby',] }],
302
348
  triggerEvent: [{ type: Input }],
303
- scrollStrategy: [{ type: Input }],
304
349
  enterDelay: [{ type: Input }],
305
350
  leaveDelay: [{ type: Input }],
351
+ position: [{ type: Input }],
306
352
  xOffset: [{ type: Input }],
307
353
  yOffset: [{ type: Input }],
308
- arrowOffsetX: [{ type: Input }],
309
- arrowOffsetY: [{ type: Input }],
310
354
  arrowWidth: [{ type: Input }],
311
355
  arrowHeight: [{ type: Input }],
356
+ arrowOffsetX: [{ type: Input }],
357
+ arrowOffsetY: [{ type: Input }],
312
358
  closeOnPanelClick: [{ type: Input }],
313
359
  closeOnBackdropClick: [{ type: Input }],
314
- disableAnimation: [{ type: Input }],
315
360
  focusTrapEnabled: [{ type: Input }],
316
361
  focusTrapAutoCaptureEnabled: [{ type: Input }],
362
+ hasBackdrop: [{ type: Input }],
363
+ elevation: [{ type: Input }],
317
364
  panelClass: [{ type: Input, args: ['class',] }],
318
365
  classList: [{ type: Input }],
319
366
  closed: [{ type: Output }],
320
- templateRef: [{ type: ViewChild, args: [TemplateRef,] }]
367
+ templateRef: [{ type: ViewChild, args: [TemplateRef,] }],
368
+ lazyContent: [{ type: ContentChild, args: [MTX_POPOVER_CONTENT,] }]
321
369
  };
322
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.js","sourceRoot":"","sources":["../../../../projects/extensions/popover/popover.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,YAAY,EACZ,KAAK,EAEL,MAAM,EACN,WAAW,EACX,SAAS,EACT,iBAAiB,EACjB,UAAU,EACV,uBAAuB,EACvB,WAAW,EACX,MAAM,EACN,QAAQ,GACT,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAgB,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC5E,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAC;AAOnD,OAAO,EACL,mCAAmC,EACnC,iCAAiC,GAClC,MAAM,kBAAkB,CAAC;AAE1B,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAWxD,MAAM,OAAO,UAAU;IAwOrB,YACsB,IAAoB,EAChC,WAAuB,EACxB,IAAY;QAFC,SAAI,GAAJ,IAAI,CAAgB;QAChC,gBAAW,GAAX,WAAW,CAAY;QACxB,SAAI,GAAJ,IAAI,CAAQ;QA1OK,SAAI,GAAG,QAAQ,CAAC;QAE1C,qEAAqE;QAC7D,cAAS,GAAuB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QACnD,kBAAa,GAA2B,OAAO,CAAC;QAChD,oBAAe,GAA6B,YAAY,CAAC;QACzD,gBAAW,GAAG,GAAG,CAAC;QAClB,gBAAW,GAAG,GAAG,CAAC;QAClB,kBAAa,GAAG,CAAC,CAAC;QAClB,kBAAa,GAAG,CAAC,CAAC;QAClB,uBAAkB,GAAG,KAAK,CAAC;QAC3B,0BAAqB,GAAG,IAAI,CAAC;QAC7B,sBAAiB,GAAG,KAAK,CAAC;QAC1B,sBAAiB,GAAG,IAAI,CAAC;QACzB,iCAA4B,GAAG,IAAI,CAAC;QACpC,kBAAa,GAAG,EAAE,CAAC;QACnB,kBAAa,GAAG,EAAE,CAAC;QACnB,gBAAW,GAAG,EAAE,CAAC;QACjB,iBAAY,GAAG,EAAE,CAAC;QAE1B,4DAA4D;QAC5D,eAAU,GAA+B,EAAE,CAAC;QAE5C,mDAAmD;QAC5C,yBAAoB,GAAG,KAAK,CAAC;QAEpC,kCAAkC;QAC3B,kBAAa,GAAG,KAAK,CAAC;QAW7B,6DAA6D;QAC7D,4BAAuB,GAAG,IAAI,YAAY,EAAkB,CAAC;QA2L7D,gDAAgD;QACtC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAS1C,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IApMD,+BAA+B;IAC/B,IACI,QAAQ;QACV,OAAO,IAAI,CAAC,SAAS,CAAC;IACxB,CAAC;IACD,IAAI,QAAQ,CAAC,KAAyB;QACpC,IAAI,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;YAC7D,mCAAmC,EAAE,CAAC;SACvC;QACD,IAAI,CAAC,CAAC,QAAQ,EAAE,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE;YACvE,iCAAiC,EAAE,CAAC;SACrC;QACD,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;QACvB,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,4BAA4B;IAC5B,IACI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,YAAY,CAAC,KAA6B;QAC5C,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED,8BAA8B;IAC9B,IACI,cAAc;QAChB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IACD,IAAI,cAAc,CAAC,KAA+B;QAChD,IAAI,CAAC,eAAe,GAAG,KAAK,CAAC;IAC/B,CAAC;IAED,0BAA0B;IAC1B,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IACD,IAAI,UAAU,CAAC,KAAa;QAC1B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,0BAA0B;IAC1B,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IACD,IAAI,UAAU,CAAC,KAAa;QAC1B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,8BAA8B;IAC9B,IACI,OAAO;QACT,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,OAAO,CAAC,KAAa;QACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED,8BAA8B;IAC9B,IACI,OAAO;QACT,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,OAAO,CAAC,KAAa;QACvB,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED,6BAA6B;IAC7B,IACI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,YAAY,CAAC,KAAa;QAC5B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED,6BAA6B;IAC7B,IACI,YAAY;QACd,OAAO,IAAI,CAAC,aAAa,CAAC;IAC5B,CAAC;IACD,IAAI,YAAY,CAAC,KAAa;QAC5B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;IAC7B,CAAC;IAED,0BAA0B;IAC1B,IACI,UAAU;QACZ,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IACD,IAAI,UAAU,CAAC,KAAa;QAC1B,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAED,2BAA2B;IAC3B,IACI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;IACD,IAAI,WAAW,CAAC,KAAa;QAC3B,IAAI,CAAC,YAAY,GAAG,KAAK,CAAC;IAC5B,CAAC;IAED,uCAAuC;IACvC,IACI,iBAAiB;QACnB,OAAO,IAAI,CAAC,kBAAkB,CAAC;IACjC,CAAC;IACD,IAAI,iBAAiB,CAAC,KAAc;QAClC,IAAI,CAAC,kBAAkB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACzD,CAAC;IAED,sCAAsC;IACtC,IACI,oBAAoB;QACtB,OAAO,IAAI,CAAC,qBAAqB,CAAC;IACpC,CAAC;IACD,IAAI,oBAAoB,CAAC,KAAc;QACrC,IAAI,CAAC,qBAAqB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IAC5D,CAAC;IAED,2DAA2D;IAC3D,IACI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IACD,IAAI,gBAAgB,CAAC,KAAc;QACjC,IAAI,CAAC,iBAAiB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;IAED,4CAA4C;IAC5C,IACI,gBAAgB;QAClB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IACD,IAAI,gBAAgB,CAAC,KAAc;QACjC,IAAI,CAAC,iBAAiB,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;IAED,oEAAoE;IACpE,IACI,2BAA2B;QAC7B,OAAO,IAAI,CAAC,4BAA4B,CAAC;IAC3C,CAAC;IACD,IAAI,2BAA2B,CAAC,KAAc;QAC5C,IAAI,CAAC,4BAA4B,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;IACnE,CAAC;IAED;;;;;OAKG;IACH,IACI,UAAU,CAAC,OAAe;QAC5B,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,EAAE;YAC7B,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC,GAAQ,EAAE,SAAiB,EAAE,EAAE;gBAC1E,GAAG,CAAC,SAAS,CAAC,GAAG,IAAI,CAAC;gBACtB,OAAO,GAAG,CAAC;YACb,CAAC,EAAE,EAAE,CAAC,CAAC;YAEP,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,GAAG,EAAE,CAAC;YAC9C,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED;;;;;;OAMG;IACH,IACI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;IACD,IAAI,SAAS,CAAC,OAAe;QAC3B,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC;IAC5B,CAAC;IAeD,WAAW;QACT,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE,CAAC;IACzB,CAAC;IAED,sFAAsF;IACtF,cAAc,CAAC,KAAoB;QACjC,QAAQ,KAAK,CAAC,OAAO,EAAE;YACrB,KAAK,MAAM;gBACT,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,OAAO;SACV;IACH,CAAC;IAED;;;OAGG;IACH,eAAe;QACb,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;IACrB,CAAC;IAED,0DAA0D;IAC1D,OAAO;QACL,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC1B,IAAI,CAAC,eAAe,EAAE,CAAC;SACxB;IACH,CAAC;IAED,wFAAwF;IACxF,WAAW;QACT,IAAI,IAAI,CAAC,YAAY,KAAK,OAAO,EAAE;YACjC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;SAC3B;IACH,CAAC;IAED,kEAAkE;IAClE,YAAY;QACV,IAAI,IAAI,CAAC,YAAY,KAAK,OAAO,EAAE;YACjC,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;gBAC3B,IAAI,CAAC,eAAe,EAAE,CAAC;YACzB,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;SACrB;IACH,CAAC;IAED,yFAAyF;IACzF,gBAAgB,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ;QAClC,MAAM,IAAI,GACR,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO;YAChB,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI;YAChD,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ;gBACrB,CAAC,CAAC,cAAc,IAAI,CAAC,UAAU,GAAG,CAAC,KAAK;gBACxC,CAAC,CAAC,EAAE,CAAC;QACT,MAAM,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAExF,MAAM,MAAM,GACV,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO;YAChB,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI;YACjD,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ;gBACrB,CAAC,CAAC,cAAc,IAAI,CAAC,WAAW,GAAG,CAAC,KAAK;gBACzC,CAAC,CAAC,EAAE,CAAC;QACT,MAAM,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QAEtF,IAAI,CAAC,kBAAkB;YACrB,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO;gBACtC,CAAC,CAAC;oBACE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK;oBAC9C,KAAK,EAAE,IAAI,CAAC,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI;iBAChD;gBACH,CAAC,CAAC;oBACE,GAAG;oBACH,MAAM;iBACP,CAAC;IACV,CAAC;IAED;;;OAGG;IACH,kBAAkB,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ;QACpC,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC;QACxF,IAAI,CAAC,UAAU,CAAC,2BAA2B,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC;QAC1F,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC;QACxF,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC;QACtF,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC;QACxF,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC;QACtF,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC;QACxF,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC;QACxF,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC;QACtF,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC;QACxF,IAAI,CAAC,UAAU,CAAC,0BAA0B,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,QAAQ,CAAC;QACxF,IAAI,CAAC,UAAU,CAAC,yBAAyB,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,IAAI,GAAG,CAAC,CAAC,CAAC,KAAK,OAAO,CAAC;IACxF,CAAC;;;;YAtVF,SAAS,SAAC;gBACT,QAAQ,EAAE,aAAa;gBACvB,myBAA6B;gBAE7B,eAAe,EAAE,uBAAuB,CAAC,MAAM;gBAC/C,aAAa,EAAE,iBAAiB,CAAC,IAAI;gBACrC,UAAU,EAAE,CAAC,gBAAgB,CAAC;gBAC9B,QAAQ,EAAE,YAAY;;aACvB;;;;;;;;;;YAtBQ,cAAc,uBAgQlB,QAAQ;YAzQX,UAAU;YAGV,MAAM;;;;mBA8BL,WAAW,SAAC,WAAW;uBA0CvB,KAAK;2BAgBL,KAAK;6BASL,KAAK;yBASL,KAAK;yBASL,KAAK;sBASL,KAAK;sBASL,KAAK;2BASL,KAAK;2BASL,KAAK;yBASL,KAAK;0BASL,KAAK;gCASL,KAAK;mCASL,KAAK;+BASL,KAAK;+BASL,KAAK;0CASL,KAAK;yBAcL,KAAK,SAAC,OAAO;wBAoBb,KAAK;qBASL,MAAM;0BAEN,SAAS,SAAC,WAAW","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 = true;\n  private _focusTrapAutoCaptureEnabled = true;\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"]}
370
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover.js","sourceRoot":"","sources":["../../../../projects/extensions/popover/popover.ts"],"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> | null = null;\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"]}
@@ -1,8 +1,9 @@
1
1
  export * from './popover-module';
2
2
  export * from './popover';
3
+ export * from './popover-content';
3
4
  export * from './popover-trigger';
4
5
  export * from './popover-target';
5
6
  export * from './popover-animations';
6
7
  export * from './popover-interfaces';
7
8
  export * from './popover-types';
8
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2V4dGVuc2lvbnMvcG9wb3Zlci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGtCQUFrQixDQUFDO0FBQ2pDLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLGlCQUFpQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9wb3BvdmVyLW1vZHVsZSc7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXInO1xuZXhwb3J0ICogZnJvbSAnLi9wb3BvdmVyLXRyaWdnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9wb3BvdmVyLXRhcmdldCc7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXItYW5pbWF0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXItaW50ZXJmYWNlcyc7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXItdHlwZXMnO1xuIl19
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2V4dGVuc2lvbnMvcG9wb3Zlci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3BvcG92ZXItbW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vcG9wb3Zlcic7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXItY29udGVudCc7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXItdHJpZ2dlcic7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXItdGFyZ2V0JztcbmV4cG9ydCAqIGZyb20gJy4vcG9wb3Zlci1hbmltYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vcG9wb3Zlci1pbnRlcmZhY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vcG9wb3Zlci10eXBlcyc7XG4iXX0=