@radix-ng/primitives 0.20.2 → 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.
Files changed (63) hide show
  1. package/avatar/src/avatar-fallback.directive.d.ts +1 -1
  2. package/avatar/src/avatar-image.directive.d.ts +3 -3
  3. package/compodoc/documentation.json +5818 -1682
  4. package/core/index.d.ts +1 -0
  5. package/core/src/id-generator.d.ts +12 -0
  6. package/esm2022/avatar/src/avatar-fallback.directive.mjs +6 -8
  7. package/esm2022/avatar/src/avatar-image.directive.mjs +4 -3
  8. package/esm2022/core/index.mjs +2 -1
  9. package/esm2022/core/src/create-inject-context/index.mjs +2 -2
  10. package/esm2022/core/src/id-generator.mjs +43 -0
  11. package/esm2022/popover/index.mjs +14 -4
  12. package/esm2022/popover/src/popover-anchor.directive.mjs +70 -0
  13. package/esm2022/popover/src/popover-anchor.token.mjs +3 -0
  14. package/esm2022/popover/src/popover-arrow.directive.mjs +12 -7
  15. package/esm2022/popover/src/popover-close.directive.mjs +16 -4
  16. package/esm2022/popover/src/popover-close.token.mjs +3 -0
  17. package/esm2022/popover/src/popover-content-attributes.component.mjs +70 -0
  18. package/esm2022/popover/src/popover-content-attributes.token.mjs +3 -0
  19. package/esm2022/popover/src/popover-content.directive.mjs +120 -84
  20. package/esm2022/popover/src/popover-root.directive.mjs +232 -64
  21. package/esm2022/popover/src/popover-root.inject.mjs +4 -4
  22. package/esm2022/popover/src/popover-trigger.directive.mjs +5 -7
  23. package/esm2022/popover/src/popover.types.mjs +18 -1
  24. package/esm2022/popover/src/popover.utils.mjs +4 -6
  25. package/esm2022/switch/src/switch-input.directive.mjs +16 -7
  26. package/esm2022/switch/src/switch-root.directive.mjs +59 -14
  27. package/esm2022/switch/src/switch-thumb.directive.mjs +3 -3
  28. package/esm2022/toggle/index.mjs +2 -2
  29. package/esm2022/toggle/src/toggle-visually-hidden-input.directive.mjs +31 -0
  30. package/esm2022/toggle/src/toggle.directive.mjs +37 -8
  31. package/fesm2022/radix-ng-primitives-avatar.mjs +8 -9
  32. package/fesm2022/radix-ng-primitives-avatar.mjs.map +1 -1
  33. package/fesm2022/radix-ng-primitives-core.mjs +44 -3
  34. package/fesm2022/radix-ng-primitives-core.mjs.map +1 -1
  35. package/fesm2022/radix-ng-primitives-popover.mjs +672 -303
  36. package/fesm2022/radix-ng-primitives-popover.mjs.map +1 -1
  37. package/fesm2022/radix-ng-primitives-switch.mjs +76 -22
  38. package/fesm2022/radix-ng-primitives-switch.mjs.map +1 -1
  39. package/fesm2022/radix-ng-primitives-toggle.mjs +45 -15
  40. package/fesm2022/radix-ng-primitives-toggle.mjs.map +1 -1
  41. package/package.json +1 -1
  42. package/popover/index.d.ts +5 -1
  43. package/popover/src/popover-anchor.directive.d.ts +28 -0
  44. package/popover/src/popover-anchor.token.d.ts +3 -0
  45. package/popover/src/popover-arrow.directive.d.ts +8 -5
  46. package/popover/src/popover-close.directive.d.ts +1 -1
  47. package/popover/src/popover-close.token.d.ts +3 -0
  48. package/popover/src/popover-content-attributes.component.d.ts +17 -0
  49. package/popover/src/popover-content-attributes.token.d.ts +3 -0
  50. package/popover/src/popover-content.directive.d.ts +36 -23
  51. package/popover/src/popover-root.directive.d.ts +89 -18
  52. package/popover/src/popover-root.inject.d.ts +2 -1
  53. package/popover/src/popover-trigger.directive.d.ts +3 -5
  54. package/popover/src/popover.types.d.ts +14 -3
  55. package/switch/src/switch-input.directive.d.ts +2 -0
  56. package/switch/src/switch-root.directive.d.ts +33 -5
  57. package/toggle/index.d.ts +2 -2
  58. package/toggle/src/toggle-visually-hidden-input.directive.d.ts +6 -0
  59. package/toggle/src/toggle.directive.d.ts +19 -2
  60. package/esm2022/popover/src/popover-root.token.mjs +0 -3
  61. package/esm2022/toggle/src/toggle-input.directive.mjs +0 -30
  62. package/popover/src/popover-root.token.d.ts +0 -3
  63. package/toggle/src/toggle-input.directive.d.ts +0 -6
