@radix-ng/primitives 0.20.1 → 0.21.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/avatar/src/avatar-fallback.directive.d.ts +1 -1
- package/avatar/src/avatar-image.directive.d.ts +3 -3
- package/compodoc/documentation.json +6022 -1655
- package/core/index.d.ts +1 -0
- package/core/src/id-generator.d.ts +12 -0
- package/esm2022/avatar/src/avatar-fallback.directive.mjs +6 -8
- package/esm2022/avatar/src/avatar-image.directive.mjs +4 -3
- package/esm2022/core/index.mjs +2 -1
- package/esm2022/core/src/create-inject-context/index.mjs +2 -2
- package/esm2022/core/src/id-generator.mjs +43 -0
- package/esm2022/popover/index.mjs +14 -4
- package/esm2022/popover/src/popover-anchor.directive.mjs +70 -0
- package/esm2022/popover/src/popover-anchor.token.mjs +3 -0
- package/esm2022/popover/src/popover-arrow.directive.mjs +12 -7
- package/esm2022/popover/src/popover-close.directive.mjs +17 -5
- package/esm2022/popover/src/popover-close.token.mjs +3 -0
- package/esm2022/popover/src/popover-content-attributes.component.mjs +70 -0
- package/esm2022/popover/src/popover-content-attributes.token.mjs +3 -0
- package/esm2022/popover/src/popover-content.directive.mjs +120 -92
- package/esm2022/popover/src/popover-root.directive.mjs +234 -61
- package/esm2022/popover/src/popover-root.inject.mjs +4 -4
- package/esm2022/popover/src/popover-trigger.directive.mjs +10 -11
- package/esm2022/popover/src/popover.constants.mjs +2 -2
- package/esm2022/popover/src/popover.types.mjs +18 -1
- package/esm2022/popover/src/popover.utils.mjs +4 -6
- package/esm2022/switch/src/switch-input.directive.mjs +16 -7
- package/esm2022/switch/src/switch-root.directive.mjs +59 -14
- package/esm2022/switch/src/switch-thumb.directive.mjs +3 -3
- package/esm2022/toggle/index.mjs +2 -2
- package/esm2022/toggle/src/toggle-visually-hidden-input.directive.mjs +31 -0
- package/esm2022/toggle/src/toggle.directive.mjs +37 -8
- package/fesm2022/radix-ng-primitives-avatar.mjs +8 -9
- package/fesm2022/radix-ng-primitives-avatar.mjs.map +1 -1
- package/fesm2022/radix-ng-primitives-core.mjs +44 -3
- package/fesm2022/radix-ng-primitives-core.mjs.map +1 -1
- package/fesm2022/radix-ng-primitives-popover.mjs +679 -312
- package/fesm2022/radix-ng-primitives-popover.mjs.map +1 -1
- package/fesm2022/radix-ng-primitives-switch.mjs +76 -22
- package/fesm2022/radix-ng-primitives-switch.mjs.map +1 -1
- package/fesm2022/radix-ng-primitives-toggle.mjs +45 -15
- package/fesm2022/radix-ng-primitives-toggle.mjs.map +1 -1
- package/package.json +1 -1
- package/popover/index.d.ts +5 -1
- package/popover/src/popover-anchor.directive.d.ts +28 -0
- package/popover/src/popover-anchor.token.d.ts +3 -0
- package/popover/src/popover-arrow.directive.d.ts +8 -5
- package/popover/src/popover-close.directive.d.ts +2 -2
- package/popover/src/popover-close.token.d.ts +3 -0
- package/popover/src/popover-content-attributes.component.d.ts +17 -0
- package/popover/src/popover-content-attributes.token.d.ts +3 -0
- package/popover/src/popover-content.directive.d.ts +35 -24
- package/popover/src/popover-root.directive.d.ts +91 -18
- package/popover/src/popover-root.inject.d.ts +2 -1
- package/popover/src/popover-trigger.directive.d.ts +5 -5
- package/popover/src/popover.constants.d.ts +1 -1
- package/popover/src/popover.types.d.ts +14 -3
- package/switch/src/switch-input.directive.d.ts +2 -0
- package/switch/src/switch-root.directive.d.ts +33 -5
- package/toggle/index.d.ts +2 -2
- package/toggle/src/toggle-visually-hidden-input.directive.d.ts +6 -0
- package/toggle/src/toggle.directive.d.ts +19 -2
- package/esm2022/popover/src/popover-root.token.mjs +0 -3
- package/esm2022/toggle/src/toggle-input.directive.mjs +0 -30
- package/popover/src/popover-root.token.d.ts +0 -3
- package/toggle/src/toggle-input.directive.d.ts +0 -6
@@ -1,24 +1,56 @@
|
|
1
|
-
import {
|
2
|
-
import {
|
1
|
+
import { afterNextRender, booleanAttribute, computed, contentChild, DestroyRef, Directive, effect, inject, input, signal, untracked, ViewContainerRef } from '@angular/core';
|
2
|
+
import { RdxPopoverAnchorToken } from './popover-anchor.token';
|
3
3
|
import { RdxPopoverArrowToken } from './popover-arrow.token';
|
4
|
+
import { RdxPopoverCloseToken } from './popover-close.token';
|
5
|
+
import { RdxPopoverContentAttributesToken } from './popover-content-attributes.token';
|
4
6
|
import { RdxPopoverContentDirective } from './popover-content.directive';
|
5
|
-
import { RdxPopoverRootToken } from './popover-root.token';
|
6
7
|
import { RdxPopoverTriggerDirective } from './popover-trigger.directive';
|
8
|
+
import { RdxPopoverAnimationStatus, RdxPopoverAttachDetachEvent, RdxPopoverState } from './popover.types';
|
7
9
|
import * as i0 from "@angular/core";
|
10
|
+
let nextId = 0;
|
8
11
|
export class RdxPopoverRootDirective {
|
9
12
|
constructor() {
|
13
|
+
/** @ignore */
|
14
|
+
this.uniqueId = signal(++nextId);
|
15
|
+
/** @ignore */
|
16
|
+
this.name = computed(() => `rdx-popover-root-${this.uniqueId()}`);
|
10
17
|
/**
|
11
|
-
* The
|
18
|
+
* @description The anchor directive that comes form outside the popover root
|
19
|
+
* @default undefined
|
20
|
+
*/
|
21
|
+
this.anchor = input(void 0);
|
22
|
+
/**
|
23
|
+
* @description The open state of the popover when it is initially rendered. Use when you do not need to control its open state.
|
24
|
+
* @default false
|
12
25
|
*/
|
13
26
|
this.defaultOpen = input(false);
|
14
27
|
/**
|
15
|
-
* The controlled
|
28
|
+
* @description The controlled state of the popover. `open` input take precedence of `defaultOpen` input.
|
29
|
+
* @default undefined
|
16
30
|
*/
|
17
|
-
this.open = input();
|
31
|
+
this.open = input(void 0);
|
18
32
|
/**
|
19
|
-
*
|
33
|
+
* @description Whether to control the state of the popover from external. Use in conjunction with `open` input.
|
34
|
+
* @default undefined
|
20
35
|
*/
|
21
|
-
this.
|
36
|
+
this.externalControl = input(void 0);
|
37
|
+
/**
|
38
|
+
* @description Whether to take into account CSS opening/closing animations.
|
39
|
+
* @default false
|
40
|
+
*/
|
41
|
+
this.cssAnimation = input(false, { transform: booleanAttribute });
|
42
|
+
/**
|
43
|
+
* @description Whether to take into account CSS opening animations. `cssAnimation` input must be set to 'true'
|
44
|
+
* @default false
|
45
|
+
*/
|
46
|
+
this.cssOpeningAnimation = input(false, { transform: booleanAttribute });
|
47
|
+
/**
|
48
|
+
* @description Whether to take into account CSS closing animations. `cssAnimation` input must be set to 'true'
|
49
|
+
* @default false
|
50
|
+
*/
|
51
|
+
this.cssClosingAnimation = input(false, { transform: booleanAttribute });
|
52
|
+
/** @ignore */
|
53
|
+
this.cssAnimationStatus = signal(null);
|
22
54
|
/** @ignore */
|
23
55
|
this.popoverContentDirective = contentChild.required(RdxPopoverContentDirective);
|
24
56
|
/** @ignore */
|
@@ -26,117 +58,258 @@ export class RdxPopoverRootDirective {
|
|
26
58
|
/** @ignore */
|
27
59
|
this.popoverArrowDirective = contentChild(RdxPopoverArrowToken);
|
28
60
|
/** @ignore */
|
61
|
+
this.popoverCloseDirective = contentChild(RdxPopoverCloseToken);
|
62
|
+
/** @ignore */
|
63
|
+
this.popoverContentAttributesComponent = contentChild(RdxPopoverContentAttributesToken);
|
64
|
+
/** @ignore */
|
65
|
+
this.internalPopoverAnchorDirective = contentChild(RdxPopoverAnchorToken);
|
66
|
+
/** @ignore */
|
29
67
|
this.viewContainerRef = inject(ViewContainerRef);
|
30
68
|
/** @ignore */
|
31
|
-
this.
|
69
|
+
this.destroyRef = inject(DestroyRef);
|
32
70
|
/** @ignore */
|
33
|
-
this.
|
71
|
+
this.state = signal(RdxPopoverState.CLOSED);
|
34
72
|
/** @ignore */
|
35
|
-
this.
|
36
|
-
|
37
|
-
|
38
|
-
return 'open';
|
39
|
-
}
|
40
|
-
return 'closed';
|
41
|
-
});
|
73
|
+
this.attachDetachEvent = signal(RdxPopoverAttachDetachEvent.DETACH);
|
74
|
+
/** @ignore */
|
75
|
+
this.isFirstDefaultOpen = signal(false);
|
42
76
|
/** @ignore */
|
43
|
-
this.
|
77
|
+
this.popoverAnchorDirective = computed(() => this.internalPopoverAnchorDirective() ?? this.anchor());
|
78
|
+
/** @ignore */
|
79
|
+
this.onAnchorChangeEffect = () => {
|
80
|
+
effect(() => {
|
81
|
+
const anchor = this.anchor();
|
82
|
+
untracked(() => {
|
83
|
+
if (anchor) {
|
84
|
+
anchor.setPopoverRoot(this);
|
85
|
+
}
|
86
|
+
});
|
87
|
+
});
|
88
|
+
};
|
89
|
+
this.onStateChangeEffect();
|
90
|
+
this.onCssAnimationStatusChangeChangeEffect();
|
44
91
|
this.onOpenChangeEffect();
|
45
|
-
this.
|
92
|
+
this.onIsFirstDefaultOpenChangeEffect();
|
93
|
+
this.onAnchorChangeEffect();
|
94
|
+
this.emitOpenOrClosedEventEffect();
|
95
|
+
afterNextRender({
|
96
|
+
write: () => {
|
97
|
+
if (this.defaultOpen() && !this.open()) {
|
98
|
+
this.isFirstDefaultOpen.set(true);
|
99
|
+
}
|
100
|
+
}
|
101
|
+
});
|
46
102
|
}
|
47
103
|
/** @ignore */
|
48
|
-
|
49
|
-
|
50
|
-
this.
|
51
|
-
|
104
|
+
getAnimationParamsSnapshot() {
|
105
|
+
return {
|
106
|
+
cssAnimation: this.cssAnimation(),
|
107
|
+
cssOpeningAnimation: this.cssOpeningAnimation(),
|
108
|
+
cssClosingAnimation: this.cssClosingAnimation(),
|
109
|
+
cssAnimationStatus: this.cssAnimationStatus(),
|
110
|
+
attachDetachEvent: this.attachDetachEvent(),
|
111
|
+
state: this.state(),
|
112
|
+
canEmitOnOpenOrOnClosed: this.canEmitOnOpenOrOnClosed()
|
113
|
+
};
|
52
114
|
}
|
53
115
|
/** @ignore */
|
54
116
|
controlledExternally() {
|
55
|
-
return this.
|
117
|
+
return this.externalControl;
|
118
|
+
}
|
119
|
+
/** @ignore */
|
120
|
+
firstDefaultOpen() {
|
121
|
+
return this.isFirstDefaultOpen();
|
56
122
|
}
|
57
123
|
/** @ignore */
|
58
124
|
handleOpen() {
|
59
|
-
if (this.
|
125
|
+
if (this.externalControl()) {
|
60
126
|
return;
|
61
127
|
}
|
62
|
-
this.
|
128
|
+
this.setState(RdxPopoverState.OPEN);
|
63
129
|
}
|
64
130
|
/** @ignore */
|
65
131
|
handleClose() {
|
66
|
-
if (this.
|
132
|
+
if (this.isFirstDefaultOpen()) {
|
133
|
+
this.isFirstDefaultOpen.set(false);
|
134
|
+
}
|
135
|
+
if (this.externalControl()) {
|
67
136
|
return;
|
68
137
|
}
|
69
|
-
this.
|
138
|
+
this.setState(RdxPopoverState.CLOSED);
|
70
139
|
}
|
71
140
|
/** @ignore */
|
72
141
|
handleToggle() {
|
73
|
-
if (this.
|
142
|
+
if (this.externalControl()) {
|
74
143
|
return;
|
75
144
|
}
|
76
145
|
this.isOpen() ? this.handleClose() : this.handleOpen();
|
77
146
|
}
|
78
147
|
/** @ignore */
|
79
|
-
|
80
|
-
|
81
|
-
|
148
|
+
isOpen(state) {
|
149
|
+
return (state ?? this.state()) === RdxPopoverState.OPEN;
|
150
|
+
}
|
151
|
+
/** @ignore */
|
152
|
+
setState(state = RdxPopoverState.CLOSED) {
|
153
|
+
if (state === this.state()) {
|
154
|
+
return;
|
155
|
+
}
|
156
|
+
this.state.set(state);
|
157
|
+
}
|
158
|
+
/** @ignore */
|
159
|
+
openContent() {
|
160
|
+
this.popoverContentDirective().open();
|
161
|
+
if (!this.cssAnimation() || !this.cssOpeningAnimation()) {
|
162
|
+
this.cssAnimationStatus.set(null);
|
163
|
+
}
|
164
|
+
}
|
165
|
+
/** @ignore */
|
166
|
+
closeContent() {
|
167
|
+
this.popoverContentDirective().close();
|
168
|
+
if (!this.cssAnimation() || !this.cssClosingAnimation()) {
|
169
|
+
this.cssAnimationStatus.set(null);
|
82
170
|
}
|
83
|
-
this.isOpen.set(open);
|
84
|
-
this.onOpenChange.emit(open);
|
85
171
|
}
|
86
172
|
/** @ignore */
|
87
|
-
|
88
|
-
this.popoverContentDirective().
|
173
|
+
emitOnOpen() {
|
174
|
+
this.popoverContentDirective().onOpen.emit();
|
89
175
|
}
|
90
176
|
/** @ignore */
|
91
|
-
|
92
|
-
this.popoverContentDirective().
|
177
|
+
emitOnClosed() {
|
178
|
+
this.popoverContentDirective().onClosed.emit();
|
93
179
|
}
|
94
180
|
/** @ignore */
|
95
|
-
|
181
|
+
ifOpenOrCloseWithoutAnimations(state) {
|
182
|
+
return (!this.popoverContentAttributesComponent() ||
|
183
|
+
!this.cssAnimation() ||
|
184
|
+
(this.cssAnimation() && !this.cssClosingAnimation() && state === RdxPopoverState.CLOSED) ||
|
185
|
+
(this.cssAnimation() && !this.cssOpeningAnimation() && state === RdxPopoverState.OPEN) ||
|
186
|
+
// !this.cssAnimationStatus() ||
|
187
|
+
(this.cssOpeningAnimation() &&
|
188
|
+
state === RdxPopoverState.OPEN &&
|
189
|
+
[RdxPopoverAnimationStatus.OPEN_STARTED].includes(this.cssAnimationStatus())) ||
|
190
|
+
(this.cssClosingAnimation() &&
|
191
|
+
state === RdxPopoverState.CLOSED &&
|
192
|
+
[RdxPopoverAnimationStatus.CLOSED_STARTED].includes(this.cssAnimationStatus())));
|
193
|
+
}
|
194
|
+
/** @ignore */
|
195
|
+
ifOpenOrCloseWithAnimations(cssAnimationStatus) {
|
196
|
+
return (this.popoverContentAttributesComponent() &&
|
197
|
+
this.cssAnimation() &&
|
198
|
+
cssAnimationStatus &&
|
199
|
+
((this.cssOpeningAnimation() &&
|
200
|
+
this.state() === RdxPopoverState.OPEN &&
|
201
|
+
[RdxPopoverAnimationStatus.OPEN_ENDED].includes(cssAnimationStatus)) ||
|
202
|
+
(this.cssClosingAnimation() &&
|
203
|
+
this.state() === RdxPopoverState.CLOSED &&
|
204
|
+
[RdxPopoverAnimationStatus.CLOSED_ENDED].includes(cssAnimationStatus))));
|
205
|
+
}
|
206
|
+
/** @ignore */
|
207
|
+
openOrClose(state) {
|
208
|
+
const isOpen = this.isOpen(state);
|
209
|
+
isOpen ? this.openContent() : this.closeContent();
|
210
|
+
}
|
211
|
+
/** @ignore */
|
212
|
+
emitOnOpenOrOnClosed(state) {
|
213
|
+
this.isOpen(state)
|
214
|
+
? this.attachDetachEvent() === RdxPopoverAttachDetachEvent.ATTACH && this.emitOnOpen()
|
215
|
+
: this.attachDetachEvent() === RdxPopoverAttachDetachEvent.DETACH && this.emitOnClosed();
|
216
|
+
}
|
217
|
+
/** @ignore */
|
218
|
+
canEmitOnOpenOrOnClosed() {
|
219
|
+
return (!this.cssAnimation() ||
|
220
|
+
(!this.cssOpeningAnimation() && this.state() === RdxPopoverState.OPEN) ||
|
221
|
+
(this.cssOpeningAnimation() &&
|
222
|
+
this.state() === RdxPopoverState.OPEN &&
|
223
|
+
this.cssAnimationStatus() === RdxPopoverAnimationStatus.OPEN_ENDED) ||
|
224
|
+
(!this.cssClosingAnimation() && this.state() === RdxPopoverState.CLOSED) ||
|
225
|
+
(this.cssClosingAnimation() &&
|
226
|
+
this.state() === RdxPopoverState.CLOSED &&
|
227
|
+
this.cssAnimationStatus() === RdxPopoverAnimationStatus.CLOSED_ENDED));
|
228
|
+
}
|
229
|
+
/** @ignore */
|
230
|
+
onStateChangeEffect() {
|
231
|
+
let isFirst = true;
|
96
232
|
effect(() => {
|
97
|
-
const
|
233
|
+
const state = this.state();
|
98
234
|
untracked(() => {
|
99
|
-
if (
|
100
|
-
|
235
|
+
if (isFirst) {
|
236
|
+
isFirst = false;
|
237
|
+
return;
|
101
238
|
}
|
102
|
-
|
103
|
-
|
239
|
+
if (!this.ifOpenOrCloseWithoutAnimations(state)) {
|
240
|
+
return;
|
104
241
|
}
|
242
|
+
this.openOrClose(state);
|
243
|
+
});
|
244
|
+
}, {});
|
245
|
+
}
|
246
|
+
/** @ignore */
|
247
|
+
onCssAnimationStatusChangeChangeEffect() {
|
248
|
+
let isFirst = true;
|
249
|
+
effect(() => {
|
250
|
+
const cssAnimationStatus = this.cssAnimationStatus();
|
251
|
+
untracked(() => {
|
252
|
+
if (isFirst) {
|
253
|
+
isFirst = false;
|
254
|
+
return;
|
255
|
+
}
|
256
|
+
if (!this.ifOpenOrCloseWithAnimations(cssAnimationStatus)) {
|
257
|
+
return;
|
258
|
+
}
|
259
|
+
this.openOrClose(this.state());
|
260
|
+
});
|
261
|
+
});
|
262
|
+
}
|
263
|
+
/** @ignore */
|
264
|
+
emitOpenOrClosedEventEffect() {
|
265
|
+
let isFirst = true;
|
266
|
+
effect(() => {
|
267
|
+
this.attachDetachEvent();
|
268
|
+
this.cssAnimationStatus();
|
269
|
+
untracked(() => {
|
270
|
+
if (isFirst) {
|
271
|
+
isFirst = false;
|
272
|
+
return;
|
273
|
+
}
|
274
|
+
const canEmitOpenClose = untracked(() => this.canEmitOnOpenOrOnClosed());
|
275
|
+
if (!canEmitOpenClose) {
|
276
|
+
return;
|
277
|
+
}
|
278
|
+
this.emitOnOpenOrOnClosed(this.state());
|
105
279
|
});
|
106
280
|
});
|
107
281
|
}
|
108
282
|
/** @ignore */
|
109
283
|
onOpenChangeEffect() {
|
110
284
|
effect(() => {
|
111
|
-
const
|
285
|
+
const open = this.open();
|
286
|
+
untracked(() => {
|
287
|
+
this.setState(open ? RdxPopoverState.OPEN : RdxPopoverState.CLOSED);
|
288
|
+
});
|
289
|
+
});
|
290
|
+
}
|
291
|
+
/** @ignore */
|
292
|
+
onIsFirstDefaultOpenChangeEffect() {
|
293
|
+
const effectRef = effect(() => {
|
294
|
+
const defaultOpen = this.defaultOpen();
|
112
295
|
untracked(() => {
|
113
|
-
this.
|
114
|
-
|
115
|
-
|
296
|
+
if (!defaultOpen || this.open()) {
|
297
|
+
effectRef.destroy();
|
298
|
+
return;
|
116
299
|
}
|
300
|
+
this.handleOpen();
|
117
301
|
});
|
118
302
|
});
|
119
303
|
}
|
120
304
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverRootDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
121
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.2.0", version: "18.2.11", type: RdxPopoverRootDirective, isStandalone: true, selector: "[rdxPopoverRoot]", inputs: { defaultOpen: { classPropertyName: "defaultOpen", publicName: "defaultOpen", isSignal: true, isRequired: false, transformFunction: null }, open: { classPropertyName: "open", publicName: "open", isSignal: true, isRequired: false, transformFunction: null } },
|
122
|
-
{
|
123
|
-
provide: RdxPopoverRootToken,
|
124
|
-
useExisting: forwardRef(() => RdxPopoverRootDirective)
|
125
|
-
}
|
126
|
-
], queries: [{ propertyName: "popoverContentDirective", first: true, predicate: RdxPopoverContentDirective, descendants: true, isSignal: true }, { propertyName: "popoverTriggerDirective", first: true, predicate: RdxPopoverTriggerDirective, descendants: true, isSignal: true }, { propertyName: "popoverArrowDirective", first: true, predicate: RdxPopoverArrowToken, descendants: true, isSignal: true }], exportAs: ["rdxPopoverRoot"], ngImport: i0 }); }
|
305
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.2.0", version: "18.2.11", type: RdxPopoverRootDirective, isStandalone: true, selector: "[rdxPopoverRoot]", inputs: { anchor: { classPropertyName: "anchor", publicName: "anchor", isSignal: true, isRequired: false, transformFunction: null }, defaultOpen: { classPropertyName: "defaultOpen", publicName: "defaultOpen", isSignal: true, isRequired: false, transformFunction: null }, open: { classPropertyName: "open", publicName: "open", isSignal: true, isRequired: false, transformFunction: null }, externalControl: { classPropertyName: "externalControl", publicName: "externalControl", isSignal: true, isRequired: false, transformFunction: null }, cssAnimation: { classPropertyName: "cssAnimation", publicName: "cssAnimation", isSignal: true, isRequired: false, transformFunction: null }, cssOpeningAnimation: { classPropertyName: "cssOpeningAnimation", publicName: "cssOpeningAnimation", isSignal: true, isRequired: false, transformFunction: null }, cssClosingAnimation: { classPropertyName: "cssClosingAnimation", publicName: "cssClosingAnimation", isSignal: true, isRequired: false, transformFunction: null } }, queries: [{ propertyName: "popoverContentDirective", first: true, predicate: RdxPopoverContentDirective, descendants: true, isSignal: true }, { propertyName: "popoverTriggerDirective", first: true, predicate: RdxPopoverTriggerDirective, descendants: true, isSignal: true }, { propertyName: "popoverArrowDirective", first: true, predicate: RdxPopoverArrowToken, descendants: true, isSignal: true }, { propertyName: "popoverCloseDirective", first: true, predicate: RdxPopoverCloseToken, descendants: true, isSignal: true }, { propertyName: "popoverContentAttributesComponent", first: true, predicate: RdxPopoverContentAttributesToken, descendants: true, isSignal: true }, { propertyName: "internalPopoverAnchorDirective", first: true, predicate: RdxPopoverAnchorToken, descendants: true, isSignal: true }], exportAs: ["rdxPopoverRoot"], ngImport: i0 }); }
|
127
306
|
}
|
128
307
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverRootDirective, decorators: [{
|
129
308
|
type: Directive,
|
130
309
|
args: [{
|
131
310
|
selector: '[rdxPopoverRoot]',
|
132
311
|
standalone: true,
|
133
|
-
providers: [
|
134
|
-
{
|
135
|
-
provide: RdxPopoverRootToken,
|
136
|
-
useExisting: forwardRef(() => RdxPopoverRootDirective)
|
137
|
-
}
|
138
|
-
],
|
139
312
|
exportAs: 'rdxPopoverRoot'
|
140
313
|
}]
|
141
314
|
}], ctorParameters: () => [] });
|
142
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-root.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/popover/src/popover-root.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport {\n    computed,\n    contentChild,\n    Directive,\n    effect,\n    forwardRef,\n    inject,\n    input,\n    OnInit,\n    output,\n    signal,\n    untracked,\n    ViewContainerRef\n} from '@angular/core';\nimport { RdxPopoverArrowToken } from './popover-arrow.token';\nimport { RdxPopoverContentDirective } from './popover-content.directive';\nimport { RdxPopoverRootToken } from './popover-root.token';\nimport { RdxPopoverTriggerDirective } from './popover-trigger.directive';\nimport { RdxPopoverState } from './popover.types';\n\n@Directive({\n    selector: '[rdxPopoverRoot]',\n    standalone: true,\n    providers: [\n        {\n            provide: RdxPopoverRootToken,\n            useExisting: forwardRef(() => RdxPopoverRootDirective)\n        }\n    ],\n    exportAs: 'rdxPopoverRoot'\n})\nexport class RdxPopoverRootDirective implements OnInit {\n    /**\n     * The open state of the popover when it is initially rendered. Use when you do not need to control its open state.\n     */\n    readonly defaultOpen = input<boolean>(false);\n    /**\n     * The controlled open state of the popover. Must be used in conjunction with onOpenChange.\n     */\n    readonly open = input<boolean | undefined>();\n\n    /**\n     * Event handler called when the open state of the popover changes.\n     */\n    readonly onOpenChange = output<boolean>();\n\n    /** @ignore */\n    readonly popoverContentDirective = contentChild.required(RdxPopoverContentDirective);\n    /** @ignore */\n    readonly popoverTriggerDirective = contentChild.required(RdxPopoverTriggerDirective);\n    /** @ignore */\n    readonly popoverArrowDirective = contentChild(RdxPopoverArrowToken);\n\n    /** @ignore */\n    readonly viewContainerRef = inject(ViewContainerRef);\n    /** @ignore */\n    private readonly document = inject(DOCUMENT);\n\n    /** @ignore */\n    readonly isOpen = signal<boolean>(this.defaultOpen());\n    /** @ignore */\n    readonly state = computed<RdxPopoverState>(() => {\n        const currentIsOpen = this.isOpen();\n        if (currentIsOpen) {\n            return 'open';\n        }\n        return 'closed';\n    });\n\n    /** @ignore */\n    private isControlledExternally = computed(() => signal(this.open() !== void 0));\n\n    constructor() {\n        this.onOpenChangeEffect();\n        this.onIsOpenChangeEffect();\n    }\n\n    /** @ignore */\n    ngOnInit(): void {\n        if (this.defaultOpen()) {\n            this.handleOpen();\n        }\n    }\n\n    /** @ignore */\n    controlledExternally() {\n        return this.isControlledExternally().asReadonly();\n    }\n\n    /** @ignore */\n    handleOpen(): void {\n        if (this.isControlledExternally()()) {\n            return;\n        }\n        this.setOpen(true);\n    }\n\n    /** @ignore */\n    handleClose(): void {\n        if (this.isControlledExternally()()) {\n            return;\n        }\n        this.setOpen(false);\n    }\n\n    /** @ignore */\n    handleToggle(): void {\n        if (this.isControlledExternally()()) {\n            return;\n        }\n        this.isOpen() ? this.handleClose() : this.handleOpen();\n    }\n\n    /** @ignore */\n    private setOpen(open = false): void {\n        if (open) {\n            this.document.dispatchEvent(new CustomEvent('popover.open'));\n        }\n\n        this.isOpen.set(open);\n        this.onOpenChange.emit(open);\n    }\n\n    /** @ignore */\n    private show(): void {\n        this.popoverContentDirective().show();\n    }\n\n    /** @ignore */\n    private hide(): void {\n        this.popoverContentDirective().hide();\n    }\n\n    /** @ignore */\n    private onIsOpenChangeEffect() {\n        effect(() => {\n            const isOpen = this.isOpen();\n\n            untracked(() => {\n                if (isOpen) {\n                    this.show();\n                } else {\n                    this.hide();\n                }\n            });\n        });\n    }\n\n    /** @ignore */\n    private onOpenChangeEffect() {\n        effect(() => {\n            const currentOpen = this.open();\n\n            untracked(() => {\n                this.isControlledExternally().set(currentOpen !== void 0);\n                if (this.isControlledExternally()()) {\n                    this.setOpen(currentOpen);\n                }\n            });\n        });\n    }\n}\n"]}
|
315
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-root.directive.js","sourceRoot":"","sources":["../../../../../packages/primitives/popover/src/popover-root.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { BooleanInput } from '@angular/cdk/coercion';\nimport {\n    afterNextRender,\n    booleanAttribute,\n    computed,\n    contentChild,\n    DestroyRef,\n    Directive,\n    effect,\n    inject,\n    input,\n    signal,\n    untracked,\n    ViewContainerRef\n} from '@angular/core';\nimport { RdxPopoverAnchorDirective } from './popover-anchor.directive';\nimport { RdxPopoverAnchorToken } from './popover-anchor.token';\nimport { RdxPopoverArrowToken } from './popover-arrow.token';\nimport { RdxPopoverCloseToken } from './popover-close.token';\nimport { RdxPopoverContentAttributesToken } from './popover-content-attributes.token';\nimport { RdxPopoverContentDirective } from './popover-content.directive';\nimport { RdxPopoverTriggerDirective } from './popover-trigger.directive';\nimport { RdxPopoverAnimationStatus, RdxPopoverAttachDetachEvent, RdxPopoverState } from './popover.types';\n\nlet nextId = 0;\n\n@Directive({\n    selector: '[rdxPopoverRoot]',\n    standalone: true,\n    exportAs: 'rdxPopoverRoot'\n})\nexport class RdxPopoverRootDirective {\n    /** @ignore */\n    readonly uniqueId = signal(++nextId);\n    /** @ignore */\n    readonly name = computed(() => `rdx-popover-root-${this.uniqueId()}`);\n\n    /**\n     * @description The anchor directive that comes form outside the popover root\n     * @default undefined\n     */\n    readonly anchor = input<RdxPopoverAnchorDirective | undefined>(void 0);\n    /**\n     * @description The open state of the popover when it is initially rendered. Use when you do not need to control its open state.\n     * @default false\n     */\n    readonly defaultOpen = input<boolean>(false);\n    /**\n     * @description The controlled state of the popover. `open` input take precedence of `defaultOpen` input.\n     * @default undefined\n     */\n    readonly open = input<boolean | undefined>(void 0);\n    /**\n     * @description Whether to control the state of the popover from external. Use in conjunction with `open` input.\n     * @default undefined\n     */\n    readonly externalControl = input<boolean | undefined>(void 0);\n    /**\n     * @description Whether to take into account CSS opening/closing animations.\n     * @default false\n     */\n    readonly cssAnimation = input<boolean, BooleanInput>(false, { transform: booleanAttribute });\n    /**\n     * @description Whether to take into account CSS opening animations. `cssAnimation` input must be set to 'true'\n     * @default false\n     */\n    readonly cssOpeningAnimation = input<boolean, BooleanInput>(false, { transform: booleanAttribute });\n    /**\n     * @description Whether to take into account CSS closing animations. `cssAnimation` input must be set to 'true'\n     * @default false\n     */\n    readonly cssClosingAnimation = input<boolean, BooleanInput>(false, { transform: booleanAttribute });\n\n    /** @ignore */\n    readonly cssAnimationStatus = signal<RdxPopoverAnimationStatus | null>(null);\n\n    /** @ignore */\n    readonly popoverContentDirective = contentChild.required(RdxPopoverContentDirective);\n    /** @ignore */\n    readonly popoverTriggerDirective = contentChild.required(RdxPopoverTriggerDirective);\n    /** @ignore */\n    readonly popoverArrowDirective = contentChild(RdxPopoverArrowToken);\n    /** @ignore */\n    readonly popoverCloseDirective = contentChild(RdxPopoverCloseToken);\n    /** @ignore */\n    readonly popoverContentAttributesComponent = contentChild(RdxPopoverContentAttributesToken);\n    /** @ignore */\n    private readonly internalPopoverAnchorDirective = contentChild(RdxPopoverAnchorToken);\n\n    /** @ignore */\n    readonly viewContainerRef = inject(ViewContainerRef);\n    /** @ignore */\n    readonly destroyRef = inject(DestroyRef);\n\n    /** @ignore */\n    readonly state = signal(RdxPopoverState.CLOSED);\n\n    /** @ignore */\n    readonly attachDetachEvent = signal(RdxPopoverAttachDetachEvent.DETACH);\n\n    /** @ignore */\n    private isFirstDefaultOpen = signal(false);\n\n    /** @ignore */\n    readonly popoverAnchorDirective = computed(() => this.internalPopoverAnchorDirective() ?? this.anchor());\n\n    constructor() {\n        this.onStateChangeEffect();\n        this.onCssAnimationStatusChangeChangeEffect();\n        this.onOpenChangeEffect();\n        this.onIsFirstDefaultOpenChangeEffect();\n        this.onAnchorChangeEffect();\n        this.emitOpenOrClosedEventEffect();\n        afterNextRender({\n            write: () => {\n                if (this.defaultOpen() && !this.open()) {\n                    this.isFirstDefaultOpen.set(true);\n                }\n            }\n        });\n    }\n\n    /** @ignore */\n    getAnimationParamsSnapshot() {\n        return {\n            cssAnimation: this.cssAnimation(),\n            cssOpeningAnimation: this.cssOpeningAnimation(),\n            cssClosingAnimation: this.cssClosingAnimation(),\n            cssAnimationStatus: this.cssAnimationStatus(),\n            attachDetachEvent: this.attachDetachEvent(),\n            state: this.state(),\n            canEmitOnOpenOrOnClosed: this.canEmitOnOpenOrOnClosed()\n        };\n    }\n\n    /** @ignore */\n    controlledExternally() {\n        return this.externalControl;\n    }\n\n    /** @ignore */\n    firstDefaultOpen() {\n        return this.isFirstDefaultOpen();\n    }\n\n    /** @ignore */\n    handleOpen(): void {\n        if (this.externalControl()) {\n            return;\n        }\n        this.setState(RdxPopoverState.OPEN);\n    }\n\n    /** @ignore */\n    handleClose(): void {\n        if (this.isFirstDefaultOpen()) {\n            this.isFirstDefaultOpen.set(false);\n        }\n        if (this.externalControl()) {\n            return;\n        }\n        this.setState(RdxPopoverState.CLOSED);\n    }\n\n    /** @ignore */\n    handleToggle(): void {\n        if (this.externalControl()) {\n            return;\n        }\n        this.isOpen() ? this.handleClose() : this.handleOpen();\n    }\n\n    /** @ignore */\n    isOpen(state?: RdxPopoverState) {\n        return (state ?? this.state()) === RdxPopoverState.OPEN;\n    }\n\n    /** @ignore */\n    private setState(state = RdxPopoverState.CLOSED): void {\n        if (state === this.state()) {\n            return;\n        }\n        this.state.set(state);\n    }\n\n    /** @ignore */\n    private openContent(): void {\n        this.popoverContentDirective().open();\n        if (!this.cssAnimation() || !this.cssOpeningAnimation()) {\n            this.cssAnimationStatus.set(null);\n        }\n    }\n\n    /** @ignore */\n    private closeContent(): void {\n        this.popoverContentDirective().close();\n        if (!this.cssAnimation() || !this.cssClosingAnimation()) {\n            this.cssAnimationStatus.set(null);\n        }\n    }\n\n    /** @ignore */\n    private emitOnOpen(): void {\n        this.popoverContentDirective().onOpen.emit();\n    }\n\n    /** @ignore */\n    private emitOnClosed(): void {\n        this.popoverContentDirective().onClosed.emit();\n    }\n\n    /** @ignore */\n    private ifOpenOrCloseWithoutAnimations(state: RdxPopoverState) {\n        return (\n            !this.popoverContentAttributesComponent() ||\n            !this.cssAnimation() ||\n            (this.cssAnimation() && !this.cssClosingAnimation() && state === RdxPopoverState.CLOSED) ||\n            (this.cssAnimation() && !this.cssOpeningAnimation() && state === RdxPopoverState.OPEN) ||\n            // !this.cssAnimationStatus() ||\n            (this.cssOpeningAnimation() &&\n                state === RdxPopoverState.OPEN &&\n                [RdxPopoverAnimationStatus.OPEN_STARTED].includes(this.cssAnimationStatus()!)) ||\n            (this.cssClosingAnimation() &&\n                state === RdxPopoverState.CLOSED &&\n                [RdxPopoverAnimationStatus.CLOSED_STARTED].includes(this.cssAnimationStatus()!))\n        );\n    }\n\n    /** @ignore */\n    private ifOpenOrCloseWithAnimations(cssAnimationStatus: RdxPopoverAnimationStatus | null) {\n        return (\n            this.popoverContentAttributesComponent() &&\n            this.cssAnimation() &&\n            cssAnimationStatus &&\n            ((this.cssOpeningAnimation() &&\n                this.state() === RdxPopoverState.OPEN &&\n                [RdxPopoverAnimationStatus.OPEN_ENDED].includes(cssAnimationStatus)) ||\n                (this.cssClosingAnimation() &&\n                    this.state() === RdxPopoverState.CLOSED &&\n                    [RdxPopoverAnimationStatus.CLOSED_ENDED].includes(cssAnimationStatus)))\n        );\n    }\n\n    /** @ignore */\n    private openOrClose(state: RdxPopoverState) {\n        const isOpen = this.isOpen(state);\n        isOpen ? this.openContent() : this.closeContent();\n    }\n\n    /** @ignore */\n    private emitOnOpenOrOnClosed(state: RdxPopoverState) {\n        this.isOpen(state)\n            ? this.attachDetachEvent() === RdxPopoverAttachDetachEvent.ATTACH && this.emitOnOpen()\n            : this.attachDetachEvent() === RdxPopoverAttachDetachEvent.DETACH && this.emitOnClosed();\n    }\n\n    /** @ignore */\n    private canEmitOnOpenOrOnClosed() {\n        return (\n            !this.cssAnimation() ||\n            (!this.cssOpeningAnimation() && this.state() === RdxPopoverState.OPEN) ||\n            (this.cssOpeningAnimation() &&\n                this.state() === RdxPopoverState.OPEN &&\n                this.cssAnimationStatus() === RdxPopoverAnimationStatus.OPEN_ENDED) ||\n            (!this.cssClosingAnimation() && this.state() === RdxPopoverState.CLOSED) ||\n            (this.cssClosingAnimation() &&\n                this.state() === RdxPopoverState.CLOSED &&\n                this.cssAnimationStatus() === RdxPopoverAnimationStatus.CLOSED_ENDED)\n        );\n    }\n\n    /** @ignore */\n    private onStateChangeEffect() {\n        let isFirst = true;\n        effect(() => {\n            const state = this.state();\n            untracked(() => {\n                if (isFirst) {\n                    isFirst = false;\n                    return;\n                }\n                if (!this.ifOpenOrCloseWithoutAnimations(state)) {\n                    return;\n                }\n                this.openOrClose(state);\n            });\n        }, {});\n    }\n\n    /** @ignore */\n    private onCssAnimationStatusChangeChangeEffect() {\n        let isFirst = true;\n        effect(() => {\n            const cssAnimationStatus = this.cssAnimationStatus();\n            untracked(() => {\n                if (isFirst) {\n                    isFirst = false;\n                    return;\n                }\n                if (!this.ifOpenOrCloseWithAnimations(cssAnimationStatus)) {\n                    return;\n                }\n                this.openOrClose(this.state());\n            });\n        });\n    }\n\n    /** @ignore */\n    private emitOpenOrClosedEventEffect() {\n        let isFirst = true;\n        effect(() => {\n            this.attachDetachEvent();\n            this.cssAnimationStatus();\n            untracked(() => {\n                if (isFirst) {\n                    isFirst = false;\n                    return;\n                }\n                const canEmitOpenClose = untracked(() => this.canEmitOnOpenOrOnClosed());\n                if (!canEmitOpenClose) {\n                    return;\n                }\n                this.emitOnOpenOrOnClosed(this.state());\n            });\n        });\n    }\n\n    /** @ignore */\n    private onOpenChangeEffect() {\n        effect(() => {\n            const open = this.open();\n            untracked(() => {\n                this.setState(open ? RdxPopoverState.OPEN : RdxPopoverState.CLOSED);\n            });\n        });\n    }\n\n    /** @ignore */\n    private onIsFirstDefaultOpenChangeEffect() {\n        const effectRef = effect(() => {\n            const defaultOpen = this.defaultOpen();\n            untracked(() => {\n                if (!defaultOpen || this.open()) {\n                    effectRef.destroy();\n                    return;\n                }\n                this.handleOpen();\n            });\n        });\n    }\n\n    /** @ignore */\n    private onAnchorChangeEffect = () => {\n        effect(() => {\n            const anchor = this.anchor();\n            untracked(() => {\n                if (anchor) {\n                    anchor.setPopoverRoot(this);\n                }\n            });\n        });\n    };\n}\n"]}
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { assertInInjectionContext, inject, isDevMode } from '@angular/core';
|
2
|
-
import {
|
3
|
-
export function injectPopoverRoot() {
|
2
|
+
import { RdxPopoverRootDirective } from './popover-root.directive';
|
3
|
+
export function injectPopoverRoot(optional = false) {
|
4
4
|
isDevMode() && assertInInjectionContext(injectPopoverRoot);
|
5
|
-
return inject(
|
5
|
+
return inject(RdxPopoverRootDirective, { optional });
|
6
6
|
}
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1yb290LmluamVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvcG9wb3Zlci9zcmMvcG9wb3Zlci1yb290LmluamVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUluRSxNQUFNLFVBQVUsaUJBQWlCLENBQUMsUUFBUSxHQUFHLEtBQUs7SUFDOUMsU0FBUyxFQUFFLElBQUksd0JBQXdCLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUMzRCxPQUFPLE1BQU0sQ0FBQyx1QkFBdUIsRUFBRSxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7QUFDekQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFzc2VydEluSW5qZWN0aW9uQ29udGV4dCwgaW5qZWN0LCBpc0Rldk1vZGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJkeFBvcG92ZXJSb290RGlyZWN0aXZlIH0gZnJvbSAnLi9wb3BvdmVyLXJvb3QuZGlyZWN0aXZlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdFBvcG92ZXJSb290KG9wdGlvbmFsPzogZmFsc2UpOiBSZHhQb3BvdmVyUm9vdERpcmVjdGl2ZTtcbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RQb3BvdmVyUm9vdChvcHRpb25hbDogdHJ1ZSk6IFJkeFBvcG92ZXJSb290RGlyZWN0aXZlIHwgbnVsbDtcbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RQb3BvdmVyUm9vdChvcHRpb25hbCA9IGZhbHNlKTogUmR4UG9wb3ZlclJvb3REaXJlY3RpdmUgfCBudWxsIHtcbiAgICBpc0Rldk1vZGUoKSAmJiBhc3NlcnRJbkluamVjdGlvbkNvbnRleHQoaW5qZWN0UG9wb3ZlclJvb3QpO1xuICAgIHJldHVybiBpbmplY3QoUmR4UG9wb3ZlclJvb3REaXJlY3RpdmUsIHsgb3B0aW9uYWwgfSk7XG59XG4iXX0=
|
@@ -1,26 +1,25 @@
|
|
1
1
|
import { CdkOverlayOrigin } from '@angular/cdk/overlay';
|
2
|
-
import { computed, Directive, ElementRef, inject
|
2
|
+
import { computed, Directive, ElementRef, inject } from '@angular/core';
|
3
3
|
import { injectPopoverRoot } from './popover-root.inject';
|
4
4
|
import * as i0 from "@angular/core";
|
5
5
|
import * as i1 from "@angular/cdk/overlay";
|
6
|
-
let nextId = 0;
|
7
6
|
export class RdxPopoverTriggerDirective {
|
8
7
|
constructor() {
|
9
|
-
this.id = input(`rdx-popover-root-${nextId++}`);
|
10
|
-
this.popoverId = computed(() => `rdx-popover-${this.id()}`);
|
11
8
|
/** @ignore */
|
12
9
|
this.popoverRoot = injectPopoverRoot();
|
13
10
|
/** @ignore */
|
14
|
-
this.elementRef = inject(
|
11
|
+
this.elementRef = inject(ElementRef);
|
15
12
|
/** @ignore */
|
16
13
|
this.overlayOrigin = inject(CdkOverlayOrigin);
|
14
|
+
/** @ignore */
|
15
|
+
this.name = computed(() => `rdx-popover-trigger-${this.popoverRoot.uniqueId()}`);
|
17
16
|
}
|
18
17
|
/** @ignore */
|
19
|
-
|
18
|
+
click() {
|
20
19
|
this.popoverRoot.handleToggle();
|
21
20
|
}
|
22
21
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverTriggerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
23
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "
|
22
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.11", type: RdxPopoverTriggerDirective, isStandalone: true, selector: "[rdxPopoverTrigger]", host: { attributes: { "type": "button" }, listeners: { "click": "click()" }, properties: { "attr.id": "name()", "attr.aria-haspopup": "\"dialog\"", "attr.aria-expanded": "popoverRoot.isOpen()", "attr.aria-controls": "popoverRoot.popoverContentDirective().name()", "attr.data-state": "popoverRoot.state()" } }, hostDirectives: [{ directive: i1.CdkOverlayOrigin }], ngImport: i0 }); }
|
24
23
|
}
|
25
24
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverTriggerDirective, decorators: [{
|
26
25
|
type: Directive,
|
@@ -30,13 +29,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
|
|
30
29
|
hostDirectives: [CdkOverlayOrigin],
|
31
30
|
host: {
|
32
31
|
type: 'button',
|
33
|
-
'[attr.id]': '
|
32
|
+
'[attr.id]': 'name()',
|
34
33
|
'[attr.aria-haspopup]': '"dialog"',
|
35
34
|
'[attr.aria-expanded]': 'popoverRoot.isOpen()',
|
36
|
-
'[attr.aria-controls]': '
|
35
|
+
'[attr.aria-controls]': 'popoverRoot.popoverContentDirective().name()',
|
37
36
|
'[attr.data-state]': 'popoverRoot.state()',
|
38
|
-
'(click)': '
|
37
|
+
'(click)': 'click()'
|
39
38
|
}
|
40
39
|
}]
|
41
40
|
}] });
|
42
|
-
//# sourceMappingURL=data:application/json;base64,
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci10cmlnZ2VyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvcG9wb3Zlci9zcmMvcG9wb3Zlci10cmlnZ2VyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOzs7QUFnQjFELE1BQU0sT0FBTywwQkFBMEI7SUFkdkM7UUFlSSxjQUFjO1FBQ0ssZ0JBQVcsR0FBRyxpQkFBaUIsRUFBRSxDQUFDO1FBQ3JELGNBQWM7UUFDTCxlQUFVLEdBQUcsTUFBTSxDQUEwQixVQUFVLENBQUMsQ0FBQztRQUNsRSxjQUFjO1FBQ0wsa0JBQWEsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUVsRCxjQUFjO1FBQ0wsU0FBSSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyx1QkFBdUIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUM7S0FNeEY7SUFKRyxjQUFjO0lBQ2QsS0FBSztRQUNELElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDcEMsQ0FBQzsrR0FkUSwwQkFBMEI7bUdBQTFCLDBCQUEwQjs7NEZBQTFCLDBCQUEwQjtrQkFkdEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsY0FBYyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7b0JBQ2xDLElBQUksRUFBRTt3QkFDRixJQUFJLEVBQUUsUUFBUTt3QkFDZCxXQUFXLEVBQUUsUUFBUTt3QkFDckIsc0JBQXNCLEVBQUUsVUFBVTt3QkFDbEMsc0JBQXNCLEVBQUUsc0JBQXNCO3dCQUM5QyxzQkFBc0IsRUFBRSw4Q0FBOEM7d0JBQ3RFLG1CQUFtQixFQUFFLHFCQUFxQjt3QkFDMUMsU0FBUyxFQUFFLFNBQVM7cUJBQ3ZCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2RrT3ZlcmxheU9yaWdpbiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IGNvbXB1dGVkLCBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgaW5qZWN0UG9wb3ZlclJvb3QgfSBmcm9tICcuL3BvcG92ZXItcm9vdC5pbmplY3QnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tyZHhQb3BvdmVyVHJpZ2dlcl0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtDZGtPdmVybGF5T3JpZ2luXSxcbiAgICBob3N0OiB7XG4gICAgICAgIHR5cGU6ICdidXR0b24nLFxuICAgICAgICAnW2F0dHIuaWRdJzogJ25hbWUoKScsXG4gICAgICAgICdbYXR0ci5hcmlhLWhhc3BvcHVwXSc6ICdcImRpYWxvZ1wiJyxcbiAgICAgICAgJ1thdHRyLmFyaWEtZXhwYW5kZWRdJzogJ3BvcG92ZXJSb290LmlzT3BlbigpJyxcbiAgICAgICAgJ1thdHRyLmFyaWEtY29udHJvbHNdJzogJ3BvcG92ZXJSb290LnBvcG92ZXJDb250ZW50RGlyZWN0aXZlKCkubmFtZSgpJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc3RhdGVdJzogJ3BvcG92ZXJSb290LnN0YXRlKCknLFxuICAgICAgICAnKGNsaWNrKSc6ICdjbGljaygpJ1xuICAgIH1cbn0pXG5leHBvcnQgY2xhc3MgUmR4UG9wb3ZlclRyaWdnZXJEaXJlY3RpdmUge1xuICAgIC8qKiBAaWdub3JlICovXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHBvcG92ZXJSb290ID0gaW5qZWN0UG9wb3ZlclJvb3QoKTtcbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIHJlYWRvbmx5IGVsZW1lbnRSZWYgPSBpbmplY3Q8RWxlbWVudFJlZjxIVE1MRWxlbWVudD4+KEVsZW1lbnRSZWYpO1xuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVhZG9ubHkgb3ZlcmxheU9yaWdpbiA9IGluamVjdChDZGtPdmVybGF5T3JpZ2luKTtcblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVhZG9ubHkgbmFtZSA9IGNvbXB1dGVkKCgpID0+IGByZHgtcG9wb3Zlci10cmlnZ2VyLSR7dGhpcy5wb3BvdmVyUm9vdC51bmlxdWVJZCgpfWApO1xuXG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBjbGljaygpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5wb3BvdmVyUm9vdC5oYW5kbGVUb2dnbGUoKTtcbiAgICB9XG59XG4iXX0=
|
@@ -84,7 +84,7 @@ export const POPOVER_POSITIONS = {
|
|
84
84
|
export const DEFAULTS = {
|
85
85
|
offsets: {
|
86
86
|
side: 10,
|
87
|
-
align:
|
87
|
+
align: 0
|
88
88
|
}
|
89
89
|
};
|
90
|
-
//# sourceMappingURL=data:application/json;base64,
|
90
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci5jb25zdGFudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9wcmltaXRpdmVzL3BvcG92ZXIvc3JjL3BvcG92ZXIuY29uc3RhbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxlQUFlLEVBQXVCLGNBQWMsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBRXZGLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUF3QjtJQUNsRCxDQUFDLGNBQWMsQ0FBQyxHQUFHLENBQUMsRUFBRTtRQUNsQixDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN0QixPQUFPLEVBQUUsUUFBUTtZQUNqQixPQUFPLEVBQUUsS0FBSztZQUNkLFFBQVEsRUFBRSxRQUFRO1lBQ2xCLFFBQVEsRUFBRSxRQUFRO1NBQ3JCO1FBQ0QsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDckIsT0FBTyxFQUFFLE9BQU87WUFDaEIsT0FBTyxFQUFFLEtBQUs7WUFDZCxRQUFRLEVBQUUsT0FBTztZQUNqQixRQUFRLEVBQUUsUUFBUTtTQUNyQjtRQUNELENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ25CLE9BQU8sRUFBRSxLQUFLO1lBQ2QsT0FBTyxFQUFFLEtBQUs7WUFDZCxRQUFRLEVBQUUsS0FBSztZQUNmLFFBQVEsRUFBRSxRQUFRO1NBQ3JCO0tBQ0o7SUFDRCxDQUFDLGNBQWMsQ0FBQyxLQUFLLENBQUMsRUFBRTtRQUNwQixDQUFDLGVBQWUsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN0QixPQUFPLEVBQUUsS0FBSztZQUNkLE9BQU8sRUFBRSxRQUFRO1lBQ2pCLFFBQVEsRUFBRSxPQUFPO1lBQ2pCLFFBQVEsRUFBRSxRQUFRO1NBQ3JCO1FBQ0QsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFDLEVBQUU7WUFDckIsT0FBTyxFQUFFLEtBQUs7WUFDZCxPQUFPLEVBQUUsS0FBSztZQUNkLFFBQVEsRUFBRSxPQUFPO1lBQ2pCLFFBQVEsRUFBRSxLQUFLO1NBQ2xCO1FBQ0QsQ0FBQyxlQUFlLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDbkIsT0FBTyxFQUFFLEtBQUs7WUFDZCxPQUFPLEVBQUUsUUFBUTtZQUNqQixRQUFRLEVBQUUsT0FBTztZQUNqQixRQUFRLEVBQUUsUUFBUTtTQUNyQjtLQUNKO0lBQ0QsQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLEVBQUU7UUFDckIsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDdEIsT0FBTyxFQUFFLFFBQVE7WUFDakIsT0FBTyxFQUFFLFFBQVE7WUFDakIsUUFBUSxFQUFFLFFBQVE7WUFDbEIsUUFBUSxFQUFFLEtBQUs7U0FDbEI7UUFDRCxDQUFDLGVBQWUsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNyQixPQUFPLEVBQUUsT0FBTztZQUNoQixPQUFPLEVBQUUsUUFBUTtZQUNqQixRQUFRLEVBQUUsT0FBTztZQUNqQixRQUFRLEVBQUUsS0FBSztTQUNsQjtRQUNELENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ25CLE9BQU8sRUFBRSxLQUFLO1lBQ2QsT0FBTyxFQUFFLFFBQVE7WUFDakIsUUFBUSxFQUFFLEtBQUs7WUFDZixRQUFRLEVBQUUsS0FBSztTQUNsQjtLQUNKO0lBQ0QsQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDbkIsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDdEIsT0FBTyxFQUFFLE9BQU87WUFDaEIsT0FBTyxFQUFFLFFBQVE7WUFDakIsUUFBUSxFQUFFLEtBQUs7WUFDZixRQUFRLEVBQUUsUUFBUTtTQUNyQjtRQUNELENBQUMsZUFBZSxDQUFDLEtBQUssQ0FBQyxFQUFFO1lBQ3JCLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLE9BQU8sRUFBRSxLQUFLO1lBQ2QsUUFBUSxFQUFFLEtBQUs7WUFDZixRQUFRLEVBQUUsS0FBSztTQUNsQjtRQUNELENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxFQUFFO1lBQ25CLE9BQU8sRUFBRSxPQUFPO1lBQ2hCLE9BQU8sRUFBRSxRQUFRO1lBQ2pCLFFBQVEsRUFBRSxLQUFLO1lBQ2YsUUFBUSxFQUFFLFFBQVE7U0FDckI7S0FDSjtDQUNLLENBQUM7QUFFWCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQUc7SUFDcEIsT0FBTyxFQUFFO1FBQ0wsSUFBSSxFQUFFLEVBQUU7UUFDUixLQUFLLEVBQUUsQ0FBQztLQUNYO0NBQ0ssQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJkeFBvcG92ZXJBbGlnbiwgUmR4UG9wb3ZlclBvc2l0aW9ucywgUmR4UG9wb3ZlclNpZGUgfSBmcm9tICcuL3BvcG92ZXIudHlwZXMnO1xuXG5leHBvcnQgY29uc3QgUE9QT1ZFUl9QT1NJVElPTlM6IFJkeFBvcG92ZXJQb3NpdGlvbnMgPSB7XG4gICAgW1JkeFBvcG92ZXJTaWRlLlRvcF06IHtcbiAgICAgICAgW1JkeFBvcG92ZXJBbGlnbi5DZW50ZXJdOiB7XG4gICAgICAgICAgICBvcmlnaW5YOiAnY2VudGVyJyxcbiAgICAgICAgICAgIG9yaWdpblk6ICd0b3AnLFxuICAgICAgICAgICAgb3ZlcmxheVg6ICdjZW50ZXInLFxuICAgICAgICAgICAgb3ZlcmxheVk6ICdib3R0b20nXG4gICAgICAgIH0sXG4gICAgICAgIFtSZHhQb3BvdmVyQWxpZ24uU3RhcnRdOiB7XG4gICAgICAgICAgICBvcmlnaW5YOiAnc3RhcnQnLFxuICAgICAgICAgICAgb3JpZ2luWTogJ3RvcCcsXG4gICAgICAgICAgICBvdmVybGF5WDogJ3N0YXJ0JyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAnYm90dG9tJ1xuICAgICAgICB9LFxuICAgICAgICBbUmR4UG9wb3ZlckFsaWduLkVuZF06IHtcbiAgICAgICAgICAgIG9yaWdpblg6ICdlbmQnLFxuICAgICAgICAgICAgb3JpZ2luWTogJ3RvcCcsXG4gICAgICAgICAgICBvdmVybGF5WDogJ2VuZCcsXG4gICAgICAgICAgICBvdmVybGF5WTogJ2JvdHRvbSdcbiAgICAgICAgfVxuICAgIH0sXG4gICAgW1JkeFBvcG92ZXJTaWRlLlJpZ2h0XToge1xuICAgICAgICBbUmR4UG9wb3ZlckFsaWduLkNlbnRlcl06IHtcbiAgICAgICAgICAgIG9yaWdpblg6ICdlbmQnLFxuICAgICAgICAgICAgb3JpZ2luWTogJ2NlbnRlcicsXG4gICAgICAgICAgICBvdmVybGF5WDogJ3N0YXJ0JyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAnY2VudGVyJ1xuICAgICAgICB9LFxuICAgICAgICBbUmR4UG9wb3ZlckFsaWduLlN0YXJ0XToge1xuICAgICAgICAgICAgb3JpZ2luWDogJ2VuZCcsXG4gICAgICAgICAgICBvcmlnaW5ZOiAndG9wJyxcbiAgICAgICAgICAgIG92ZXJsYXlYOiAnc3RhcnQnLFxuICAgICAgICAgICAgb3ZlcmxheVk6ICd0b3AnXG4gICAgICAgIH0sXG4gICAgICAgIFtSZHhQb3BvdmVyQWxpZ24uRW5kXToge1xuICAgICAgICAgICAgb3JpZ2luWDogJ2VuZCcsXG4gICAgICAgICAgICBvcmlnaW5ZOiAnYm90dG9tJyxcbiAgICAgICAgICAgIG92ZXJsYXlYOiAnc3RhcnQnLFxuICAgICAgICAgICAgb3ZlcmxheVk6ICdib3R0b20nXG4gICAgICAgIH1cbiAgICB9LFxuICAgIFtSZHhQb3BvdmVyU2lkZS5Cb3R0b21dOiB7XG4gICAgICAgIFtSZHhQb3BvdmVyQWxpZ24uQ2VudGVyXToge1xuICAgICAgICAgICAgb3JpZ2luWDogJ2NlbnRlcicsXG4gICAgICAgICAgICBvcmlnaW5ZOiAnYm90dG9tJyxcbiAgICAgICAgICAgIG92ZXJsYXlYOiAnY2VudGVyJyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAndG9wJ1xuICAgICAgICB9LFxuICAgICAgICBbUmR4UG9wb3ZlckFsaWduLlN0YXJ0XToge1xuICAgICAgICAgICAgb3JpZ2luWDogJ3N0YXJ0JyxcbiAgICAgICAgICAgIG9yaWdpblk6ICdib3R0b20nLFxuICAgICAgICAgICAgb3ZlcmxheVg6ICdzdGFydCcsXG4gICAgICAgICAgICBvdmVybGF5WTogJ3RvcCdcbiAgICAgICAgfSxcbiAgICAgICAgW1JkeFBvcG92ZXJBbGlnbi5FbmRdOiB7XG4gICAgICAgICAgICBvcmlnaW5YOiAnZW5kJyxcbiAgICAgICAgICAgIG9yaWdpblk6ICdib3R0b20nLFxuICAgICAgICAgICAgb3ZlcmxheVg6ICdlbmQnLFxuICAgICAgICAgICAgb3ZlcmxheVk6ICd0b3AnXG4gICAgICAgIH1cbiAgICB9LFxuICAgIFtSZHhQb3BvdmVyU2lkZS5MZWZ0XToge1xuICAgICAgICBbUmR4UG9wb3ZlckFsaWduLkNlbnRlcl06IHtcbiAgICAgICAgICAgIG9yaWdpblg6ICdzdGFydCcsXG4gICAgICAgICAgICBvcmlnaW5ZOiAnY2VudGVyJyxcbiAgICAgICAgICAgIG92ZXJsYXlYOiAnZW5kJyxcbiAgICAgICAgICAgIG92ZXJsYXlZOiAnY2VudGVyJ1xuICAgICAgICB9LFxuICAgICAgICBbUmR4UG9wb3ZlckFsaWduLlN0YXJ0XToge1xuICAgICAgICAgICAgb3JpZ2luWDogJ3N0YXJ0JyxcbiAgICAgICAgICAgIG9yaWdpblk6ICd0b3AnLFxuICAgICAgICAgICAgb3ZlcmxheVg6ICdlbmQnLFxuICAgICAgICAgICAgb3ZlcmxheVk6ICd0b3AnXG4gICAgICAgIH0sXG4gICAgICAgIFtSZHhQb3BvdmVyQWxpZ24uRW5kXToge1xuICAgICAgICAgICAgb3JpZ2luWDogJ3N0YXJ0JyxcbiAgICAgICAgICAgIG9yaWdpblk6ICdib3R0b20nLFxuICAgICAgICAgICAgb3ZlcmxheVg6ICdlbmQnLFxuICAgICAgICAgICAgb3ZlcmxheVk6ICdib3R0b20nXG4gICAgICAgIH1cbiAgICB9XG59IGFzIGNvbnN0O1xuXG5leHBvcnQgY29uc3QgREVGQVVMVFMgPSB7XG4gICAgb2Zmc2V0czoge1xuICAgICAgICBzaWRlOiAxMCxcbiAgICAgICAgYWxpZ246IDBcbiAgICB9XG59IGFzIGNvbnN0O1xuIl19
|
@@ -11,4 +11,21 @@ export var RdxPopoverAlign;
|
|
11
11
|
RdxPopoverAlign["Center"] = "center";
|
12
12
|
RdxPopoverAlign["End"] = "end";
|
13
13
|
})(RdxPopoverAlign || (RdxPopoverAlign = {}));
|
14
|
-
|
14
|
+
export var RdxPopoverState;
|
15
|
+
(function (RdxPopoverState) {
|
16
|
+
RdxPopoverState["OPEN"] = "open";
|
17
|
+
RdxPopoverState["CLOSED"] = "closed";
|
18
|
+
})(RdxPopoverState || (RdxPopoverState = {}));
|
19
|
+
export var RdxPopoverAttachDetachEvent;
|
20
|
+
(function (RdxPopoverAttachDetachEvent) {
|
21
|
+
RdxPopoverAttachDetachEvent["ATTACH"] = "attach";
|
22
|
+
RdxPopoverAttachDetachEvent["DETACH"] = "detach";
|
23
|
+
})(RdxPopoverAttachDetachEvent || (RdxPopoverAttachDetachEvent = {}));
|
24
|
+
export var RdxPopoverAnimationStatus;
|
25
|
+
(function (RdxPopoverAnimationStatus) {
|
26
|
+
RdxPopoverAnimationStatus["OPEN_STARTED"] = "open_started";
|
27
|
+
RdxPopoverAnimationStatus["OPEN_ENDED"] = "open_ended";
|
28
|
+
RdxPopoverAnimationStatus["CLOSED_STARTED"] = "closed_started";
|
29
|
+
RdxPopoverAnimationStatus["CLOSED_ENDED"] = "closed_ended";
|
30
|
+
})(RdxPopoverAnimationStatus || (RdxPopoverAnimationStatus = {}));
|
31
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvcG9wb3Zlci9zcmMvcG9wb3Zlci50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQU4sSUFBWSxjQUtYO0FBTEQsV0FBWSxjQUFjO0lBQ3RCLDZCQUFXLENBQUE7SUFDWCxpQ0FBZSxDQUFBO0lBQ2YsbUNBQWlCLENBQUE7SUFDakIsK0JBQWEsQ0FBQTtBQUNqQixDQUFDLEVBTFcsY0FBYyxLQUFkLGNBQWMsUUFLekI7QUFFRCxNQUFNLENBQU4sSUFBWSxlQUlYO0FBSkQsV0FBWSxlQUFlO0lBQ3ZCLGtDQUFlLENBQUE7SUFDZixvQ0FBaUIsQ0FBQTtJQUNqQiw4QkFBVyxDQUFBO0FBQ2YsQ0FBQyxFQUpXLGVBQWUsS0FBZixlQUFlLFFBSTFCO0FBRUQsTUFBTSxDQUFOLElBQVksZUFHWDtBQUhELFdBQVksZUFBZTtJQUN2QixnQ0FBYSxDQUFBO0lBQ2Isb0NBQWlCLENBQUE7QUFDckIsQ0FBQyxFQUhXLGVBQWUsS0FBZixlQUFlLFFBRzFCO0FBRUQsTUFBTSxDQUFOLElBQVksMkJBR1g7QUFIRCxXQUFZLDJCQUEyQjtJQUNuQyxnREFBaUIsQ0FBQTtJQUNqQixnREFBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSFcsMkJBQTJCLEtBQTNCLDJCQUEyQixRQUd0QztBQUVELE1BQU0sQ0FBTixJQUFZLHlCQUtYO0FBTEQsV0FBWSx5QkFBeUI7SUFDakMsMERBQTZCLENBQUE7SUFDN0Isc0RBQXlCLENBQUE7SUFDekIsOERBQWlDLENBQUE7SUFDakMsMERBQTZCLENBQUE7QUFDakMsQ0FBQyxFQUxXLHlCQUF5QixLQUF6Qix5QkFBeUIsUUFLcEMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25uZWN0aW9uUG9zaXRpb25QYWlyIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuXG5leHBvcnQgZW51bSBSZHhQb3BvdmVyU2lkZSB7XG4gICAgVG9wID0gJ3RvcCcsXG4gICAgUmlnaHQgPSAncmlnaHQnLFxuICAgIEJvdHRvbSA9ICdib3R0b20nLFxuICAgIExlZnQgPSAnbGVmdCdcbn1cblxuZXhwb3J0IGVudW0gUmR4UG9wb3ZlckFsaWduIHtcbiAgICBTdGFydCA9ICdzdGFydCcsXG4gICAgQ2VudGVyID0gJ2NlbnRlcicsXG4gICAgRW5kID0gJ2VuZCdcbn1cblxuZXhwb3J0IGVudW0gUmR4UG9wb3ZlclN0YXRlIHtcbiAgICBPUEVOID0gJ29wZW4nLFxuICAgIENMT1NFRCA9ICdjbG9zZWQnXG59XG5cbmV4cG9ydCBlbnVtIFJkeFBvcG92ZXJBdHRhY2hEZXRhY2hFdmVudCB7XG4gICAgQVRUQUNIID0gJ2F0dGFjaCcsXG4gICAgREVUQUNIID0gJ2RldGFjaCdcbn1cblxuZXhwb3J0IGVudW0gUmR4UG9wb3ZlckFuaW1hdGlvblN0YXR1cyB7XG4gICAgT1BFTl9TVEFSVEVEID0gJ29wZW5fc3RhcnRlZCcsXG4gICAgT1BFTl9FTkRFRCA9ICdvcGVuX2VuZGVkJyxcbiAgICBDTE9TRURfU1RBUlRFRCA9ICdjbG9zZWRfc3RhcnRlZCcsXG4gICAgQ0xPU0VEX0VOREVEID0gJ2Nsb3NlZF9lbmRlZCdcbn1cblxuZXhwb3J0IHR5cGUgUmR4U2lkZUFuZEFsaWduID0geyBzaWRlOiBSZHhQb3BvdmVyU2lkZTsgYWxpZ246IFJkeFBvcG92ZXJBbGlnbiB9O1xuZXhwb3J0IHR5cGUgUmR4U2lkZUFuZEFsaWduT2Zmc2V0cyA9IHsgc2lkZU9mZnNldDogbnVtYmVyOyBhbGlnbk9mZnNldDogbnVtYmVyIH07XG5cbmV4cG9ydCB0eXBlIFJkeFBvcG92ZXJQb3NpdGlvbnMgPSB7XG4gICAgW2tleSBpbiBSZHhQb3BvdmVyU2lkZV06IHtcbiAgICAgICAgW2tleSBpbiBSZHhQb3BvdmVyQWxpZ25dOiBDb25uZWN0aW9uUG9zaXRpb25QYWlyO1xuICAgIH07XG59O1xuXG5leHBvcnQgdHlwZSBSZHhBbGxQb3NzaWJsZUNvbm5lY3RlZFBvc2l0aW9ucyA9IFJlYWRvbmx5TWFwPFxuICAgIGAke1JkeFBvcG92ZXJTaWRlfXwke1JkeFBvcG92ZXJBbGlnbn1gLFxuICAgIENvbm5lY3Rpb25Qb3NpdGlvblBhaXJcbj47XG5cbmV4cG9ydCB0eXBlIFJkeEFycm93UG9zaXRpb25QYXJhbXMgPSB7XG4gICAgdG9wOiBzdHJpbmc7XG4gICAgbGVmdDogc3RyaW5nO1xuICAgIHRyYW5zZm9ybTogc3RyaW5nO1xufTtcbiJdfQ==
|