@ng-matero/extensions 12.9.2 → 12.10.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/mtxCore.umd.js.map +1 -1
- package/bundles/mtxDatetimepicker.umd.js +5 -0
- package/bundles/mtxDatetimepicker.umd.js.map +1 -1
- package/bundles/mtxGrid.umd.js +24 -21
- package/bundles/mtxGrid.umd.js.map +1 -1
- package/bundles/mtxPopover.umd.js +997 -803
- package/bundles/mtxPopover.umd.js.map +1 -1
- package/bundles/mtxSelect.umd.js +237 -156
- package/bundles/mtxSelect.umd.js.map +1 -1
- package/core/datetime/datetime-formats.d.ts +2 -0
- package/esm2015/core/datetime/datetime-formats.js +1 -1
- package/esm2015/datetimepicker/datetimepicker-input.js +6 -1
- package/esm2015/grid/cell.component.js +7 -4
- package/esm2015/grid/column-menu.component.js +10 -14
- package/esm2015/grid/grid.component.js +10 -6
- package/esm2015/popover/popover-animations.js +10 -13
- package/esm2015/popover/popover-content.js +99 -0
- package/esm2015/popover/popover-interfaces.js +1 -1
- package/esm2015/popover/popover-module.js +7 -5
- package/esm2015/popover/popover-target.js +3 -3
- package/esm2015/popover/popover-trigger.js +210 -172
- package/esm2015/popover/popover-types.js +1 -1
- package/esm2015/popover/popover.js +173 -125
- package/esm2015/popover/public-api.js +2 -1
- package/esm2015/select/option.component.js +4 -6
- package/esm2015/select/select.component.js +111 -31
- package/fesm2015/mtxCore.js.map +1 -1
- package/fesm2015/mtxDatetimepicker.js +5 -0
- package/fesm2015/mtxDatetimepicker.js.map +1 -1
- package/fesm2015/mtxGrid.js +24 -21
- package/fesm2015/mtxGrid.js.map +1 -1
- package/fesm2015/mtxPopover.js +526 -351
- package/fesm2015/mtxPopover.js.map +1 -1
- package/fesm2015/mtxSelect.js +169 -92
- package/fesm2015/mtxSelect.js.map +1 -1
- package/grid/cell.component.d.ts +4 -2
- package/grid/column-menu.component.d.ts +3 -5
- package/grid/grid.component.d.ts +6 -4
- package/grid/mtxGrid.metadata.json +1 -1
- package/package.json +1 -1
- package/popover/mtxPopover.metadata.json +1 -1
- package/popover/popover-animations.d.ts +1 -1
- package/popover/popover-content.d.ts +38 -0
- package/popover/popover-interfaces.d.ts +37 -31
- package/popover/popover-target.d.ts +2 -2
- package/popover/popover-trigger.d.ts +65 -60
- package/popover/popover-types.d.ts +6 -1
- package/popover/popover.d.ts +97 -69
- package/popover/popover.scss +2 -0
- package/popover/public-api.d.ts +1 -0
- package/select/mtxSelect.metadata.json +1 -1
- package/select/option.component.d.ts +7 -6
- package/select/select.component.d.ts +59 -20
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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 {
|
|
5
|
-
import {
|
|
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(
|
|
9
|
-
|
|
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.
|
|
12
|
-
this.
|
|
13
|
-
|
|
14
|
-
this.
|
|
15
|
-
this.
|
|
16
|
-
this.
|
|
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
|
-
/** 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
|
-
/**
|
|
33
|
-
this.
|
|
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
|
-
/**
|
|
37
|
-
this.
|
|
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.
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
|
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
|
-
/**
|
|
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
|
-
/**
|
|
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
|
-
/**
|
|
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.
|
|
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.
|
|
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
|
-
|
|
219
|
+
const keyCode = event.keyCode;
|
|
220
|
+
switch (keyCode) {
|
|
197
221
|
case ESCAPE:
|
|
198
|
-
|
|
199
|
-
|
|
222
|
+
if (!hasModifierKey(event)) {
|
|
223
|
+
event.preventDefault();
|
|
224
|
+
this.closed.emit('keydown');
|
|
225
|
+
}
|
|
226
|
+
break;
|
|
200
227
|
}
|
|
201
228
|
}
|
|
202
|
-
/**
|
|
203
|
-
|
|
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.
|
|
232
|
+
this.closed.emit('click');
|
|
213
233
|
}
|
|
214
234
|
}
|
|
215
|
-
/** Disables close of popover when leaving trigger element and mouse over the popover */
|
|
216
|
-
|
|
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
|
-
|
|
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.
|
|
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.
|
|
264
|
+
this.arrowStyles =
|
|
245
265
|
pos[0] === 'above' || pos[0] === 'below'
|
|
246
266
|
? {
|
|
247
|
-
left: this.
|
|
248
|
-
right: this.
|
|
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
|
|
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
|
-
|
|
301
|
-
|
|
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":"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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 = 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,
|
|
9
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2V4dGVuc2lvbnMvcG9wb3Zlci9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxXQUFXLENBQUM7QUFDMUIsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsaUJBQWlCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3BvcG92ZXItbW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vcG9wb3Zlcic7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXItY29udGVudCc7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXItdHJpZ2dlcic7XG5leHBvcnQgKiBmcm9tICcuL3BvcG92ZXItdGFyZ2V0JztcbmV4cG9ydCAqIGZyb20gJy4vcG9wb3Zlci1hbmltYXRpb25zJztcbmV4cG9ydCAqIGZyb20gJy4vcG9wb3Zlci1pbnRlcmZhY2VzJztcbmV4cG9ydCAqIGZyb20gJy4vcG9wb3Zlci10eXBlcyc7XG4iXX0=
|