@@ -1,27 +1,56 @@
1
- import { DOCUMENT } from '@angular/common';
2
- import { computed, contentChild, Directive, effect, forwardRef, inject, input, output, signal, untracked, ViewContainerRef } from '@angular/core';
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";
8
10
  let nextId = 0;
9
11
  export class RdxPopoverRootDirective {
10
12
  constructor() {
13
+ /** @ignore */
11
14
  this.uniqueId = signal(++nextId);
15
+ /** @ignore */
12
16
  this.name = computed(() => `rdx-popover-root-${this.uniqueId()}`);
13
17
  /**
14
- * The open state of the popover when it is initially rendered. Use when you do not need to control its open state.
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
15
25
  */
16
26
  this.defaultOpen = input(false);
17
27
  /**
18
- * The controlled open state of the popover. Must be used in conjunction with onOpenChange.
28
+ * @description The controlled state of the popover. `open` input take precedence of `defaultOpen` input.
29
+ * @default undefined
19
30
  */
20
- this.open = input();
31
+ this.open = input(void 0);
21
32
  /**
22
- * Event handler called when the open state of the popover changes.
33
+ * @description Whether to control the state of the popover from external. Use in conjunction with `open` input.
34
+ * @default undefined
23
35
  */
24
- this.onOpenChange = output();
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);
25
54
  /** @ignore */
26
55
  this.popoverContentDirective = contentChild.required(RdxPopoverContentDirective);
27
56
  /** @ignore */
@@ -29,119 +58,258 @@ export class RdxPopoverRootDirective {
29
58
  /** @ignore */
30
59
  this.popoverArrowDirective = contentChild(RdxPopoverArrowToken);
31
60
  /** @ignore */
61
+ this.popoverCloseDirective = contentChild(RdxPopoverCloseToken);
62
+ /** @ignore */
63
+ this.popoverContentAttributesComponent = contentChild(RdxPopoverContentAttributesToken);
64
+ /** @ignore */
65
+ this.internalPopoverAnchorDirective = contentChild(RdxPopoverAnchorToken);
66
+ /** @ignore */
32
67
  this.viewContainerRef = inject(ViewContainerRef);
33
68
  /** @ignore */
34
- this.document = inject(DOCUMENT);
69
+ this.destroyRef = inject(DestroyRef);
35
70
  /** @ignore */
36
- this.isOpen = signal(this.defaultOpen());
71
+ this.state = signal(RdxPopoverState.CLOSED);
37
72
  /** @ignore */
38
- this.state = computed(() => {
39
- const currentIsOpen = this.isOpen();
40
- if (currentIsOpen) {
41
- return 'open';
42
- }
43
- return 'closed';
44
- });
73
+ this.attachDetachEvent = signal(RdxPopoverAttachDetachEvent.DETACH);
74
+ /** @ignore */
75
+ this.isFirstDefaultOpen = signal(false);
45
76
  /** @ignore */
46
- this.isControlledExternally = computed(() => signal(this.open() !== void 0));
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();
47
91
  this.onOpenChangeEffect();
48
- this.onIsOpenChangeEffect();
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
+ });
49
102
  }
50
103
  /** @ignore */
51
- ngOnInit() {
52
- if (this.defaultOpen()) {
53
- this.handleOpen();
54
- }
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
+ };
55
114
  }
56
115
  /** @ignore */
57
116
  controlledExternally() {
58
- return this.isControlledExternally().asReadonly();
117
+ return this.externalControl;
118
+ }
119
+ /** @ignore */
120
+ firstDefaultOpen() {
121
+ return this.isFirstDefaultOpen();
59
122
  }
