Configure the Communications Plugin
The off-the-shelf communications plugin comes with a default configuration. This configuration provides a default behavior, such as closing the frontend when making an outgoing call. This configuration is based on the configuration-framework and can be changed if necessary. This guide explains how to make such changes.
For a code example, see the
examples/communications/configuration
directory.
Communications plugin default configuration
The communications plugin default configuration is defined as a resource file that contains configuration keys and their values. The following keys and values are defined in the communications plugin:
1<resources>2 <!-- Indicates whether pairing with a Bluetooth device is restricted by the safety lock mode when available. By default it is set to true -->3 <bool name="isBluetoothDevicePairingRestrictedBySafetyLockConfigKey">true</bool>4 <!-- Indicates that the communications panel will be kept open when starting an outgoing call. By default it is set to false. -->5 <bool name="keepCommunicationsPanelOpenOnOutgoingCallConfigKey">false</bool>6 <!-- The timeout in milliseconds, which is started after the last received phone book synchronization batch update, indicating phone book synchronization has finished. By default it is set to 15000 milliseconds -->7 <string name="phoneBookSynchronizationTimeoutMillisecondConfigKey">15000</string>8 <!-- Indicates that the task process panel will not be instantiated for an ongoing call. By default it is set to false. -->9 <bool name="suppressCallTaskProcessPanelConfigKey">false</bool>10 <!-- Indicates which filter strategy should be used for filtering contacts and recent calls. -->11 <string name="phoneBookFilterStrategyConfigKey">HFP_HSP_BLUETOOTH_PROFILE_BOUND</string>12</resources>
Changing the communications plugin configuration
The communications plugin default configuration can be changed by adding a custom configuration
resource file in your application, such as
src/main/res/values/example-communication-configuration.xml
,
which then overrides the default values with the ones provided.
Configuring the frontend's behavior to allow it to start pairing with a Bluetooth device.
When the safety lock is available and enabled, the communications frontend will not show a button allowing it to start pairing with a Bluetooth device.
If you do want to allow the user to start pairing with a Bluetooth device when the safety lock is
available and enabled, you can configure it by setting the
isBluetoothDevicePairingRestrictedBySafetyLockConfigKey
to false
:
src/main/res/values/example-communication-configuration.xml
<bool name="isBluetoothDevicePairingRestrictedBySafetyLockConfigKey">false</bool>
Configuring the frontend's behavior when making an outgoing call
When an outgoing call is made, the communications frontend will be closed by default.
If you don't want to close the frontend provided with the off-the-shelf communications plugin, you
can configure it by setting the keepCommunicationsPanelOpenOnOutgoingCallConfigKey
to true
:
src/main/res/values/example-communication-configuration.xml
<bool name="keepCommunicationsPanelOpenOnOutgoingCallConfigKey">true</bool>
Timeout indicating phone book synchronization has finished
The timeout is restarted after every phone book update, and when it triggers it is assumed that the phone book synchronization has finished. The timeout defaults to 15000 milliseconds.
If you want a different timeout, you can change the value of
phoneBookSynchronizationTimeoutMillisecondConfigKey
:
src/main/res/values/example-communication-configuration.xml
<string name="phoneBookSynchronizationTimeoutMillisecondConfigKey">20000</string>
Suppressing the task process panel for an ongoing call
By default, for an ongoing call the communications frontend shows a task process panel with the call information.
If you don't want this task process panel to show, you can configure it by setting the
suppressCallTaskProcessPanelConfigKey
to true
:
src/main/res/values/example-communication-configuration.xml
<bool name="suppressCallTaskProcessPanelConfigKey">true</bool>
Filtering contacts and recent calls
By default, the contacts and recent calls are not filtered.
If you do want to filter the contacts and recent calls, you can configure it by setting the
phoneBookFilterStrategyConfigKey
to HFP_HSP_BLUETOOTH_PROFILE_BOUND
which will filter contacts
and recent calls based on the HFP_HSP Bluetooth profile connection status. See
PhoneBookFilterStrategy
enum for more details about the available filter strategies."
src/main/res/values/example-communication-configuration.xml
<string name="phoneBookFilterStrategyConfigKey">HFP_HSP_BLUETOOTH_PROFILE_BOUND</string>