@ng-atomic/core 16.0.0 → 16.1.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.
|
@@ -19,7 +19,6 @@ export class NgAtomicComponent extends InjectableComponent {
|
|
|
19
19
|
#destroy$;
|
|
20
20
|
constructor() {
|
|
21
21
|
super();
|
|
22
|
-
this._effectMap = new EffectMap();
|
|
23
22
|
this.root = inject(NgAtomicRootActionStore);
|
|
24
23
|
this.#destroy$ = inject(DestroyRef);
|
|
25
24
|
this.root.actions$.pipe(takeUntilDestroyed(this.#destroy$)).subscribe(action => this.#effect(action, 'root'));
|
|
@@ -48,4 +47,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
48
47
|
type: Directive,
|
|
49
48
|
args: [{ standalone: true }]
|
|
50
49
|
}], ctorParameters: function () { return []; } });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
50
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tcG9uZW50LXN0b3JlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb3JlL3NyYy9saWIvY29tcG9uZW50LXN0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDNUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFFaEUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDN0QsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLFVBQVUsQ0FBQztBQUNyQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQzs7QUFHekQsTUFBTSxPQUFPLHNCQUFzQjtJQURuQztRQUVXLFdBQU0sR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0tBQzlDOytHQUZZLHNCQUFzQjttR0FBdEIsc0JBQXNCOzs0RkFBdEIsc0JBQXNCO2tCQURsQyxTQUFTO21CQUFDLEVBQUUsVUFBVSxFQUFFLElBQUksRUFBRTs7QUFNL0IsTUFBTSxPQUFPLGlCQUFrQixTQUFRLG1CQUFtQjtJQUl4RCxTQUFTLENBQXNCO0lBRS9CO1FBQ0UsS0FBSyxFQUFFLENBQUM7UUFKQSxTQUFJLEdBQUcsTUFBTSxDQUFDLHVCQUF1QixDQUFDLENBQUM7UUFDakQsY0FBUyxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQztRQUk3QixJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQ3JCLGtCQUFrQixDQUFDLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FDbkMsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBQ3RELENBQUM7SUFFRCxRQUFRLENBQUMsTUFBYyxFQUFFLEtBQUssR0FBRyxTQUFTO1FBQ3hDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztRQUM3QixNQUFNLE1BQU0sR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxLQUFLLENBQUMsQ0FBQztRQUMzQyxJQUFJLEtBQUssS0FBSyxNQUFNLElBQUksQ0FBQyxDQUFDLE1BQU0sRUFBRSxLQUFLLElBQUksTUFBTSxFQUFFLEtBQUssRUFBRSxRQUFRLENBQUMsRUFBRTtZQUNuRSxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7U0FDakM7YUFBTSxJQUFJLENBQUMsTUFBTSxFQUFFLEtBQUssSUFBSSxNQUFNLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRTtZQUNwRCxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztTQUMxQjtJQUNILENBQUM7SUFFRCxPQUFPLENBQUMsTUFBYyxFQUFFLEtBQUssR0FBRyxTQUFTO1FBQ3ZDLE1BQU0sTUFBTSxHQUFHLENBQUMsSUFBSSxDQUFDLFVBQVUsSUFBSSxJQUFJLFNBQVMsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFLEVBQUUsS0FBSyxDQUFDLENBQUM7UUFDMUUsSUFBSSxNQUFNLEVBQUUsR0FBRyxJQUFJLE1BQU0sRUFBRSxLQUFLLEVBQUUsS0FBSyxLQUFLLEtBQUssRUFBRTtZQUNoRCxJQUFZLENBQUMsTUFBTSxFQUFFLEdBQUcsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUM7U0FDM0Q7UUFDRCxPQUFPLE1BQU0sQ0FBQztJQUNoQixDQUFDOytHQTdCVSxpQkFBaUI7bUdBQWpCLGlCQUFpQjs7NEZBQWpCLGlCQUFpQjtrQkFEN0IsU0FBUzttQkFBQyxFQUFFLFVBQVUsRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEZXN0cm95UmVmLCBEaXJlY3RpdmUsIEV2ZW50RW1pdHRlciwgaW5qZWN0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IHRha2VVbnRpbERlc3Ryb3llZCB9IGZyb20gXCJAYW5ndWxhci9jb3JlL3J4anMtaW50ZXJvcFwiO1xuaW1wb3J0IHsgQWN0aW9uIH0gZnJvbSBcIi4vYWN0aW9uXCI7XG5pbXBvcnQgeyBJbmplY3RhYmxlQ29tcG9uZW50IH0gZnJvbSBcIi4vaW5qZWN0YWJsZS1jb21wb25lbnRcIjtcbmltcG9ydCB7IEVmZmVjdE1hcCB9IGZyb20gXCIuL2VmZmVjdFwiO1xuaW1wb3J0IHsgTmdBdG9taWNSb290QWN0aW9uU3RvcmUgfSBmcm9tIFwiLi9hY3Rpb24tc3RvcmVcIjtcblxuQERpcmVjdGl2ZSh7IHN0YW5kYWxvbmU6IHRydWUgfSlcbmV4cG9ydCBjbGFzcyBOZ0F0b21pY0NvbXBvbmVudFN0b3JlIHtcbiAgcmVhZG9ubHkgYWN0aW9uID0gbmV3IEV2ZW50RW1pdHRlcjxBY3Rpb24+KCk7XG59XG5cbkBEaXJlY3RpdmUoeyBzdGFuZGFsb25lOiB0cnVlIH0pXG5leHBvcnQgY2xhc3MgTmdBdG9taWNDb21wb25lbnQgZXh0ZW5kcyBJbmplY3RhYmxlQ29tcG9uZW50IHtcbiAgLy8gQHRzLWlnbm9yZVxuICBwcm90ZWN0ZWQgX2VmZmVjdE1hcDogRWZmZWN0TWFwO1xuICBwcm90ZWN0ZWQgcm9vdCA9IGluamVjdChOZ0F0b21pY1Jvb3RBY3Rpb25TdG9yZSk7XG4gICNkZXN0cm95JCA9IGluamVjdChEZXN0cm95UmVmKTtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICBzdXBlcigpO1xuICAgIHRoaXMucm9vdC5hY3Rpb25zJC5waXBlKFxuICAgICAgdGFrZVVudGlsRGVzdHJveWVkKHRoaXMuI2Rlc3Ryb3kkKSxcbiAgICApLnN1YnNjcmliZShhY3Rpb24gPT4gdGhpcy4jZWZmZWN0KGFjdGlvbiwgJ3Jvb3QnKSk7XG4gIH1cblxuICBkaXNwYXRjaChhY3Rpb246IEFjdGlvbiwgc2NvcGUgPSAnZGVmYXVsdCcpIHtcbiAgICB0aGlzLnJvb3QubG9nKGFjdGlvbiwgc2NvcGUpO1xuICAgIGNvbnN0IGVmZmVjdCA9IHRoaXMuI2VmZmVjdChhY3Rpb24sIHNjb3BlKTtcbiAgICBpZiAoc2NvcGUgPT09ICdyb290JyAmJiAoIWVmZmVjdD8ucHJvcHMgfHwgZWZmZWN0Py5wcm9wcz8uZGlzcGF0Y2gpKSB7XG4gICAgICB0aGlzLnJvb3QuYWN0aW9ucyQuZW1pdChhY3Rpb24pO1xuICAgIH0gZWxzZSBpZiAoIWVmZmVjdD8ucHJvcHMgfHwgZWZmZWN0Py5wcm9wcz8uZGlzcGF0Y2gpIHtcbiAgICAgIHRoaXMuYWN0aW9uLmVtaXQoYWN0aW9uKTtcbiAgICB9XG4gIH1cblxuICAjZWZmZWN0KGFjdGlvbjogQWN0aW9uLCBzY29wZSA9ICdkZWZhdWx0Jykge1xuICAgIGNvbnN0IGVmZmVjdCA9ICh0aGlzLl9lZmZlY3RNYXAgPz8gbmV3IEVmZmVjdE1hcCgpKS5nZXQoYWN0aW9uLmlkLCBzY29wZSk7XG4gICAgaWYgKGVmZmVjdD8ua2V5ICYmIGVmZmVjdD8ucHJvcHM/LnNjb3BlID09PSBzY29wZSkge1xuICAgICAgKHRoaXMgYXMgYW55KVtlZmZlY3Q/LmtleV0oZWZmZWN0LnByb3BzLmFjY2Vzc29yKGFjdGlvbikpO1xuICAgIH1cbiAgICByZXR1cm4gZWZmZWN0O1xuICB9XG59XG4iXX0=
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { DestroyRef, Directive, ElementRef, EventEmitter, Injector, Input, Output, ViewContainerRef, inject } from "@angular/core";
|
|
2
2
|
import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
|
|
3
|
+
import { reflectComponentType } from "@angular/core";
|
|
3
4
|
import * as i0 from "@angular/core";
|
|
4
5
|
export function provideComponent(abstract, typeOrFactory) {
|
|
5
6
|
async function loadComponentType() {
|
|
@@ -13,14 +14,27 @@ export function provideComponent(abstract, typeOrFactory) {
|
|
|
13
14
|
;
|
|
14
15
|
return { provide: abstract['TOKEN'], useValue: loadComponentType };
|
|
15
16
|
}
|
|
16
|
-
export
|
|
17
|
-
|
|
17
|
+
export var HostType;
|
|
18
|
+
(function (HostType) {
|
|
19
|
+
HostType["Dir"] = "\u0275dir";
|
|
20
|
+
HostType["Cmp"] = "\u0275cmp";
|
|
21
|
+
})(HostType || (HostType = {}));
|
|
22
|
+
export function getMeta(type) {
|
|
23
|
+
return type[HostType.Cmp] || type[HostType.Dir];
|
|
24
|
+
}
|
|
25
|
+
export function getInputs(type) {
|
|
26
|
+
return Object.entries(getMeta(type)['inputs'])
|
|
27
|
+
.map(([propName, templateName]) => ({ propName, templateName }));
|
|
28
|
+
}
|
|
29
|
+
export function getOutputs(type) {
|
|
30
|
+
return Object.entries(getMeta(type)['outputs'])
|
|
31
|
+
.map(([propName, templateName]) => ({ propName, templateName }));
|
|
18
32
|
}
|
|
19
33
|
export function getInputsByComponentRef(cmp) {
|
|
20
34
|
return getInputs(cmp.instance.constructor);
|
|
21
35
|
}
|
|
22
36
|
export function getOutputsByInstance(cmp) {
|
|
23
|
-
return
|
|
37
|
+
return getOutputs(cmp.instance.constructor);
|
|
24
38
|
}
|
|
25
39
|
export class InjectableComponent {
|
|
26
40
|
constructor() {
|
|
@@ -28,6 +42,8 @@ export class InjectableComponent {
|
|
|
28
42
|
this.#injector = inject(Injector);
|
|
29
43
|
this.#destroy$ = inject(DestroyRef);
|
|
30
44
|
this.#el = inject(ElementRef);
|
|
45
|
+
this.#component = null;
|
|
46
|
+
this.#componentMirror = null;
|
|
31
47
|
this.injectable = false;
|
|
32
48
|
this.action = new EventEmitter();
|
|
33
49
|
}
|
|
@@ -35,8 +51,10 @@ export class InjectableComponent {
|
|
|
35
51
|
#injector;
|
|
36
52
|
#destroy$;
|
|
37
53
|
#el;
|
|
38
|
-
#
|
|
39
|
-
|
|
54
|
+
#component;
|
|
55
|
+
#componentMirror;
|
|
56
|
+
#setAttribute() {
|
|
57
|
+
const hostElement = this.#component.hostView.rootNodes[0];
|
|
40
58
|
const attributes = this.#el.nativeElement.attributes;
|
|
41
59
|
for (let i = 0; i < attributes.length; i++) {
|
|
42
60
|
const attr = attributes.item(i);
|
|
@@ -45,30 +63,62 @@ export class InjectableComponent {
|
|
|
45
63
|
}
|
|
46
64
|
}
|
|
47
65
|
}
|
|
48
|
-
#bindInputs(
|
|
49
|
-
|
|
50
|
-
|
|
66
|
+
#bindInputs() {
|
|
67
|
+
// for (const input of this.#componentMirror!.inputs) {
|
|
68
|
+
// if (input.propName === 'injectable') return;
|
|
69
|
+
// this.#component!.setInput(input.propName, (this as any)[input.propName]);
|
|
70
|
+
// }
|
|
71
|
+
for (const input of getInputs(this.constructor)) {
|
|
72
|
+
if (input.propName === 'injectable')
|
|
51
73
|
return;
|
|
52
|
-
component.setInput(
|
|
53
|
-
}
|
|
74
|
+
this.#component.setInput(input.propName, this[input.propName]);
|
|
75
|
+
}
|
|
54
76
|
}
|
|
55
|
-
#bindOutputs(
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
77
|
+
#bindOutputs() {
|
|
78
|
+
// for (const output of this.#componentMirror!.outputs) {
|
|
79
|
+
// (this.#component!.instance as any)[output.templateName].pipe(
|
|
80
|
+
// takeUntilDestroyed(this.#destroy$)
|
|
81
|
+
// ).subscribe((value: any) => (this as any)[output.templateName].emit(value));
|
|
82
|
+
// }
|
|
83
|
+
for (const output of getOutputs(this.constructor)) {
|
|
84
|
+
this.#component.instance[output.templateName]?.pipe(takeUntilDestroyed(this.#destroy$)).subscribe((value) => {
|
|
85
|
+
console.debug('output=>>', output.templateName, value);
|
|
86
|
+
this[output.templateName].emit(value);
|
|
87
|
+
});
|
|
88
|
+
}
|
|
59
89
|
}
|
|
60
90
|
ngOnInit() {
|
|
61
91
|
if (this.injectable) {
|
|
62
92
|
this.#injector.get(this.constructor['TOKEN'])().then(type => {
|
|
63
|
-
|
|
64
|
-
this.#
|
|
65
|
-
this.#
|
|
66
|
-
this.#
|
|
93
|
+
this.#component = this.#outlet.createComponent(type);
|
|
94
|
+
this.#componentMirror = reflectComponentType(type);
|
|
95
|
+
this.#bindInputs();
|
|
96
|
+
this.#bindOutputs();
|
|
97
|
+
this.#setAttribute();
|
|
67
98
|
});
|
|
68
99
|
}
|
|
69
100
|
}
|
|
101
|
+
ngOnChanges(simpleChanges) {
|
|
102
|
+
if (this.injectable && this.#componentMirror) {
|
|
103
|
+
// for (const input of this.#componentMirror.inputs) {
|
|
104
|
+
// if (input.propName === 'injectable') return;
|
|
105
|
+
// const change = simpleChanges[input.propName] as SimpleChange;
|
|
106
|
+
// if (change) {
|
|
107
|
+
// this.#component!.setInput(input.propName, change.currentValue);
|
|
108
|
+
// }
|
|
109
|
+
// }
|
|
110
|
+
for (const input of getInputs(this.constructor)) {
|
|
111
|
+
if (input.propName === 'injectable')
|
|
112
|
+
return;
|
|
113
|
+
const change = simpleChanges[input.propName];
|
|
114
|
+
if (change) {
|
|
115
|
+
this.#component.setInput(input.propName, change.currentValue);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
70
120
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InjectableComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
71
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "16.2.12", type: InjectableComponent, isStandalone: true, inputs: { injectable: ["injectable", "injectable", (value) => value === '' ? true : value] }, outputs: { action: "action" }, ngImport: i0 }); }
|
|
121
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "16.2.12", type: InjectableComponent, isStandalone: true, inputs: { injectable: ["injectable", "injectable", (value) => value === '' ? true : value] }, outputs: { action: "action" }, usesOnChanges: true, ngImport: i0 }); }
|
|
72
122
|
}
|
|
73
123
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InjectableComponent, decorators: [{
|
|
74
124
|
type: Directive,
|
|
@@ -79,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
79
129
|
}], action: [{
|
|
80
130
|
type: Output
|
|
81
131
|
}] } });
|
|
82
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"injectable-component.js","sourceRoot":"","sources":["../../../../../../packages/@ng-atomic/core/src/lib/injectable-component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentRef, DestroyRef, Directive, ElementRef, EmbeddedViewRef, EventEmitter, Injector, Input, Output, Type, ViewContainerRef, inject } from \"@angular/core\";\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\nimport { Action } from \"./action\";\nimport { NgAtomicComponentStore } from \"./component-store\";\n\nexport type TypeFactoryAsync<T> = () => Promise<Type<T>>;\n\nexport type TypeFactory<T> = () => (Type<T> | Promise<Type<T>>);\n\nexport function provideComponent<ABS = any, IMPL = any>(\n  abstract: Type<ABS>,\n  typeOrFactory: Type<IMPL> | TypeFactory<IMPL>,\n) {\n  async function loadComponentType(): Promise<Type<IMPL>> {\n    if (typeof typeOrFactory === 'function' && !typeOrFactory.prototype) {\n      return await (typeOrFactory as TypeFactory<IMPL>)();\n    } else {\n      return typeOrFactory as Type<IMPL>;\n    }\n  };\n  return { provide: (abstract as any)['TOKEN'], useValue: loadComponentType };\n}\n\nexport function getInputs<T>(type: Type<T>, meta: 'ɵcmp' | 'ɵdir' = 'ɵcmp'): [string, string][] {\n  return Object.entries((type as any)[meta]['inputs']);\n}\n\nexport function getInputsByComponentRef<T = any>(cmp: ComponentRef<T>): [string, string][] {\n  return getInputs((cmp.instance as any).constructor as Type<T>);\n}\n\nexport function getOutputsByInstance<T = any>(cmp: ComponentRef<T>): [string, string][] {\n  return Object.entries((cmp.instance as any).constructor['ɵcmp']['outputs']);\n}\n\n@Directive({ standalone: true })\nexport abstract class InjectableComponent<T extends NgAtomicComponentStore = any> {\n  readonly #outlet = inject(ViewContainerRef);\n  readonly #injector = inject(Injector);\n  readonly #destroy$ = inject(DestroyRef);\n  readonly #el = inject(ElementRef);\n\n  #setAttribute(component: ComponentRef<T>) {\n    const hostElement = (component.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n    const attributes: NamedNodeMap = this.#el.nativeElement.attributes;\n    for (let i = 0; i < attributes.length; i++) {\n      const attr = attributes.item(i)!;\n      if (attr.name.startsWith('_ngcontent')) {\n        hostElement.setAttribute(attr.name, attr.value);\n      }\n    }\n  }\n\n  #bindInputs(component: ComponentRef<T>) {\n    Object.entries<string>((this.constructor as any)['ɵdir']['inputs']).forEach(([key, value]: [string, string]) => {\n      if (key === 'injectable') return;\n      component.setInput(key, (this as any)[value]);\n    });\n  }\n\n  #bindOutputs(component: ComponentRef<T>) {\n    getOutputsByInstance(component).forEach(([alias, attr]: [string, string]) => {\n      (component.instance as any)[attr].pipe(\n        takeUntilDestroyed(this.#destroy$)\n      ).subscribe((value: any) => (this as any)[attr].emit(value));\n    });\n  }\n\n  ngOnInit() {\n    if (this.injectable) {\n      this.#injector.get<TypeFactoryAsync<T>>((this.constructor as any)['TOKEN'])().then(type => {\n        const ref = this.#outlet.createComponent(type);\n        this.#bindInputs(ref);\n        this.#bindOutputs(ref);\n        this.#setAttribute(ref);\n      });\n    }\n  }\n\n  @Input({transform: (value: any) => value === '' ? true : value})\n  private injectable = false;\n\n  @Output()\n  protected action = new EventEmitter<Action>();\n}\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"injectable-component.js","sourceRoot":"","sources":["../../../../../../packages/@ng-atomic/core/src/lib/injectable-component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ComponentMirror, ComponentRef, DestroyRef, Directive, ElementRef, EmbeddedViewRef, EventEmitter, Injector, Input, Output, SimpleChange, SimpleChanges, Type, ViewContainerRef, inject } from \"@angular/core\";\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\nimport { reflectComponentType } from \"@angular/core\";\nimport { Action } from \"./action\";\nimport { NgAtomicComponentStore } from \"./component-store\";\n\nexport type TypeFactoryAsync<T> = () => Promise<Type<T>>;\n\nexport type TypeFactory<T> = () => (Type<T> | Promise<Type<T>>);\n\nexport function provideComponent<ABS = any, IMPL = any>(\n  abstract: Type<ABS>,\n  typeOrFactory: Type<IMPL> | TypeFactory<IMPL>,\n) {\n  async function loadComponentType(): Promise<Type<IMPL>> {\n    if (typeof typeOrFactory === 'function' && !typeOrFactory.prototype) {\n      return await (typeOrFactory as TypeFactory<IMPL>)();\n    } else {\n      return typeOrFactory as Type<IMPL>;\n    }\n  };\n  return { provide: (abstract as any)['TOKEN'], useValue: loadComponentType };\n}\n\nexport enum HostType {\n  Dir = 'ɵdir',\n  Cmp = 'ɵcmp',\n}\n\ntype IO = {propName: string, templateName: string};\n\nexport function getMeta<T>(type: Type<T>) {\n  return (type as any)[HostType.Cmp] || (type as any)[HostType.Dir];\n}\n\nexport function getInputs<T>(type: Type<T>): IO[] {\n  return Object.entries<string>(getMeta(type)['inputs'])\n    .map(([propName, templateName]) => ({propName, templateName}));\n}\n\nexport function getOutputs<T>(type: Type<T>): IO[] {\n  return Object.entries<string>(getMeta(type)['outputs'])\n    .map(([propName, templateName]) => ({propName, templateName}));\n}\n\nexport function getInputsByComponentRef<T extends {} = any>(cmp: ComponentRef<T>): IO[] {\n  return getInputs(cmp.instance.constructor as Type<T>);\n}\n\nexport function getOutputsByInstance<T extends {} = any>(cmp: ComponentRef<T>): IO[] {\n  return getOutputs(cmp.instance.constructor as Type<T>);\n}\n\n@Directive({ standalone: true })\nexport abstract class InjectableComponent<T extends NgAtomicComponentStore = any> {\n  readonly #outlet = inject(ViewContainerRef);\n  readonly #injector = inject(Injector);\n  readonly #destroy$ = inject(DestroyRef);\n  readonly #el = inject(ElementRef);\n  #component: ComponentRef<T> | null = null;\n  #componentMirror: ComponentMirror<T> | null = null;\n\n  #setAttribute() {\n    const hostElement = (this.#component!.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n    const attributes: NamedNodeMap = this.#el.nativeElement.attributes;\n    for (let i = 0; i < attributes.length; i++) {\n      const attr = attributes.item(i)!;\n      if (attr.name.startsWith('_ngcontent')) {\n        hostElement.setAttribute(attr.name, attr.value);\n      }\n    }\n  }\n\n  #bindInputs() {\n    // for (const input of this.#componentMirror!.inputs) {\n    //   if (input.propName === 'injectable') return;\n    //   this.#component!.setInput(input.propName, (this as any)[input.propName]);\n    // }\n\n    for (const input of getInputs(this.constructor as Type<T>)) {\n      if (input.propName === 'injectable') return;\n      this.#component!.setInput(input.propName, (this as any)[input.propName]);\n    }\n  }\n\n  #bindOutputs() {\n    // for (const output of this.#componentMirror!.outputs) {\n    //   (this.#component!.instance as any)[output.templateName].pipe(\n    //     takeUntilDestroyed(this.#destroy$)\n    //   ).subscribe((value: any) => (this as any)[output.templateName].emit(value));\n    // }\n\n    for (const output of getOutputs(this.constructor as Type<T>)) {\n      (this.#component!.instance as any)[output.templateName]?.pipe(\n        takeUntilDestroyed(this.#destroy$)\n      ).subscribe((value: any) => {\n        console.debug('output=>>', output.templateName, value);\n        (this as any)[output.templateName].emit(value);\n      });\n    }\n  }\n\n  ngOnInit() {\n    if (this.injectable) {\n      this.#injector.get<TypeFactoryAsync<T>>((this.constructor as any)['TOKEN'])().then(type => {\n        this.#component = this.#outlet.createComponent(type);\n        this.#componentMirror = reflectComponentType(type);\n        this.#bindInputs();\n        this.#bindOutputs();\n        this.#setAttribute();\n      });\n    }\n  }\n\n  ngOnChanges(simpleChanges: SimpleChanges) {\n    if (this.injectable && this.#componentMirror) {\n      // for (const input of this.#componentMirror.inputs) {\n      //   if (input.propName === 'injectable') return;\n      //   const change = simpleChanges[input.propName] as SimpleChange;\n      //   if (change) {\n      //     this.#component!.setInput(input.propName, change.currentValue);\n      //   }\n      // }\n\n      for (const input of getInputs(this.constructor as Type<T>)) {\n        if (input.propName === 'injectable') return;\n        const change = simpleChanges[input.propName] as SimpleChange;\n        if (change) {\n          this.#component!.setInput(input.propName, change.currentValue);\n        }\n      }\n    }\n  }\n\n  @Input({transform: (value: any) => value === '' ? true : value})\n  private injectable = false;\n\n  @Output()\n  protected action = new EventEmitter<Action>();\n}\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { EventEmitter, Injectable, inject, ViewContainerRef, Injector, DestroyRef, ElementRef, Directive, Input, Output } from '@angular/core';
|
|
2
|
+
import { EventEmitter, Injectable, inject, ViewContainerRef, Injector, DestroyRef, ElementRef, reflectComponentType, Directive, Input, Output } from '@angular/core';
|
|
3
3
|
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
4
4
|
|
|
5
5
|
class NgAtomicRootActionStore {
|
|
@@ -61,14 +61,27 @@ function provideComponent(abstract, typeOrFactory) {
|
|
|
61
61
|
;
|
|
62
62
|
return { provide: abstract['TOKEN'], useValue: loadComponentType };
|
|
63
63
|
}
|
|
64
|
-
|
|
65
|
-
|
|
64
|
+
var HostType;
|
|
65
|
+
(function (HostType) {
|
|
66
|
+
HostType["Dir"] = "\u0275dir";
|
|
67
|
+
HostType["Cmp"] = "\u0275cmp";
|
|
68
|
+
})(HostType || (HostType = {}));
|
|
69
|
+
function getMeta(type) {
|
|
70
|
+
return type[HostType.Cmp] || type[HostType.Dir];
|
|
71
|
+
}
|
|
72
|
+
function getInputs(type) {
|
|
73
|
+
return Object.entries(getMeta(type)['inputs'])
|
|
74
|
+
.map(([propName, templateName]) => ({ propName, templateName }));
|
|
75
|
+
}
|
|
76
|
+
function getOutputs(type) {
|
|
77
|
+
return Object.entries(getMeta(type)['outputs'])
|
|
78
|
+
.map(([propName, templateName]) => ({ propName, templateName }));
|
|
66
79
|
}
|
|
67
80
|
function getInputsByComponentRef(cmp) {
|
|
68
81
|
return getInputs(cmp.instance.constructor);
|
|
69
82
|
}
|
|
70
83
|
function getOutputsByInstance(cmp) {
|
|
71
|
-
return
|
|
84
|
+
return getOutputs(cmp.instance.constructor);
|
|
72
85
|
}
|
|
73
86
|
class InjectableComponent {
|
|
74
87
|
constructor() {
|
|
@@ -76,6 +89,8 @@ class InjectableComponent {
|
|
|
76
89
|
this.#injector = inject(Injector);
|
|
77
90
|
this.#destroy$ = inject(DestroyRef);
|
|
78
91
|
this.#el = inject(ElementRef);
|
|
92
|
+
this.#component = null;
|
|
93
|
+
this.#componentMirror = null;
|
|
79
94
|
this.injectable = false;
|
|
80
95
|
this.action = new EventEmitter();
|
|
81
96
|
}
|
|
@@ -83,8 +98,10 @@ class InjectableComponent {
|
|
|
83
98
|
#injector;
|
|
84
99
|
#destroy$;
|
|
85
100
|
#el;
|
|
86
|
-
#
|
|
87
|
-
|
|
101
|
+
#component;
|
|
102
|
+
#componentMirror;
|
|
103
|
+
#setAttribute() {
|
|
104
|
+
const hostElement = this.#component.hostView.rootNodes[0];
|
|
88
105
|
const attributes = this.#el.nativeElement.attributes;
|
|
89
106
|
for (let i = 0; i < attributes.length; i++) {
|
|
90
107
|
const attr = attributes.item(i);
|
|
@@ -93,30 +110,62 @@ class InjectableComponent {
|
|
|
93
110
|
}
|
|
94
111
|
}
|
|
95
112
|
}
|
|
96
|
-
#bindInputs(
|
|
97
|
-
|
|
98
|
-
|
|
113
|
+
#bindInputs() {
|
|
114
|
+
// for (const input of this.#componentMirror!.inputs) {
|
|
115
|
+
// if (input.propName === 'injectable') return;
|
|
116
|
+
// this.#component!.setInput(input.propName, (this as any)[input.propName]);
|
|
117
|
+
// }
|
|
118
|
+
for (const input of getInputs(this.constructor)) {
|
|
119
|
+
if (input.propName === 'injectable')
|
|
99
120
|
return;
|
|
100
|
-
component.setInput(
|
|
101
|
-
}
|
|
121
|
+
this.#component.setInput(input.propName, this[input.propName]);
|
|
122
|
+
}
|
|
102
123
|
}
|
|
103
|
-
#bindOutputs(
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
124
|
+
#bindOutputs() {
|
|
125
|
+
// for (const output of this.#componentMirror!.outputs) {
|
|
126
|
+
// (this.#component!.instance as any)[output.templateName].pipe(
|
|
127
|
+
// takeUntilDestroyed(this.#destroy$)
|
|
128
|
+
// ).subscribe((value: any) => (this as any)[output.templateName].emit(value));
|
|
129
|
+
// }
|
|
130
|
+
for (const output of getOutputs(this.constructor)) {
|
|
131
|
+
this.#component.instance[output.templateName]?.pipe(takeUntilDestroyed(this.#destroy$)).subscribe((value) => {
|
|
132
|
+
console.debug('output=>>', output.templateName, value);
|
|
133
|
+
this[output.templateName].emit(value);
|
|
134
|
+
});
|
|
135
|
+
}
|
|
107
136
|
}
|
|
108
137
|
ngOnInit() {
|
|
109
138
|
if (this.injectable) {
|
|
110
139
|
this.#injector.get(this.constructor['TOKEN'])().then(type => {
|
|
111
|
-
|
|
112
|
-
this.#
|
|
113
|
-
this.#
|
|
114
|
-
this.#
|
|
140
|
+
this.#component = this.#outlet.createComponent(type);
|
|
141
|
+
this.#componentMirror = reflectComponentType(type);
|
|
142
|
+
this.#bindInputs();
|
|
143
|
+
this.#bindOutputs();
|
|
144
|
+
this.#setAttribute();
|
|
115
145
|
});
|
|
116
146
|
}
|
|
117
147
|
}
|
|
148
|
+
ngOnChanges(simpleChanges) {
|
|
149
|
+
if (this.injectable && this.#componentMirror) {
|
|
150
|
+
// for (const input of this.#componentMirror.inputs) {
|
|
151
|
+
// if (input.propName === 'injectable') return;
|
|
152
|
+
// const change = simpleChanges[input.propName] as SimpleChange;
|
|
153
|
+
// if (change) {
|
|
154
|
+
// this.#component!.setInput(input.propName, change.currentValue);
|
|
155
|
+
// }
|
|
156
|
+
// }
|
|
157
|
+
for (const input of getInputs(this.constructor)) {
|
|
158
|
+
if (input.propName === 'injectable')
|
|
159
|
+
return;
|
|
160
|
+
const change = simpleChanges[input.propName];
|
|
161
|
+
if (change) {
|
|
162
|
+
this.#component.setInput(input.propName, change.currentValue);
|
|
163
|
+
}
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
}
|
|
118
167
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InjectableComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
119
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "16.2.12", type: InjectableComponent, isStandalone: true, inputs: { injectable: ["injectable", "injectable", (value) => value === '' ? true : value] }, outputs: { action: "action" }, ngImport: i0 }); }
|
|
168
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "16.1.0", version: "16.2.12", type: InjectableComponent, isStandalone: true, inputs: { injectable: ["injectable", "injectable", (value) => value === '' ? true : value] }, outputs: { action: "action" }, usesOnChanges: true, ngImport: i0 }); }
|
|
120
169
|
}
|
|
121
170
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InjectableComponent, decorators: [{
|
|
122
171
|
type: Directive,
|
|
@@ -143,7 +192,6 @@ class NgAtomicComponent extends InjectableComponent {
|
|
|
143
192
|
#destroy$;
|
|
144
193
|
constructor() {
|
|
145
194
|
super();
|
|
146
|
-
this._effectMap = new EffectMap();
|
|
147
195
|
this.root = inject(NgAtomicRootActionStore);
|
|
148
196
|
this.#destroy$ = inject(DestroyRef);
|
|
149
197
|
this.root.actions$.pipe(takeUntilDestroyed(this.#destroy$)).subscribe(action => this.#effect(action, 'root'));
|
|
@@ -177,5 +225,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
177
225
|
* Generated bundle index. Do not edit.
|
|
178
226
|
*/
|
|
179
227
|
|
|
180
|
-
export { Effect, EffectMap, InjectableComponent, NgAtomicComponent, NgAtomicComponentStore, NgAtomicRootActionStore, getInputs, getInputsByComponentRef, getOutputsByInstance, provideComponent, resolveActions };
|
|
228
|
+
export { Effect, EffectMap, HostType, InjectableComponent, NgAtomicComponent, NgAtomicComponentStore, NgAtomicRootActionStore, getInputs, getInputsByComponentRef, getMeta, getOutputs, getOutputsByInstance, provideComponent, resolveActions };
|
|
181
229
|
//# sourceMappingURL=ng-atomic-core.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"ng-atomic-core.mjs","sources":["../../../../../packages/@ng-atomic/core/src/lib/action-store.ts","../../../../../packages/@ng-atomic/core/src/lib/action.ts","../../../../../packages/@ng-atomic/core/src/lib/effect.ts","../../../../../packages/@ng-atomic/core/src/lib/injectable-component.ts","../../../../../packages/@ng-atomic/core/src/lib/component-store.ts","../../../../../packages/@ng-atomic/core/src/ng-atomic-core.ts"],"sourcesContent":["import { EventEmitter, Injectable } from \"@angular/core\";\nimport { Action } from \"./action\";\n\n@Injectable({providedIn: 'root'})\nexport class NgAtomicRootActionStore {\n readonly actions$ = new EventEmitter<Action>();\n\n constructor() {\n this.actions$.subscribe(action => this.log(action, 'root'));\n }\n\n dispatch(action: Action) {\n this.actions$.emit(action);\n }\n\n log(action: Action, scope: string = 'default') {\n console.debug(action, scope);\n }\n}\n","export interface Action<T = any> {\n id: string;\n payload?: T;\n name?: string;\n icon?: string;\n color?: string;\n disabled?: boolean;\n children?: Action<T>[],\n}\n\nexport type Actions = ((...args: any[]) => Action[]) | Action[];\n\nexport function resolveActions(actions: Actions, ...args: any[]) {\n if (typeof actions === 'function') {\n return actions(...args);\n }\n return actions;\n}\n","import { Action } from \"./action\";\n\nexport interface EffectProps {\n dispatch: boolean;\n scope: string;\n accessor: <T = any>(action: Action) => T;\n}\n\nexport class EffectMap extends Map<string, {key: string, props: EffectProps}> {\n override get(key: string, scope = 'default'): { key: string; props: EffectProps; } {\n return super.get(this.makeKey(key, scope))!; \n }\n\n override set(key: string, value: { key: string; props: EffectProps; }): this {\n return super.set(this.makeKey(key, value.props.scope), value);\n }\n\n override has(key: string, scope = 'default'): boolean {\n return super.has(this.makeKey(key, scope));\n }\n\n private makeKey(key: string, scope = 'default') {\n return `[${scope}]#${key}`;\n }\n}\n\nexport function Effect(id: string, {\n dispatch = false,\n scope = 'default',\n accessor = (action: Action) => action.payload,\n}: Partial<EffectProps> = {}) {\n return function (target: any, propertyKey: string, descriptor: PropertyDescriptor) {\n target['_effectMap'] ??= new EffectMap();\n target['_effectMap'].set(id, {key: propertyKey, props: {dispatch, scope, accessor}});\n };\n}\n","import { ComponentRef, DestroyRef, Directive, ElementRef, EmbeddedViewRef, EventEmitter, Injector, Input, Output, Type, ViewContainerRef, inject } from \"@angular/core\";\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\nimport { Action } from \"./action\";\nimport { NgAtomicComponentStore } from \"./component-store\";\n\nexport type TypeFactoryAsync<T> = () => Promise<Type<T>>;\n\nexport type TypeFactory<T> = () => (Type<T> | Promise<Type<T>>);\n\nexport function provideComponent<ABS = any, IMPL = any>(\n abstract: Type<ABS>,\n typeOrFactory: Type<IMPL> | TypeFactory<IMPL>,\n) {\n async function loadComponentType(): Promise<Type<IMPL>> {\n if (typeof typeOrFactory === 'function' && !typeOrFactory.prototype) {\n return await (typeOrFactory as TypeFactory<IMPL>)();\n } else {\n return typeOrFactory as Type<IMPL>;\n }\n };\n return { provide: (abstract as any)['TOKEN'], useValue: loadComponentType };\n}\n\nexport function getInputs<T>(type: Type<T>, meta: 'ɵcmp' | 'ɵdir' = 'ɵcmp'): [string, string][] {\n return Object.entries((type as any)[meta]['inputs']);\n}\n\nexport function getInputsByComponentRef<T = any>(cmp: ComponentRef<T>): [string, string][] {\n return getInputs((cmp.instance as any).constructor as Type<T>);\n}\n\nexport function getOutputsByInstance<T = any>(cmp: ComponentRef<T>): [string, string][] {\n return Object.entries((cmp.instance as any).constructor['ɵcmp']['outputs']);\n}\n\n@Directive({ standalone: true })\nexport abstract class InjectableComponent<T extends NgAtomicComponentStore = any> {\n readonly #outlet = inject(ViewContainerRef);\n readonly #injector = inject(Injector);\n readonly #destroy$ = inject(DestroyRef);\n readonly #el = inject(ElementRef);\n\n #setAttribute(component: ComponentRef<T>) {\n const hostElement = (component.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n const attributes: NamedNodeMap = this.#el.nativeElement.attributes;\n for (let i = 0; i < attributes.length; i++) {\n const attr = attributes.item(i)!;\n if (attr.name.startsWith('_ngcontent')) {\n hostElement.setAttribute(attr.name, attr.value);\n }\n }\n }\n\n #bindInputs(component: ComponentRef<T>) {\n Object.entries<string>((this.constructor as any)['ɵdir']['inputs']).forEach(([key, value]: [string, string]) => {\n if (key === 'injectable') return;\n component.setInput(key, (this as any)[value]);\n });\n }\n\n #bindOutputs(component: ComponentRef<T>) {\n getOutputsByInstance(component).forEach(([alias, attr]: [string, string]) => {\n (component.instance as any)[attr].pipe(\n takeUntilDestroyed(this.#destroy$)\n ).subscribe((value: any) => (this as any)[attr].emit(value));\n });\n }\n\n ngOnInit() {\n if (this.injectable) {\n this.#injector.get<TypeFactoryAsync<T>>((this.constructor as any)['TOKEN'])().then(type => {\n const ref = this.#outlet.createComponent(type);\n this.#bindInputs(ref);\n this.#bindOutputs(ref);\n this.#setAttribute(ref);\n });\n }\n }\n\n @Input({transform: (value: any) => value === '' ? true : value})\n private injectable = false;\n\n @Output()\n protected action = new EventEmitter<Action>();\n}\n","import { DestroyRef, Directive, EventEmitter, inject } from \"@angular/core\";\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\nimport { Action } from \"./action\";\nimport { InjectableComponent } from \"./injectable-component\";\nimport { EffectMap } from \"./effect\";\nimport { NgAtomicRootActionStore } from \"./action-store\";\n\n@Directive({ standalone: true })\nexport class NgAtomicComponentStore {\n readonly action = new EventEmitter<Action>();\n}\n\n@Directive({ standalone: true })\nexport class NgAtomicComponent extends InjectableComponent {\n protected _effectMap = new EffectMap();\n protected root = inject(NgAtomicRootActionStore);\n #destroy$ = inject(DestroyRef);\n\n constructor() {\n super();\n this.root.actions$.pipe(\n takeUntilDestroyed(this.#destroy$),\n ).subscribe(action => this.#effect(action, 'root'));\n }\n\n dispatch(action: Action, scope = 'default') {\n this.root.log(action, scope);\n const effect = this.#effect(action, scope);\n if (scope === 'root' && (!effect?.props || effect?.props?.dispatch)) {\n this.root.actions$.emit(action);\n } else if (!effect?.props || effect?.props?.dispatch) {\n this.action.emit(action);\n }\n }\n\n #effect(action: Action, scope = 'default') {\n const effect = (this._effectMap ?? new EffectMap()).get(action.id, scope);\n if (effect?.key && effect?.props?.scope === scope) {\n (this as any)[effect?.key](effect.props.accessor(action));\n }\n return effect;\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"ng-atomic-core.mjs","sources":["../../../../../packages/@ng-atomic/core/src/lib/action-store.ts","../../../../../packages/@ng-atomic/core/src/lib/action.ts","../../../../../packages/@ng-atomic/core/src/lib/effect.ts","../../../../../packages/@ng-atomic/core/src/lib/injectable-component.ts","../../../../../packages/@ng-atomic/core/src/lib/component-store.ts","../../../../../packages/@ng-atomic/core/src/ng-atomic-core.ts"],"sourcesContent":["import { EventEmitter, Injectable } from \"@angular/core\";\nimport { Action } from \"./action\";\n\n@Injectable({providedIn: 'root'})\nexport class NgAtomicRootActionStore {\n readonly actions$ = new EventEmitter<Action>();\n\n constructor() {\n this.actions$.subscribe(action => this.log(action, 'root'));\n }\n\n dispatch(action: Action) {\n this.actions$.emit(action);\n }\n\n log(action: Action, scope: string = 'default') {\n console.debug(action, scope);\n }\n}\n","export interface Action<T = any> {\n id: string;\n payload?: T;\n name?: string;\n icon?: string;\n color?: string;\n disabled?: boolean;\n children?: Action<T>[],\n}\n\nexport type Actions = ((...args: any[]) => Action[]) | Action[];\n\nexport function resolveActions(actions: Actions, ...args: any[]) {\n if (typeof actions === 'function') {\n return actions(...args);\n }\n return actions;\n}\n","import { Action } from \"./action\";\n\nexport interface EffectProps {\n dispatch: boolean;\n scope: string;\n accessor: <T = any>(action: Action) => T;\n}\n\nexport class EffectMap extends Map<string, {key: string, props: EffectProps}> {\n override get(key: string, scope = 'default'): { key: string; props: EffectProps; } {\n return super.get(this.makeKey(key, scope))!; \n }\n\n override set(key: string, value: { key: string; props: EffectProps; }): this {\n return super.set(this.makeKey(key, value.props.scope), value);\n }\n\n override has(key: string, scope = 'default'): boolean {\n return super.has(this.makeKey(key, scope));\n }\n\n private makeKey(key: string, scope = 'default') {\n return `[${scope}]#${key}`;\n }\n}\n\nexport function Effect(id: string, {\n dispatch = false,\n scope = 'default',\n accessor = (action: Action) => action.payload,\n}: Partial<EffectProps> = {}) {\n return function (target: any, propertyKey: string, descriptor: PropertyDescriptor) {\n target['_effectMap'] ??= new EffectMap();\n target['_effectMap'].set(id, {key: propertyKey, props: {dispatch, scope, accessor}});\n };\n}\n","import { ComponentMirror, ComponentRef, DestroyRef, Directive, ElementRef, EmbeddedViewRef, EventEmitter, Injector, Input, Output, SimpleChange, SimpleChanges, Type, ViewContainerRef, inject } from \"@angular/core\";\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\nimport { reflectComponentType } from \"@angular/core\";\nimport { Action } from \"./action\";\nimport { NgAtomicComponentStore } from \"./component-store\";\n\nexport type TypeFactoryAsync<T> = () => Promise<Type<T>>;\n\nexport type TypeFactory<T> = () => (Type<T> | Promise<Type<T>>);\n\nexport function provideComponent<ABS = any, IMPL = any>(\n abstract: Type<ABS>,\n typeOrFactory: Type<IMPL> | TypeFactory<IMPL>,\n) {\n async function loadComponentType(): Promise<Type<IMPL>> {\n if (typeof typeOrFactory === 'function' && !typeOrFactory.prototype) {\n return await (typeOrFactory as TypeFactory<IMPL>)();\n } else {\n return typeOrFactory as Type<IMPL>;\n }\n };\n return { provide: (abstract as any)['TOKEN'], useValue: loadComponentType };\n}\n\nexport enum HostType {\n Dir = 'ɵdir',\n Cmp = 'ɵcmp',\n}\n\ntype IO = {propName: string, templateName: string};\n\nexport function getMeta<T>(type: Type<T>) {\n return (type as any)[HostType.Cmp] || (type as any)[HostType.Dir];\n}\n\nexport function getInputs<T>(type: Type<T>): IO[] {\n return Object.entries<string>(getMeta(type)['inputs'])\n .map(([propName, templateName]) => ({propName, templateName}));\n}\n\nexport function getOutputs<T>(type: Type<T>): IO[] {\n return Object.entries<string>(getMeta(type)['outputs'])\n .map(([propName, templateName]) => ({propName, templateName}));\n}\n\nexport function getInputsByComponentRef<T extends {} = any>(cmp: ComponentRef<T>): IO[] {\n return getInputs(cmp.instance.constructor as Type<T>);\n}\n\nexport function getOutputsByInstance<T extends {} = any>(cmp: ComponentRef<T>): IO[] {\n return getOutputs(cmp.instance.constructor as Type<T>);\n}\n\n@Directive({ standalone: true })\nexport abstract class InjectableComponent<T extends NgAtomicComponentStore = any> {\n readonly #outlet = inject(ViewContainerRef);\n readonly #injector = inject(Injector);\n readonly #destroy$ = inject(DestroyRef);\n readonly #el = inject(ElementRef);\n #component: ComponentRef<T> | null = null;\n #componentMirror: ComponentMirror<T> | null = null;\n\n #setAttribute() {\n const hostElement = (this.#component!.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n const attributes: NamedNodeMap = this.#el.nativeElement.attributes;\n for (let i = 0; i < attributes.length; i++) {\n const attr = attributes.item(i)!;\n if (attr.name.startsWith('_ngcontent')) {\n hostElement.setAttribute(attr.name, attr.value);\n }\n }\n }\n\n #bindInputs() {\n // for (const input of this.#componentMirror!.inputs) {\n // if (input.propName === 'injectable') return;\n // this.#component!.setInput(input.propName, (this as any)[input.propName]);\n // }\n\n for (const input of getInputs(this.constructor as Type<T>)) {\n if (input.propName === 'injectable') return;\n this.#component!.setInput(input.propName, (this as any)[input.propName]);\n }\n }\n\n #bindOutputs() {\n // for (const output of this.#componentMirror!.outputs) {\n // (this.#component!.instance as any)[output.templateName].pipe(\n // takeUntilDestroyed(this.#destroy$)\n // ).subscribe((value: any) => (this as any)[output.templateName].emit(value));\n // }\n\n for (const output of getOutputs(this.constructor as Type<T>)) {\n (this.#component!.instance as any)[output.templateName]?.pipe(\n takeUntilDestroyed(this.#destroy$)\n ).subscribe((value: any) => {\n console.debug('output=>>', output.templateName, value);\n (this as any)[output.templateName].emit(value);\n });\n }\n }\n\n ngOnInit() {\n if (this.injectable) {\n this.#injector.get<TypeFactoryAsync<T>>((this.constructor as any)['TOKEN'])().then(type => {\n this.#component = this.#outlet.createComponent(type);\n this.#componentMirror = reflectComponentType(type);\n this.#bindInputs();\n this.#bindOutputs();\n this.#setAttribute();\n });\n }\n }\n\n ngOnChanges(simpleChanges: SimpleChanges) {\n if (this.injectable && this.#componentMirror) {\n // for (const input of this.#componentMirror.inputs) {\n // if (input.propName === 'injectable') return;\n // const change = simpleChanges[input.propName] as SimpleChange;\n // if (change) {\n // this.#component!.setInput(input.propName, change.currentValue);\n // }\n // }\n\n for (const input of getInputs(this.constructor as Type<T>)) {\n if (input.propName === 'injectable') return;\n const change = simpleChanges[input.propName] as SimpleChange;\n if (change) {\n this.#component!.setInput(input.propName, change.currentValue);\n }\n }\n }\n }\n\n @Input({transform: (value: any) => value === '' ? true : value})\n private injectable = false;\n\n @Output()\n protected action = new EventEmitter<Action>();\n}\n","import { DestroyRef, Directive, EventEmitter, inject } from \"@angular/core\";\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\nimport { Action } from \"./action\";\nimport { InjectableComponent } from \"./injectable-component\";\nimport { EffectMap } from \"./effect\";\nimport { NgAtomicRootActionStore } from \"./action-store\";\n\n@Directive({ standalone: true })\nexport class NgAtomicComponentStore {\n readonly action = new EventEmitter<Action>();\n}\n\n@Directive({ standalone: true })\nexport class NgAtomicComponent extends InjectableComponent {\n // @ts-ignore\n protected _effectMap: EffectMap;\n protected root = inject(NgAtomicRootActionStore);\n #destroy$ = inject(DestroyRef);\n\n constructor() {\n super();\n this.root.actions$.pipe(\n takeUntilDestroyed(this.#destroy$),\n ).subscribe(action => this.#effect(action, 'root'));\n }\n\n dispatch(action: Action, scope = 'default') {\n this.root.log(action, scope);\n const effect = this.#effect(action, scope);\n if (scope === 'root' && (!effect?.props || effect?.props?.dispatch)) {\n this.root.actions$.emit(action);\n } else if (!effect?.props || effect?.props?.dispatch) {\n this.action.emit(action);\n }\n }\n\n #effect(action: Action, scope = 'default') {\n const effect = (this._effectMap ?? new EffectMap()).get(action.id, scope);\n if (effect?.key && effect?.props?.scope === scope) {\n (this as any)[effect?.key](effect.props.accessor(action));\n }\n return effect;\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ComponentRef, EventEmitter, Type } from "@angular/core";
|
|
1
|
+
import { ComponentRef, EventEmitter, SimpleChanges, Type } from "@angular/core";
|
|
2
2
|
import { Action } from "./action";
|
|
3
3
|
import { NgAtomicComponentStore } from "./component-store";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
@@ -8,24 +8,27 @@ export declare function provideComponent<ABS = any, IMPL = any>(abstract: Type<A
|
|
|
8
8
|
provide: any;
|
|
9
9
|
useValue: () => Promise<Type<IMPL>>;
|
|
10
10
|
};
|
|
11
|
-
export declare
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
string
|
|
17
|
-
string
|
|
18
|
-
|
|
19
|
-
export declare function
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
11
|
+
export declare enum HostType {
|
|
12
|
+
Dir = "\u0275dir",
|
|
13
|
+
Cmp = "\u0275cmp"
|
|
14
|
+
}
|
|
15
|
+
type IO = {
|
|
16
|
+
propName: string;
|
|
17
|
+
templateName: string;
|
|
18
|
+
};
|
|
19
|
+
export declare function getMeta<T>(type: Type<T>): any;
|
|
20
|
+
export declare function getInputs<T>(type: Type<T>): IO[];
|
|
21
|
+
export declare function getOutputs<T>(type: Type<T>): IO[];
|
|
22
|
+
export declare function getInputsByComponentRef<T extends {} = any>(cmp: ComponentRef<T>): IO[];
|
|
23
|
+
export declare function getOutputsByInstance<T extends {} = any>(cmp: ComponentRef<T>): IO[];
|
|
23
24
|
export declare abstract class InjectableComponent<T extends NgAtomicComponentStore = any> {
|
|
24
25
|
#private;
|
|
25
26
|
ngOnInit(): void;
|
|
27
|
+
ngOnChanges(simpleChanges: SimpleChanges): void;
|
|
26
28
|
private injectable;
|
|
27
29
|
protected action: EventEmitter<Action<any>>;
|
|
28
30
|
static ɵfac: i0.ɵɵFactoryDeclaration<InjectableComponent<any>, never>;
|
|
29
31
|
static ɵdir: i0.ɵɵDirectiveDeclaration<InjectableComponent<any>, never, never, { "injectable": { "alias": "injectable"; "required": false; }; }, { "action": "action"; }, never, never, true, never>;
|
|
30
32
|
static ngAcceptInputType_injectable: any;
|
|
31
33
|
}
|
|
34
|
+
export {};
|