60
123
  /** @ignore */
61
124
  handleOpen() {
62
- if (this.isControlledExternally()()) {
125
+ if (this.externalControl()) {
63
126
  return;
64
127
  }
65
- this.setOpen(true);
128
+ this.setState(RdxPopoverState.OPEN);
66
129
  }
67
130
  /** @ignore */
68
131
  handleClose() {
69
- if (this.isControlledExternally()()) {
132
+ if (this.isFirstDefaultOpen()) {
133
+ this.isFirstDefaultOpen.set(false);
134
+ }
135
+ if (this.externalControl()) {
70
136
  return;
71
137
  }
72
- this.setOpen(false);
138
+ this.setState(RdxPopoverState.CLOSED);
73
139
  }
74
140
  /** @ignore */
75
141
  handleToggle() {
76
- if (this.isControlledExternally()()) {
142
+ if (this.externalControl()) {
77
143
  return;
78
144
  }
79
145
  this.isOpen() ? this.handleClose() : this.handleOpen();
80
146
  }
81
147
  /** @ignore */
82
- setOpen(open = false) {
83
- this.document.dispatchEvent(new CustomEvent(`popover.${open ? 'open' : 'close'}`, {
84
- detail: {
85
- id: this.name()
86
- }
87
- }));
88
- this.isOpen.set(open);
89
- this.onOpenChange.emit(open);
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
+ }
90
164
  }
91
165
  /** @ignore */
92
- show() {
93
- this.popoverContentDirective().show();
166
+ closeContent() {
167
+ this.popoverContentDirective().close();
168
+ if (!this.cssAnimation() || !this.cssClosingAnimation()) {
169
+ this.cssAnimationStatus.set(null);
170
+ }
171
+ }
172
+ /** @ignore */
173
+ emitOnOpen() {
174
+ this.popoverContentDirective().onOpen.emit();
175
+ }
176
+ /** @ignore */
177
+ emitOnClosed() {
178
+ this.popoverContentDirective().onClosed.emit();
179
+ }
180
+ /** @ignore */
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;
232
+ effect(() => {
233
+ const state = this.state();
234
+ untracked(() => {
235
+ if (isFirst) {
236
+ isFirst = false;
237
+ return;
238
+ }
239
+ if (!this.ifOpenOrCloseWithoutAnimations(state)) {
240
+ return;
241
+ }
242
+ this.openOrClose(state);
243
+ });
244
+ }, {});
94
245
  }
95
246
  /** @ignore */
96
- hide() {
97
- this.popoverContentDirective().hide();
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
+ });
98
262
  }
99
263
  /** @ignore */
100
- onIsOpenChangeEffect() {
264
+ emitOpenOrClosedEventEffect() {
265
+ let isFirst = true;
101
266
  effect(() => {
102
- const isOpen = this.isOpen();
267
+ this.attachDetachEvent();
268
+ this.cssAnimationStatus();
103
269
  untracked(() => {
104
- if (isOpen) {
105
- this.show();
270
+ if (isFirst) {
271
+ isFirst = false;
272
+ return;
106
273
  }
107
- else {
108
- this.hide();
274
+ const canEmitOpenClose = untracked(() => this.canEmitOnOpenOrOnClosed());
275
+ if (!canEmitOpenClose) {
276
+ return;
109
277
  }
278
+ this.emitOnOpenOrOnClosed(this.state());
110
279
  });
111
280
  });
112
281
  }
113
282
  /** @ignore */
114
283
  onOpenChangeEffect() {
115
284
  effect(() => {
116
- const currentOpen = this.open();
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();
117
295
  untracked(() => {
118
- this.isControlledExternally().set(currentOpen !== void 0);
119
- if (this.isControlledExternally()()) {
120
- this.setOpen(currentOpen);
296
+ if (!defaultOpen || this.open()) {
297
+ effectRef.destroy();
298
+ return;
121
299
  }
300
+ this.handleOpen();
122
301
  });
123
302
  });
124
303
  }
125
304
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverRootDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
126
- 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 } }, outputs: { onOpenChange: "onOpenChange" }, providers: [
127
- {
128
- provide: RdxPopoverRootToken,
129
- useExisting: forwardRef(() => RdxPopoverRootDirective)
130
- }
131
- ], 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 }); }
132
306
  }
