@agnos-ui/angular-headless 0.0.1-alpha.1 → 0.0.1-alpha.10

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 (110) hide show
  1. package/components/accordion/accordion.d.ts +11 -0
  2. package/components/accordion/index.d.ts +1 -0
  3. package/components/alert/alert.d.ts +7 -0
  4. package/components/alert/index.d.ts +1 -0
  5. package/components/modal/index.d.ts +1 -0
  6. package/components/modal/modal.d.ts +7 -0
  7. package/components/pagination/index.d.ts +1 -0
  8. package/components/pagination/pagination.d.ts +8 -0
  9. package/components/progressbar/index.d.ts +1 -0
  10. package/components/progressbar/progressbar.d.ts +7 -0
  11. package/components/rating/index.d.ts +1 -0
  12. package/components/rating/rating.d.ts +6 -0
  13. package/components/select/index.d.ts +1 -0
  14. package/components/select/select.d.ts +8 -0
  15. package/components/slider/index.d.ts +1 -0
  16. package/components/slider/slider.d.ts +1 -0
  17. package/config.d.ts +44 -0
  18. package/esm2022/agnos-ui-angular-headless.mjs +2 -2
  19. package/esm2022/components/accordion/accordion.mjs +4 -0
  20. package/esm2022/components/accordion/index.mjs +2 -0
  21. package/esm2022/components/alert/alert.mjs +4 -0
  22. package/esm2022/components/alert/index.mjs +2 -0
  23. package/esm2022/components/modal/index.mjs +2 -0
  24. package/esm2022/components/modal/modal.mjs +4 -0
  25. package/esm2022/components/pagination/index.mjs +2 -0
  26. package/esm2022/components/pagination/pagination.mjs +4 -0
  27. package/esm2022/components/progressbar/index.mjs +2 -0
  28. package/esm2022/components/progressbar/progressbar.mjs +4 -0
  29. package/esm2022/components/rating/index.mjs +2 -0
  30. package/esm2022/components/rating/rating.mjs +4 -0
  31. package/esm2022/components/select/index.mjs +2 -0
  32. package/esm2022/components/select/select.mjs +4 -0
  33. package/esm2022/components/slider/index.mjs +2 -0
  34. package/esm2022/components/slider/slider.mjs +2 -0
  35. package/esm2022/config.mjs +112 -0
  36. package/esm2022/generated/config.mjs +2 -0
  37. package/esm2022/generated/index.mjs +23 -0
  38. package/esm2022/generated/services/extendWidget.mjs +2 -0
  39. package/esm2022/generated/services/floatingUI.mjs +2 -0
  40. package/esm2022/generated/services/focustrack.mjs +2 -0
  41. package/esm2022/generated/services/intersection.mjs +2 -0
  42. package/esm2022/generated/services/navManager.mjs +2 -0
  43. package/esm2022/generated/services/portal.mjs +2 -0
  44. package/esm2022/generated/services/siblingsInert.mjs +2 -0
  45. package/esm2022/generated/services/transitions/baseTransitions.mjs +2 -0
  46. package/esm2022/generated/services/transitions/bootstrap.mjs +2 -0
  47. package/esm2022/generated/services/transitions/collapse.mjs +2 -0
  48. package/esm2022/generated/services/transitions/cssTransitions.mjs +2 -0
  49. package/esm2022/generated/services/transitions/simpleClassTransition.mjs +2 -0
  50. package/esm2022/generated/slot.directive.mjs +2 -0
  51. package/esm2022/generated/slotDefault.directive.mjs +2 -0
  52. package/esm2022/generated/types.mjs +2 -0
  53. package/esm2022/generated/utils/coercion.mjs +2 -0
  54. package/esm2022/generated/utils/directive.mjs +2 -0
  55. package/esm2022/generated/utils/stores.mjs +2 -0
  56. package/esm2022/generated/utils/widget.mjs +2 -0
  57. package/esm2022/generated/utils/writables.mjs +2 -0
  58. package/esm2022/generated/utils/zone.mjs +2 -0
  59. package/esm2022/index.mjs +13 -0
  60. package/esm2022/slot.directive.mjs +201 -0
  61. package/esm2022/slotDefault.directive.mjs +21 -0
  62. package/esm2022/types.mjs +21 -0
  63. package/esm2022/utils/coercion.mjs +32 -0
  64. package/esm2022/utils/directive.mjs +72 -0
  65. package/esm2022/utils/stores.mjs +23 -0
  66. package/esm2022/utils/widget.mjs +131 -0
  67. package/esm2022/utils/zone.mjs +73 -0
  68. package/fesm2022/agnos-ui-angular-headless.mjs +486 -174
  69. package/fesm2022/agnos-ui-angular-headless.mjs.map +1 -1
  70. package/generated/config.d.ts +1 -0
  71. package/generated/index.d.ts +22 -0
  72. package/generated/services/extendWidget.d.ts +1 -0
  73. package/generated/services/floatingUI.d.ts +1 -0
  74. package/generated/services/focustrack.d.ts +1 -0
  75. package/generated/services/intersection.d.ts +1 -0
  76. package/generated/services/navManager.d.ts +1 -0
  77. package/generated/services/portal.d.ts +1 -0
  78. package/generated/services/siblingsInert.d.ts +1 -0
  79. package/generated/services/transitions/baseTransitions.d.ts +1 -0
  80. package/generated/services/transitions/bootstrap.d.ts +1 -0
  81. package/generated/services/transitions/collapse.d.ts +1 -0
  82. package/generated/services/transitions/cssTransitions.d.ts +1 -0
  83. package/generated/services/transitions/simpleClassTransition.d.ts +1 -0
  84. package/generated/slot.directive.d.ts +1 -0
  85. package/generated/slotDefault.directive.d.ts +1 -0
  86. package/generated/types.d.ts +1 -0
  87. package/generated/utils/coercion.d.ts +1 -0
  88. package/generated/utils/directive.d.ts +1 -0
  89. package/generated/utils/stores.d.ts +1 -0
  90. package/generated/utils/widget.d.ts +1 -0
  91. package/generated/utils/writables.d.ts +1 -0
  92. package/generated/utils/zone.d.ts +1 -0
  93. package/index.d.ts +9 -5
  94. package/package.json +14 -17
  95. package/{lib/slot.directive.d.ts → slot.directive.d.ts} +3 -1
  96. package/{lib/slotDefault.directive.d.ts → slotDefault.directive.d.ts} +2 -1
  97. package/types.d.ts +35 -0
  98. package/utils/coercion.d.ts +20 -0
  99. package/utils/directive.d.ts +23 -0
  100. package/utils/stores.d.ts +13 -0
  101. package/utils/widget.d.ts +44 -0
  102. package/utils/zone.d.ts +22 -0
  103. package/esm2022/lib/slot.directive.mjs +0 -199
  104. package/esm2022/lib/slotDefault.directive.mjs +0 -20
  105. package/esm2022/lib/use.directive.mjs +0 -57
  106. package/esm2022/lib/utils.mjs +0 -127
  107. package/esm2022/public-api.mjs +0 -9
  108. package/lib/use.directive.d.ts +0 -12
  109. package/lib/utils.d.ts +0 -95
  110. package/public-api.d.ts +0 -34
