@react-native-firebase/app
Version:
A well tested, feature rich Firebase implementation for React Native, supporting iOS & Android. Individual module support for Admob, Analytics, Auth, Crash Reporting, Cloud Firestore, Database, Dynamic Links, Functions, Messaging (FCM), Remote Config, Sto
63 lines (53 loc) • 1.67 kB
JavaScript
/*
* Copyright (c) 2016-present Invertase Limited & Contributors
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this library except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*
*/
import { getAppModule, getNativeModule } from './registry/nativeModule';
import SharedEventEmitter from './SharedEventEmitter';
let firebaseJson = null;
export default class FirebaseModule {
constructor(app, config, customUrlOrRegion) {
this._app = app;
this._nativeModule = null;
this._customUrlOrRegion = customUrlOrRegion;
this._config = Object.assign({}, config);
}
get app() {
return this._app;
}
get firebaseJson() {
if (firebaseJson) {
return firebaseJson;
}
firebaseJson = JSON.parse(getAppModule().FIREBASE_RAW_JSON);
return firebaseJson;
}
get emitter() {
return SharedEventEmitter;
}
// TODO Handle custom url or region?
eventNameForApp(...args) {
return `${this.app.name}-${args.join('-')}`;
}
get native() {
if (this._nativeModule) {
return this._nativeModule;
}
this._nativeModule = getNativeModule(this);
return this._nativeModule;
}
}
// Instance of checks don't work once compiled
FirebaseModule.__extended__ = {};