angular/projects/ng-devtools/src/lib/devtools.component.ts

62 lines
1.8 KiB
TypeScript
Raw Normal View History

import { Component, OnInit, OnDestroy } from '@angular/core';
2020-01-27 18:40:18 +00:00
import { MessageBus, Events } from 'protocol';
import { interval } from 'rxjs';
import { animate, style, transition, trigger } from '@angular/animations';
import { take } from 'rxjs/operators';
2020-01-27 18:40:18 +00:00
@Component({
selector: 'ng-devtools',
templateUrl: './devtools.component.html',
styleUrls: ['./devtools.component.css'],
animations: [
trigger('enterAnimation', [
transition(':enter', [style({ opacity: 0 }), animate('200ms', style({ opacity: 1 }))]),
transition(':leave', [style({ opacity: 1 }), animate('200ms', style({ opacity: 0 }))]),
]),
],
2020-01-27 18:40:18 +00:00
})
export class DevToolsComponent implements OnInit, OnDestroy {
angularExists: boolean | null = null;
angularVersion: string | boolean | undefined = undefined;
prodMode: boolean;
constructor(private _messageBus: MessageBus<Events>) {}
2020-01-27 18:40:18 +00:00
private _interval$ = interval(500)
.pipe(take(10))
.subscribe({
next: () => this._messageBus.emit('queryNgAvailability'),
complete: () => {
if (this.angularExists === null) {
this.angularExists = false;
}
},
});
2020-01-27 18:40:18 +00:00
ngOnInit(): void {
2020-01-27 18:40:18 +00:00
console.log('Initialized the devtools UI');
this._messageBus.once('ngAvailability', ({ version, prodMode }) => {
this.angularExists = !!version;
this.angularVersion = version;
this.prodMode = prodMode;
2020-01-27 18:40:18 +00:00
this._interval$.unsubscribe();
});
}
majorAngularVersion(): number {
if (!this.angularVersion) {
return -1;
}
return +this.angularVersion.toString().split('.')[0];
}
get supportedVersion(): boolean {
return (this.majorAngularVersion() >= 9 || this.majorAngularVersion() === 0) && !this.prodMode;
}
ngOnDestroy(): void {
2020-01-27 18:40:18 +00:00
this._interval$.unsubscribe();
}
}