Package Exports
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (cordova-plugin-firebase-config) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
Cordova plugin for Firebase Remote Config
|  | Your help is appreciated. Create a PR, submit a bug or just grab me 🍺 | 
|---|
Index
Supported Platforms
- iOS
- Android
Installation
$ cordova plugin add cordova-plugin-firebase-configUse variables IOS_FIREBASE_POD_VERSION and ANDROID_FIREBASE_BOM_VERSION to override dependency versions for Firebase SDKs:
$ cordova plugin add cordova-plugin-firebase-config \
--variable IOS_FIREBASE_POD_VERSION="9.3.0" \
--variable ANDROID_FIREBASE_BOM_VERSION="30.3.1"Adding required configuration files
Cordova supports resource-file tag for easy copying resources files. Firebase SDK requires google-services.json on Android and GoogleService-Info.plist on iOS platforms.
- Put google-services.jsonand/orGoogleService-Info.plistinto the root directory of your Cordova project
- Add new tag for Android platform
<platform name="android">
    ...
    <resource-file src="google-services.json" target="app/google-services.json" />
</platform>
...
<platform name="ios">
    ...
    <resource-file src="GoogleService-Info.plist" />
</platform>Preferences
You can specify FirebaseRemoteConfigDefaults in config.xml to define filename of a file with default values. Keep in mind that android and ios have different naming convensions there it's useful to specify different file names.
<platform name="android">
    ...
    <preference name="FirebaseRemoteConfigDefaults" value="remote_config_defaults" />
    <resource-file src="resources/android/remote_config_defaults.xml" target="app/src/main/res/xml/remote_config_defaults.xml" />
</platform>
<platform name="ios">
    ...
    <preference name="FirebaseRemoteConfigDefaults" value="RemoteConfigDefaults" />
    <resource-file src="resources/ios/RemoteConfigDefaults.plist" />
</platform>On Android platform file remote_config_defaults.xml has a structure like below:
<?xml version="1.0" encoding="utf-8"?>
<defaultsMap>
    <entry>
        <key>param1</key>
        <value>value1</value>
    </entry>
    <entry>
        <key>param2</key>
        <value>value2</value>
    </entry>
</defaultsMap>On iOS platform file RemoteConfigDefaults.plist has a structure like below:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
    <key>param1</key>
    <string>value1</string>
    <key>param2</key>
    <string>value2</string>
</dict>
</plist>Variables
VALUE_SOURCE_DEFAULT
 VALUE_SOURCE_DEFAULT: number
Indicates that the value returned was retrieved from the defaults set by the client.
Constant
VALUE_SOURCE_REMOTE
 VALUE_SOURCE_REMOTE: number
Indicates that the value returned was retrieved from the Firebase Remote Config Server.
Constant
VALUE_SOURCE_STATIC
 VALUE_SOURCE_STATIC: number
Indicates that the value returned is the static default value.
Constant
Functions
activate
activate(): Promise<boolean>
Asynchronously activates the most recently fetched configs, so that the fetched key value pairs take effect.
Example
cordova.plugins.firebase.config.activate();Returns
Promise<boolean>
Fulfills promise with flag if current config was activated
fetch
fetch(expirationDuration): Promise<void>
Starts fetching configs, adhering to the specified minimum fetch interval.
Example
cordova.plugins.firebase.config.fetch(8 * 3600);Parameters
| Name | Type | Description | 
|---|---|---|
| expirationDuration | number | Minimum fetch interval in seconds | 
Returns
Promise<void>
Callback when operation is completed
fetchAndActivate
fetchAndActivate(): Promise<boolean>
Asynchronously fetches and then activates the fetched configs.
Example
cordova.plugins.firebase.config.fetchAndActivate();Returns
Promise<boolean>
Fulfills promise with flag if current config was activated
getBoolean
getBoolean(key): Promise<boolean>
Returns the boolean parameter value for the given key
Example
cordova.plugins.firebase.config.getBoolean("myBool").then(function(value) {
    // use value from remote config
});Parameters
| Name | Type | Description | 
|---|---|---|
| key | string | Parameter key | 
Returns
Promise<boolean>
Fulfills promise with parameter value
getBytes
getBytes(key): Promise<ArrayBuffer>
Returns the bytes parameter value for the given key
Example
cordova.plugins.firebase.config.getBytes("myByteArray").then(function(value) {
    // use value from remote config
});Parameters
| Name | Type | Description | 
|---|---|---|
| key | string | Parameter key | 
Returns
Promise<ArrayBuffer>
Fulfills promise with parameter value
getNumber
getNumber(key): Promise<number>
Returns the number parameter value for the given key
Example
cordova.plugins.firebase.config.getNumber("myNumber").then(function(value) {
    // use value from remote config
});Parameters
| Name | Type | Description | 
|---|---|---|
| key | string | Parameter key | 
Returns
Promise<number>
Fulfills promise with parameter value
getString
getString(key): Promise<string>
Returns the string parameter value for the given key
Example
cordova.plugins.firebase.config.getString("myStr").then(function(value) {
    // use value from remote config
});Parameters
| Name | Type | Description | 
|---|---|---|
| key | string | Parameter key | 
Returns
Promise<string>
Fulfills promise with parameter value
getValueSource
getValueSource(key): Promise<number>
Returns source of the value for the specified key.
Example
cordova.plugins.firebase.config.getValueSource("myArbitraryValue").then(function(source) {
    if (source === cordova.plugins.firebase.config.VALUE_SOURCE_DEFAULT) {
        // ...
    }
});Parameters
| Name | Type | Description | 
|---|---|---|
| key | string | Parameter key | 
Returns
Promise<number>
Fulfills promise with parameter value