NgxObservableLifecycle
data:image/s3,"s3://crabby-images/12319/123193a74d079a2d2870ba9ef8e717a83d08f525" alt="npm peer dependency version"
data:image/s3,"s3://crabby-images/269a1/269a193154db68fbde63222c1627b8c4346406b0" alt="NPM"
This library is current a work in progress,
but here's the basics of how it will work:
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
import {
getObservableLifecycle,
ObservableLifecycle,
} from 'ngx-observable-lifecycle';
import { take, takeUntil } from 'rxjs/operators';
@ObservableLifecycle()
@Component({
selector: 'app-child',
templateUrl: './child.component.html',
styleUrls: ['./child.component.scss'],
changeDetection: ChangeDetectionStrategy.OnPush,
})
export class ChildComponent {
@Input() input: number;
constructor() {
const {
onChanges,
onInit,
doCheck,
afterContentInit,
afterContentChecked,
afterViewInit,
afterViewChecked,
onDestroy,
} = getObservableLifecycle(this);
onChanges
.pipe(takeUntil(onDestroy))
.subscribe(() => console.count('onChanges'));
onInit.pipe(takeUntil(onDestroy)).subscribe(() => console.count('onInit'));
doCheck
.pipe(takeUntil(onDestroy))
.subscribe(() => console.count('doCheck'));
afterContentInit
.pipe(takeUntil(onDestroy))
.subscribe(() => console.count('afterContentInit'));
afterContentChecked
.pipe(takeUntil(onDestroy))
.subscribe(() => console.count('afterContentChecked'));
afterViewInit
.pipe(takeUntil(onDestroy))
.subscribe(() => console.count('afterViewInit'));
afterViewChecked
.pipe(takeUntil(onDestroy))
.subscribe(() => console.count('afterViewChecked'));
onDestroy.pipe(take(1)).subscribe(() => console.count('onDestroy'));
}
}