@ng-atomic/core 16.2.0 → 17.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -1,7 +1,60 @@
1
- # packages/@ng-atomic/core
1
+ # @ng-atomic/core
2
+ `@ng-atomic/core`は
2
3
 
3
- This library was generated with [Nx](https://nx.dev).
4
+ ## Concept
5
+ - Injectable Component
6
+ - Action and Effect
4
7
 
5
- ## Running unit tests
8
+ ## Install
9
+ ```sh
10
+ $ npm i @ng-atomic/core
11
+ ```
6
12
 
7
- Run `nx test packages/@ng-atomic/core` to execute the unit tests.
13
+ ## Example
14
+
15
+ ```ts
16
+ @Directive({standalone: true, selector: 'example'})
17
+ export class ExampleComponentStore extends InjectableComponent {
18
+ @Input() name: string;
19
+ }
20
+
21
+ @Component({
22
+ standalone: true,
23
+ selector: 'example',
24
+ hostDirectives: [ExampleComponentStore],
25
+ template: `<button (click)="onButtonClick()">{{ store.name }}</button>`
26
+ })
27
+ export class ExampleComponent extends NgAtomicComponent {
28
+ protected store = inject(ExampleComponentStore);
29
+
30
+ protected onButtonClick() {
31
+ this.dispatch({
32
+ id: ActionId.BUTTON_CLICK,
33
+ payload: 'Hello World!',
34
+ });
35
+ }
36
+ }
37
+
38
+ @Component({
39
+ standalone: true,
40
+ selector: 'example',
41
+ imports: [
42
+ // Import Injectable Component
43
+ ExampleComponentStore
44
+ ],
45
+ template: `<example [name]="'example'" (action)="dispatch($event)" injectable/>`,
46
+ provider: [
47
+ // Provide Component Implementation
48
+ provideComponent(ExampleComponentStore, () => ExampleComponent),
49
+ ],
50
+ })
51
+ export class AppComponent extends NgAtomicComponent {
52
+ @Effect(ExampleComponent.ActionId.BUTTON_CLICK)
53
+ protected onButtonClick(message: string) {
54
+ alert(message);
55
+ }
56
+ }
57
+ ```
58
+
59
+ # LISENCE
60
+ MIT
@@ -1,8 +1,8 @@
1
1
  import { EventEmitter, Injectable } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  export class NgAtomicRootActionStore {
4
+ actions$ = new EventEmitter();
4
5
  constructor() {
5
- this.actions$ = new EventEmitter();
6
6
  this.actions$.subscribe(action => this.log(action, 'root'));
7
7
  }
8
8
  dispatch(action) {
@@ -11,11 +11,11 @@ export class NgAtomicRootActionStore {
11
11
  log(action, scope = 'default') {
12
12
  console.debug(action, scope);
13
13
  }
14
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgAtomicRootActionStore, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
15
- static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgAtomicRootActionStore, providedIn: 'root' }); }
14
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NgAtomicRootActionStore, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
15
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NgAtomicRootActionStore, providedIn: 'root' });
16
16
  }
17
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: NgAtomicRootActionStore, decorators: [{
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: NgAtomicRootActionStore, decorators: [{
18
18
  type: Injectable,
19
19
  args: [{ providedIn: 'root' }]
20
- }], ctorParameters: function () { return []; } });
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLXN0b3JlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb3JlL3NyYy9saWIvYWN0aW9uLXN0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUl6RCxNQUFNLE9BQU8sdUJBQXVCO0lBR2xDO1FBRlMsYUFBUSxHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFHN0MsSUFBSSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxRQUFRLENBQUMsTUFBYztRQUNyQixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQsR0FBRyxDQUFDLE1BQWMsRUFBRSxRQUFnQixTQUFTO1FBQzNDLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQy9CLENBQUM7K0dBYlUsdUJBQXVCO21IQUF2Qix1QkFBdUIsY0FEWCxNQUFNOzs0RkFDbEIsdUJBQXVCO2tCQURuQyxVQUFVO21CQUFDLEVBQUMsVUFBVSxFQUFFLE1BQU0sRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW1pdHRlciwgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBBY3Rpb24gfSBmcm9tIFwiLi9hY3Rpb25cIjtcblxuQEluamVjdGFibGUoe3Byb3ZpZGVkSW46ICdyb290J30pXG5leHBvcnQgY2xhc3MgTmdBdG9taWNSb290QWN0aW9uU3RvcmUge1xuICByZWFkb25seSBhY3Rpb25zJCA9IG5ldyBFdmVudEVtaXR0ZXI8QWN0aW9uPigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMuYWN0aW9ucyQuc3Vic2NyaWJlKGFjdGlvbiA9PiB0aGlzLmxvZyhhY3Rpb24sICdyb290JykpO1xuICB9XG5cbiAgZGlzcGF0Y2goYWN0aW9uOiBBY3Rpb24pIHtcbiAgICB0aGlzLmFjdGlvbnMkLmVtaXQoYWN0aW9uKTtcbiAgfVxuXG4gIGxvZyhhY3Rpb246IEFjdGlvbiwgc2NvcGU6IHN0cmluZyA9ICdkZWZhdWx0Jykge1xuICAgIGNvbnNvbGUuZGVidWcoYWN0aW9uLCBzY29wZSk7XG4gIH1cbn1cbiJdfQ==
20
+ }], ctorParameters: () => [] });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLXN0b3JlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb3JlL3NyYy9saWIvYWN0aW9uLXN0b3JlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUl6RCxNQUFNLE9BQU8sdUJBQXVCO0lBQ3pCLFFBQVEsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO0lBRS9DO1FBQ0UsSUFBSSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxNQUFNLENBQUMsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFRCxRQUFRLENBQUMsTUFBYztRQUNyQixJQUFJLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM3QixDQUFDO0lBRUQsR0FBRyxDQUFDLE1BQWMsRUFBRSxRQUFnQixTQUFTO1FBQzNDLE9BQU8sQ0FBQyxLQUFLLENBQUMsTUFBTSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQy9CLENBQUM7dUdBYlUsdUJBQXVCOzJHQUF2Qix1QkFBdUIsY0FEWCxNQUFNOzsyRkFDbEIsdUJBQXVCO2tCQURuQyxVQUFVO21CQUFDLEVBQUMsVUFBVSxFQUFFLE1BQU0sRUFBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW1pdHRlciwgSW5qZWN0YWJsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBBY3Rpb24gfSBmcm9tIFwiLi9hY3Rpb25cIjtcblxuQEluamVjdGFibGUoe3Byb3ZpZGVkSW46ICdyb290J30pXG5leHBvcnQgY2xhc3MgTmdBdG9taWNSb290QWN0aW9uU3RvcmUge1xuICByZWFkb25seSBhY3Rpb25zJCA9IG5ldyBFdmVudEVtaXR0ZXI8QWN0aW9uPigpO1xuXG4gIGNvbnN0cnVjdG9yKCkge1xuICAgIHRoaXMuYWN0aW9ucyQuc3Vic2NyaWJlKGFjdGlvbiA9PiB0aGlzLmxvZyhhY3Rpb24sICdyb290JykpO1xuICB9XG5cbiAgZGlzcGF0Y2goYWN0aW9uOiBBY3Rpb24pIHtcbiAgICB0aGlzLmFjdGlvbnMkLmVtaXQoYWN0aW9uKTtcbiAgfVxuXG4gIGxvZyhhY3Rpb246IEFjdGlvbiwgc2NvcGU6IHN0cmluZyA9ICdkZWZhdWx0Jykge1xuICAgIGNvbnNvbGUuZGVidWcoYWN0aW9uLCBzY29wZSk7XG4gIH1cbn1cbiJdfQ==
@@ -4,4 +4,7 @@ export function resolveActions(actions, ...args) {
4
4
  }
5
5
  return actions;
6
6
  }