133
307
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverRootDirective, decorators: [{
134
308
  type: Directive,
135
309
  args: [{
136
310
  selector: '[rdxPopoverRoot]',
137
311
  standalone: true,
138
- providers: [
139
- {
140
- provide: RdxPopoverRootToken,
141
- useExisting: forwardRef(() => RdxPopoverRootDirective)
142
- }
143
- ],
144
312
  exportAs: 'rdxPopoverRoot'
145
313
  }]
146
314
  }], ctorParameters: () => [] });
147
- //# 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\nlet nextId = 0;\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    readonly uniqueId = signal(++nextId);\n    readonly name = computed(() => `rdx-popover-root-${this.uniqueId()}`);\n\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        this.document.dispatchEvent(\n            new CustomEvent(`popover.${open ? 'open' : 'close'}`, {\n                detail: {\n                    id: this.name()\n                }\n            })\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 { RdxPopoverRootToken } from './popover-root.token';
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(RdxPopoverRootToken);
5
+ return inject(RdxPopoverRootDirective, { optional });
6
6
  }
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1yb290LmluamVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvcG9wb3Zlci9zcmMvcG9wb3Zlci1yb290LmluamVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUU1RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUUzRCxNQUFNLFVBQVUsaUJBQWlCO0lBQzdCLFNBQVMsRUFBRSxJQUFJLHdCQUF3QixDQUFDLGlCQUFpQixDQUFDLENBQUM7SUFDM0QsT0FBTyxNQUFNLENBQUMsbUJBQW1CLENBQUMsQ0FBQztBQUN2QyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYXNzZXJ0SW5JbmplY3Rpb25Db250ZXh0LCBpbmplY3QsIGlzRGV2TW9kZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUmR4UG9wb3ZlclJvb3REaXJlY3RpdmUgfSBmcm9tICcuL3BvcG92ZXItcm9vdC5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgUmR4UG9wb3ZlclJvb3RUb2tlbiB9IGZyb20gJy4vcG9wb3Zlci1yb290LnRva2VuJztcblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdFBvcG92ZXJSb290KCk6IFJkeFBvcG92ZXJSb290RGlyZWN0aXZlIHtcbiAgICBpc0Rldk1vZGUoKSAmJiBhc3NlcnRJbkluamVjdGlvbkNvbnRleHQoaW5qZWN0UG9wb3ZlclJvb3QpO1xuICAgIHJldHVybiBpbmplY3QoUmR4UG9wb3ZlclJvb3RUb2tlbik7XG59XG4iXX0=
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci1yb290LmluamVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvcG9wb3Zlci9zcmMvcG9wb3Zlci1yb290LmluamVjdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUM1RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUluRSxNQUFNLFVBQVUsaUJBQWlCLENBQUMsUUFBUSxHQUFHLEtBQUs7SUFDOUMsU0FBUyxFQUFFLElBQUksd0JBQXdCLENBQUMsaUJBQWlCLENBQUMsQ0FBQztJQUMzRCxPQUFPLE1BQU0sQ0FBQyx1QkFBdUIsRUFBRSxFQUFFLFFBQVEsRUFBRSxDQUFDLENBQUM7QUFDekQsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFzc2VydEluSW5qZWN0aW9uQ29udGV4dCwgaW5qZWN0LCBpc0Rldk1vZGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFJkeFBvcG92ZXJSb290RGlyZWN0aXZlIH0gZnJvbSAnLi9wb3BvdmVyLXJvb3QuZGlyZWN0aXZlJztcblxuZXhwb3J0IGZ1bmN0aW9uIGluamVjdFBvcG92ZXJSb290KG9wdGlvbmFsPzogZmFsc2UpOiBSZHhQb3BvdmVyUm9vdERpcmVjdGl2ZTtcbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RQb3BvdmVyUm9vdChvcHRpb25hbDogdHJ1ZSk6IFJkeFBvcG92ZXJSb290RGlyZWN0aXZlIHwgbnVsbDtcbmV4cG9ydCBmdW5jdGlvbiBpbmplY3RQb3BvdmVyUm9vdChvcHRpb25hbCA9IGZhbHNlKTogUmR4UG9wb3ZlclJvb3REaXJlY3RpdmUgfCBudWxsIHtcbiAgICBpc0Rldk1vZGUoKSAmJiBhc3NlcnRJbkluamVjdGlvbkNvbnRleHQoaW5qZWN0UG9wb3ZlclJvb3QpO1xuICAgIHJldHVybiBpbmplY3QoUmR4UG9wb3ZlclJvb3REaXJlY3RpdmUsIHsgb3B0aW9uYWwgfSk7XG59XG4iXX0=
@@ -13,15 +13,13 @@ export class RdxPopoverTriggerDirective {
13
13
  this.overlayOrigin = inject(CdkOverlayOrigin);
14
14
  /** @ignore */
15
15
  this.name = computed(() => `rdx-popover-trigger-${this.popoverRoot.uniqueId()}`);
16
- /** @ignore */
17
- this.controlsId = computed(() => `rdx-popover-trigger-controls-${this.popoverRoot.uniqueId()}`);
18
16
  }
