19.0.0-preview.36 • Published 10 months ago

@ng-atomic/core v19.0.0-preview.36

Weekly downloads
-
License
-
Repository
github
Last release
10 months ago

@ng-atomic/core

@ng-atomic/core is a library that enables dependency injection for components.

Install

$ npm i @ng-atomic/core

Usage

import { Component, Directive, inject, input } from '@angular/core';
import { bootstrapApplication } from '@angular/platform-browser';
import { Effect, TokenizedType, provideComponent, InjectableComponent } from '@ng-atomic/core';
import { NgAtomicComponent } from '@ng-atomic/core';
import 'zone.js';

export enum ActionId {
  CREATE = 'Create',
}

@TokenizedType()
@Directive({ standalone: true, selector: 'example' })
export class ExampleComponentStore extends InjectableComponent {
  static readonly ActionId = ActionId;
  readonly name = input<string>('');
}

@Component({
  standalone: true,
  selector: `example`,
  template: `
  <div>{{ store.name() }}</div>
  <button (click)="onClick()">ADD</button>
  `,
  hostDirectives: [
    {
      directive: ExampleComponentStore,
      inputs: ['name'],
    },
  ],
})
export class ExampleComponent extends NgAtomicComponent {
  protected readonly store = inject(ExampleComponentStore);

  protected onClick() {
    this.dispatch({ id: ActionId.CREATE, payload: 'ADD' });
  }
}

@Component({
  selector: 'app-root',
  standalone: true,
  imports: [ExampleComponentStore],
  template: `
    <example [name]="'test'" (action)="dispatch($event)" injectable/>
  `,
  providers: [provideComponent(ExampleComponentStore, () => ExampleComponent)],
})
export class App extends NgAtomicComponent {
  @Effect(ExampleComponentStore.ActionId.CREATE)
  protected create() {
    alert('created!!');
  }
}

bootstrapApplication(App);

LISENCE

MIT

19.0.0-preview.28

10 months ago

19.0.0-preview.27

10 months ago

19.0.0-preview.29

10 months ago

18.8.1

12 months ago

19.0.0-preview.24

10 months ago

18.8.0

12 months ago

19.0.0-preview.23

10 months ago

19.0.0-preview.26

10 months ago

18.6.0

12 months ago

19.0.0-preview.25

10 months ago

19.0.0-preview.20

10 months ago

19.0.0-preview.8

10 months ago

19.0.0-preview.7

10 months ago

18.11.0

11 months ago

19.0.0-preview.22

10 months ago

19.0.0-preview.21

10 months ago

19.0.0-preview.9

10 months ago

19.0.0-preview.2

10 months ago

19.0.0-preview.4

10 months ago

19.0.0-preview.3

10 months ago

19.0.0-preview.6

10 months ago

19.0.0-preview.5

10 months ago

18.4.0

12 months ago

19.0.0-preview.17

10 months ago

19.0.0-preview.16

10 months ago

19.0.0-preview.19

10 months ago

19.0.0-preview.18

10 months ago

19.0.0-preview.13

10 months ago

19.0.0-preview.12

10 months ago

19.0.0-preview.15

10 months ago

19.0.0-preview.14

10 months ago

19.0.0-preview.11

10 months ago

19.0.0-preview.10

10 months ago

18.9.1

12 months ago

18.9.0

12 months ago

18.7.0

12 months ago

18.5.0

12 months ago

18.10.0

12 months ago

18.12.0

10 months ago

19.0.0-preview.35

10 months ago

19.0.0-preview.34

10 months ago

19.0.0-preview.36

10 months ago

19.0.0-preview.31

10 months ago

19.0.0-preview.30

10 months ago

19.0.0-preview.33

10 months ago

19.0.0-preview.32

10 months ago

17.13.0

1 year ago

18.2.1

1 year ago

17.14.0

1 year ago

18.2.0

1 year ago

18.1.0

1 year ago

18.0.0

1 year ago

17.10.0

1 year ago

17.11.0

1 year ago

17.12.0

1 year ago

17.3.0

2 years ago

17.0.3

2 years ago

17.2.0

2 years ago

17.0.2

2 years ago

17.5.0

2 years ago

17.3.2

2 years ago

17.4.0

2 years ago

17.3.1

2 years ago

17.0.4

2 years ago

17.1.0

2 years ago

17.0.1

2 years ago

17.0.0

2 years ago

17.7.0

1 year ago

17.6.1

1 year ago

17.3.4

2 years ago

17.6.0

1 year ago

17.3.3

2 years ago

17.9.0

1 year ago

17.8.0

1 year ago

17.7.1

1 year ago

17.3.5

2 years ago

16.3.1

2 years ago

16.2.0

2 years ago

16.1.1

2 years ago

16.1.0

2 years ago

16.0.0

2 years ago

15.1.1

2 years ago

0.0.1

2 years ago