7
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb3JlL3NyYy9saWIvYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVlBLE1BQU0sVUFBVSxjQUFjLENBQUMsT0FBZ0IsRUFBRSxHQUFHLElBQVc7SUFDN0QsSUFBSSxPQUFPLE9BQU8sS0FBSyxVQUFVLEVBQUU7UUFDakMsT0FBTyxPQUFPLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztLQUN6QjtJQUNELE9BQU8sT0FBTyxDQUFDO0FBQ2pCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgaW50ZXJmYWNlIEFjdGlvbjxUID0gYW55PiB7XG4gIGlkOiBzdHJpbmc7XG4gIHBheWxvYWQ/OiBUO1xuICBuYW1lPzogc3RyaW5nO1xuICBpY29uPzogc3RyaW5nO1xuICBjb2xvcj86IHN0cmluZztcbiAgZGlzYWJsZWQ/OiBib29sZWFuO1xuICBjaGlsZHJlbj86IEFjdGlvbjxUPltdLFxufVxuXG5leHBvcnQgdHlwZSBBY3Rpb25zID0gKCguLi5hcmdzOiBhbnlbXSkgPT4gQWN0aW9uW10pIHwgQWN0aW9uW107XG5cbmV4cG9ydCBmdW5jdGlvbiByZXNvbHZlQWN0aW9ucyhhY3Rpb25zOiBBY3Rpb25zLCAuLi5hcmdzOiBhbnlbXSkge1xuICBpZiAodHlwZW9mIGFjdGlvbnMgPT09ICdmdW5jdGlvbicpIHtcbiAgICByZXR1cm4gYWN0aW9ucyguLi5hcmdzKTtcbiAgfVxuICByZXR1cm4gYWN0aW9ucztcbn1cbiJdfQ==
7
+ export function wrapActions(actions) {
8
+ return typeof actions === 'function' ? actions : () => actions;
9
+ }
10
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb3JlL3NyYy9saWIvYWN0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVBLE1BQU0sVUFBVSxjQUFjLENBQUMsT0FBZ0IsRUFBRSxHQUFHLElBQVc7SUFDN0QsSUFBSSxPQUFPLE9BQU8sS0FBSyxVQUFVLEVBQUU7UUFDakMsT0FBTyxPQUFPLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQztLQUN6QjtJQUNELE9BQU8sT0FBTyxDQUFDO0FBQ2pCLENBQUM7QUFFRCxNQUFNLFVBQVUsV0FBVyxDQUFDLE9BQWdCO0lBQzFDLE9BQU8sT0FBTyxPQUFPLEtBQUssVUFBVSxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQztBQUNqRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBBY3Rpb248VCA9IGFueT4ge1xuICBpZDogc3RyaW5nO1xuICBwYXlsb2FkPzogVDtcbiAgbmFtZT86IHN0cmluZztcbiAgaWNvbj86IHN0cmluZztcbiAgY29sb3I/OiBzdHJpbmc7XG4gIGRpc2FibGVkPzogYm9vbGVhbjtcbiAgY2hpbGRyZW4/OiBBY3Rpb248VD5bXSxcbiAgbWV0YT86IHtjb21wb25lbnRJZD86IHN0cmluZyB8IG51bWJlciB8IG51bGx9IHwgYW55O1xufVxuXG5leHBvcnQgdHlwZSBBY3Rpb25zRmFjdG9yeTxUID0gYW55PiA9ICguLi5hcmdzOiBhbnlbXSkgPT4gQWN0aW9uPFQ+W107XG5cbmV4cG9ydCB0eXBlIEFjdGlvbnMgPSBBY3Rpb25zRmFjdG9yeSB8IEFjdGlvbltdO1xuXG5leHBvcnQgZnVuY3Rpb24gcmVzb2x2ZUFjdGlvbnMoYWN0aW9uczogQWN0aW9ucywgLi4uYXJnczogYW55W10pIHtcbiAgaWYgKHR5cGVvZiBhY3Rpb25zID09PSAnZnVuY3Rpb24nKSB7XG4gICAgcmV0dXJuIGFjdGlvbnMoLi4uYXJncyk7XG4gIH1cbiAgcmV0dXJuIGFjdGlvbnM7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB3cmFwQWN0aW9ucyhhY3Rpb25zOiBBY3Rpb25zKTogQWN0aW9uc0ZhY3Rvcnkge1xuICByZXR1cm4gdHlwZW9mIGFjdGlvbnMgPT09ICdmdW5jdGlvbicgPyBhY3Rpb25zIDogKCkgPT4gYWN0aW9ucztcbn1cbiJdfQ==
@@ -0,0 +1,62 @@
1
+ import { isPlatformBrowser } from '@angular/common';
2
+ import { Directive, ElementRef, PLATFORM_ID, inject } from '@angular/core';
3
+ import { NG_ATOMIC_DEBUG } from '../ng-atomic-debug';
4
+ import * as i0 from "@angular/core";
5
+ const DEBUG_CONFIG = {
6
+ outline: '1px',
7
+ colors: {
8
+ 'templates': '#f00',
9
+ 'organisms': '#0f0',
10
+ 'molecules': '#00f',
11
+ 'atoms': '#ff0',
12
+ 'frames': 'transparent',
13
+ 'default': '#000',
14
+ },
15
+ excludes: ['frames', 'app', 'pages', 'atoms'],
16
+ };
17
+ export class DebugDirective {
18
+ el = inject(ElementRef);
19
+ platformId = inject(PLATFORM_ID);
20
+ isDebug = inject(NG_ATOMIC_DEBUG, { optional: true }) ?? false;
21
+ ngOnInit() {
22
+ if (isPlatformBrowser(this.platformId) && this.isDebug) {
23
+ const name = this.el.nativeElement.tagName.toLowerCase();
24
+ const type = name.split('-')[0];
25
+ if (DEBUG_CONFIG.excludes.includes(type))
26
+ return;
27
+ const color = DEBUG_CONFIG.colors?.[type] ?? DEBUG_CONFIG.colors.default;
28
+ // 1pxのアウトラインを設定
29
+ this.el.nativeElement.style.outline = `${DEBUG_CONFIG.outline} solid ${color}`;
30
+ // 疑似要素でコンポーネント名を表示
31
+ const labelEl = this.createLabelElement({
32
+ name: `${name}${this.el.nativeElement.hasAttribute('injected') ? '[injected]' : ''}`,
33
+ color
34
+ });
35
+ this.el.nativeElement.style.outlineOffset = '-1px';
36
+ this.el.nativeElement.style.position = 'relative';
37
+ this.el.nativeElement.appendChild(labelEl);
38
+ }
39
+ }
40
+ createLabelElement(options) {
41
+ const content = document.createElement('span');
42
+ content.textContent = options.name;
43
+ content.style.backgroundColor = `${options.color}`;
44
+ content.style.color = '#fff';
45
+ content.style.padding = '2px 4px';
46
+ content.style.position = 'absolute';
47
+ content.style.fontSize = '10px';
48
+ content.style.top = '0';
49
+ content.style.left = '0';
50
+ content.style.zIndex = '9999';
51
+ content.style.lineHeight = '1.5em';
52
+ content.style.whiteSpace = 'nowrap';
53
+ return content;
54
+ }
55
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DebugDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
56
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.2.2", type: DebugDirective, isStandalone: true, selector: "debug", ngImport: i0 });
57
+ }
58
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: DebugDirective, decorators: [{
59
+ type: Directive,
60
+ args: [{ standalone: true, selector: 'debug' }]
61
+ }] });
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVidWcuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb3JlL3NyYy9saWIvZGVidWcvZGVidWcuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQ3BELE9BQU8sRUFBRSxTQUFTLEVBQUUsVUFBVSxFQUFFLFdBQVcsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0UsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFDOztBQUVyRCxNQUFNLFlBQVksR0FBRztJQUNuQixPQUFPLEVBQUUsS0FBSztJQUNkLE1BQU0sRUFBRTtRQUNOLFdBQVcsRUFBRSxNQUFNO1FBQ25CLFdBQVcsRUFBRSxNQUFNO1FBQ25CLFdBQVcsRUFBRSxNQUFNO1FBQ25CLE9BQU8sRUFBRSxNQUFNO1FBQ2YsUUFBUSxFQUFFLGFBQWE7UUFDdkIsU0FBUyxFQUFFLE1BQU07S0FDbEI7SUFDRCxRQUFRLEVBQUUsQ0FBQyxRQUFRLEVBQUUsS0FBSyxFQUFFLE9BQU8sRUFBRSxPQUFPLENBQUM7Q0FDOUMsQ0FBQztBQUdGLE1BQU0sT0FBTyxjQUFjO0lBQ2YsRUFBRSxHQUE0QixNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDakQsVUFBVSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUNqQyxPQUFPLEdBQUcsTUFBTSxDQUFDLGVBQWUsRUFBRSxFQUFDLFFBQVEsRUFBRSxJQUFJLEVBQUMsQ0FBQyxJQUFJLEtBQUssQ0FBQztJQUV2RSxRQUFRO1FBQ04sSUFBSSxpQkFBaUIsQ0FBQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUN0RCxNQUFNLElBQUksR0FBRyxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDekQsTUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNoQyxJQUFJLFlBQVksQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQztnQkFBRSxPQUFPO1lBQ2pELE1BQU0sS0FBSyxHQUFHLFlBQVksQ0FBQyxNQUFNLEVBQUUsQ0FBQyxJQUFJLENBQUMsSUFBSSxZQUFZLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQztZQUV6RSxnQkFBZ0I7WUFDaEIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxHQUFHLFlBQVksQ0FBQyxPQUFPLFVBQVUsS0FBSyxFQUFFLENBQUM7WUFFL0UsbUJBQW1CO1lBQ25CLE1BQU0sT0FBTyxHQUFHLElBQUksQ0FBQyxrQkFBa0IsQ0FBQztnQkFDdEMsSUFBSSxFQUFFLEdBQUcsSUFBSSxHQUFHLElBQUksQ0FBQyxFQUFFLENBQUMsYUFBYSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUU7Z0JBQ3BGLEtBQUs7YUFDTixDQUFDLENBQUM7WUFDSCxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsYUFBYSxHQUFHLE1BQU0sQ0FBQztZQUNuRCxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQztZQUNsRCxJQUFJLENBQUMsRUFBRSxDQUFDLGFBQWEsQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLENBQUM7U0FDNUM7SUFDSCxDQUFDO0lBRVMsa0JBQWtCLENBQUMsT0FHNUI7UUFDQyxNQUFNLE9BQU8sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQy9DLE9BQU8sQ0FBQyxXQUFXLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQztRQUNuQyxPQUFPLENBQUMsS0FBSyxDQUFDLGVBQWUsR0FBRyxHQUFHLE9BQU8sQ0FBQyxLQUFLLEVBQUUsQ0FBQztRQUNuRCxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssR0FBRyxNQUFNLENBQUM7UUFDN0IsT0FBTyxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsU0FBUyxDQUFDO1FBQ2xDLE9BQU8sQ0FBQyxLQUFLLENBQUMsUUFBUSxHQUFHLFVBQVUsQ0FBQztRQUNwQyxPQUFPLENBQUMsS0FBSyxDQUFDLFFBQVEsR0FBRyxNQUFNLENBQUM7UUFDaEMsT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDO1FBQ3hCLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxHQUFHLEdBQUcsQ0FBQztRQUN6QixPQUFPLENBQUMsS0FBSyxDQUFDLE1BQU0sR0FBRyxNQUFNLENBQUM7UUFDOUIsT0FBTyxDQUFDLEtBQUssQ0FBQyxVQUFVLEdBQUcsT0FBTyxDQUFDO1FBQ25DLE9BQU8sQ0FBQyxLQUFLLENBQUMsVUFBVSxHQUFHLFFBQVEsQ0FBQztRQUNwQyxPQUFPLE9BQU8sQ0FBQztJQUNqQixDQUFDO3VHQTNDVSxjQUFjOzJGQUFkLGNBQWM7OzJGQUFkLGNBQWM7a0JBRDFCLFNBQVM7bUJBQUMsRUFBQyxVQUFVLEVBQUUsSUFBSSxFQUFFLFFBQVEsRUFBRSxPQUFPLEVBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBpc1BsYXRmb3JtQnJvd3NlciB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIFBMQVRGT1JNX0lELCBpbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5HX0FUT01JQ19ERUJVRyB9IGZyb20gJy4uL25nLWF0b21pYy1kZWJ1Zyc7XG5cbmNvbnN0IERFQlVHX0NPTkZJRyA9IHtcbiAgb3V0bGluZTogJzFweCcsXG4gIGNvbG9yczoge1xuICAgICd0ZW1wbGF0ZXMnOiAnI2YwMCcsXG4gICAgJ29yZ2FuaXNtcyc6ICcjMGYwJyxcbiAgICAnbW9sZWN1bGVzJzogJyMwMGYnLFxuICAgICdhdG9tcyc6ICcjZmYwJyxcbiAgICAnZnJhbWVzJzogJ3RyYW5zcGFyZW50JyxcbiAgICAnZGVmYXVsdCc6ICcjMDAwJyxcbiAgfSxcbiAgZXhjbHVkZXM6IFsnZnJhbWVzJywgJ2FwcCcsICdwYWdlcycsICdhdG9tcyddLFxufTtcblxuQERpcmVjdGl2ZSh7c3RhbmRhbG9uZTogdHJ1ZSwgc2VsZWN0b3I6ICdkZWJ1Zyd9KVxuZXhwb3J0IGNsYXNzIERlYnVnRGlyZWN0aXZlIHtcbiAgcHJvdGVjdGVkIGVsOiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PiA9IGluamVjdChFbGVtZW50UmVmKTtcbiAgcHJvdGVjdGVkIHBsYXRmb3JtSWQgPSBpbmplY3QoUExBVEZPUk1fSUQpO1xuICBwcm90ZWN0ZWQgaXNEZWJ1ZyA9IGluamVjdChOR19BVE9NSUNfREVCVUcsIHtvcHRpb25hbDogdHJ1ZX0pID8/IGZhbHNlO1xuXG4gIG5nT25Jbml0KCkge1xuICAgIGlmIChpc1BsYXRmb3JtQnJvd3Nlcih0aGlzLnBsYXRmb3JtSWQpICYmIHRoaXMuaXNEZWJ1Zykge1xuICAgICAgY29uc3QgbmFtZSA9IHRoaXMuZWwubmF0aXZlRWxlbWVudC50YWdOYW1lLnRvTG93ZXJDYXNlKCk7XG4gICAgICBjb25zdCB0eXBlID0gbmFtZS5zcGxpdCgnLScpWzBdO1xuICAgICAgaWYgKERFQlVHX0NPTkZJRy5leGNsdWRlcy5pbmNsdWRlcyh0eXBlKSkgcmV0dXJuO1xuICAgICAgY29uc3QgY29sb3IgPSBERUJVR19DT05GSUcuY29sb3JzPy5bdHlwZV0gPz8gREVCVUdfQ09ORklHLmNvbG9ycy5kZWZhdWx0O1xuXG4gICAgICAvLyAxcHjjga7jgqLjgqbjg4jjg6njgqTjg7PjgpLoqK3lrppcbiAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5zdHlsZS5vdXRsaW5lID0gYCR7REVCVUdfQ09ORklHLm91dGxpbmV9IHNvbGlkICR7Y29sb3J9YDtcblxuICAgICAgLy8g55aR5Ly86KaB57Sg44Gn44Kz44Oz44Od44O844ON44Oz44OI5ZCN44KS6KGo56S6XG4gICAgICBjb25zdCBsYWJlbEVsID0gdGhpcy5jcmVhdGVMYWJlbEVsZW1lbnQoe1xuICAgICAgICBuYW1lOiBgJHtuYW1lfSR7dGhpcy5lbC5uYXRpdmVFbGVtZW50Lmhhc0F0dHJpYnV0ZSgnaW5qZWN0ZWQnKSA/ICdbaW5qZWN0ZWRdJyA6ICcnfWAsXG4gICAgICAgIGNvbG9yXG4gICAgICB9KTtcbiAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5zdHlsZS5vdXRsaW5lT2Zmc2V0ID0gJy0xcHgnO1xuICAgICAgdGhpcy5lbC5uYXRpdmVFbGVtZW50LnN0eWxlLnBvc2l0aW9uID0gJ3JlbGF0aXZlJztcbiAgICAgIHRoaXMuZWwubmF0aXZlRWxlbWVudC5hcHBlbmRDaGlsZChsYWJlbEVsKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgY3JlYXRlTGFiZWxFbGVtZW50KG9wdGlvbnM6IHtcbiAgICBuYW1lOiBzdHJpbmdcbiAgICBjb2xvcjogc3RyaW5nXG4gIH0pOiBIVE1MRWxlbWVudCB7XG4gICAgY29uc3QgY29udGVudCA9IGRvY3VtZW50LmNyZWF0ZUVsZW1lbnQoJ3NwYW4nKTtcbiAgICBjb250ZW50LnRleHRDb250ZW50ID0gb3B0aW9ucy5uYW1lO1xuICAgIGNvbnRlbnQuc3R5bGUuYmFja2dyb3VuZENvbG9yID0gYCR7b3B0aW9ucy5jb2xvcn1gO1xuICAgIGNvbnRlbnQuc3R5bGUuY29sb3IgPSAnI2ZmZic7XG4gICAgY29udGVudC5zdHlsZS5wYWRkaW5nID0gJzJweCA0cHgnO1xuICAgIGNvbnRlbnQuc3R5bGUucG9zaXRpb24gPSAnYWJzb2x1dGUnO1xuICAgIGNvbnRlbnQuc3R5bGUuZm9udFNpemUgPSAnMTBweCc7XG4gICAgY29udGVudC5zdHlsZS50b3AgPSAnMCc7XG4gICAgY29udGVudC5zdHlsZS5sZWZ0ID0gJzAnO1xuICAgIGNvbnRlbnQuc3R5bGUuekluZGV4ID0gJzk5OTknO1xuICAgIGNvbnRlbnQuc3R5bGUubGluZUhlaWdodCA9ICcxLjVlbSc7XG4gICAgY29udGVudC5zdHlsZS53aGl0ZVNwYWNlID0gJ25vd3JhcCc7XG4gICAgcmV0dXJuIGNvbnRlbnQ7XG4gIH1cbn0iXX0=
@@ -0,0 +1,2 @@
1
+ export * from './debug.directive';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvcmUvc3JjL2xpYi9kZWJ1Zy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kZWJ1Zy5kaXJlY3RpdmUnO1xuIl19
@@ -1,3 +1,5 @@
1
+ import { Injectable, InjectionToken, Injector, inject, runInInjectionContext } from "@angular/core";
2
+ import * as i0 from "@angular/core";
1
3
  export class EffectMap extends Map {
2
4
  get(key, scope = 'default') {
3
5
  return super.get(this.makeKey(key, scope));
@@ -18,4 +20,67 @@ export function Effect(id, { dispatch = false, scope = 'default', accessor = (ac
18
20
  target['_effectMap'].set(id, { key: propertyKey, props: { dispatch, scope, accessor } });
19
21
  };
20
22
  }
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZWZmZWN0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcGFja2FnZXMvQG5nLWF0b21pYy9jb3JlL3NyYy9saWIvZWZmZWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFBLE1BQU0sT0FBTyxTQUFVLFNBQVEsR0FBOEM7SUFDbEUsR0FBRyxDQUFDLEdBQVcsRUFBRSxLQUFLLEdBQUcsU0FBUztRQUN6QyxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUUsQ0FBQztJQUM5QyxDQUFDO0lBRVEsR0FBRyxDQUFDLEdBQVcsRUFBRSxLQUEyQztRQUNuRSxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQztJQUNoRSxDQUFDO0lBRVEsR0FBRyxDQUFDLEdBQVcsRUFBRSxLQUFLLEdBQUcsU0FBUztRQUN6QyxPQUFPLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRU8sT0FBTyxDQUFDLEdBQVcsRUFBRSxLQUFLLEdBQUcsU0FBUztRQUM1QyxPQUFPLElBQUksS0FBSyxLQUFLLEdBQUcsRUFBRSxDQUFDO0lBQzdCLENBQUM7Q0FDRjtBQUVELE1BQU0sVUFBVSxNQUFNLENBQUMsRUFBVSxFQUFFLEVBQ2pDLFFBQVEsR0FBRyxLQUFLLEVBQ2hCLEtBQUssR0FBRyxTQUFTLEVBQ2pCLFFBQVEsR0FBRyxDQUFDLE1BQWMsRUFBRSxFQUFFLENBQUMsTUFBTSxDQUFDLE9BQU8sTUFDckIsRUFBRTtJQUMxQixPQUFPLFVBQVUsTUFBVyxFQUFFLFdBQW1CLEVBQUUsVUFBOEI7UUFDL0UsTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFLLElBQUksU0FBUyxFQUFFLENBQUM7UUFDekMsTUFBTSxDQUFDLFlBQVksQ0FBQyxDQUFDLEdBQUcsQ0FBQyxFQUFFLEVBQUUsRUFBQyxHQUFHLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxFQUFDLFFBQVEsRUFBRSxLQUFLLEVBQUUsUUFBUSxFQUFDLEVBQUMsQ0FBQyxDQUFDO0lBQ3ZGLENBQUMsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBY3Rpb24gfSBmcm9tIFwiLi9hY3Rpb25cIjtcblxuZXhwb3J0IGludGVyZmFjZSBFZmZlY3RQcm9wcyB7XG4gIGRpc3BhdGNoOiBib29sZWFuO1xuICBzY29wZTogc3RyaW5nO1xuICBhY2Nlc3NvcjogPFQgPSBhbnk+KGFjdGlvbjogQWN0aW9uKSA9PiBUO1xufVxuXG5leHBvcnQgY2xhc3MgRWZmZWN0TWFwIGV4dGVuZHMgTWFwPHN0cmluZywge2tleTogc3RyaW5nLCBwcm9wczogRWZmZWN0UHJvcHN9PiB7XG4gIG92ZXJyaWRlIGdldChrZXk6IHN0cmluZywgc2NvcGUgPSAnZGVmYXVsdCcpOiB7IGtleTogc3RyaW5nOyBwcm9wczogRWZmZWN0UHJvcHM7IH0ge1xuICAgIHJldHVybiBzdXBlci5nZXQodGhpcy5tYWtlS2V5KGtleSwgc2NvcGUpKSE7IFxuICB9XG5cbiAgb3ZlcnJpZGUgc2V0KGtleTogc3RyaW5nLCB2YWx1ZTogeyBrZXk6IHN0cmluZzsgcHJvcHM6IEVmZmVjdFByb3BzOyB9KTogdGhpcyB7XG4gICAgcmV0dXJuIHN1cGVyLnNldCh0aGlzLm1ha2VLZXkoa2V5LCB2YWx1ZS5wcm9wcy5zY29wZSksIHZhbHVlKTtcbiAgfVxuXG4gIG92ZXJyaWRlIGhhcyhrZXk6IHN0cmluZywgc2NvcGUgPSAnZGVmYXVsdCcpOiBib29sZWFuIHtcbiAgICByZXR1cm4gc3VwZXIuaGFzKHRoaXMubWFrZUtleShrZXksIHNjb3BlKSk7XG4gIH1cblxuICBwcml2YXRlIG1ha2VLZXkoa2V5OiBzdHJpbmcsIHNjb3BlID0gJ2RlZmF1bHQnKSB7XG4gICAgcmV0dXJuIGBbJHtzY29wZX1dIyR7a2V5fWA7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIEVmZmVjdChpZDogc3RyaW5nLCB7XG4gIGRpc3BhdGNoID0gZmFsc2UsXG4gIHNjb3BlID0gJ2RlZmF1bHQnLFxuICBhY2Nlc3NvciA9IChhY3Rpb246IEFjdGlvbikgPT4gYWN0aW9uLnBheWxvYWQsXG59OiBQYXJ0aWFsPEVmZmVjdFByb3BzPiA9IHt9KSB7XG4gIHJldHVybiBmdW5jdGlvbiAodGFyZ2V0OiBhbnksIHByb3BlcnR5S2V5OiBzdHJpbmcsIGRlc2NyaXB0b3I6IFByb3BlcnR5RGVzY3JpcHRvcikge1xuICAgIHRhcmdldFsnX2VmZmVjdE1hcCddID8/PSBuZXcgRWZmZWN0TWFwKCk7XG4gICAgdGFyZ2V0WydfZWZmZWN0TWFwJ10uc2V0KGlkLCB7a2V5OiBwcm9wZXJ0eUtleSwgcHJvcHM6IHtkaXNwYXRjaCwgc2NvcGUsIGFjY2Vzc29yfX0pO1xuICB9O1xufVxuIl19
23
+ export const EFFECT_ENTRY = new InjectionToken('EFFECT_ENTRY');
24
+ export function provideEffect(ActionIds, _effectFactory, options = { dispatch: false }) {
25
+ return {
26
+ provide: EFFECT_ENTRY,
27
+ useFactory: (injector) => {
28
+ const effectFactory = (hostInjector) => {
29
+ return runInInjectionContext(hostInjector, () => _effectFactory(injector));
30
+ };
31
+ return { actionIds: ActionIds, effectFactory, options };
32
+ },
33
+ multi: true,
34
+ deps: [Injector]
35
+ };
36
+ }
37
+ export function injectEffectEntries() {
38
+ return inject(EFFECT_ENTRY, { optional: true }) ?? [];
39
+ }
40
+ function buildEffectEntryMap(injector, effectEntries) {
41
+ const effectEntryMap = new Map();
42
+ for (const entry of effectEntries) {
43
+ const ids = Array.isArray(entry.actionIds) ? entry.actionIds : [entry.actionIds];
44
+ for (const id of ids) {
45
+ const effect = () => entry.effectFactory(injector);
46
+ effectEntryMap.set(id, { effect, options: entry.options });
47
+ }
48
+ }
49
+ return effectEntryMap;
50
+ }
51
+ export class EffectReducer {
52
+ injector = inject(Injector);
53
+ effectEntries = injectEffectEntries();
54
+ effectEntryMap = buildEffectEntryMap(this.injector, this.effectEntries);
55
+ async reduce(action) {
56
+ const entry = this.effectEntryMap.get(action.id);
57
+ if (entry) {
58
+ await runInInjectionContext(this.injector, () => {
59
+ return entry?.effect()(action.payload, { injector: this.injector });
60
+ });
61
+ return this.effectEntryMap.get(action.id)?.options ?? { dispatch: false };
62
+ }
63
+ return { dispatch: true };
64
+ }
65
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: EffectReducer, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
66
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: EffectReducer });
67
+ }
68
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: EffectReducer, decorators: [{
69
+ type: Injectable
70
+ }] });
71
+ export function injectEffectReducer() {
72
+ const injector = inject(Injector);
73
+ const effectEntries = injectEffectEntries();
74
+ const effectEntryMap = buildEffectEntryMap(injector, effectEntries);
75
+ return async (action) => {
76
+ const entry = effectEntryMap.get(action.id);
77
+ if (entry) {
78
+ await runInInjectionContext(injector, () => {
79
+ return entry?.effect()(action.payload, { injector: injector });
80
+ });
81
+ return effectEntryMap.get(action.id)?.options ?? { dispatch: false };
82
+ }
83
+ return { dispatch: true };
84
+ };
85
+ }
86
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"effect.js","sourceRoot":"","sources":["../../../../../../packages/@ng-atomic/core/src/lib/effect.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, InjectionToken, Injector, Provider, inject, runInInjectionContext } from \"@angular/core\";\nimport { Action } from \"./action\";\n\nexport interface EffectProps {\n  dispatch: boolean;\n  scope: string;\n  accessor: (action: Action) => any;\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\nexport interface EffectFunctionOptions {\n  dispatch?: boolean;\n}\n\nexport interface EffectContext {\n  injector?: Injector;\n}\n\nexport type EffectFunction = (payload?: any, context?: EffectContext) => any | Promise<any>;\nexport type EffectFunctionFactory = (hostInjector?: Injector) => EffectFunction;\n\nexport interface EffectEntry {\n\tactionIds: string | string[];\n  effectFactory?: EffectFunctionFactory;\n  options?: EffectFunctionOptions;\n}\n\nexport const EFFECT_ENTRY = new InjectionToken<EffectEntry>('EFFECT_ENTRY');\n\nexport function provideEffect(\n  ActionIds: string[] | string,\n  _effectFactory: (injector: Injector) => EffectFunction,\n  options: EffectFunctionOptions = {dispatch: false},\n): Provider {\n\treturn {\n\t\tprovide: EFFECT_ENTRY,\n\t\tuseFactory: (injector: Injector) => {\n      const effectFactory = (hostInjector: Injector) => {\n        return runInInjectionContext(hostInjector, () => _effectFactory(injector));\n      };\n      return { actionIds: ActionIds, effectFactory, options };\n    },\n\t\tmulti: true,\n\t\tdeps: [Injector]\n\t};\n}\n\nexport function injectEffectEntries(): EffectEntry[] {\n\treturn inject<EffectEntry[]>(EFFECT_ENTRY, {optional: true}) ?? [];\n}\n\nfunction buildEffectEntryMap(injector: Injector, effectEntries: EffectEntry[]) {\n  const effectEntryMap = new Map<string, {effect: EffectFunction, options: EffectFunctionOptions}>();\n\n  for (const entry of effectEntries) {\n    const ids = Array.isArray(entry.actionIds) ? entry.actionIds : [entry.actionIds];\n    for (const id of ids) {\n      const effect = () => entry.effectFactory(injector);\n      effectEntryMap.set(id, { effect, options: entry.options });\n    }\n  }\n\n  return effectEntryMap;\n}\n\n@Injectable()\nexport class EffectReducer {\n  readonly injector = inject(Injector);\n\treadonly effectEntries = injectEffectEntries();\n  readonly effectEntryMap = buildEffectEntryMap(this.injector, this.effectEntries);\n\n\tasync reduce(action: Action): Promise<EffectFunctionOptions> {\n    const entry = this.effectEntryMap.get(action.id);\n    if (entry) {\n      await runInInjectionContext(this.injector, () => {\n        return entry?.effect()(action.payload, {injector: this.injector});\n      });\n      return this.effectEntryMap.get(action.id)?.options ?? {dispatch: false};\n    }\n    return {dispatch: true};\n\t}\n}\n\nexport function injectEffectReducer() {\n  const injector = inject(Injector);\n\tconst effectEntries = injectEffectEntries();\n  const effectEntryMap = buildEffectEntryMap(injector, effectEntries);\n\n  return async (action: Action) => {\n    const entry = effectEntryMap.get(action.id);\n    if (entry) {\n      await runInInjectionContext(injector, () => {\n        return entry?.effect()(action.payload, {injector: injector});\n      });\n      return effectEntryMap.get(action.id)?.options ?? {dispatch: false};\n    }\n    return {dispatch: true};\n\t}\n}\n"]}
@@ -1,6 +1,9 @@
1
1
  export * from './action-store';