@@ -0,0 +1,201 @@
1
+ import { DOCUMENT } from '@angular/common';
2
+ import { Directive, EnvironmentInjector, Input, TemplateRef, ViewContainerRef, createComponent, inject, reflectComponentType } from '@angular/core';
3
+ import { ComponentTemplate } from './types';
4
+ import * as i0 from "@angular/core";
5
+ class SlotHandler {
6
+ constructor(viewContainerRef, document) {
7
+ this.viewContainerRef = viewContainerRef;
8
+ this.document = document;
9
+ }
10
+ slotChange(slot, props) { }
11
+ propsChange(slot, props) { }
12
+ destroy() { }
13
+ }
14
+ class StringSlotHandler extends SlotHandler {
15
+ #nodeRef;
16
+ #previousText = '';
17
+ slotChange(slot) {
18
+ if (slot === this.#previousText) {
19
+ return;
20
+ }
21
+ this.#previousText = slot;
22
+ if (this.#nodeRef) {
23
+ this.#nodeRef.textContent = slot;
24
+ }
25
+ else {
26
+ const viewContainerElement = this.viewContainerRef.element.nativeElement;
27
+ if (this.document && viewContainerElement?.parentNode) {
28
+ this.#nodeRef = viewContainerElement.parentNode.insertBefore(this.document.createTextNode(slot), viewContainerElement);
29
+ }
30
+ }
31
+ }
32
+ destroy() {
33
+ this.#nodeRef?.parentNode?.removeChild(this.#nodeRef);
34
+ this.#nodeRef = undefined;
35
+ }
36
+ }
37
+ class FunctionSlotHandler extends SlotHandler {
38
+ #stringSlotHandler = new StringSlotHandler(this.viewContainerRef, this.document);
39
+ slotChange(slot, props) {
40
+ this.#stringSlotHandler.slotChange(slot(props));
41
+ }
42
+ propsChange(slot, props) {
43
+ this.#stringSlotHandler.slotChange(slot(props));
44
+ }
45
+ destroy() {
46
+ this.#stringSlotHandler.destroy();
47
+ }
48
+ }
49
+ class ComponentSlotHandler extends SlotHandler {
50
+ #componentRef;
51
+ #properties;
52
+ slotChange(slot, props) {
53
+ if (this.#componentRef) {
54
+ this.destroy();
55
+ }
56
+ this.#componentRef = this.viewContainerRef.createComponent(slot);
57
+ this.#applyProperties(props);
58
+ }
59
+ #applyProperties(props, oldProperties) {
60
+ const properties = Object.keys(props);
61
+ this.#properties = properties;
62
+ const componentRef = this.#componentRef;
63
+ for (const property of properties) {
64
+ componentRef.setInput(property, props[property]);
65
+ oldProperties?.delete(property);
66
+ }
67
+ }
68
+ propsChange(slot, props) {
69
+ const oldProperties = new Set(this.#properties);
70
+ this.#applyProperties(props, oldProperties);
71
+ const componentRef = this.#componentRef;
72
+ for (const property of oldProperties) {
73
+ componentRef.setInput(property, undefined);
74
+ }
75
+ }
76
+ destroy() {
77
+ this.viewContainerRef.clear();
78
+ this.#componentRef = undefined;
79
+ }
80
+ }
81
+ class TemplateRefSlotHandler extends SlotHandler {
82
+ #viewRef;
83
+ #props;
84
+ slotChange(slot, props) {
85
+ if (this.#viewRef) {
86
+ this.destroy();
87
+ }
88
+ props = { ...props };
89
+ this.#props = props;
90
+ this.#viewRef = this.viewContainerRef.createEmbeddedView(slot, props);
91
+ }
92
+ propsChange(slot, props) {
93
+ if (this.#viewRef) {
94
+ const templateProps = this.#props;
95
+ const oldProperties = new Set(Object.keys(templateProps));
96
+ for (const property of Object.keys(props)) {
97
+ templateProps[property] = props[property];
98
+ oldProperties.delete(property);
99
+ }
100
+ for (const oldProperty of oldProperties) {
101
+ delete templateProps[oldProperty];
102
+ }
103
+ this.#viewRef.markForCheck();
104
+ }
105
+ }
106
+ destroy() {
107
+ this.viewContainerRef.clear();
108
+ }
109
+ }
110
+ class ComponentTemplateSlotHandler extends SlotHandler {
111
+ #componentRef;
112
+ #templateSlotHandler = new TemplateRefSlotHandler(this.viewContainerRef, this.document);
113
+ #templateRef;
114
+ slotChange(slot, props) {
115
+ if (this.#componentRef) {
116
+ this.destroy();
117
+ }
118
+ this.#componentRef = createComponent(slot.component, {
119
+ elementInjector: this.viewContainerRef.injector,
120
+ environmentInjector: this.viewContainerRef.injector.get(EnvironmentInjector),
121
+ });
122
+ this.#templateRef = this.#componentRef.instance[slot.templateProp];
123
+ this.#templateSlotHandler.slotChange(this.#templateRef, props);
124
+ }
125
+ propsChange(slot, props) {
126
+ this.#templateSlotHandler.propsChange(this.#templateRef, props);
127
+ }
128
+ destroy() {
129
+ this.#templateSlotHandler.destroy();
130
+ this.#componentRef?.destroy();
131
+ this.#componentRef = undefined;
132
+ }
133
+ }
134
+ const getSlotType = (value) => {
135
+ if (!value)
136
+ return undefined;
137
+ const type = typeof value;
138
+ switch (type) {
139
+ case 'string':
140
+ return StringSlotHandler;
141
+ case 'function':
142
+ if (reflectComponentType(value)) {
143
+ return ComponentSlotHandler;
144
+ }
145
+ return FunctionSlotHandler;
146
+ case 'object':
147
+ if (value instanceof TemplateRef) {
148
+ return TemplateRefSlotHandler;
149
+ }
150
+ if (value instanceof ComponentTemplate) {
151
+ return ComponentTemplateSlotHandler;
152
+ }
153
+ break;
154
+ }
155
+ return undefined;
156
+ };
157
+ export class SlotDirective {
158
+ constructor() {
159
+ this._viewContainerRef = inject(ViewContainerRef);
160
+ this._document = inject(DOCUMENT);
161
+ }
162
+ /** @inheritdoc */
163
+ ngOnChanges(changes) {
164
+ const slotChange = changes['slot'];
165
+ const propsChange = changes['props'];
166
+ const slot = this.slot;
167
+ if (slotChange) {
168
+ const newSlotType = getSlotType(slot);
169
+ if (newSlotType !== this._slotType) {
170
+ this._slotHandler?.destroy();
171
+ this._slotHandler = newSlotType ? new newSlotType(this._viewContainerRef, this._document) : undefined;
172
+ this._slotType = newSlotType;
173
+ }
174
+ this._slotHandler?.slotChange(slot, this.props);
175
+ }
176
+ else if (propsChange) {
177
+ this._slotHandler?.propsChange(slot, this.props);
178
+ }
179
+ }
180
+ /** @inheritdoc */
181
+ ngOnDestroy() {
182
+ this._slotHandler?.destroy();
183
+ this._slotHandler = undefined;
184
+ }
185
+ static { this.ɵfac = function SlotDirective_Factory(t) { return new (t || SlotDirective)(); }; }
186
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SlotDirective, selectors: [["", "auSlot", ""]], inputs: { slot: [i0.ɵɵInputFlags.None, "auSlot", "slot"], props: [i0.ɵɵInputFlags.None, "auSlotProps", "props"] }, standalone: true, features: [i0.ɵɵNgOnChangesFeature] }); }
187
+ }
188
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SlotDirective, [{
189
+ type: Directive,
190
+ args: [{
191
+ selector: '[auSlot]',
192
+ standalone: true,
193
+ }]
194
+ }], null, { slot: [{
195
+ type: Input,
196
+ args: ['auSlot']
197
+ }], props: [{
198
+ type: Input,
199
+ args: ['auSlotProps']
200
+ }] }); })();
201
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slot.directive.js","sourceRoot":"","sources":["../../src/slot.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {DOCUMENT} from '@angular/common';\nimport type {ComponentRef, EmbeddedViewRef, OnChanges, OnDestroy, SimpleChanges, Type} from '@angular/core';\nimport {Directive, EnvironmentInjector, Input, TemplateRef, ViewContainerRef, createComponent, inject, reflectComponentType} from '@angular/core';\nimport type {SlotContent} from './types';\nimport {ComponentTemplate} from './types';\n\nabstract class SlotHandler<Props extends Record<string, any>, Slot extends SlotContent<Props> = SlotContent<Props>> {\n\tconstructor(\n\t\tpublic viewContainerRef: ViewContainerRef,\n\t\tpublic document: Document,\n\t) {}\n\tslotChange(slot: Slot, props: Props) {}\n\tpropsChange(slot: Slot, props: Props) {}\n\tdestroy() {}\n}\n\nclass StringSlotHandler<Props extends Record<string, any>> extends SlotHandler<Props, string> {\n\t#nodeRef: Text | undefined;\n\t#previousText = '';\n\n\toverride slotChange(slot: string): void {\n\t\tif (slot === this.#previousText) {\n\t\t\treturn;\n\t\t}\n\t\tthis.#previousText = slot;\n\t\tif (this.#nodeRef) {\n\t\t\tthis.#nodeRef.textContent = slot;\n\t\t} else {\n\t\t\tconst viewContainerElement: Comment | undefined = this.viewContainerRef.element.nativeElement;\n\t\t\tif (this.document && viewContainerElement?.parentNode) {\n\t\t\t\tthis.#nodeRef = viewContainerElement.parentNode.insertBefore(this.document.createTextNode(slot), viewContainerElement);\n\t\t\t}\n\t\t}\n\t}\n\n\toverride destroy(): void {\n\t\tthis.#nodeRef?.parentNode?.removeChild(this.#nodeRef);\n\t\tthis.#nodeRef = undefined;\n\t}\n}\n\nclass FunctionSlotHandler<Props extends Record<string, any>> extends SlotHandler<Props, (props: Props) => string> {\n\t#stringSlotHandler = new StringSlotHandler(this.viewContainerRef, this.document);\n\n\toverride slotChange(slot: (props: Props) => string, props: Props): void {\n\t\tthis.#stringSlotHandler.slotChange(slot(props));\n\t}\n\n\toverride propsChange(slot: (props: Props) => string, props: Props): void {\n\t\tthis.#stringSlotHandler.slotChange(slot(props));\n\t}\n\n\toverride destroy(): void {\n\t\tthis.#stringSlotHandler.destroy();\n\t}\n}\n\nclass ComponentSlotHandler<Props extends Record<string, any>> extends SlotHandler<Props, Type<unknown>> {\n\t#componentRef: ComponentRef<any> | undefined;\n\t#properties: string[];\n\n\toverride slotChange(slot: Type<unknown>, props: Props): void {\n\t\tif (this.#componentRef) {\n\t\t\tthis.destroy();\n\t\t}\n\t\tthis.#componentRef = this.viewContainerRef.createComponent(slot);\n\t\tthis.#applyProperties(props);\n\t}\n\n\t#applyProperties(props: Props, oldProperties?: Set<string>) {\n\t\tconst properties = Object.keys(props);\n\t\tthis.#properties = properties;\n\t\tconst componentRef = this.#componentRef!;\n\t\tfor (const property of properties) {\n\t\t\tcomponentRef.setInput(property, props[property]);\n\t\t\toldProperties?.delete(property);\n\t\t}\n\t}\n\n\toverride propsChange(slot: Type<unknown>, props: Props): void {\n\t\tconst oldProperties = new Set(this.#properties);\n\t\tthis.#applyProperties(props, oldProperties);\n\t\tconst componentRef = this.#componentRef!;\n\t\tfor (const property of oldProperties) {\n\t\t\tcomponentRef.setInput(property, undefined);\n\t\t}\n\t}\n\n\toverride destroy(): void {\n\t\tthis.viewContainerRef.clear();\n\t\tthis.#componentRef = undefined;\n\t}\n}\n\nclass TemplateRefSlotHandler<Props extends Record<string, any>> extends SlotHandler<Props, TemplateRef<Props>> {\n\t#viewRef: EmbeddedViewRef<Props> | undefined;\n\t#props: Props;\n\n\toverride slotChange(slot: TemplateRef<Props>, props: Props): void {\n\t\tif (this.#viewRef) {\n\t\t\tthis.destroy();\n\t\t}\n\t\tprops = {...props};\n\t\tthis.#props = props;\n\t\tthis.#viewRef = this.viewContainerRef.createEmbeddedView(slot, props);\n\t}\n\n\toverride propsChange(slot: TemplateRef<Props>, props: Props): void {\n\t\tif (this.#viewRef) {\n\t\t\tconst templateProps = this.#props;\n\t\t\tconst oldProperties = new Set<keyof Props>(Object.keys(templateProps));\n\t\t\tfor (const property of Object.keys(props) as (keyof Props)[]) {\n\t\t\t\ttemplateProps[property] = props[property];\n\t\t\t\toldProperties.delete(property);\n\t\t\t}\n\t\t\tfor (const oldProperty of oldProperties) {\n\t\t\t\tdelete templateProps[oldProperty];\n\t\t\t}\n\t\t\tthis.#viewRef.markForCheck();\n\t\t}\n\t}\n\n\toverride destroy(): void {\n\t\tthis.viewContainerRef.clear();\n\t}\n}\n\nclass ComponentTemplateSlotHandler<\n\tProps extends Record<string, any>,\n\tK extends string,\n\tT extends {[key in K]: TemplateRef<Props>},\n> extends SlotHandler<Props, ComponentTemplate<Props, K, T>> {\n\t#componentRef: ComponentRef<T> | undefined;\n\t#templateSlotHandler = new TemplateRefSlotHandler(this.viewContainerRef, this.document);\n\t#templateRef: TemplateRef<Props> | undefined;\n\n\toverride slotChange(slot: ComponentTemplate<Props, K, T>, props: Props): void {\n\t\tif (this.#componentRef) {\n\t\t\tthis.destroy();\n\t\t}\n\t\tthis.#componentRef = createComponent(slot.component, {\n\t\t\telementInjector: this.viewContainerRef.injector,\n\t\t\tenvironmentInjector: this.viewContainerRef.injector.get(EnvironmentInjector),\n\t\t});\n\t\tthis.#templateRef = this.#componentRef.instance[slot.templateProp];\n\t\tthis.#templateSlotHandler.slotChange(this.#templateRef, props);\n\t}\n\n\toverride propsChange(slot: ComponentTemplate<Props, K, T>, props: Props): void {\n\t\tthis.#templateSlotHandler.propsChange(this.#templateRef!, props);\n\t}\n\n\toverride destroy(): void {\n\t\tthis.#templateSlotHandler.destroy();\n\t\tthis.#componentRef?.destroy();\n\t\tthis.#componentRef = undefined;\n\t}\n}\n\nconst getSlotType = (value: any): undefined | {new (viewContainerRef: ViewContainerRef, document: Document): SlotHandler<any>} => {\n\tif (!value) return undefined;\n\tconst type = typeof value;\n\tswitch (type) {\n\t\tcase 'string':\n\t\t\treturn StringSlotHandler;\n\t\tcase 'function':\n\t\t\tif (reflectComponentType(value)) {\n\t\t\t\treturn ComponentSlotHandler;\n\t\t\t}\n\t\t\treturn FunctionSlotHandler;\n\t\tcase 'object':\n\t\t\tif (value instanceof TemplateRef) {\n\t\t\t\treturn TemplateRefSlotHandler;\n\t\t\t}\n\t\t\tif (value instanceof ComponentTemplate) {\n\t\t\t\treturn ComponentTemplateSlotHandler;\n\t\t\t}\n\t\t\tbreak;\n\t}\n\treturn undefined;\n};\n\n@Directive({\n\tselector: '[auSlot]',\n\tstandalone: true,\n})\nexport class SlotDirective<Props extends Record<string, any>> implements OnChanges, OnDestroy {\n\t@Input('auSlot') slot: SlotContent<Props>;\n\t@Input('auSlotProps') props: Props;\n\n\tprivate _viewContainerRef = inject(ViewContainerRef);\n\tprivate _document = inject(DOCUMENT);\n\tprivate _slotType: ReturnType<typeof getSlotType>;\n\tprivate _slotHandler: SlotHandler<Props> | undefined;\n\n\t/** @inheritdoc */\n\tngOnChanges(changes: SimpleChanges): void {\n\t\tconst slotChange = changes['slot'];\n\t\tconst propsChange = changes['props'];\n\t\tconst slot = this.slot;\n\t\tif (slotChange) {\n\t\t\tconst newSlotType = getSlotType(slot);\n\t\t\tif (newSlotType !== this._slotType) {\n\t\t\t\tthis._slotHandler?.destroy();\n\t\t\t\tthis._slotHandler = newSlotType ? new newSlotType(this._viewContainerRef, this._document) : undefined;\n\t\t\t\tthis._slotType = newSlotType;\n\t\t\t}\n\t\t\tthis._slotHandler?.slotChange(slot, this.props);\n\t\t} else if (propsChange) {\n\t\t\tthis._slotHandler?.propsChange(slot, this.props);\n\t\t}\n\t}\n\n\t/** @inheritdoc */\n\tngOnDestroy(): void {\n\t\tthis._slotHandler?.destroy();\n\t\tthis._slotHandler = undefined;\n\t}\n}\n"]}
@@ -0,0 +1,21 @@
1
+ import { Directive, Input, TemplateRef, inject } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class SlotDefaultDirective {
4
+ constructor() {
5
+ this.templateRef = inject((TemplateRef));
6
+ }
7
+ /** @inheritdoc */
8
+ ngOnInit() {
9
+ this.auSlotDefault.update((value) => ({ ...value, slotDefault: this.templateRef }));
10
+ }
11
+ static { this.ɵfac = function SlotDefaultDirective_Factory(t) { return new (t || SlotDefaultDirective)(); }; }
12
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SlotDefaultDirective, selectors: [["", "auSlotDefault", ""]], inputs: { auSlotDefault: "auSlotDefault" }, standalone: true }); }
13
+ }
14
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SlotDefaultDirective, [{
15
+ type: Directive,
16
+ args: [{ selector: '[auSlotDefault]', standalone: true }]
17
+ }], null, { auSlotDefault: [{
18
+ type: Input,
19
+ args: ['auSlotDefault']
20
+ }] }); })();
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2xvdERlZmF1bHQuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Nsb3REZWZhdWx0LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDOztBQUlwRSxNQUFNLE9BQU8sb0JBQW9CO0lBRGpDO1FBSUMsZ0JBQVcsR0FBRyxNQUFNLENBQUMsQ0FBQSxXQUFjLENBQUEsQ0FBQyxDQUFDO0tBTXJDO0lBSkEsa0JBQWtCO0lBQ2xCLFFBQVE7UUFDUCxJQUFJLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxFQUFDLEdBQUcsS0FBSyxFQUFFLFdBQVcsRUFBRSxJQUFJLENBQUMsV0FBVyxFQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ25GLENBQUM7cUZBUlcsb0JBQW9CO29FQUFwQixvQkFBb0I7O2lGQUFwQixvQkFBb0I7Y0FEaEMsU0FBUztlQUFDLEVBQUMsUUFBUSxFQUFFLGlCQUFpQixFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUM7Z0JBRWpDLGFBQWE7a0JBQXBDLEtBQUs7bUJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtXcml0YWJsZVNpZ25hbH0gZnJvbSAnQGFtYWRldXMtaXQtZ3JvdXAvdGFuc3UnO1xuaW1wb3J0IHR5cGUge09uSW5pdH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0RpcmVjdGl2ZSwgSW5wdXQsIFRlbXBsYXRlUmVmLCBpbmplY3R9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHR5cGUge1Nsb3RDb250ZW50fSBmcm9tICcuL3R5cGVzJztcblxuQERpcmVjdGl2ZSh7c2VsZWN0b3I6ICdbYXVTbG90RGVmYXVsdF0nLCBzdGFuZGFsb25lOiB0cnVlfSlcbmV4cG9ydCBjbGFzcyBTbG90RGVmYXVsdERpcmVjdGl2ZTxUIGV4dGVuZHMgb2JqZWN0PiBpbXBsZW1lbnRzIE9uSW5pdCB7XG5cdEBJbnB1dCgnYXVTbG90RGVmYXVsdCcpIGF1U2xvdERlZmF1bHQ6IFdyaXRhYmxlU2lnbmFsPHtzbG90RGVmYXVsdD86IFNsb3RDb250ZW50PFQ+fT47XG5cblx0dGVtcGxhdGVSZWYgPSBpbmplY3QoVGVtcGxhdGVSZWY8VD4pO1xuXG5cdC8qKiBAaW5oZXJpdGRvYyAqL1xuXHRuZ09uSW5pdCgpOiB2b2lkIHtcblx0XHR0aGlzLmF1U2xvdERlZmF1bHQudXBkYXRlKCh2YWx1ZSkgPT4gKHsuLi52YWx1ZSwgc2xvdERlZmF1bHQ6IHRoaXMudGVtcGxhdGVSZWZ9KSk7XG5cdH1cbn1cbiJdfQ==
@@ -0,0 +1,21 @@
1
+ import { Directive, Input } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export * from '@agnos-ui/core/types';
4
+ export class ComponentTemplate {
5
+ constructor(component, templateProp) {
6
+ this.component = component;
7
+ this.templateProp = templateProp;
8
+ }
9
+ }
10
+ export class SlotComponent {
11
+ static { this.ɵfac = function SlotComponent_Factory(t) { return new (t || SlotComponent)(); }; }
12
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SlotComponent, inputs: { state: "state", widget: "widget" } }); }
13
+ }
14
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SlotComponent, [{
15
+ type: Directive
16
+ }], null, { state: [{
17
+ type: Input
18
+ }], widget: [{
19
+ type: Input
20
+ }] }); })();
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVUEsT0FBTyxFQUFDLFNBQVMsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7O0FBRS9DLGNBQWMsc0JBQXNCLENBQUM7QUFFckMsTUFBTSxPQUFPLGlCQUFpQjtJQUM3QixZQUNpQixTQUFrQixFQUNsQixZQUFlO1FBRGYsY0FBUyxHQUFULFNBQVMsQ0FBUztRQUNsQixpQkFBWSxHQUFaLFlBQVksQ0FBRztJQUM3QixDQUFDO0NBQ0o7QUE4QkQsTUFBTSxPQUFnQixhQUFhOzhFQUFiLGFBQWE7b0VBQWIsYUFBYTs7aUZBQWIsYUFBYTtjQURsQyxTQUFTO2dCQUdULEtBQUs7a0JBREosS0FBSztZQUdOLE1BQU07a0JBREwsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtcblx0Q29udGV4dFdpZGdldCxcblx0U2xvdENvbnRlbnQgYXMgQ29yZVNsb3RDb250ZW50LFxuXHRXaWRnZXQsXG5cdFdpZGdldEZhY3RvcnksXG5cdFdpZGdldFByb3BzLFxuXHRXaWRnZXRTbG90Q29udGV4dCxcblx0V2lkZ2V0U3RhdGUsXG59IGZyb20gJ0BhZ25vcy11aS9jb3JlL3R5cGVzJztcbmltcG9ydCB0eXBlIHtTaWduYWwsIFRlbXBsYXRlUmVmLCBUeXBlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7RGlyZWN0aXZlLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCAqIGZyb20gJ0BhZ25vcy11aS9jb3JlL3R5cGVzJztcblxuZXhwb3J0IGNsYXNzIENvbXBvbmVudFRlbXBsYXRlPFByb3BzLCBLIGV4dGVuZHMgc3RyaW5nLCBUIGV4dGVuZHMge1trZXkgaW4gS106IFRlbXBsYXRlUmVmPFByb3BzPn0+IHtcblx0Y29uc3RydWN0b3IoXG5cdFx0cHVibGljIHJlYWRvbmx5IGNvbXBvbmVudDogVHlwZTxUPixcblx0XHRwdWJsaWMgcmVhZG9ubHkgdGVtcGxhdGVQcm9wOiBLLFxuXHQpIHt9XG59XG5cbmV4cG9ydCB0eXBlIFNsb3RDb250ZW50PFByb3BzIGV4dGVuZHMgb2JqZWN0ID0gb2JqZWN0PiA9XG5cdHwgQ29yZVNsb3RDb250ZW50PFByb3BzPlxuXHR8IFRlbXBsYXRlUmVmPFByb3BzPlxuXHR8IFR5cGU8dW5rbm93bj5cblx0fCBDb21wb25lbnRUZW1wbGF0ZTxQcm9wcywgYW55LCBhbnk+O1xuXG5leHBvcnQgdHlwZSBBZGFwdFNsb3RDb250ZW50UHJvcHM8UHJvcHMgZXh0ZW5kcyBSZWNvcmQ8c3RyaW5nLCBhbnk+PiA9XG5cdFByb3BzIGV4dGVuZHMgV2lkZ2V0U2xvdENvbnRleHQ8aW5mZXIgVT5cblx0XHQ/IFdpZGdldFNsb3RDb250ZXh0PEFkYXB0V2lkZ2V0U2xvdHM8VT4+ICYgQWRhcHRQcm9wc1Nsb3RzPE9taXQ8UHJvcHMsIGtleW9mIFdpZGdldFNsb3RDb250ZXh0PGFueT4+PlxuXHRcdDogQWRhcHRQcm9wc1Nsb3RzPFByb3BzPjtcblxuZXhwb3J0IHR5cGUgQWRhcHRQcm9wc1Nsb3RzPFByb3BzPiA9IE9taXQ8UHJvcHMsIGBzbG90JHtzdHJpbmd9YD4gJiB7XG5cdFtLIGluIGtleW9mIFByb3BzICYgYHNsb3Qke3N0cmluZ31gXTogUHJvcHNbS10gZXh0ZW5kcyBDb3JlU2xvdENvbnRlbnQ8aW5mZXIgVT4gPyBTbG90Q29udGVudDxBZGFwdFNsb3RDb250ZW50UHJvcHM8VT4+IDogUHJvcHNbS107XG59O1xuXG5leHBvcnQgdHlwZSBBZGFwdFdpZGdldEZhY3RvcmllczxUPiA9IHtcblx0W0sgaW4ga2V5b2YgVF06IFRbS10gZXh0ZW5kcyBXaWRnZXRGYWN0b3J5PGluZmVyIFU+ID8gV2lkZ2V0RmFjdG9yeTxBZGFwdFdpZGdldFNsb3RzPFU+PiA6IFRbS107XG59O1xuXG5leHBvcnQgdHlwZSBBZGFwdFdpZGdldFNsb3RzPFcgZXh0ZW5kcyBXaWRnZXQ+ID0gV2lkZ2V0PFxuXHRBZGFwdFByb3BzU2xvdHM8V2lkZ2V0UHJvcHM8Vz4+LFxuXHRBZGFwdFByb3BzU2xvdHM8V2lkZ2V0U3RhdGU8Vz4+LFxuXHRBZGFwdFdpZGdldEZhY3RvcmllczxXWydhcGknXT4sXG5cdFdbJ2FjdGlvbnMnXSxcblx0V1snZGlyZWN0aXZlcyddXG4+O1xuXG5ARGlyZWN0aXZlKClcbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBTbG90Q29tcG9uZW50PFcgZXh0ZW5kcyBXaWRnZXQ+IHtcblx0QElucHV0KClcblx0c3RhdGUhOiBXaWRnZXRTdGF0ZTxXPjtcblx0QElucHV0KClcblx0d2lkZ2V0ITogQ29udGV4dFdpZGdldDxXPjtcbn1cblxuZXhwb3J0IHR5cGUgQW5ndWxhcldpZGdldDxXIGV4dGVuZHMgV2lkZ2V0PiA9IFcgJiB7XG5cdGluaXRpYWxpemVkOiBQcm9taXNlPHZvaWQ+O1xuXHR3aWRnZXQ6IENvbnRleHRXaWRnZXQ8Vz47XG5cdG5nU3RhdGU6IFNpZ25hbDxXaWRnZXRTdGF0ZTxXPj47XG5cdG5nSW5pdDogKCkgPT4gdm9pZDtcblx0cGF0Y2hTbG90cyhzbG90czoge1xuXHRcdFtLIGluIGtleW9mIFdpZGdldFByb3BzPFc+ICYgYHNsb3Qke3N0cmluZ31gXTogV2lkZ2V0UHJvcHM8Vz5bS10gZXh0ZW5kcyBTbG90Q29udGVudDxpbmZlciBVPiA/IFRlbXBsYXRlUmVmPFU+IHwgdW5kZWZpbmVkIDogbmV2ZXI7XG5cdH0pOiB2b2lkO1xufTtcbiJdfQ==
@@ -0,0 +1,32 @@
1
+ import { booleanAttribute, numberAttribute } from '@angular/core';
2
+ /**
3
+ * Transforms a value (typically a string) to a boolean.
4
+ * Intended to be used as a transform function of an input.
5
+ *
6
+ * @example
7
+ * ```@Input({ transform: auBooleanAttribute }) status: boolean | undefined;```
8
+ * @param value - Value to be transformed.
9
+ * @returns the value transformed
10
+ */
11
+ export function auBooleanAttribute(value) {
12
+ if (value === undefined) {
13
+ return undefined;
14
+ }
15
+ return booleanAttribute(value);
16
+ }
17
+ /**
18
+ * Transforms a value (typically a string) to a number.
19
+ * Intended to be used as a transform function of an input.
20
+ * @param value - Value to be transformed.
21
+ *
22
+ * @example
23
+ * ```@Input({ transform: auNumberAttribute }) id: number | undefined;```
24
+ * @returns the value transformed
25
+ */
26
+ export function auNumberAttribute(value) {
27
+ if (value === undefined) {
28
+ return undefined;
29
+ }
30
+ return numberAttribute(value);
31
+ }
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29lcmNpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdXRpbHMvY29lcmNpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGdCQUFnQixFQUFFLGVBQWUsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUVoRTs7Ozs7Ozs7R0FRRztBQUNILE1BQU0sVUFBVSxrQkFBa0IsQ0FBQyxLQUFjO0lBQ2hELElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRSxDQUFDO1FBQ3pCLE9BQU8sU0FBUyxDQUFDO0lBQ2xCLENBQUM7SUFDRCxPQUFPLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQ2hDLENBQUM7QUFFRDs7Ozs7Ozs7R0FRRztBQUNILE1BQU0sVUFBVSxpQkFBaUIsQ0FBQyxLQUFjO0lBQy9DLElBQUksS0FBSyxLQUFLLFNBQVMsRUFBRSxDQUFDO1FBQ3pCLE9BQU8sU0FBUyxDQUFDO0lBQ2xCLENBQUM7SUFDRCxPQUFPLGVBQWUsQ0FBQyxLQUFLLENBQUMsQ0FBQztBQUMvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtib29sZWFuQXR0cmlidXRlLCBudW1iZXJBdHRyaWJ1dGV9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKipcbiAqIFRyYW5zZm9ybXMgYSB2YWx1ZSAodHlwaWNhbGx5IGEgc3RyaW5nKSB0byBhIGJvb2xlYW4uXG4gKiBJbnRlbmRlZCB0byBiZSB1c2VkIGFzIGEgdHJhbnNmb3JtIGZ1bmN0aW9uIG9mIGFuIGlucHV0LlxuICpcbiAqIEBleGFtcGxlXG4gKiBgYGBASW5wdXQoeyB0cmFuc2Zvcm06IGF1Qm9vbGVhbkF0dHJpYnV0ZSB9KSBzdGF0dXM6IGJvb2xlYW4gfCB1bmRlZmluZWQ7YGBgXG4gKiBAcGFyYW0gdmFsdWUgLSBWYWx1ZSB0byBiZSB0cmFuc2Zvcm1lZC5cbiAqIEByZXR1cm5zIHRoZSB2YWx1ZSB0cmFuc2Zvcm1lZFxuICovXG5leHBvcnQgZnVuY3Rpb24gYXVCb29sZWFuQXR0cmlidXRlKHZhbHVlOiB1bmtub3duKTogYm9vbGVhbiB8IHVuZGVmaW5lZCB7XG5cdGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkKSB7XG5cdFx0cmV0dXJuIHVuZGVmaW5lZDtcblx0fVxuXHRyZXR1cm4gYm9vbGVhbkF0dHJpYnV0ZSh2YWx1ZSk7XG59XG5cbi8qKlxuICogVHJhbnNmb3JtcyBhIHZhbHVlICh0eXBpY2FsbHkgYSBzdHJpbmcpIHRvIGEgbnVtYmVyLlxuICogSW50ZW5kZWQgdG8gYmUgdXNlZCBhcyBhIHRyYW5zZm9ybSBmdW5jdGlvbiBvZiBhbiBpbnB1dC5cbiAqIEBwYXJhbSB2YWx1ZSAtIFZhbHVlIHRvIGJlIHRyYW5zZm9ybWVkLlxuICpcbiAqIEBleGFtcGxlXG4gKiAgYGBgQElucHV0KHsgdHJhbnNmb3JtOiBhdU51bWJlckF0dHJpYnV0ZSB9KSBpZDogbnVtYmVyIHwgdW5kZWZpbmVkO2BgYFxuICogQHJldHVybnMgdGhlIHZhbHVlIHRyYW5zZm9ybWVkXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBhdU51bWJlckF0dHJpYnV0ZSh2YWx1ZTogdW5rbm93bik6IG51bWJlciB8IHVuZGVmaW5lZCB7XG5cdGlmICh2YWx1ZSA9PT0gdW5kZWZpbmVkKSB7XG5cdFx0cmV0dXJuIHVuZGVmaW5lZDtcblx0fVxuXHRyZXR1cm4gbnVtYmVyQXR0cmlidXRlKHZhbHVlKTtcbn1cbiJdfQ==
@@ -0,0 +1,72 @@
1
+ import { DestroyRef, Directive, ElementRef, Injector, Input, afterNextRender, inject, runInInjectionContext } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export * from '@agnos-ui/core/utils/directive';
4
+ /**
5
+ * Set up an agnos-ui directive as an angular host directive.
6
+ *
7
+ * @param directive - the directive
8
+ * @param params - the params to pass to the directive
9
+ * @returns the update function to change the directive or params
10
+ */
11
+ export const useDirectiveForHost = (directive, params) => {
12
+ const injector = inject(Injector);
13
+ const ref = inject(ElementRef);
14
+ let instance;
15
+ let plannedCallDirective = false;
16
+ const callDirective = () => {
17
+ if (plannedCallDirective || !directive) {
18
+ return;
19
+ }
20
+ plannedCallDirective = true;
21
+ runInInjectionContext(injector, () => {
22
+ afterNextRender(() => {
23
+ plannedCallDirective = false;
24
+ instance = directive?.(ref.nativeElement, params);
25
+ });
26
+ });
27
+ };
28
+ function destroyDirectiveInstance() {
29
+ const oldInstance = instance;
30
+ instance = undefined;
31
+ directive = undefined;
32
+ oldInstance?.destroy?.();
33
+ }
34
+ inject(DestroyRef).onDestroy(destroyDirectiveInstance);
35
+ function update(newDirective, newParams) {
36
+ if (newDirective !== directive) {
37
+ void destroyDirectiveInstance();
38
+ directive = newDirective;
39
+ params = newParams;
40
+ callDirective();
41
+ }
42
+ else if (newParams != params) {
43
+ params = newParams;
44
+ instance?.update?.(params);
45
+ }
46
+ }
47
+ callDirective();
48
+ return { update };
49
+ };
50
+ export class UseDirective {
51
+ #useDirective = useDirectiveForHost();
52
+ /** @inheritdoc */
53
+ ngOnChanges() {
54
+ this.#useDirective.update(this.use, this.params);
55
+ }
56
+ static { this.ɵfac = function UseDirective_Factory(t) { return new (t || UseDirective)(); }; }
57
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: UseDirective, selectors: [["", "auUse", ""]], inputs: { use: [i0.ɵɵInputFlags.None, "auUse", "use"], params: [i0.ɵɵInputFlags.None, "auUseParams", "params"] }, standalone: true, features: [i0.ɵɵNgOnChangesFeature] }); }
58
+ }
59
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(UseDirective, [{
60
+ type: Directive,
61
+ args: [{
62
+ standalone: true,
63
+ selector: '[auUse]',
64
+ }]
65
+ }], null, { use: [{
66
+ type: Input,
67
+ args: ['auUse']
68
+ }], params: [{
69
+ type: Input,
70
+ args: ['auUseParams']
71
+ }] }); })();
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL2RpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUMsVUFBVSxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLEtBQUssRUFBRSxlQUFlLEVBQUUsTUFBTSxFQUFFLHFCQUFxQixFQUFDLE1BQU0sZUFBZSxDQUFDOztBQUVqSSxjQUFjLGdDQUFnQyxDQUFDO0FBRS9DOzs7Ozs7R0FNRztBQUNILE1BQU0sQ0FBQyxNQUFNLG1CQUFtQixHQUFHLENBQUksU0FBK0IsRUFBRSxNQUFVLEVBQUUsRUFBRTtJQUNyRixNQUFNLFFBQVEsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbEMsTUFBTSxHQUFHLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDO0lBRS9CLElBQUksUUFBcUQsQ0FBQztJQUMxRCxJQUFJLG9CQUFvQixHQUFHLEtBQUssQ0FBQztJQUVqQyxNQUFNLGFBQWEsR0FBRyxHQUFHLEVBQUU7UUFDMUIsSUFBSSxvQkFBb0IsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3hDLE9BQU87UUFDUixDQUFDO1FBQ0Qsb0JBQW9CLEdBQUcsSUFBSSxDQUFDO1FBQzVCLHFCQUFxQixDQUFDLFFBQVEsRUFBRSxHQUFHLEVBQUU7WUFDcEMsZUFBZSxDQUFDLEdBQUcsRUFBRTtnQkFDcEIsb0JBQW9CLEdBQUcsS0FBSyxDQUFDO2dCQUM3QixRQUFRLEdBQUcsU0FBUyxFQUFFLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxNQUFXLENBQUMsQ0FBQztZQUN4RCxDQUFDLENBQUMsQ0FBQztRQUNKLENBQUMsQ0FBQyxDQUFDO0lBQ0osQ0FBQyxDQUFDO0lBRUYsU0FBUyx3QkFBd0I7UUFDaEMsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDO1FBQzdCLFFBQVEsR0FBRyxTQUFTLENBQUM7UUFDckIsU0FBUyxHQUFHLFNBQVMsQ0FBQztRQUN0QixXQUFXLEVBQUUsT0FBTyxFQUFFLEVBQUUsQ0FBQztJQUMxQixDQUFDO0lBRUQsTUFBTSxDQUFDLFVBQVUsQ0FBQyxDQUFDLFNBQVMsQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO0lBRXZELFNBQVMsTUFBTSxDQUFDLFlBQWtDLEVBQUUsU0FBYTtRQUNoRSxJQUFJLFlBQVksS0FBSyxTQUFTLEVBQUUsQ0FBQztZQUNoQyxLQUFLLHdCQUF3QixFQUFFLENBQUM7WUFDaEMsU0FBUyxHQUFHLFlBQVksQ0FBQztZQUN6QixNQUFNLEdBQUcsU0FBUyxDQUFDO1lBQ25CLGFBQWEsRUFBRSxDQUFDO1FBQ2pCLENBQUM7YUFBTSxJQUFJLFNBQVMsSUFBSSxNQUFNLEVBQUUsQ0FBQztZQUNoQyxNQUFNLEdBQUcsU0FBUyxDQUFDO1lBQ25CLFFBQVEsRUFBRSxNQUFNLEVBQUUsQ0FBQyxNQUFXLENBQUMsQ0FBQztRQUNqQyxDQUFDO0lBQ0YsQ0FBQztJQUVELGFBQWEsRUFBRSxDQUFDO0lBQ2hCLE9BQU8sRUFBQyxNQUFNLEVBQUMsQ0FBQztBQUNqQixDQUFDLENBQUM7QUFNRixNQUFNLE9BQU8sWUFBWTtJQU94QixhQUFhLEdBQUcsbUJBQW1CLEVBQUssQ0FBQztJQUV6QyxrQkFBa0I7SUFDbEIsV0FBVztRQUNWLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQ2xELENBQUM7NkVBWlcsWUFBWTtvRUFBWixZQUFZOztpRkFBWixZQUFZO2NBSnhCLFNBQVM7ZUFBQztnQkFDVixVQUFVLEVBQUUsSUFBSTtnQkFDaEIsUUFBUSxFQUFFLFNBQVM7YUFDbkI7Z0JBR0EsR0FBRztrQkFERixLQUFLO21CQUFDLE9BQU87WUFJZCxNQUFNO2tCQURMLEtBQUs7bUJBQUMsYUFBYSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHtEaXJlY3RpdmUgYXMgQWdub3NVSURpcmVjdGl2ZX0gZnJvbSAnQGFnbm9zLXVpL2NvcmUvdHlwZXMnO1xuaW1wb3J0IHR5cGUge09uQ2hhbmdlc30gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Rlc3Ryb3lSZWYsIERpcmVjdGl2ZSwgRWxlbWVudFJlZiwgSW5qZWN0b3IsIElucHV0LCBhZnRlck5leHRSZW5kZXIsIGluamVjdCwgcnVuSW5JbmplY3Rpb25Db250ZXh0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuZXhwb3J0ICogZnJvbSAnQGFnbm9zLXVpL2NvcmUvdXRpbHMvZGlyZWN0aXZlJztcblxuLyoqXG4gKiBTZXQgdXAgYW4gYWdub3MtdWkgZGlyZWN0aXZlIGFzIGFuIGFuZ3VsYXIgaG9zdCBkaXJlY3RpdmUuXG4gKlxuICogQHBhcmFtIGRpcmVjdGl2ZSAtIHRoZSBkaXJlY3RpdmVcbiAqIEBwYXJhbSBwYXJhbXMgLSB0aGUgcGFyYW1zIHRvIHBhc3MgdG8gdGhlIGRpcmVjdGl2ZVxuICogQHJldHVybnMgdGhlIHVwZGF0ZSBmdW5jdGlvbiB0byBjaGFuZ2UgdGhlIGRpcmVjdGl2ZSBvciBwYXJhbXNcbiAqL1xuZXhwb3J0IGNvbnN0IHVzZURpcmVjdGl2ZUZvckhvc3QgPSA8VD4oZGlyZWN0aXZlPzogQWdub3NVSURpcmVjdGl2ZTxUPiwgcGFyYW1zPzogVCkgPT4ge1xuXHRjb25zdCBpbmplY3RvciA9IGluamVjdChJbmplY3Rvcik7XG5cdGNvbnN0IHJlZiA9IGluamVjdChFbGVtZW50UmVmKTtcblxuXHRsZXQgaW5zdGFuY2U6IHVuZGVmaW5lZCB8IFJldHVyblR5cGU8QWdub3NVSURpcmVjdGl2ZTxUPj47XG5cdGxldCBwbGFubmVkQ2FsbERpcmVjdGl2ZSA9IGZhbHNlO1xuXG5cdGNvbnN0IGNhbGxEaXJlY3RpdmUgPSAoKSA9PiB7XG5cdFx0aWYgKHBsYW5uZWRDYWxsRGlyZWN0aXZlIHx8ICFkaXJlY3RpdmUpIHtcblx0XHRcdHJldHVybjtcblx0XHR9XG5cdFx0cGxhbm5lZENhbGxEaXJlY3RpdmUgPSB0cnVlO1xuXHRcdHJ1bkluSW5qZWN0aW9uQ29udGV4dChpbmplY3RvciwgKCkgPT4ge1xuXHRcdFx0YWZ0ZXJOZXh0UmVuZGVyKCgpID0+IHtcblx0XHRcdFx0cGxhbm5lZENhbGxEaXJlY3RpdmUgPSBmYWxzZTtcblx0XHRcdFx0aW5zdGFuY2UgPSBkaXJlY3RpdmU/LihyZWYubmF0aXZlRWxlbWVudCwgcGFyYW1zIGFzIFQpO1xuXHRcdFx0fSk7XG5cdFx0fSk7XG5cdH07XG5cblx0ZnVuY3Rpb24gZGVzdHJveURpcmVjdGl2ZUluc3RhbmNlKCkge1xuXHRcdGNvbnN0IG9sZEluc3RhbmNlID0gaW5zdGFuY2U7XG5cdFx0aW5zdGFuY2UgPSB1bmRlZmluZWQ7XG5cdFx0ZGlyZWN0aXZlID0gdW5kZWZpbmVkO1xuXHRcdG9sZEluc3RhbmNlPy5kZXN0cm95Py4oKTtcblx0fVxuXG5cdGluamVjdChEZXN0cm95UmVmKS5vbkRlc3Ryb3koZGVzdHJveURpcmVjdGl2ZUluc3RhbmNlKTtcblxuXHRmdW5jdGlvbiB1cGRhdGUobmV3RGlyZWN0aXZlPzogQWdub3NVSURpcmVjdGl2ZTxUPiwgbmV3UGFyYW1zPzogVCkge1xuXHRcdGlmIChuZXdEaXJlY3RpdmUgIT09IGRpcmVjdGl2ZSkge1xuXHRcdFx0dm9pZCBkZXN0cm95RGlyZWN0aXZlSW5zdGFuY2UoKTtcblx0XHRcdGRpcmVjdGl2ZSA9IG5ld0RpcmVjdGl2ZTtcblx0XHRcdHBhcmFtcyA9IG5ld1BhcmFtcztcblx0XHRcdGNhbGxEaXJlY3RpdmUoKTtcblx0XHR9IGVsc2UgaWYgKG5ld1BhcmFtcyAhPSBwYXJhbXMpIHtcblx0XHRcdHBhcmFtcyA9IG5ld1BhcmFtcztcblx0XHRcdGluc3RhbmNlPy51cGRhdGU/LihwYXJhbXMgYXMgVCk7XG5cdFx0fVxuXHR9XG5cblx0Y2FsbERpcmVjdGl2ZSgpO1xuXHRyZXR1cm4ge3VwZGF0ZX07XG59O1xuXG5ARGlyZWN0aXZlKHtcblx0c3RhbmRhbG9uZTogdHJ1ZSxcblx0c2VsZWN0b3I6ICdbYXVVc2VdJyxcbn0pXG5leHBvcnQgY2xhc3MgVXNlRGlyZWN0aXZlPFQ+IGltcGxlbWVudHMgT25DaGFuZ2VzIHtcblx0QElucHV0KCdhdVVzZScpXG5cdHVzZTogQWdub3NVSURpcmVjdGl2ZTxUPiB8IHVuZGVmaW5lZDtcblxuXHRASW5wdXQoJ2F1VXNlUGFyYW1zJylcblx0cGFyYW1zOiBUIHwgdW5kZWZpbmVkO1xuXG5cdCN1c2VEaXJlY3RpdmUgPSB1c2VEaXJlY3RpdmVGb3JIb3N0PFQ+KCk7XG5cblx0LyoqIEBpbmhlcml0ZG9jICovXG5cdG5nT25DaGFuZ2VzKCkge1xuXHRcdHRoaXMuI3VzZURpcmVjdGl2ZS51cGRhdGUodGhpcy51c2UsIHRoaXMucGFyYW1zKTtcblx0fVxufVxuIl19
@@ -0,0 +1,23 @@
1
+ import { DestroyRef, inject, signal } from '@angular/core';
2
+ import { ZoneWrapper } from './zone';
3
+ export * from '@agnos-ui/core/utils/stores';
4
+ /**
5
+ * Convert a tansu readable signal into an Angular signal.
6
+ *
7
+ * @param tansuSignal - a tansu readable signal
8
+ * @returns an angular signal
9
+ *
10
+ * @remarks
11
+ * Note that as it uses Angular's `inject`, this can only be called at component construction time.
12
+ */
13
+ export const toAngularSignal = (tansuSignal) => {
14
+ const zoneWrapper = inject(ZoneWrapper);
15
+ const res = signal(undefined);
16
+ const subscription = zoneWrapper.outsideNgZone(tansuSignal.subscribe)((value) => {
17
+ res.set(value);
18
+ zoneWrapper.planNgZoneRun();
19
+ });
20
+ inject(DestroyRef).onDestroy(zoneWrapper.outsideNgZone(subscription));
21
+ return res;
22
+ };
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic3RvcmVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3V0aWxzL3N0b3Jlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUMsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDekQsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLFFBQVEsQ0FBQztBQUVuQyxjQUFjLDZCQUE2QixDQUFDO0FBRTVDOzs7Ozs7OztHQVFHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sZUFBZSxHQUFHLENBQUksV0FBOEIsRUFBYSxFQUFFO0lBQy9FLE1BQU0sV0FBVyxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUN4QyxNQUFNLEdBQUcsR0FBRyxNQUFNLENBQUMsU0FBcUIsQ0FBQyxDQUFDO0lBQzFDLE1BQU0sWUFBWSxHQUFHLFdBQVcsQ0FBQyxhQUFhLENBQUMsV0FBVyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7UUFDL0UsR0FBRyxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNmLFdBQVcsQ0FBQyxhQUFhLEVBQUUsQ0FBQztJQUM3QixDQUFDLENBQUMsQ0FBQztJQUNILE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxTQUFTLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQUMsQ0FBQyxDQUFDO0lBQ3RFLE9BQU8sR0FBRyxDQUFDO0FBQ1osQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUge1JlYWRhYmxlU2lnbmFsfSBmcm9tICdAYW1hZGV1cy1pdC1ncm91cC90YW5zdSc7XG5pbXBvcnQgdHlwZSB7U2lnbmFsfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7RGVzdHJveVJlZiwgaW5qZWN0LCBzaWduYWx9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtab25lV3JhcHBlcn0gZnJvbSAnLi96b25lJztcblxuZXhwb3J0ICogZnJvbSAnQGFnbm9zLXVpL2NvcmUvdXRpbHMvc3RvcmVzJztcblxuLyoqXG4gKiBDb252ZXJ0IGEgdGFuc3UgcmVhZGFibGUgc2lnbmFsIGludG8gYW4gQW5ndWxhciBzaWduYWwuXG4gKlxuICogQHBhcmFtIHRhbnN1U2lnbmFsIC0gYSB0YW5zdSByZWFkYWJsZSBzaWduYWxcbiAqIEByZXR1cm5zIGFuIGFuZ3VsYXIgc2lnbmFsXG4gKlxuICogQHJlbWFya3NcbiAqIE5vdGUgdGhhdCBhcyBpdCB1c2VzIEFuZ3VsYXIncyBgaW5qZWN0YCwgdGhpcyBjYW4gb25seSBiZSBjYWxsZWQgYXQgY29tcG9uZW50IGNvbnN0cnVjdGlvbiB0aW1lLlxuICovXG5leHBvcnQgY29uc3QgdG9Bbmd1bGFyU2lnbmFsID0gPFQ+KHRhbnN1U2lnbmFsOiBSZWFkYWJsZVNpZ25hbDxUPik6IFNpZ25hbDxUPiA9PiB7XG5cdGNvbnN0IHpvbmVXcmFwcGVyID0gaW5qZWN0KFpvbmVXcmFwcGVyKTtcblx0Y29uc3QgcmVzID0gc2lnbmFsKHVuZGVmaW5lZCBhcyBhbnkgYXMgVCk7XG5cdGNvbnN0IHN1YnNjcmlwdGlvbiA9IHpvbmVXcmFwcGVyLm91dHNpZGVOZ1pvbmUodGFuc3VTaWduYWwuc3Vic2NyaWJlKSgodmFsdWUpID0+IHtcblx0XHRyZXMuc2V0KHZhbHVlKTtcblx0XHR6b25lV3JhcHBlci5wbGFuTmdab25lUnVuKCk7XG5cdH0pO1xuXHRpbmplY3QoRGVzdHJveVJlZikub25EZXN0cm95KHpvbmVXcmFwcGVyLm91dHNpZGVOZ1pvbmUoc3Vic2NyaXB0aW9uKSk7XG5cdHJldHVybiByZXM7XG59O1xuIl19
@@ -0,0 +1,131 @@
1
+ import { computed, writable } from '@amadeus-it-group/tansu';
2
+ import { Directive, Injector, inject, runInInjectionContext } from '@angular/core';
3
+ import { toSlotContextWidget, } from '../types';
4
+ import { toAngularSignal, toReadableStore } from './stores';
5
+ import { ZoneWrapper } from './zone';
6
+ import * as i0 from "@angular/core";
7
+ const createPatchSlots = (set) => {
8
+ let lastValue = {};
9
+ return (object) => {
10
+ const newValue = {};
11
+ let hasChange = false;
12
+ for (const key of Object.keys(object)) {
13
+ const objectKey = object[key];
14
+ if (objectKey != null) {
15
+ // only use defined slots
16
+ newValue[key] = objectKey;
17
+ }
18
+ if (objectKey != lastValue[key]) {
19
+ hasChange = true;
20
+ }
21
+ }
22
+ if (hasChange) {
23
+ lastValue = newValue;
24
+ set(newValue);
25
+ }
26
+ };
27
+ };
28
+ /**
29
+ * Call a widget factory using provided configs.
30
+ *
31
+ * @param parameter - the parameter
32
+ * @param parameter.factory - the widget factory to call
33
+ * @param parameter.defaultConfig - the default config of the widget
34
+ * @param parameter.widgetConfig - the config of the widget, overriding the defaultConfig
35
+ * @param parameter.events - the events of the widget
36
+ * @param parameter.afterInit - a callback to call after successful setup of the widget
37
+ * @returns the widget
38
+ */
39
+ export const callWidgetFactoryWithConfig = ({ factory, defaultConfig, widgetConfig, events, afterInit, }) => {
40
+ const injector = inject(Injector);
41
+ const slots$ = writable({});
42
+ const props = {};
43
+ let initDone;
44
+ const res = {
45
+ initialized: new Promise((resolve) => {
46
+ initDone = resolve;
47
+ }),
48
+ patchSlots: createPatchSlots(slots$.set),
49
+ patch(newProps) {
50
+ // temporary function replaced in ngInit
51
+ Object.assign(props, newProps);
52
+ },
53
+ ngInit() {
54
+ runInInjectionContext(injector, () => {
55
+ const zoneWrapper = inject(ZoneWrapper);
56
+ factory = zoneWrapper.outsideNgZone(factory);
57
+ const defaultConfig$ = toReadableStore(defaultConfig);
58
+ events = zoneWrapper.insideNgZoneWrapFunctionsObject(events);
59
+ const widget = factory({
60
+ config: computed(() => ({ ...defaultConfig$(), ...widgetConfig?.(), ...slots$(), ...events })),
61
+ props,
62
+ });
63
+ const wrappedWidget = {
64
+ ...widget,
65
+ patch: zoneWrapper.outsideNgZone(widget.patch),
66
+ directives: zoneWrapper.outsideNgZoneWrapDirectivesObject(widget.directives),
67
+ actions: zoneWrapper.outsideNgZoneWrapFunctionsObject(widget.actions),
68
+ api: zoneWrapper.outsideNgZoneWrapFunctionsObject(widget.api),
69
+ };
70
+ Object.assign(res, wrappedWidget, {
71
+ widget: toSlotContextWidget(wrappedWidget),
72
+ ngState: toAngularSignal(wrappedWidget.state$),
73
+ });
74
+ afterInit?.();
75
+ initDone();
76
+ });
77
+ },
78
+ };
79
+ return res;
80
+ };
81
+ function patchSimpleChanges(patchFn, changes) {
82
+ const obj = {};
83
+ for (const [key, simpleChange] of Object.entries(changes)) {
84
+ if (simpleChange !== undefined) {
85
+ obj[key] = simpleChange.currentValue;
86
+ }
87
+ }
88
+ patchFn(obj);
89
+ }
90
+ /**
91
+ * Stores the result of the first call to the getter and returns that result directly for subsequent calls
92
+ *
93
+ * Applies to: class getters
94
+ *
95
+ * @param target - the target
96
+ * @param property - the property
97
+ * @param descriptor - the property descriptor
98
+ */
99
+ export const CachedProperty = (target, property, descriptor) => {
100
+ const originalGet = descriptor.get;
101
+ descriptor.get = function () {
102
+ const value = originalGet?.call(this);
103
+ Object.defineProperty(this, property, { value, writable: false });
104
+ return value;
105
+ };
106
+ };
107
+ export class BaseWidgetDirective {
108
+ get api() {
109
+ return this._widget.api;
110
+ }
111
+ get state() {
112
+ return this._widget.ngState;
113
+ }
114
+ get widget() {
115
+ return this._widget.widget;
116
+ }
117
+ /** @inheritdoc */
118
+ ngOnChanges(changes) {
119
+ patchSimpleChanges(this._widget.patch, changes);
120
+ }
121
+ /** @inheritdoc */
122
+ ngOnInit() {
123
+ this._widget.ngInit();
124
+ }
125
+ static { this.ɵfac = function BaseWidgetDirective_Factory(t) { return new (t || BaseWidgetDirective)(); }; }
126
+ static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: BaseWidgetDirective, features: [i0.ɵɵNgOnChangesFeature] }); }
127
+ }
128
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BaseWidgetDirective, [{
129
+ type: Directive
130
+ }], null, null); })();
131
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"widget.js","sourceRoot":"","sources":["../../../src/utils/widget.ts"],"names":[],"mappings":"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","sourcesContent":["import {computed, writable, type ReadableSignal} from '@amadeus-it-group/tansu';\nimport type {OnChanges, OnInit, Signal, SimpleChanges} from '@angular/core';\nimport {Directive, Injector, inject, runInInjectionContext} from '@angular/core';\nimport {\n\ttoSlotContextWidget,\n\ttype AngularWidget,\n\ttype ContextWidget,\n\ttype Widget,\n\ttype WidgetFactory,\n\ttype WidgetProps,\n\ttype WidgetState,\n} from '../types';\nimport {toAngularSignal, toReadableStore} from './stores';\nimport {ZoneWrapper} from './zone';\n\nconst createPatchSlots = <T extends object>(set: (object: Partial<T>) => void) => {\n\tlet lastValue: Partial<T> = {};\n\treturn (object: T) => {\n\t\tconst newValue: Partial<T> = {};\n\t\tlet hasChange = false;\n\t\tfor (const key of Object.keys(object) as (string & keyof T)[]) {\n\t\t\tconst objectKey = (object as any)[key];\n\t\t\tif (objectKey != null) {\n\t\t\t\t// only use defined slots\n\t\t\t\tnewValue[key] = objectKey;\n\t\t\t}\n\t\t\tif (objectKey != lastValue[key]) {\n\t\t\t\thasChange = true;\n\t\t\t}\n\t\t}\n\t\tif (hasChange) {\n\t\t\tlastValue = newValue;\n\t\t\tset(newValue);\n\t\t}\n\t};\n};\n\n/**\n * Call a widget factory using provided configs.\n *\n * @param parameter - the parameter\n * @param parameter.factory - the widget factory to call\n * @param parameter.defaultConfig - the default config of the widget\n * @param parameter.widgetConfig - the config of the widget, overriding the defaultConfig\n * @param parameter.events - the events of the widget\n * @param parameter.afterInit - a callback to call after successful setup of the widget\n * @returns the widget\n */\nexport const callWidgetFactoryWithConfig = <W extends Widget>({\n\tfactory,\n\tdefaultConfig,\n\twidgetConfig,\n\tevents,\n\tafterInit,\n}: {\n\tfactory: WidgetFactory<W>;\n\tdefaultConfig?: Partial<WidgetProps<W>> | ReadableSignal<Partial<WidgetProps<W>> | undefined>;\n\twidgetConfig?: null | undefined | ReadableSignal<Partial<WidgetProps<W>> | undefined>;\n\tevents: Pick<WidgetProps<W>, keyof WidgetProps<W> & `on${string}`>;\n\tafterInit?: () => void;\n}): AngularWidget<W> => {\n\tconst injector = inject(Injector);\n\tconst slots$ = writable({});\n\tconst props = {};\n\tlet initDone: () => void;\n\tconst res = {\n\t\tinitialized: new Promise((resolve) => {\n\t\t\tinitDone = resolve;\n\t\t}),\n\t\tpatchSlots: createPatchSlots(slots$.set),\n\t\tpatch(newProps) {\n\t\t\t// temporary function replaced in ngInit\n\t\t\tObject.assign(props, newProps);\n\t\t},\n\t\tngInit() {\n\t\t\trunInInjectionContext(injector, () => {\n\t\t\t\tconst zoneWrapper = inject(ZoneWrapper);\n\t\t\t\tfactory = zoneWrapper.outsideNgZone(factory);\n\t\t\t\tconst defaultConfig$ = toReadableStore(defaultConfig);\n\t\t\t\tevents = zoneWrapper.insideNgZoneWrapFunctionsObject(events);\n\t\t\t\tconst widget = factory({\n\t\t\t\t\tconfig: computed(() => ({...defaultConfig$(), ...widgetConfig?.(), ...slots$(), ...(events as Partial<WidgetProps<W>>)})),\n\t\t\t\t\tprops,\n\t\t\t\t});\n\t\t\t\tconst wrappedWidget: W = {\n\t\t\t\t\t...widget,\n\t\t\t\t\tpatch: zoneWrapper.outsideNgZone(widget.patch),\n\t\t\t\t\tdirectives: zoneWrapper.outsideNgZoneWrapDirectivesObject(widget.directives),\n\t\t\t\t\tactions: zoneWrapper.outsideNgZoneWrapFunctionsObject(widget.actions),\n\t\t\t\t\tapi: zoneWrapper.outsideNgZoneWrapFunctionsObject(widget.api),\n\t\t\t\t};\n\t\t\t\tObject.assign(res, wrappedWidget, {\n\t\t\t\t\twidget: toSlotContextWidget(wrappedWidget),\n\t\t\t\t\tngState: toAngularSignal(wrappedWidget.state$ as ReadableSignal<WidgetState<W>>),\n\t\t\t\t});\n\t\t\t\tafterInit?.();\n\t\t\t\tinitDone();\n\t\t\t});\n\t\t},\n\t} as AngularWidget<W>;\n\n\treturn res;\n};\n\nfunction patchSimpleChanges(patchFn: (obj: any) => void, changes: SimpleChanges) {\n\tconst obj: any = {};\n\tfor (const [key, simpleChange] of Object.entries(changes)) {\n\t\tif (simpleChange !== undefined) {\n\t\t\tobj[key] = simpleChange.currentValue;\n\t\t}\n\t}\n\tpatchFn(obj);\n}\n\n/**\n * Stores the result of the first call to the getter and returns that result directly for subsequent calls\n *\n * Applies to: class getters\n *\n * @param target - the target\n * @param property - the property\n * @param descriptor - the property descriptor\n */\nexport const CachedProperty = (target: any, property: PropertyKey, descriptor: PropertyDescriptor) => {\n\tconst originalGet = descriptor.get;\n\tdescriptor.get = function (this: any) {\n\t\tconst value = originalGet?.call(this);\n\t\tObject.defineProperty(this, property, {value, writable: false});\n\t\treturn value;\n\t};\n};\n\n@Directive()\nexport abstract class BaseWidgetDirective<W extends Widget> implements OnChanges, OnInit {\n\tprotected abstract readonly _widget: AngularWidget<W>;\n\n\tget api(): W['api'] {\n\t\treturn this._widget.api;\n\t}\n\n\tget state(): Signal<WidgetState<W>> {\n\t\treturn this._widget.ngState;\n\t}\n\n\tget widget(): ContextWidget<W> {\n\t\treturn this._widget.widget;\n\t}\n\n\t/** @inheritdoc */\n\tngOnChanges(changes: SimpleChanges): void {\n\t\tpatchSimpleChanges(this._widget.patch, changes);\n\t}\n\n\t/** @inheritdoc */\n\tngOnInit(): void {\n\t\tthis._widget.ngInit();\n\t}\n}\n"]}