19
17
  /** @ignore */
20
- onClick() {
18
+ click() {
21
19
  this.popoverRoot.handleToggle();
22
20
  }
23
21
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverTriggerDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
24
- 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": "onClick()" }, properties: { "attr.id": "name()", "attr.aria-haspopup": "\"dialog\"", "attr.aria-expanded": "popoverRoot.isOpen()", "attr.aria-controls": "controlsId()", "attr.data-state": "popoverRoot.state()" } }, hostDirectives: [{ directive: i1.CdkOverlayOrigin }], ngImport: i0 }); }
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 }); }
25
23
  }
26
24
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImport: i0, type: RdxPopoverTriggerDirective, decorators: [{
27
25
  type: Directive,
@@ -34,10 +32,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.11", ngImpo
34
32
  '[attr.id]': 'name()',
35
33
  '[attr.aria-haspopup]': '"dialog"',
36
34
  '[attr.aria-expanded]': 'popoverRoot.isOpen()',
37
- '[attr.aria-controls]': 'controlsId()',
35
+ '[attr.aria-controls]': 'popoverRoot.popoverContentDirective().name()',
38
36
  '[attr.data-state]': 'popoverRoot.state()',
39
- '(click)': 'onClick()'
37
+ '(click)': 'click()'
40
38
  }
41
39
  }]
42
40
  }] });