2
2
  export * from './action';
3
3
  export * from './effect';
4
- export * from './component-store';
5
4
  export * from './injectable-component';
6
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvcmUvc3JjL2xpYi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsbUJBQW1CLENBQUM7QUFDbEMsY0FBYyx3QkFBd0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vYWN0aW9uLXN0b3JlJztcbmV4cG9ydCAqIGZyb20gJy4vYWN0aW9uJztcbmV4cG9ydCAqIGZyb20gJy4vZWZmZWN0JztcbmV4cG9ydCAqIGZyb20gJy4vY29tcG9uZW50LXN0b3JlJztcbmV4cG9ydCAqIGZyb20gJy4vaW5qZWN0YWJsZS1jb21wb25lbnQnO1xuIl19
5
+ export * from './ng-atomic-component';
6
+ export * from './signals';
7
+ export * from './debug';
8
+ export * from './ng-atomic-debug';
9
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wYWNrYWdlcy9AbmctYXRvbWljL2NvcmUvc3JjL2xpYi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsVUFBVSxDQUFDO0FBQ3pCLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLFNBQVMsQ0FBQztBQUN4QixjQUFjLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9hY3Rpb24tc3RvcmUnO1xuZXhwb3J0ICogZnJvbSAnLi9hY3Rpb24nO1xuZXhwb3J0ICogZnJvbSAnLi9lZmZlY3QnO1xuZXhwb3J0ICogZnJvbSAnLi9pbmplY3RhYmxlLWNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL25nLWF0b21pYy1jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9zaWduYWxzJztcbmV4cG9ydCAqIGZyb20gJy4vZGVidWcnO1xuZXhwb3J0ICogZnJvbSAnLi9uZy1hdG9taWMtZGVidWcnO1xuIl19
@@ -1,7 +1,10 @@
1
- import { DestroyRef, Directive, ElementRef, EventEmitter, Injector, Input, Output, ViewContainerRef, inject } from "@angular/core";
1
+ import { DestroyRef, Directive, ɵoutput, ElementRef, InjectionToken, Injector, ViewContainerRef, inject, input, PLATFORM_ID } from "@angular/core";
2
2
  import { takeUntilDestroyed } from "@angular/core/rxjs-interop";
