@agnos-ui/angular-headless 0.0.1-alpha.6 → 0.0.1-alpha.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/accordion/index.d.ts +1 -0
- package/components/alert/index.d.ts +1 -0
- package/components/modal/index.d.ts +1 -0
- package/components/pagination/index.d.ts +1 -0
- package/components/progressbar/index.d.ts +1 -0
- package/components/rating/index.d.ts +1 -0
- package/components/select/index.d.ts +1 -0
- package/components/slider/index.d.ts +1 -0
- package/config.d.ts +8 -0
- package/esm2022/components/accordion/index.mjs +2 -0
- package/esm2022/components/alert/index.mjs +2 -0
- package/esm2022/components/modal/index.mjs +2 -0
- package/esm2022/components/pagination/index.mjs +2 -0
- package/esm2022/components/progressbar/index.mjs +2 -0
- package/esm2022/components/rating/index.mjs +2 -0
- package/esm2022/components/select/index.mjs +2 -0
- package/esm2022/components/slider/index.mjs +2 -0
- package/esm2022/config.mjs +40 -32
- package/esm2022/index.mjs +9 -9
- package/esm2022/slot.directive.mjs +4 -2
- package/esm2022/slotDefault.directive.mjs +2 -1
- package/esm2022/utils/coercion.mjs +9 -11
- package/esm2022/utils/directive.mjs +36 -27
- package/esm2022/utils/stores.mjs +10 -1
- package/esm2022/utils/widget.mjs +18 -1
- package/esm2022/utils/zone.mjs +7 -1
- package/fesm2022/agnos-ui-angular-headless.mjs +118 -68
- package/fesm2022/agnos-ui-angular-headless.mjs.map +1 -1
- package/index.d.ts +8 -8
- package/package.json +3 -8
- package/slot.directive.d.ts +2 -0
- package/slotDefault.directive.d.ts +1 -0
- package/utils/coercion.d.ts +8 -10
- package/utils/directive.d.ts +10 -2
- package/utils/stores.d.ts +9 -0
- package/utils/widget.d.ts +17 -0
- package/utils/zone.d.ts +6 -0
package/esm2022/utils/widget.mjs
CHANGED
|
@@ -25,6 +25,17 @@ const createPatchSlots = (set) => {
|
|
|
25
25
|
}
|
|
26
26
|
};
|
|
27
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
|
+
*/
|
|
28
39
|
export const callWidgetFactoryWithConfig = ({ factory, defaultConfig, widgetConfig, events, afterInit, }) => {
|
|
29
40
|
const injector = inject(Injector);
|
|
30
41
|
const slots$ = writable({});
|
|
@@ -80,6 +91,10 @@ function patchSimpleChanges(patchFn, changes) {
|
|
|
80
91
|
* Stores the result of the first call to the getter and returns that result directly for subsequent calls
|
|
81
92
|
*
|
|
82
93
|
* Applies to: class getters
|
|
94
|
+
*
|
|
95
|
+
* @param target - the target
|
|
96
|
+
* @param property - the property
|
|
97
|
+
* @param descriptor - the property descriptor
|
|
83
98
|
*/
|
|
84
99
|
export const CachedProperty = (target, property, descriptor) => {
|
|
85
100
|
const originalGet = descriptor.get;
|
|
@@ -99,9 +114,11 @@ export class BaseWidgetDirective {
|
|
|
99
114
|
get widget() {
|
|
100
115
|
return this._widget.widget;
|
|
101
116
|
}
|
|
117
|
+
/** @inheritdoc */
|
|
102
118
|
ngOnChanges(changes) {
|
|
103
119
|
patchSimpleChanges(this._widget.patch, changes);
|
|
104
120
|
}
|
|
121
|
+
/** @inheritdoc */
|
|
105
122
|
ngOnInit() {
|
|
106
123
|
this._widget.ngInit();
|
|
107
124
|
}
|
|
@@ -111,4 +128,4 @@ export class BaseWidgetDirective {
|
|
|
111
128
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BaseWidgetDirective, [{
|
|
112
129
|
type: Directive
|
|
113
130
|
}], null, null); })();
|
|
114
|
-
//# 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\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 */\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\tngOnChanges(changes: SimpleChanges): void {\n\t\tpatchSimpleChanges(this._widget.patch, changes);\n\t}\n\n\tngOnInit(): void {\n\t\tthis._widget.ngInit();\n\t}\n}\n"]}
|
|
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"]}
|
package/esm2022/utils/zone.mjs
CHANGED
|
@@ -51,6 +51,12 @@ export class ZoneWrapper {
|
|
|
51
51
|
#hasZone; // check if zone is enabled (can be NoopZone, cf https://angular.io/guide/zone#noopzone)
|
|
52
52
|
#runNeeded;
|
|
53
53
|
#runPlanned;
|
|
54
|
+
/**
|
|
55
|
+
* Run the input function synchronously within the Angular zone
|
|
56
|
+
*
|
|
57
|
+
* @param fn - a function to run
|
|
58
|
+
* @returns the value returned by the function
|
|
59
|
+
*/
|
|
54
60
|
ngZoneRun(fn) {
|
|
55
61
|
this.#runNeeded = false;
|
|
56
62
|
return this.#zone.run(fn);
|
|
@@ -64,4 +70,4 @@ export class ZoneWrapper {
|
|
|
64
70
|
providedIn: 'root',
|
|
65
71
|
}]
|
|
66
72
|
}], null, null); })();
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
73
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiem9uZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91dGlscy96b25lLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFFekQsTUFBTSxJQUFJLEdBQUcsR0FBRyxFQUFFLEdBQUUsQ0FBQyxDQUFDO0FBQ3RCLE1BQU0sUUFBUSxHQUFHLENBQUksQ0FBSSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFJaEMsTUFBTSxtQkFBbUIsR0FDeEIsQ0FBQyxJQUFhLEVBQVcsRUFBRSxDQUMzQixDQUFDLE1BQU0sRUFBRSxFQUFFO0lBQ1YsSUFBSSxDQUFDLE1BQU0sSUFBSSxPQUFPLE1BQU0sS0FBSyxRQUFRLEVBQUUsQ0FBQztRQUMzQyxPQUFPLE1BQU0sQ0FBQztJQUNmLENBQUM7SUFDRCxNQUFNLEdBQUcsR0FBRyxFQUFTLENBQUM7SUFDdEIsS0FBSyxNQUFNLEdBQUcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDdkMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBRSxNQUFjLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBQ0QsT0FBTyxHQUFHLENBQUM7QUFDWixDQUFDLENBQUM7QUFFSCxNQUFNLHdCQUF3QixHQUM3QixDQUFDLGVBQXdCLEVBQUUsVUFBbUIsRUFBVyxFQUFFLENBQzNELENBQUMsRUFBRSxFQUFFLEVBQUUsQ0FDTixVQUFVLENBQUMsT0FBTyxFQUFFLEtBQUssVUFBVSxDQUFDLENBQUMsQ0FBRSxDQUFDLENBQUMsR0FBRyxJQUFXLEVBQUUsRUFBRSxDQUFDLGVBQWUsQ0FBQyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDO0FBSzFHLE1BQU0sT0FBTyxX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bEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGFibGUsIE5nWm9uZSwgaW5qZWN0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuY29uc3Qgbm9vcCA9ICgpID0+IHt9O1xuY29uc3QgaWRlbnRpdHkgPSA8VD4oYTogVCkgPT4gYTtcblxudHlwZSBXcmFwcGVyID0gPFQ+KGZuOiBUKSA9PiBUO1xuXG5jb25zdCBjcmVhdGVPYmplY3RXcmFwcGVyID1cblx0KHdyYXA6IFdyYXBwZXIpOiBXcmFwcGVyID0+XG5cdChvYmplY3QpID0+IHtcblx0XHRpZiAoIW9iamVjdCB8fCB0eXBlb2Ygb2JqZWN0ICE9PSAnb2JqZWN0Jykge1xuXHRcdFx0cmV0dXJuIG9iamVjdDtcblx0XHR9XG5cdFx0Y29uc3QgcmVzID0ge30gYXMgYW55O1xuXHRcdGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKG9iamVjdCkpIHtcblx0XHRcdHJlc1trZXldID0gd3JhcCgob2JqZWN0IGFzIGFueSlba2V5XSk7XG5cdFx0fVxuXHRcdHJldHVybiByZXM7XG5cdH07XG5cbmNvbnN0IGNyZWF0ZVJldHVyblZhbHVlV3JhcHBlciA9XG5cdCh3cmFwUmV0dXJuVmFsdWU6IFdyYXBwZXIsIHdyYXBSZXN1bHQ6IFdyYXBwZXIpOiBXcmFwcGVyID0+XG5cdChmbikgPT5cblx0XHR3cmFwUmVzdWx0KHR5cGVvZiBmbiA9PT0gJ2Z1bmN0aW9uJyA/ICgoKC4uLmFyZ3M6IGFueVtdKSA9PiB3cmFwUmV0dXJuVmFsdWUoZm4oLi4uYXJncykpKSBhcyBhbnkpIDogZm4pO1xuXG5ASW5qZWN0YWJsZSh7XG5cdHByb3ZpZGVkSW46ICdyb290Jyxcbn0pXG5leHBvcnQgY2xhc3MgWm9uZVdyYXBwZXIge1xuXHRyZWFkb25seSAjem9uZSA9IGluamVjdChOZ1pvbmUpO1xuXHRyZWFkb25seSAjaGFzWm9uZSA9IHRoaXMuI3pvbmUucnVuKCgpID0+IE5nWm9uZS5pc0luQW5ndWxhclpvbmUoKSk7IC8vIGNoZWNrIGlmIHpvbmUgaXMgZW5hYmxlZCAoY2FuIGJlIE5vb3Bab25lLCBjZiBodHRwczovL2FuZ3VsYXIuaW8vZ3VpZGUvem9uZSNub29wem9uZSlcblx0I3J1bk5lZWRlZCA9IGZhbHNlO1xuXHQjcnVuUGxhbm5lZCA9IGZhbHNlO1xuXG5cdHBsYW5OZ1pvbmVSdW4gPSB0aGlzLiNoYXNab25lXG5cdFx0PyAoKSA9PiB7XG5cdFx0XHRcdGlmICh0aGlzLiN6b25lLmlzU3RhYmxlKSB7XG5cdFx0XHRcdFx0dGhpcy4jcnVuTmVlZGVkID0gdHJ1ZTtcblx0XHRcdFx0XHRpZiAoIXRoaXMuI3J1blBsYW5uZWQpIHtcblx0XHRcdFx0XHRcdHRoaXMuI3J1blBsYW5uZWQgPSB0cnVlO1xuXHRcdFx0XHRcdFx0dm9pZCAoYXN5bmMgKCkgPT4ge1xuXHRcdFx0XHRcdFx0XHRhd2FpdCAwO1xuXHRcdFx0XHRcdFx0XHR0aGlzLiNydW5QbGFubmVkID0gZmFsc2U7XG5cdFx0XHRcdFx0XHRcdGlmICh0aGlzLiNydW5OZWVkZWQpIHtcblx0XHRcdFx0XHRcdFx0XHR0aGlzLm5nWm9uZVJ1bihub29wKTtcblx0XHRcdFx0XHRcdFx0fVxuXHRcdFx0XHRcdFx0fSkoKTtcblx0XHRcdFx0XHR9XG5cdFx0XHRcdH1cblx0XHRcdH1cblx0XHQ6IG5vb3A7XG5cblx0LyoqXG5cdCAqIFJ1biB0aGUgaW5wdXQgZnVuY3Rpb24gc3luY2hyb25vdXNseSB3aXRoaW4gdGhlIEFuZ3VsYXIgem9uZVxuXHQgKlxuXHQgKiBAcGFyYW0gZm4gLSBhIGZ1bmN0aW9uIHRvIHJ1blxuXHQgKiBAcmV0dXJucyB0aGUgdmFsdWUgcmV0dXJuZWQgYnkgdGhlIGZ1bmN0aW9uXG5cdCAqL1xuXHRuZ1pvbmVSdW48VD4oZm46ICgpID0+IFQpOiBUIHtcblx0XHR0aGlzLiNydW5OZWVkZWQgPSBmYWxzZTtcblx0XHRyZXR1cm4gdGhpcy4jem9uZS5ydW4oZm4pO1xuXHR9XG5cblx0aW5zaWRlTmdab25lOiBXcmFwcGVyID0gdGhpcy4jaGFzWm9uZVxuXHRcdD8gKGZuKSA9PiAodHlwZW9mIGZuID09PSAnZnVuY3Rpb24nID8gKCgoLi4uYXJnczogYW55W10pID0+IHRoaXMubmdab25lUnVuKCgpID0+IGZuKC4uLmFyZ3MpKSkgYXMgYW55KSA6IGZuKVxuXHRcdDogaWRlbnRpdHk7XG5cdGluc2lkZU5nWm9uZVdyYXBGdW5jdGlvbnNPYmplY3QgPSBjcmVhdGVPYmplY3RXcmFwcGVyKHRoaXMuaW5zaWRlTmdab25lKTtcblxuXHRvdXRzaWRlTmdab25lOiBXcmFwcGVyID0gdGhpcy4jaGFzWm9uZVxuXHRcdD8gKGZuKSA9PiAodHlwZW9mIGZuID09PSAnZnVuY3Rpb24nID8gKCgoLi4uYXJnczogYW55W10pID0+IHRoaXMuI3pvbmUucnVuT3V0c2lkZUFuZ3VsYXIoKCkgPT4gZm4oLi4uYXJncykpKSBhcyBhbnkpIDogZm4pXG5cdFx0OiBpZGVudGl0eTtcblxuXHRvdXRzaWRlTmdab25lV3JhcEZ1bmN0aW9uc09iamVjdCA9IGNyZWF0ZU9iamVjdFdyYXBwZXIodGhpcy5vdXRzaWRlTmdab25lKTtcblx0b3V0c2lkZU5nWm9uZVdyYXBEaXJlY3RpdmUgPSBjcmVhdGVSZXR1cm5WYWx1ZVdyYXBwZXIodGhpcy5vdXRzaWRlTmdab25lV3JhcEZ1bmN0aW9uc09iamVjdCwgdGhpcy5vdXRzaWRlTmdab25lKTtcblx0b3V0c2lkZU5nWm9uZVdyYXBEaXJlY3RpdmVzT2JqZWN0ID0gY3JlYXRlT2JqZWN0V3JhcHBlcih0aGlzLm91dHNpZGVOZ1pvbmVXcmFwRGlyZWN0aXZlKTtcbn1cbiJdfQ==
|
|
@@ -27,7 +27,7 @@ export * from '@agnos-ui/core/services/transitions/bootstrap';
|
|
|
27
27
|
export * from '@agnos-ui/core/services/transitions/baseTransitions';
|
|
28
28
|
export * from '@agnos-ui/core/utils/writables';
|
|
29
29
|
import * as i0 from '@angular/core';
|
|
30
|
-
import {
|
|
30
|
+
import { inject, NgZone, Injectable, signal, DestroyRef, Injector, ElementRef, runInInjectionContext, afterNextRender, Directive, Input, SkipSelf, Optional, InjectionToken, booleanAttribute, numberAttribute, TemplateRef, createComponent, EnvironmentInjector, reflectComponentType, ViewContainerRef } from '@angular/core';
|
|
31
31
|
import { toReadableStore } from '@agnos-ui/core/utils/stores';
|
|
32
32
|
export * from '@agnos-ui/core/utils/stores';
|
|
33
33
|
export * from '@agnos-ui/core/utils/directive';
|
|
@@ -103,6 +103,12 @@ class ZoneWrapper {
|
|
|
103
103
|
#hasZone; // check if zone is enabled (can be NoopZone, cf https://angular.io/guide/zone#noopzone)
|
|
104
104
|
#runNeeded;
|
|
105
105
|
#runPlanned;
|
|
106
|
+
/**
|
|
107
|
+
* Run the input function synchronously within the Angular zone
|
|
108
|
+
*
|
|
109
|
+
* @param fn - a function to run
|
|
110
|
+
* @returns the value returned by the function
|
|
111
|
+
*/
|
|
106
112
|
ngZoneRun(fn) {
|
|
107
113
|
this.#runNeeded = false;
|
|
108
114
|
return this.#zone.run(fn);
|
|
@@ -117,6 +123,15 @@ class ZoneWrapper {
|
|
|
117
123
|
}]
|
|
118
124
|
}], null, null); })();
|
|
119
125
|
|
|
126
|
+
/**
|
|
127
|
+
* Convert a tansu readable signal into an Angular signal.
|
|
128
|
+
*
|
|
129
|
+
* @param tansuSignal - a tansu readable signal
|
|
130
|
+
* @returns an angular signal
|
|
131
|
+
*
|
|
132
|
+
* @remarks
|
|
133
|
+
* Note that as it uses Angular's `inject`, this can only be called at component construction time.
|
|
134
|
+
*/
|
|
120
135
|
const toAngularSignal = (tansuSignal) => {
|
|
121
136
|
const zoneWrapper = inject(ZoneWrapper);
|
|
122
137
|
const res = signal(undefined);
|
|
@@ -128,51 +143,60 @@ const toAngularSignal = (tansuSignal) => {
|
|
|
128
143
|
return res;
|
|
129
144
|
};
|
|
130
145
|
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
146
|
+
/**
|
|
147
|
+
* Set up an agnos-ui directive as an angular host directive.
|
|
148
|
+
*
|
|
149
|
+
* @param directive - the directive
|
|
150
|
+
* @param params - the params to pass to the directive
|
|
151
|
+
* @returns the update function to change the directive or params
|
|
152
|
+
*/
|
|
153
|
+
const useDirectiveForHost = (directive, params) => {
|
|
154
|
+
const injector = inject(Injector);
|
|
136
155
|
const ref = inject(ElementRef);
|
|
137
|
-
let instance
|
|
138
|
-
|
|
156
|
+
let instance;
|
|
157
|
+
let plannedCallDirective = false;
|
|
158
|
+
const callDirective = () => {
|
|
159
|
+
if (plannedCallDirective || !directive) {
|
|
160
|
+
return;
|
|
161
|
+
}
|
|
162
|
+
plannedCallDirective = true;
|
|
163
|
+
runInInjectionContext(injector, () => {
|
|
164
|
+
afterNextRender(() => {
|
|
165
|
+
plannedCallDirective = false;
|
|
166
|
+
instance = directive?.(ref.nativeElement, params);
|
|
167
|
+
});
|
|
168
|
+
});
|
|
169
|
+
};
|
|
170
|
+
function destroyDirectiveInstance() {
|
|
139
171
|
const oldInstance = instance;
|
|
140
172
|
instance = undefined;
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
await 0;
|
|
144
|
-
oldInstance.destroy?.();
|
|
145
|
-
}
|
|
173
|
+
directive = undefined;
|
|
174
|
+
oldInstance?.destroy?.();
|
|
146
175
|
}
|
|
147
176
|
inject(DestroyRef).onDestroy(destroyDirectiveInstance);
|
|
148
|
-
|
|
149
|
-
if (
|
|
177
|
+
function update(newDirective, newParams) {
|
|
178
|
+
if (newDirective !== directive) {
|
|
150
179
|
void destroyDirectiveInstance();
|
|
151
|
-
|
|
180
|
+
directive = newDirective;
|
|
152
181
|
params = newParams;
|
|
153
|
-
|
|
154
|
-
await 0;
|
|
155
|
-
// checks that the directive did not change while waiting:
|
|
156
|
-
if (use === newUse && !instance) {
|
|
157
|
-
instance = use(ref.nativeElement, params);
|
|
158
|
-
}
|
|
159
|
-
}
|
|
182
|
+
callDirective();
|
|
160
183
|
}
|
|
161
184
|
else if (newParams != params) {
|
|
162
185
|
params = newParams;
|
|
163
|
-
await 0;
|
|
164
186
|
instance?.update?.(params);
|
|
165
187
|
}
|
|
166
188
|
}
|
|
189
|
+
callDirective();
|
|
167
190
|
return { update };
|
|
168
191
|
};
|
|
169
192
|
class UseDirective {
|
|
170
193
|
#useDirective = useDirectiveForHost();
|
|
194
|
+
/** @inheritdoc */
|
|
171
195
|
ngOnChanges() {
|
|
172
|
-
|
|
196
|
+
this.#useDirective.update(this.use, this.params);
|
|
173
197
|
}
|
|
174
198
|
static { this.ɵfac = function UseDirective_Factory(t) { return new (t || UseDirective)(); }; }
|
|
175
|
-
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: UseDirective, selectors: [["", "auUse", ""]], inputs: { use: ["auUse", "use"], params: ["auUseParams", "params"] }, standalone: true, features: [i0.ɵɵNgOnChangesFeature] }); }
|
|
199
|
+
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] }); }
|
|
176
200
|
}
|
|
177
201
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(UseDirective, [{
|
|
178
202
|
type: Directive,
|
|
@@ -227,6 +251,17 @@ const createPatchSlots = (set) => {
|
|
|
227
251
|
}
|
|
228
252
|
};
|
|
229
253
|
};
|
|
254
|
+
/**
|
|
255
|
+
* Call a widget factory using provided configs.
|
|
256
|
+
*
|
|
257
|
+
* @param parameter - the parameter
|
|
258
|
+
* @param parameter.factory - the widget factory to call
|
|
259
|
+
* @param parameter.defaultConfig - the default config of the widget
|
|
260
|
+
* @param parameter.widgetConfig - the config of the widget, overriding the defaultConfig
|
|
261
|
+
* @param parameter.events - the events of the widget
|
|
262
|
+
* @param parameter.afterInit - a callback to call after successful setup of the widget
|
|
263
|
+
* @returns the widget
|
|
264
|
+
*/
|
|
230
265
|
const callWidgetFactoryWithConfig = ({ factory, defaultConfig, widgetConfig, events, afterInit, }) => {
|
|
231
266
|
const injector = inject(Injector);
|
|
232
267
|
const slots$ = writable({});
|
|
@@ -282,6 +317,10 @@ function patchSimpleChanges(patchFn, changes) {
|
|
|
282
317
|
* Stores the result of the first call to the getter and returns that result directly for subsequent calls
|
|
283
318
|
*
|
|
284
319
|
* Applies to: class getters
|
|
320
|
+
*
|
|
321
|
+
* @param target - the target
|
|
322
|
+
* @param property - the property
|
|
323
|
+
* @param descriptor - the property descriptor
|
|
285
324
|
*/
|
|
286
325
|
const CachedProperty = (target, property, descriptor) => {
|
|
287
326
|
const originalGet = descriptor.get;
|
|
@@ -301,9 +340,11 @@ class BaseWidgetDirective {
|
|
|
301
340
|
get widget() {
|
|
302
341
|
return this._widget.widget;
|
|
303
342
|
}
|
|
343
|
+
/** @inheritdoc */
|
|
304
344
|
ngOnChanges(changes) {
|
|
305
345
|
patchSimpleChanges(this._widget.patch, changes);
|
|
306
346
|
}
|
|
347
|
+
/** @inheritdoc */
|
|
307
348
|
ngOnInit() {
|
|
308
349
|
this._widget.ngInit();
|
|
309
350
|
}
|
|
@@ -314,6 +355,14 @@ class BaseWidgetDirective {
|
|
|
314
355
|
type: Directive
|
|
315
356
|
}], null, null); })();
|
|
316
357
|
|
|
358
|
+
/**
|
|
359
|
+
* A factory to create the utilities to allow widgets to be context-aware.
|
|
360
|
+
*
|
|
361
|
+
* It can be used when extending the core and creating new widgets.
|
|
362
|
+
*
|
|
363
|
+
* @param widgetsConfigInjectionToken - the widgets config injection token
|
|
364
|
+
* @returns the utilities to create / manage widgets and contexts
|
|
365
|
+
*/
|
|
317
366
|
const widgetsConfigFactory = (widgetsConfigInjectionToken = new InjectionToken('widgetsConfig')) => {
|
|
318
367
|
/**
|
|
319
368
|
* Creates a provider of widgets default configuration that inherits from any widgets default configuration already defined at an upper level
|
|
@@ -335,37 +384,37 @@ const widgetsConfigFactory = (widgetsConfigInjectionToken = new InjectionToken('
|
|
|
335
384
|
* It is called in a tansu reactive context, so it can use any tansu store and will be called again if those stores change.
|
|
336
385
|
* It is also called in an Angular injection context, so it can call the Angular inject function to get and use dependencies from the
|
|
337
386
|
* Angular dependency injection system.
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
|
|
354
|
-
|
|
355
|
-
|
|
356
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
387
|
+
*
|
|
388
|
+
* @returns DI provider to be included a list of `providers` (for example at a component level or
|
|
389
|
+
* any other level of the Angular dependency injection system)
|
|
390
|
+
*
|
|
391
|
+
* @example
|
|
392
|
+
* ```typescript
|
|
393
|
+
* @Component({
|
|
394
|
+
* // ...
|
|
395
|
+
* providers: [
|
|
396
|
+
* provideWidgetsConfig((parentConfig) => {
|
|
397
|
+
* // first step configuration: transforms the parent configuration
|
|
398
|
+
* parentConfig.rating = parentConfig.rating ?? {};
|
|
399
|
+
* parentConfig.rating.className = `${parentConfig.rating.className ?? ''} my-rating-extra-class`
|
|
400
|
+
* return parentConfig;
|
|
401
|
+
* })
|
|
402
|
+
* ]
|
|
403
|
+
* })
|
|
404
|
+
* class MyComponent {
|
|
405
|
+
* widgetsConfig = injectWidgetsConfig();
|
|
406
|
+
* constructor() {
|
|
407
|
+
* this.widgetsConfig.set({
|
|
408
|
+
* // second step configuration: overrides the parent configuration
|
|
409
|
+
* rating: {
|
|
410
|
+
* slotStar: MyCustomSlotStar
|
|
411
|
+
* }
|
|
412
|
+
* });
|
|
413
|
+
* }
|
|
414
|
+
* // ...
|
|
415
|
+
* }
|
|
416
|
+
* ```
|
|
417
|
+
*/
|
|
369
418
|
const provideWidgetsConfig = (adaptParentConfig) => ({
|
|
370
419
|
provide: widgetsConfigInjectionToken,
|
|
371
420
|
useFactory: (parent) => {
|
|
@@ -417,11 +466,10 @@ const { widgetsConfigInjectionToken, provideWidgetsConfig, injectWidgetConfig, i
|
|
|
417
466
|
* Transforms a value (typically a string) to a boolean.
|
|
418
467
|
* Intended to be used as a transform function of an input.
|
|
419
468
|
*
|
|
420
|
-
*
|
|
421
|
-
*
|
|
422
|
-
*
|
|
423
|
-
*
|
|
424
|
-
* @param value Value to be transformed.
|
|
469
|
+
* @example
|
|
470
|
+
* ```@Input({ transform: auBooleanAttribute }) status: boolean | undefined;```
|
|
471
|
+
* @param value - Value to be transformed.
|
|
472
|
+
* @returns the value transformed
|
|
425
473
|
*/
|
|
426
474
|
function auBooleanAttribute(value) {
|
|
427
475
|
if (value === undefined) {
|
|
@@ -432,12 +480,11 @@ function auBooleanAttribute(value) {
|
|
|
432
480
|
/**
|
|
433
481
|
* Transforms a value (typically a string) to a number.
|
|
434
482
|
* Intended to be used as a transform function of an input.
|
|
435
|
-
* @param value Value to be transformed.
|
|
483
|
+
* @param value - Value to be transformed.
|
|
436
484
|
*
|
|
437
|
-
*
|
|
438
|
-
*
|
|
439
|
-
*
|
|
440
|
-
* ```
|
|
485
|
+
* @example
|
|
486
|
+
* ```@Input({ transform: auNumberAttribute }) id: number | undefined;```
|
|
487
|
+
* @returns the value transformed
|
|
441
488
|
*/
|
|
442
489
|
function auNumberAttribute(value) {
|
|
443
490
|
if (value === undefined) {
|
|
@@ -450,6 +497,7 @@ class SlotDefaultDirective {
|
|
|
450
497
|
constructor() {
|
|
451
498
|
this.templateRef = inject((TemplateRef));
|
|
452
499
|
}
|
|
500
|
+
/** @inheritdoc */
|
|
453
501
|
ngOnInit() {
|
|
454
502
|
this.auSlotDefault.update((value) => ({ ...value, slotDefault: this.templateRef }));
|
|
455
503
|
}
|
|
@@ -621,6 +669,7 @@ class SlotDirective {
|
|
|
621
669
|
this._viewContainerRef = inject(ViewContainerRef);
|
|
622
670
|
this._document = inject(DOCUMENT);
|
|
623
671
|
}
|
|
672
|
+
/** @inheritdoc */
|
|
624
673
|
ngOnChanges(changes) {
|
|
625
674
|
const slotChange = changes['slot'];
|
|
626
675
|
const propsChange = changes['props'];
|
|
@@ -638,12 +687,13 @@ class SlotDirective {
|
|
|
638
687
|
this._slotHandler?.propsChange(slot, this.props);
|
|
639
688
|
}
|
|
640
689
|
}
|
|
690
|
+
/** @inheritdoc */
|
|
641
691
|
ngOnDestroy() {
|
|
642
692
|
this._slotHandler?.destroy();
|
|
643
693
|
this._slotHandler = undefined;
|
|
644
694
|
}
|
|
645
695
|
static { this.ɵfac = function SlotDirective_Factory(t) { return new (t || SlotDirective)(); }; }
|
|
646
|
-
static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: SlotDirective, selectors: [["", "auSlot", ""]], inputs: { slot: ["auSlot", "slot"], props: ["auSlotProps", "props"] }, standalone: true, features: [i0.ɵɵNgOnChangesFeature] }); }
|
|
696
|
+
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] }); }
|
|
647
697
|
}
|
|
648
698
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(SlotDirective, [{
|
|
649
699
|
type: Directive,
|