UNPKG

@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

65 lines (62 loc) 1.7 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.promiseDefer = promiseDefer; exports.promiseWithOptionalCallback = promiseWithOptionalCallback; var _validate = require("./validate.js"); /* * 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. * */ /** * Creates a deferred promise */ function promiseDefer() { const deferred = { promise: null, resolve: null, reject: null }; deferred.promise = new Promise((resolve, reject) => { deferred.resolve = resolve; deferred.reject = reject; }); return deferred; } /** * Attaches an optional callback to a promise * @param promise * @param callback */ function promiseWithOptionalCallback(promise, callback) { if (!(0, _validate.isFunction)(callback)) { return promise; } return promise.then(result => { if (callback && callback.length === 1) { callback(null); } else if (callback) { callback(null, result); } return result; }).catch(error => { if (callback) { callback(error); } return Promise.reject(error); }); } //# sourceMappingURL=promise.js.map