3
3
  import { reflectComponentType } from "@angular/core";
4
+ import { proxyFakeComputedInputs } from "./signals";
5
+ import { isPlatformBrowser } from "@angular/common";
4
6
  import * as i0 from "@angular/core";
7
+ export const TOKEN = 'Δtkn';
5
8
  export function provideComponent(abstract, typeOrFactory) {
6
9
  async function loadComponentType() {
7
10
  if (typeof typeOrFactory === 'function' && !typeOrFactory.prototype) {
@@ -12,7 +15,15 @@ export function provideComponent(abstract, typeOrFactory) {
12
15
  }
13
16
  }
14
17
  ;
15
- return { provide: abstract['TOKEN'], useValue: loadComponentType };
18
+ return { provide: abstract[TOKEN], useValue: loadComponentType };
19
+ }
20
+ export function TokenizedType() {
21
+ return function (type) {
22
+ type[TOKEN] = new InjectionToken(type.name);
23
+ };
24
+ }
25
+ export function getToken(type) {
26
+ return type[TOKEN];
16
27
  }
17
28
  export var HostType;
18
29
  (function (HostType) {
@@ -24,11 +35,12 @@ export function getMeta(type) {
24
35
  }
25
36
  export function getInputs(type) {
26
37
  return Object.entries(getMeta(type)['inputs'])
27
- .map(([propName, templateName]) => ({ propName, templateName }));
38
+ .map(([templateName, [propName]]) => ({ propName, templateName }));
28
39
  }
29
40
  export function getOutputs(type) {
30
- return Object.entries(getMeta(type)['outputs'])
31
- .map(([propName, templateName]) => ({ propName, templateName }));
41
+ const meta = getMeta(type);
42
+ return Object.entries(meta['outputs'])
43
+ .map(([templateName, propName]) => ({ propName, templateName }));
32
44
  }
33
45
  export function getInputsByComponentRef(cmp) {
34
46
  return getInputs(cmp.instance.constructor);
@@ -37,77 +49,94 @@ export function getOutputsByInstance(cmp) {
37
49
  return getOutputs(cmp.instance.constructor);
38
50
  }
39
51
  export class InjectableComponent {
40
- constructor() {
41
- this.#outlet = inject(ViewContainerRef);
42
- this.#injector = inject(Injector);
43
- this.#destroy$ = inject(DestroyRef);
44
- this.#el = inject(ElementRef);
45
- this.#component = null;
46
- this.#componentMirror = null;
47
- this.injectable = false;
48
- this.action = new EventEmitter();
52
+ #platformId = inject(PLATFORM_ID);
53
+ #viewContainerRef = inject(ViewContainerRef);
54
+ #injector = inject(Injector);
55
+ #destroyRef = inject(DestroyRef);
56
+ #el = inject(ElementRef);
57
+ #component = null;
58
+ #componentMirror = null;
59
+ injectable = input(false, { transform: (value) => value === '' ? true : value, alias: 'injectable' });
60
+ __action = ɵoutput({ alias: 'action' });
61
+ dispatch(action) {
62
+ this.__action.emit(action);
63
+ }
64
+ get #inputs() {
65
+ const abs = getInputs(this.constructor);
66
+ return abs;
67
+ }
68
+ get #outputs() {
69
+ const abs = getOutputs(this.constructor);
70
+ return abs;
71
+ // const impl = this.#componentMirror!.outputs;
72
+ // return abs.filter(abstractOutput => impl.some(implOutput => implOutput.templateName === abstractOutput.templateName));
49
73
  }
50
- #outlet;
51
- #injector;
52
- #destroy$;
53
- #el;
54
- #component;
55
- #componentMirror;
56
74
  #setAttribute() {
57
75
  const hostElement = this.#component.hostView.rootNodes[0];
58
76
  const attributes = this.#el.nativeElement.attributes;
59
77
  for (let i = 0; i < attributes.length; i++) {
60
78
  const attr = attributes.item(i);
61
- if (attr.name.startsWith('_ngcontent')) {
79
+ if (attr.name === 'injectable') {
80
+ hostElement.setAttribute('injected', '');
81
+ }
82
+ else {
62
83
  hostElement.setAttribute(attr.name, attr.value);
63
84
  }
64
85
  }
65
86
  }
66
87
  #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)) {
88
+ for (const input of this.#inputs) {
72
89
  if (input.propName === 'injectable')
73
- return;
74
- this.#component.setInput(input.propName, this[input.propName]);
90
+ continue;
91
+ const valueOrInputValueFn = this[input.propName];
92
+ const value = typeof valueOrInputValueFn === 'function' ? valueOrInputValueFn() : valueOrInputValueFn;
93
+ this.#component.setInput(input.templateName, value);
75
94
  }
76
95
  }
96
+ get propNames() {
97
+ return this.#inputs.map(input => input.propName);
98
+ }
99
+ proxyFakeComputedInputs() {
100
+ proxyFakeComputedInputs(this, this.propNames);
101
+ }
77
102
  #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);
103
+ for (const output of this.#outputs) {
104
+ this.#component.instance[output.propName]?.pipe(takeUntilDestroyed(this.#destroyRef)).subscribe((value) => this[output.propName].emit(value));
105
+ }
106
+ }
107
+ #bindEvents() {
108
+ for (const name of ['click']) {
109
+ this.#component.injector.get(ElementRef).nativeElement.addEventListener(name, (event) => {
110
+ this.#el.nativeElement.dispatchEvent(new Event(name, {}));
87
111
  });
88
112
  }
