Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adding global caches to survive/warn on HMR, cleanup, etc. #2661

Merged
merged 4 commits into from
Nov 17, 2020
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
16 changes: 16 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,10 @@ export class MyApp {

## Compatibility

### Angular and Firebase versions

AngularFire doesn't follow Angular's versioning as Firebase also has breaking changes throughout the year. Instead we try to maintain compatability with both Firebase and Angular majors for as long as possible, only breaking when we need to support a new major of one or the other. We've been forunate that the APIs we rely on have been fairly stable, but we understand this can lead to some confusion so we've created the following table for advice.

| Angular | Firebase | AngularFire |
| --------|----------|--------------|
| 11 | 7,8 | @next |
Expand All @@ -53,6 +57,18 @@ export class MyApp {

<sub>Version combinations not documented here __may__ work but are untested and you will see NPM peer warnings.</sub>

### Polyfills

Neither AngularFire or Firebase ship with polyfills & we tend to use modern ES features in our development. To have compatability across as wide-range of environments we suggest the following polyfills be added to your application:

| API | Environments | Suggested Polyfill | License |
|-----|--------------|--------------------|---------|
| Various ES5+ features | IE 11<br>Safari &lt; 10<br>Node &lt; 6.5 | [`core-js/stable`](https://github.com/zloirock/core-js#readme) | MIT |
| `globalThis` | [most](https://caniuse.com/mdn-javascript_builtins_globalthis) | [`globalThis`](https://github.com/es-shims/globalThis#readme) | MIT |
| `Proxy` | [IE 11<br>Safari &lt; 10](https://caniuse.com/proxy) | [`proxy-polyfill`](https://github.com/GoogleChrome/proxy-polyfill#readme) | Apache 2.0 |
| `fetch` | [IE 11<br>Node<br>Safari &lt; 10.1<br>iOS &lt; 10.3](https://caniuse.com/fetch) | [`cross-fetch`](https://github.com/lquixada/cross-fetch#readme) | MIT |
| `Headers` | [IE 11<br>Node<br>Safari &lt; 10.1<br>iOS Safari](https://caniuse.com/mdn-api_headers) | [`cross-fetch`](https://github.com/lquixada/cross-fetch#readme) | MIT |

## Resources

[Quickstart](docs/install-and-setup.md) - Get your first application up and running by following our quickstart guide.
Expand Down
5 changes: 4 additions & 1 deletion sample/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
"scripts": {
"ng": "ng",
"start": "ng serve",
"started:emulated": "concurrently -n ng,firebase -c red,yellow \"ng serve -c emulated\" \"firebase emulators:start\"",
"start:emulated": "concurrently -n ng,firebase -c red,yellow \"ng serve -c emulated\" \"firebase emulators:start\"",
"build": "ng build",
"test": "ng test",
"lint": "ng lint",
Expand Down Expand Up @@ -69,5 +69,8 @@
"ts-node": "~9.0.0",
"tslint": "~6.1.3",
"typescript": "~4.0.5"
},
"resolutions": {
"webpack": "5.4.0"
}
}
10 changes: 7 additions & 3 deletions sample/src/app/app.module.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,12 +35,15 @@ import { HomeComponent } from './home/home.component';
import { AuthComponent } from './auth/auth.component';
import { MessagingComponent } from './messaging/messaging.component';
import { FunctionsComponent } from './functions/functions.component';
import { FirestoreOfflineComponent } from './firestore-offline/firestore-offline.component';
import { FirestoreOfflineModule } from './firestore-offline/firestore-offline.module';

@NgModule({
declarations: [
AppComponent,
StorageComponent,
FirestoreComponent,
FirestoreOfflineComponent,
DatabaseComponent,
RemoteConfigComponent,
HomeComponent,
Expand All @@ -56,21 +59,22 @@ import { FunctionsComponent } from './functions/functions.component';
AngularFireModule.initializeApp(environment.firebase),
AngularFireStorageModule,
AngularFireDatabaseModule,
AngularFirestoreModule.enablePersistence({ synchronizeTabs: true }),
AngularFirestoreModule,
AngularFireAuthModule,
AngularFireAuthGuardModule,
AngularFireRemoteConfigModule,
AngularFireMessagingModule,
AngularFireAnalyticsModule,
AngularFireFunctionsModule,
AngularFirePerformanceModule,
AngularFireAuthGuardModule
AngularFireAuthGuardModule,
FirestoreOfflineModule
],
providers: [
UserTrackingService,
ScreenTrackingService,
PerformanceMonitoringService,
{ provide: ANALYTICS_DEBUG_MODE, useValue: false },
{ provide: ANALYTICS_DEBUG_MODE, useValue: true },
{ provide: COLLECTION_ENABLED, useValue: true },
{ provide: USE_AUTH_EMULATOR, useValue: environment.useEmulators ? ['localhost', 9099] : undefined },
{ provide: USE_DATABASE_EMULATOR, useValue: environment.useEmulators ? ['localhost', 9000] : undefined },
Expand Down
8 changes: 6 additions & 2 deletions sample/src/app/auth/auth.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,6 +13,7 @@ import { isPlatformServer } from '@angular/common';
<p>
Auth!
{{ (auth.user | async)?.uid | json }}
{{ (auth.user | async)?.metadata | json }}
<button (click)="login()" *ngIf="showLoginButton">Log in with Google</button>
<button (click)="logout()" *ngIf="showLogoutButton">Log out</button>
</p>
Expand Down Expand Up @@ -46,12 +47,15 @@ export class AuthComponent implements OnInit, OnDestroy {
}
}

login() {
this.auth.signInWithPopup(new firebase.auth.GoogleAuthProvider());
async login() {
const user = await this.auth.signInWithPopup(new firebase.auth.GoogleAuthProvider());
console.log(user?.additionalUserInfo.isNewUser);
// TODO sign into offline app
}

logout() {
this.auth.signOut();
// TODO sign out of offline app
}

}
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import { waitForAsync, ComponentFixture, TestBed } from '@angular/core/testing';

import { FirestoreOfflineComponent } from './firestore-offline.component';

describe('FirestoreComponent', () => {
let component: FirestoreOfflineComponent;
let fixture: ComponentFixture<FirestoreOfflineComponent>;

beforeEach(waitForAsync(() => {
TestBed.configureTestingModule({
declarations: [ FirestoreOfflineComponent ]
})
.compileComponents();
}));

beforeEach(() => {
fixture = TestBed.createComponent(FirestoreOfflineComponent);
component = fixture.componentInstance;
fixture.detectChanges();
});

it('should create', () => {
expect(component).toBeTruthy();
});
});
37 changes: 37 additions & 0 deletions sample/src/app/firestore-offline/firestore-offline.component.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,37 @@
import { Component, OnInit } from '@angular/core';
import { AngularFirestore } from '@angular/fire/firestore';
import { Observable } from 'rxjs';
import { startWith, tap } from 'rxjs/operators';
import { makeStateKey, TransferState } from '@angular/platform-browser';
import { trace } from '@angular/fire/performance';
import { AngularFirestoreOffline } from './firestore-offline.module';

@Component({
selector: 'app-firestore-offline',
template: `<p>
Firestore Offline!
{{ testDocValue$ | async | json }}
{{ persistenceEnabled$ | async }}
</p>`,
styles: [``]
})
export class FirestoreOfflineComponent implements OnInit {

public readonly persistenceEnabled$: Observable<boolean>;
public readonly testDocValue$: Observable<any>;

constructor(state: TransferState, firestore: AngularFirestoreOffline) {
const doc = firestore.doc('test/1');
const key = makeStateKey(doc.ref.path);
const existing = state.get(key, undefined);
this.testDocValue$ = firestore.doc('test/1').valueChanges().pipe(
trace('firestore'),
existing ? startWith(existing) : tap(it => state.set(key, it))
);
this.persistenceEnabled$ = firestore.persistenceEnabled$;
}

ngOnInit(): void {
}

}
28 changes: 28 additions & 0 deletions sample/src/app/firestore-offline/firestore-offline.module.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,28 @@
import { Inject, Injectable, InjectionToken, NgModule, NgZone, Optional, PLATFORM_ID } from '@angular/core';
import { FirebaseOptions, FIREBASE_OPTIONS } from '@angular/fire';
import { USE_EMULATOR } from '@angular/fire/firestore';
import { AngularFirestore, SETTINGS, Settings } from '@angular/fire/firestore';
import { USE_EMULATOR as USE_AUTH_EMULATOR } from '@angular/fire/auth';

export const FIRESTORE_OFFLINE = new InjectionToken<AngularFirestore>('my.firestore');

@Injectable()
export class AngularFirestoreOffline extends AngularFirestore {
constructor(
@Inject(FIREBASE_OPTIONS) options: FirebaseOptions,
@Optional() @Inject(SETTINGS) settings: Settings | null,
// tslint:disable-next-line:ban-types
@Inject(PLATFORM_ID) platformId: Object,
zone: NgZone,
@Optional() @Inject(USE_EMULATOR) useEmulator: any,
@Optional() @Inject(USE_AUTH_EMULATOR) useAuthEmulator: any,
) {
super(options, 'offline', true, settings, platformId, zone, { synchronizeTabs: true }, useEmulator, useAuthEmulator);
}
}

@NgModule({
providers: [ AngularFirestoreOffline ]
}) export class FirestoreOfflineModule {

}
1 change: 1 addition & 0 deletions sample/src/app/home/home.component.ts
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@ import { FirebaseApp } from '@angular/fire';
{{ firebaseApp.name }}
<!-- TODO wrap the Zone issue <app-database></app-database> -->
<app-firestore></app-firestore>
<app-firestore-offline></app-firestore-offline>
<app-storage></app-storage>
<app-auth></app-auth>
<app-remote-config></app-remote-config>
Expand Down
Loading