43
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci10cmlnZ2VyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvcG9wb3Zlci9zcmMvcG9wb3Zlci10cmlnZ2VyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOzs7QUFnQjFELE1BQU0sT0FBTywwQkFBMEI7SUFkdkM7UUFlSSxjQUFjO1FBQ0wsZ0JBQVcsR0FBRyxpQkFBaUIsRUFBRSxDQUFDO1FBQzNDLGNBQWM7UUFDTCxlQUFVLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO1FBQ3pDLGNBQWM7UUFDTCxrQkFBYSxHQUFHLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO1FBRWxELGNBQWM7UUFDTCxTQUFJLEdBQUcsUUFBUSxDQUFDLEdBQUcsRUFBRSxDQUFDLHVCQUF1QixJQUFJLENBQUMsV0FBVyxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUNyRixjQUFjO1FBQ0wsZUFBVSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxnQ0FBZ0MsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUM7S0FNdkc7SUFKRyxjQUFjO0lBQ2QsT0FBTztRQUNILElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDcEMsQ0FBQzsrR0FoQlEsMEJBQTBCO21HQUExQiwwQkFBMEI7OzRGQUExQiwwQkFBMEI7a0JBZHRDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHFCQUFxQjtvQkFDL0IsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLGNBQWMsRUFBRSxDQUFDLGdCQUFnQixDQUFDO29CQUNsQyxJQUFJLEVBQUU7d0JBQ0YsSUFBSSxFQUFFLFFBQVE7d0JBQ2QsV0FBVyxFQUFFLFFBQVE7d0JBQ3JCLHNCQUFzQixFQUFFLFVBQVU7d0JBQ2xDLHNCQUFzQixFQUFFLHNCQUFzQjt3QkFDOUMsc0JBQXNCLEVBQUUsY0FBYzt3QkFDdEMsbUJBQW1CLEVBQUUscUJBQXFCO3dCQUMxQyxTQUFTLEVBQUUsV0FBVztxQkFDekI7aUJBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDZGtPdmVybGF5T3JpZ2luIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgY29tcHV0ZWQsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBpbmplY3RQb3BvdmVyUm9vdCB9IGZyb20gJy4vcG9wb3Zlci1yb290LmluamVjdCc7XG5cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAnW3JkeFBvcG92ZXJUcmlnZ2VyXScsXG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBob3N0RGlyZWN0aXZlczogW0Nka092ZXJsYXlPcmlnaW5dLFxuICAgIGhvc3Q6IHtcbiAgICAgICAgdHlwZTogJ2J1dHRvbicsXG4gICAgICAgICdbYXR0ci5pZF0nOiAnbmFtZSgpJyxcbiAgICAgICAgJ1thdHRyLmFyaWEtaGFzcG9wdXBdJzogJ1wiZGlhbG9nXCInLFxuICAgICAgICAnW2F0dHIuYXJpYS1leHBhbmRlZF0nOiAncG9wb3ZlclJvb3QuaXNPcGVuKCknLFxuICAgICAgICAnW2F0dHIuYXJpYS1jb250cm9sc10nOiAnY29udHJvbHNJZCgpJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc3RhdGVdJzogJ3BvcG92ZXJSb290LnN0YXRlKCknLFxuICAgICAgICAnKGNsaWNrKSc6ICdvbkNsaWNrKCknXG4gICAgfVxufSlcbmV4cG9ydCBjbGFzcyBSZHhQb3BvdmVyVHJpZ2dlckRpcmVjdGl2ZSB7XG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICByZWFkb25seSBwb3BvdmVyUm9vdCA9IGluamVjdFBvcG92ZXJSb290KCk7XG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICByZWFkb25seSBlbGVtZW50UmVmID0gaW5qZWN0KEVsZW1lbnRSZWYpO1xuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVhZG9ubHkgb3ZlcmxheU9yaWdpbiA9IGluamVjdChDZGtPdmVybGF5T3JpZ2luKTtcblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVhZG9ubHkgbmFtZSA9IGNvbXB1dGVkKCgpID0+IGByZHgtcG9wb3Zlci10cmlnZ2VyLSR7dGhpcy5wb3BvdmVyUm9vdC51bmlxdWVJZCgpfWApO1xuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVhZG9ubHkgY29udHJvbHNJZCA9IGNvbXB1dGVkKCgpID0+IGByZHgtcG9wb3Zlci10cmlnZ2VyLWNvbnRyb2xzLSR7dGhpcy5wb3BvdmVyUm9vdC51bmlxdWVJZCgpfWApO1xuXG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBvbkNsaWNrKCk6IHZvaWQge1xuICAgICAgICB0aGlzLnBvcG92ZXJSb290LmhhbmRsZVRvZ2dsZSgpO1xuICAgIH1cbn1cbiJdfQ==
41
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci10cmlnZ2VyLmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvcG9wb3Zlci9zcmMvcG9wb3Zlci10cmlnZ2VyLmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3hFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOzs7QUFnQjFELE1BQU0sT0FBTywwQkFBMEI7SUFkdkM7UUFlSSxjQUFjO1FBQ0ssZ0JBQVcsR0FBRyxpQkFBaUIsRUFBRSxDQUFDO1FBQ3JELGNBQWM7UUFDTCxlQUFVLEdBQUcsTUFBTSxDQUEwQixVQUFVLENBQUMsQ0FBQztRQUNsRSxjQUFjO1FBQ0wsa0JBQWEsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztRQUVsRCxjQUFjO1FBQ0wsU0FBSSxHQUFHLFFBQVEsQ0FBQyxHQUFHLEVBQUUsQ0FBQyx1QkFBdUIsSUFBSSxDQUFDLFdBQVcsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUM7S0FNeEY7SUFKRyxjQUFjO0lBQ2QsS0FBSztRQUNELElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDcEMsQ0FBQzsrR0FkUSwwQkFBMEI7bUdBQTFCLDBCQUEwQjs7NEZBQTFCLDBCQUEwQjtrQkFkdEMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUscUJBQXFCO29CQUMvQixVQUFVLEVBQUUsSUFBSTtvQkFDaEIsY0FBYyxFQUFFLENBQUMsZ0JBQWdCLENBQUM7b0JBQ2xDLElBQUksRUFBRTt3QkFDRixJQUFJLEVBQUUsUUFBUTt3QkFDZCxXQUFXLEVBQUUsUUFBUTt3QkFDckIsc0JBQXNCLEVBQUUsVUFBVTt3QkFDbEMsc0JBQXNCLEVBQUUsc0JBQXNCO3dCQUM5QyxzQkFBc0IsRUFBRSw4Q0FBOEM7d0JBQ3RFLG1CQUFtQixFQUFFLHFCQUFxQjt3QkFDMUMsU0FBUyxFQUFFLFNBQVM7cUJBQ3ZCO2lCQUNKIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2RrT3ZlcmxheU9yaWdpbiB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcbmltcG9ydCB7IGNvbXB1dGVkLCBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIGluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgaW5qZWN0UG9wb3ZlclJvb3QgfSBmcm9tICcuL3BvcG92ZXItcm9vdC5pbmplY3QnO1xuXG5ARGlyZWN0aXZlKHtcbiAgICBzZWxlY3RvcjogJ1tyZHhQb3BvdmVyVHJpZ2dlcl0nLFxuICAgIHN0YW5kYWxvbmU6IHRydWUsXG4gICAgaG9zdERpcmVjdGl2ZXM6IFtDZGtPdmVybGF5T3JpZ2luXSxcbiAgICBob3N0OiB7XG4gICAgICAgIHR5cGU6ICdidXR0b24nLFxuICAgICAgICAnW2F0dHIuaWRdJzogJ25hbWUoKScsXG4gICAgICAgICdbYXR0ci5hcmlhLWhhc3BvcHVwXSc6ICdcImRpYWxvZ1wiJyxcbiAgICAgICAgJ1thdHRyLmFyaWEtZXhwYW5kZWRdJzogJ3BvcG92ZXJSb290LmlzT3BlbigpJyxcbiAgICAgICAgJ1thdHRyLmFyaWEtY29udHJvbHNdJzogJ3BvcG92ZXJSb290LnBvcG92ZXJDb250ZW50RGlyZWN0aXZlKCkubmFtZSgpJyxcbiAgICAgICAgJ1thdHRyLmRhdGEtc3RhdGVdJzogJ3BvcG92ZXJSb290LnN0YXRlKCknLFxuICAgICAgICAnKGNsaWNrKSc6ICdjbGljaygpJ1xuICAgIH1cbn0pXG5leHBvcnQgY2xhc3MgUmR4UG9wb3ZlclRyaWdnZXJEaXJlY3RpdmUge1xuICAgIC8qKiBAaWdub3JlICovXG4gICAgcHJvdGVjdGVkIHJlYWRvbmx5IHBvcG92ZXJSb290ID0gaW5qZWN0UG9wb3ZlclJvb3QoKTtcbiAgICAvKiogQGlnbm9yZSAqL1xuICAgIHJlYWRvbmx5IGVsZW1lbnRSZWYgPSBpbmplY3Q8RWxlbWVudFJlZjxIVE1MRWxlbWVudD4+KEVsZW1lbnRSZWYpO1xuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVhZG9ubHkgb3ZlcmxheU9yaWdpbiA9IGluamVjdChDZGtPdmVybGF5T3JpZ2luKTtcblxuICAgIC8qKiBAaWdub3JlICovXG4gICAgcmVhZG9ubHkgbmFtZSA9IGNvbXB1dGVkKCgpID0+IGByZHgtcG9wb3Zlci10cmlnZ2VyLSR7dGhpcy5wb3BvdmVyUm9vdC51bmlxdWVJZCgpfWApO1xuXG4gICAgLyoqIEBpZ25vcmUgKi9cbiAgICBjbGljaygpOiB2b2lkIHtcbiAgICAgICAgdGhpcy5wb3BvdmVyUm9vdC5oYW5kbGVUb2dnbGUoKTtcbiAgICB9XG59XG4iXX0=
@@ -11,4 +11,21 @@ export var RdxPopoverAlign;
11
11
  RdxPopoverAlign["Center"] = "center";