89
113
  }
114
+ constructor() {
115
+ this.proxyFakeComputedInputs();
116
+ }
90
117
  ngOnInit() {
91
- if (this.injectable) {
92
- this.#injector.get(this.constructor['TOKEN'])().then(type => {
93
- this.#component = this.#outlet.createComponent(type);
118
+ if (this.injectable() && isPlatformBrowser(this.#platformId)) {
119
+ this.#injector.get(getToken(this.constructor))().then(type => {
120
+ this.#component = this.#viewContainerRef.createComponent(type, {
121
+ projectableNodes: [
122
+ Array.from(this.#el.nativeElement.childNodes)
123
+ ],
124
+ });
94
125
  this.#componentMirror = reflectComponentType(type);
95
126
  this.#bindInputs();
96
127
  this.#bindOutputs();
128
+ this.#bindEvents();
97
129
  this.#setAttribute();
130
+ // this.#viewContainerRef.remove(0);
131
+ this.#component.changeDetectorRef.detectChanges();
132
+ // this.#el.nativeElement.remove();
98
133
  });
99
134
  }
135
+ this.proxyFakeComputedInputs();
100
136
  }
101
137
  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)) {
138
+ if (this.injectable() && this.#componentMirror) {
139
+ for (const input of this.#inputs) {
111
140
  if (input.propName === 'injectable')
112
141
  return;
113
142
  const change = simpleChanges[input.propName];
@@ -117,16 +146,14 @@ export class InjectableComponent {
117
146
  }
118
147
  }
119
148
  }
120
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InjectableComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
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 }); }
149
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: InjectableComponent, deps: [], target: i0.ɵɵFactoryTarget.Directive });
150
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "17.2.2", type: InjectableComponent, isStandalone: true, inputs: { injectable: { classPropertyName: "injectable", publicName: "injectable", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { __action: "action" }, usesOnChanges: true, ngImport: i0 });
122
151
  }
