|  | 
| 1 |  | -import { ApplicationRef, Component, NgZone, Optional } from '@angular/core'; | 
|  | 1 | +import { ApplicationRef, Component, NgZone } from '@angular/core'; | 
| 2 | 2 | import { FirebaseApp, FirebaseApps } from '@angular/fire/app'; | 
| 3 | 3 | import { Auth, AuthInstances, authState } from '@angular/fire/auth'; | 
| 4 |  | -import { Firestore, FirestoreInstances } from '@angular/fire/firestore'; | 
| 5 |  | -import { firestoreInstance$ } from '@angular/fire/firestore'; | 
| 6 |  | -import { debounceTime } from 'rxjs/operators'; | 
| 7 |  | -import { initializeFirestore$ } from './firestore'; | 
|  | 4 | +import { Firestore, FirestoreInstances, getDoc, doc, DocumentSnapshot } from '@angular/fire/firestore/lite'; | 
|  | 5 | +import { DocumentData } from 'rxfire/firestore/lite/interfaces'; | 
|  | 6 | +import { debounceTime, distinctUntilChanged } from 'rxjs/operators'; | 
| 8 | 7 | 
 | 
| 9 | 8 | @Component({ | 
| 10 | 9 |   selector: 'app-root', | 
| 11 | 10 |   template: ` | 
| 12 |  | -    <!--The content below is only a placeholder and can be replaced.--> | 
| 13 |  | -    <div style="text-align:center" class="content"> | 
| 14 |  | -      <h1> | 
| 15 |  | -        Welcome to {{title}}! | 
| 16 |  | -      </h1> | 
| 17 |  | -      <span style="display: block">{{ app.name }} app is running!</span> | 
| 18 |  | -      <img width="300" alt="Angular Logo" src=""> | 
| 19 |  | -    </div> | 
| 20 |  | -    <h2>Here are some links to help you start: </h2> | 
| 21 |  | -    <ul> | 
| 22 |  | -      <li> | 
| 23 |  | -        <h2><a target="_blank" rel="noopener" href="https://angular.io/tutorial">Tour of Heroes</a></h2> | 
| 24 |  | -      </li> | 
| 25 |  | -      <li> | 
| 26 |  | -        <h2><a target="_blank" rel="noopener" href="https://angular.io/cli">CLI Documentation</a></h2> | 
| 27 |  | -      </li> | 
| 28 |  | -      <li> | 
| 29 |  | -        <h2><a target="_blank" rel="noopener" href="https://blog.angular.io/">Angular blog</a></h2> | 
| 30 |  | -      </li> | 
| 31 |  | -    </ul> | 
|  | 11 | +    <pre>{{ (myDocData | async)?.data() | json }}</pre> | 
| 32 | 12 |     <router-outlet></router-outlet> | 
| 33 | 13 |   `, | 
| 34 | 14 |   styles: [] | 
| 35 | 15 | }) | 
| 36 | 16 | export class AppComponent { | 
|  | 17 | +  myDocData: Promise<DocumentSnapshot<DocumentData>>; | 
| 37 | 18 |   title = 'sample'; | 
| 38 | 19 |   constructor( | 
| 39 | 20 |     public app: FirebaseApp, // default Firebase App | 
| 40 | 21 |     public auth: Auth, // default Firbase Auth | 
| 41 | 22 |     public apps: FirebaseApps, // all initialized App instances | 
| 42 | 23 |     public authInstances: AuthInstances, // all initialized Auth instances | 
| 43 |  | -    @Optional() public firestore: Firestore, | 
| 44 |  | -    @Optional() public firestoreInstances: FirestoreInstances, | 
|  | 24 | +    public firestore: Firestore, | 
|  | 25 | +    public firestoreInstances: FirestoreInstances, | 
| 45 | 26 |     appRef: ApplicationRef, | 
| 46 | 27 |     zone: NgZone, | 
| 47 | 28 |   ) { | 
| 48 | 29 |     console.log({app, auth, apps, authInstances, firestore, firestoreInstances }); | 
| 49 |  | -    // onAuthStateChanged should destablize the zone | 
| 50 |  | -    // onAuthStateChanged(auth, it => console.log('onAuthStateChanged', it)); | 
| 51 | 30 |     authState(auth).subscribe(it => console.log('authState', it)); | 
| 52 |  | -    appRef.isStable.pipe(debounceTime(200)).subscribe(it => console.log('isStable', it)); | 
| 53 |  | -    firestoreInstance$.subscribe(it => console.log('$', it)); | 
| 54 |  | -    initializeFirestore$.subscribe(it => console.log('init', it)); | 
|  | 31 | +    appRef.isStable.pipe(distinctUntilChanged()).subscribe(it => console.log('isStable', it)); | 
|  | 32 | +    this.myDocData = getDoc(doc(firestore, 'animals/NJdGQCv1P92SWsp4nSE7')); | 
|  | 33 | +    // firestoreInstance$.subscribe(it => console.log('$', it)); | 
|  | 34 | +    // initializeFirestore$.subscribe(it => console.log('init', it)); | 
| 55 | 35 |   } | 
| 56 | 36 | } | 
0 commit comments