12
12
  RdxPopoverAlign["End"] = "end";
13
13
  })(RdxPopoverAlign || (RdxPopoverAlign = {}));
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicG9wb3Zlci50eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3BhY2thZ2VzL3ByaW1pdGl2ZXMvcG9wb3Zlci9zcmMvcG9wb3Zlci50eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxNQUFNLENBQU4sSUFBWSxjQUtYO0FBTEQsV0FBWSxjQUFjO0lBQ3RCLDZCQUFXLENBQUE7SUFDWCxpQ0FBZSxDQUFBO0lBQ2YsbUNBQWlCLENBQUE7SUFDakIsK0JBQWEsQ0FBQTtBQUNqQixDQUFDLEVBTFcsY0FBYyxLQUFkLGNBQWMsUUFLekI7QUFFRCxNQUFNLENBQU4sSUFBWSxlQUlYO0FBSkQsV0FBWSxlQUFlO0lBQ3ZCLGtDQUFlLENBQUE7SUFDZixvQ0FBaUIsQ0FBQTtJQUNqQiw4QkFBVyxDQUFBO0FBQ2YsQ0FBQyxFQUpXLGVBQWUsS0FBZixlQUFlLFFBSTFCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29ubmVjdGlvblBvc2l0aW9uUGFpciB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9vdmVybGF5JztcblxuZXhwb3J0IGVudW0gUmR4UG9wb3ZlclNpZGUge1xuICAgIFRvcCA9ICd0b3AnLFxuICAgIFJpZ2h0ID0gJ3JpZ2h0JyxcbiAgICBCb3R0b20gPSAnYm90dG9tJyxcbiAgICBMZWZ0ID0gJ2xlZnQnXG59XG5cbmV4cG9ydCBlbnVtIFJkeFBvcG92ZXJBbGlnbiB7XG4gICAgU3RhcnQgPSAnc3RhcnQnLFxuICAgIENlbnRlciA9ICdjZW50ZXInLFxuICAgIEVuZCA9ICdlbmQnXG59XG5cbmV4cG9ydCB0eXBlIFJkeFBvcG92ZXJTdGF0ZSA9ICdvcGVuJyB8ICdjbG9zZWQnO1xuXG5leHBvcnQgdHlwZSBSZHhTaWRlQW5kQWxpZ24gPSB7IHNpZGU6IFJkeFBvcG92ZXJTaWRlOyBhbGlnbjogUmR4UG9wb3ZlckFsaWduIH07XG5leHBvcnQgdHlwZSBSZHhTaWRlQW5kQWxpZ25PZmZzZXRzID0geyBzaWRlT2Zmc2V0OiBudW1iZXI7IGFsaWduT2Zmc2V0OiBudW1iZXIgfTtcblxuZXhwb3J0IHR5cGUgUmR4UG9wb3ZlclBvc2l0aW9ucyA9IHtcbiAgICBba2V5IGluIFJkeFBvcG92ZXJTaWRlXToge1xuICAgICAgICBba2V5IGluIFJkeFBvcG92ZXJBbGlnbl06IENvbm5lY3Rpb25Qb3NpdGlvblBhaXI7XG4gICAgfTtcbn07XG5cbmV4cG9ydCB0eXBlIFJkeEFsbFBvc3NpYmxlQ29ubmVjdGVkUG9zaXRpb25zID0gUmVhZG9ubHlNYXA8XG4gICAgYCR7UmR4UG9wb3ZlclNpZGV9fCR7UmR4UG9wb3ZlckFsaWdufWAsXG4gICAgQ29ubmVjdGlvblBvc2l0aW9uUGFpclxuPjtcblxuZXhwb3J0IHR5cGUgUmR4QXJyb3dQb3NpdGlvblBhcmFtcyA9IHtcbiAgICB0b3A6IHN0cmluZztcbiAgICBib3R0b206IHN0cmluZztcbiAgICBsZWZ0OiBzdHJpbmc7XG4gICAgcmlnaHQ6IHN0cmluZztcbiAgICB0cmFuc2Zvcm06IHN0cmluZztcbn07XG4iXX0=
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==