123
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InjectableComponent, decorators: [{
152
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.2", ngImport: i0, type: InjectableComponent, decorators: [{
124
153
  type: Directive,
125
- args: [{ standalone: true }]
126
- }], propDecorators: { injectable: [{
127
- type: Input,
128
- args: [{ transform: (value) => value === '' ? true : value }]
129
- }], action: [{
130
- type: Output
131
- }] } });
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"]}
154
+ args: [{
155
+ standalone: true,
156
+ // host: {ngSkipHydration: 'true'}
157
+ }]
158
+ }], ctorParameters: () => [] });
159
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"injectable-component.js","sourceRoot":"","sources":["../../../../../../packages/@ng-atomic/core/src/lib/injectable-component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiC,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAmB,cAAc,EAAE,QAAQ,EAAqC,gBAAgB,EAAE,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AACtO,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAMrD,OAAO,EAAE,uBAAuB,EAAE,MAAM,WAAW,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAC;;AAEpD,MAAM,CAAC,MAAM,KAAK,GAAG,MAAM,CAAC;AAE5B,MAAM,UAAU,gBAAgB,CAC9B,QAAmB,EACnB,aAA6C;IAE7C,KAAK,UAAU,iBAAiB;QAC9B,IAAI,OAAO,aAAa,KAAK,UAAU,IAAI,CAAC,aAAa,CAAC,SAAS,EAAE;YACnE,OAAO,MAAO,aAAmC,EAAE,CAAC;SACrD;aAAM;YACL,OAAO,aAA2B,CAAC;SACpC;IACH,CAAC;IAAA,CAAC;IACF,OAAO,EAAE,OAAO,EAAG,QAAgB,CAAC,KAAK,CAAC,EAAE,QAAQ,EAAE,iBAAiB,EAAE,CAAC;AAC5E,CAAC;AAED,MAAM,UAAU,aAAa;IAC3B,OAAO,UAA+B,IAAO;QAC1C,IAAY,CAAC,KAAK,CAAC,GAAG,IAAI,cAAc,CAAI,IAAI,CAAC,IAAI,CAAC,CAAC;IAC1D,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,IAAe;IACtC,OAAQ,IAAY,CAAC,KAAK,CAAC,CAAC;AAC9B,CAAC;AAED,MAAM,CAAN,IAAY,QAGX;AAHD,WAAY,QAAQ;IAClB,6BAAY,CAAA;IACZ,6BAAY,CAAA;AACd,CAAC,EAHW,QAAQ,KAAR,QAAQ,QAGnB;AAID,MAAM,UAAU,OAAO,CAAI,IAAa;IACtC,OAAQ,IAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAK,IAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;AACpE,CAAC;AAED,MAAM,UAAU,SAAS,CAAI,IAAa;IACxC,OAAO,MAAM,CAAC,OAAO,CAAS,OAAO,CAAC,IAAI,CAAC,CAAC,QAAQ,CAAC,CAAC;SACnD,GAAG,CAAC,CAAC,CAAC,YAAY,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAC,QAAQ,EAAE,YAAY,EAAC,CAAC,CAAC,CAAC;AACrE,CAAC;AAED,MAAM,UAAU,UAAU,CAAI,IAAa;IACzC,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAC3B,OAAO,MAAM,CAAC,OAAO,CAAS,IAAI,CAAC,SAAS,CAAC,CAAC;SAC3C,GAAG,CAAC,CAAC,CAAC,YAAY,EAAE,QAAQ,CAAC,EAAE,EAAE,CAAC,CAAC,EAAC,QAAQ,EAAE,YAAY,EAAC,CAAC,CAAC,CAAC;AACnE,CAAC;AAED,MAAM,UAAU,uBAAuB,CAAqB,GAAoB;IAC9E,OAAO,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,WAAsB,CAAC,CAAC;AACxD,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAqB,GAAoB;IAC3E,OAAO,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,WAAsB,CAAC,CAAC;AACzD,CAAC;AAMD,MAAM,OAAO,mBAAmB;IACrB,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;IAClC,iBAAiB,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;IAC7C,SAAS,GAAG,MAAM,CAAC,QAAQ,CAAC,CAAC;IAC7B,WAAW,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;IACjC,GAAG,GAA4B,MAAM,CAAC,UAAU,CAAC,CAAC;IAC3D,UAAU,GAA2B,IAAI,CAAC;IAC1C,gBAAgB,GAA8B,IAAI,CAAC;IAE1C,UAAU,GAAG,KAAK,CAAC,KAAK,EAAE,EAAC,SAAS,EAAE,CAAC,KAAU,EAAE,EAAE,CAAC,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,YAAY,EAAC,CAAC,CAAC;IACzG,QAAQ,GAAG,OAAO,CAAS,EAAC,KAAK,EAAE,QAAQ,EAAC,CAAC,CAAC;IAEvD,QAAQ,CAAC,MAAc;QACrB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAC7B,CAAC;IAED,IAAI,OAAO;QACT,MAAM,GAAG,GAAG,SAAS,CAAC,IAAI,CAAC,WAAsB,CAAC,CAAC;QACnD,OAAO,GAAG,CAAC;IACb,CAAC;IAED,IAAI,QAAQ;QACV,MAAM,GAAG,GAAG,UAAU,CAAC,IAAI,CAAC,WAAsB,CAAC,CAAC;QACpD,OAAO,GAAG,CAAC;QACX,+CAA+C;QAC/C,yHAAyH;IAC3H,CAAC;IAED,aAAa;QACX,MAAM,WAAW,GAAI,IAAI,CAAC,UAAW,CAAC,QAAiC,CAAC,SAAS,CAAC,CAAC,CAAgB,CAAC;QACpG,MAAM,UAAU,GAAiB,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC;QACnE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC1C,MAAM,IAAI,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC,CAAE,CAAC;YACjC,IAAI,IAAI,CAAC,IAAI,KAAK,YAAY,EAAE;gBAC9B,WAAW,CAAC,YAAY,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;aAC1C;iBAAM;gBACL,WAAW,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;aACjD;SACF;IACH,CAAC;IAED,WAAW;QACT,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE;YAChC,IAAI,KAAK,CAAC,QAAQ,KAAK,YAAY;gBAAE,SAAS;YAC9C,MAAM,mBAAmB,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YACjD,MAAM,KAAK,GAAG,OAAO,mBAAmB,KAAK,UAAU,CAAC,CAAC,CAAC,mBAAmB,EAAE,CAAC,CAAC,CAAC,mBAAmB,CAAC;YACtG,IAAI,CAAC,UAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;SACtD;IACH,CAAC;IAED,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IACnD,CAAC;IAED,uBAAuB;QACrB,uBAAuB,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IAChD,CAAC;IAED,YAAY;QACV,KAAK,MAAM,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjC,IAAI,CAAC,UAAW,CAAC,QAAgB,CAAC,MAAM,CAAC,QAAQ,CAAC,EAAE,IAAI,CACvD,kBAAkB,CAAC,IAAI,CAAC,WAAW,CAAC,CACrC,CAAC,SAAS,CAAC,CAAC,KAAU,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;SAChE;IACH,CAAC;IAED,WAAW;QACT,KAAK,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,EAAE;YAC5B,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,aAAa,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC,KAAK,EAAE,EAAE;gBACtF,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,aAAa,CAAC,IAAI,KAAK,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAC;YAC5D,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAED;QACE,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,QAAQ;QACN,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,iBAAiB,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YAC5D,IAAI,CAAC,SAAS,CAAC,GAAG,CAAsB,QAAQ,CAAC,IAAI,CAAC,WAAkB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;gBACvF,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,IAAI,EAAE;oBAC7D,gBAAgB,EAAE;wBAChB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC;qBAC9C;iBACF,CAAC,CAAC;gBACH,IAAI,CAAC,gBAAgB,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC;gBACnD,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,IAAI,CAAC,YAAY,EAAE,CAAC;gBACpB,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnB,IAAI,CAAC,aAAa,EAAE,CAAC;gBACrB,oCAAoC;gBACpC,IAAI,CAAC,UAAU,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;gBAClD,mCAAmC;YACrC,CAAC,CAAC,CAAC;SACJ;QACD,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,WAAW,CAAC,aAA4B;QACtC,IAAI,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,gBAAgB,EAAE;YAC9C,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,OAAO,EAAE;gBAChC,IAAI,KAAK,CAAC,QAAQ,KAAK,YAAY;oBAAE,OAAO;gBAC5C,MAAM,MAAM,GAAG,aAAa,CAAC,KAAK,CAAC,QAAQ,CAAiB,CAAC;gBAC7D,IAAI,MAAM,EAAE;oBACV,IAAI,CAAC,UAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC,YAAY,CAAC,CAAC;iBAChE;aACF;SACF;IACH,CAAC;uGA7GU,mBAAmB;2FAAnB,mBAAmB;;2FAAnB,mBAAmB;kBAJ/B,SAAS;mBAAC;oBACT,UAAU,EAAE,IAAI;oBAChB,kCAAkC;iBACnC","sourcesContent":["import { ComponentMirror, ComponentRef, DestroyRef, Directive, ɵoutput, ElementRef, EmbeddedViewRef, InjectionToken, Injector, SimpleChange, SimpleChanges, Type, ViewContainerRef, inject, input, PLATFORM_ID } from \"@angular/core\";\nimport { takeUntilDestroyed } from \"@angular/core/rxjs-interop\";\nimport { reflectComponentType } from \"@angular/core\";\nimport { Action } from \"./action\";\n\nexport type TypeFactoryAsync<T> = () => Promise<Type<T>>;\n\nexport type TypeFactory<T> = () => (Type<T> | Promise<Type<T>>);\nimport { proxyFakeComputedInputs } from \"./signals\";\nimport { isPlatformBrowser } from \"@angular/common\";\n\nexport const TOKEN = 'Δtkn';\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 TokenizedType() {\n  return function <T extends Type<any>>(type: T) {\n    (type as any)[TOKEN] = new InjectionToken<T>(type.name);\n  };\n}\n\nexport function getToken(type: Type<any>) {\n  return (type as any)[TOKEN];\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(([templateName, [propName]]) => ({propName, templateName}));\n}\n\nexport function getOutputs<T>(type: Type<T>): IO[] {\n  const meta = getMeta(type);\n  return Object.entries<string>(meta['outputs'])\n    .map(([templateName, propName]) => ({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({\n  standalone: true,\n  // host: {ngSkipHydration: 'true'}\n})\nexport class InjectableComponent<T = any> {\n  readonly #platformId = inject(PLATFORM_ID);\n  readonly #viewContainerRef = inject(ViewContainerRef);\n  readonly #injector = inject(Injector);\n  readonly #destroyRef = inject(DestroyRef);\n  readonly #el: ElementRef<HTMLElement> = inject(ElementRef);\n  #component: ComponentRef<T> | null = null;\n  #componentMirror: ComponentMirror<T> | null = null;\n\n  readonly injectable = input(false, {transform: (value: any) => value === '' ? true : value, alias: 'injectable'});\n  readonly __action = ɵoutput<Action>({alias: 'action'});\n\n  dispatch(action: Action) {\n    this.__action.emit(action);\n  }\n\n  get #inputs(): IO[] {\n    const abs = getInputs(this.constructor as Type<T>);\n    return abs;\n  }\n\n  get #outputs(): IO[] {\n    const abs = getOutputs(this.constructor as Type<T>);\n    return abs;\n    // const impl = this.#componentMirror!.outputs;\n    // return abs.filter(abstractOutput => impl.some(implOutput => implOutput.templateName === abstractOutput.templateName));\n  }\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 === 'injectable') {\n        hostElement.setAttribute('injected', '');\n      } else {\n        hostElement.setAttribute(attr.name, attr.value);\n      }\n    }\n  }\n\n  #bindInputs() {\n    for (const input of this.#inputs) {\n      if (input.propName === 'injectable') continue;\n      const valueOrInputValueFn = this[input.propName];\n      const value = typeof valueOrInputValueFn === 'function' ? valueOrInputValueFn() : valueOrInputValueFn;\n      this.#component!.setInput(input.templateName, value);\n    }\n  }\n\n  get propNames() {\n    return this.#inputs.map(input => input.propName);\n  }\n\n  proxyFakeComputedInputs() {\n    proxyFakeComputedInputs(this, this.propNames);\n  }\n\n  #bindOutputs() {\n    for (const output of this.#outputs) {\n      (this.#component!.instance as any)[output.propName]?.pipe(\n        takeUntilDestroyed(this.#destroyRef)\n      ).subscribe((value: any) => this[output.propName].emit(value));\n    }\n  }\n\n  #bindEvents() {\n    for (const name of ['click']) {\n      this.#component.injector.get(ElementRef).nativeElement.addEventListener(name, (event) => {\n        this.#el.nativeElement.dispatchEvent(new Event(name, {}));\n      });\n    }\n  }\n  \n  constructor() {\n    this.proxyFakeComputedInputs();\n  }\n\n  ngOnInit() {\n    if (this.injectable() && isPlatformBrowser(this.#platformId)) {\n      this.#injector.get<TypeFactoryAsync<T>>(getToken(this.constructor as any))().then(type => {\n        this.#component = this.#viewContainerRef.createComponent(type, {\n          projectableNodes: [\n            Array.from(this.#el.nativeElement.childNodes)\n          ],\n        });\n        this.#componentMirror = reflectComponentType(type);\n        this.#bindInputs();\n        this.#bindOutputs();\n        this.#bindEvents();\n        this.#setAttribute();\n        // this.#viewContainerRef.remove(0);\n        this.#component.changeDetectorRef.detectChanges();\n        // this.#el.nativeElement.remove();\n      });\n    }\n    this.proxyFakeComputedInputs();\n  }\n\n  ngOnChanges(simpleChanges: SimpleChanges) {\n    if (this.injectable() && this.#componentMirror) {\n      for (const input of this.#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  }\n}\n"]}