Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit adb949da authored by Daniel Nishi's avatar Daniel Nishi Committed by Android (Google) Code Review
Browse files

Merge "Add a new toggle for Bluetooth while driving."

parents f3b61d12 cf4a5c74
Loading
Loading
Loading
Loading
+5 −0
Original line number Diff line number Diff line
@@ -9248,4 +9248,9 @@
    <!-- Title for preference showing the name of the device. [CHAR LIMIT=60]-->
    <string name="my_device_info_device_name_preference_title">Device name</string>
    <!-- Settings item title for automatic Bluetooth on while driving preference [CHAR LIMIT=35] -->
    <string name="bluetooth_on_while_driving_pref">Use Bluetooth when driving</string>
    <!-- Settings item summary for automatic Bluetooth on while driving preference [CHAR LIMIT=100] -->
    <string name="bluetooth_on_while_driving_summary">Turn on Bluetooth automatically when driving</string>
</resources>
+8 −1
Original line number Diff line number Diff line
@@ -47,11 +47,18 @@
        android:summary="@string/summary_placeholder"
        android:order="-3"/>

    <SwitchPreference
        android:key="bluetooth_on_while_driving"
        android:title="@string/bluetooth_on_while_driving_pref"
        android:icon="@drawable/ic_settings_bluetooth"
        android:summary="@string/bluetooth_on_while_driving_summary"
        android:order="-2"/>

    <Preference
        android:key="usb_mode"
        android:title="@string/usb_pref"
        android:icon="@drawable/ic_usb"
        android:order="-2">
        android:order="-1">
        <intent android:action="android.intent.action.MAIN"
                android:targetPackage="com.android.settings"
                android:targetClass="com.android.settings.deviceinfo.UsbModeChooserActivity"/>
+1 −3
Original line number Diff line number Diff line
@@ -21,11 +21,9 @@ import android.provider.SearchIndexableResource;

import com.android.internal.logging.nano.MetricsProto;
import com.android.settings.R;
import com.android.settings.SettingsActivity;
import com.android.settings.bluetooth.BluetoothFilesPreferenceController;
import com.android.settings.bluetooth.BluetoothMasterSwitchPreferenceController;
import com.android.settings.bluetooth.BluetoothSwitchPreferenceController;
import com.android.settings.bluetooth.Utils;
import com.android.settings.dashboard.DashboardFragment;
import com.android.settings.deviceinfo.UsbBackend;
import com.android.settings.nfc.NfcPreferenceController;
@@ -33,7 +31,6 @@ import com.android.settings.overlay.FeatureFactory;
import com.android.settings.search.BaseSearchIndexProvider;
import com.android.settingslib.core.AbstractPreferenceController;
import com.android.settingslib.core.lifecycle.Lifecycle;
import com.android.settingslib.drawer.CategoryKey;

import java.util.ArrayList;
import java.util.Arrays;
@@ -89,6 +86,7 @@ public class AdvancedConnectedDeviceDashboardFragment extends DashboardFragment
                smsMirroringFeatureProvider.getController(context);
        controllers.add(smsMirroringController);
        controllers.add(new BluetoothFilesPreferenceController(context));
        controllers.add(new BluetoothOnWhileDrivingPreferenceController(context));
        return controllers;
    }

+59 −0
Original line number Diff line number Diff line
/*
 * Copyright (C) 2018 The Android Open Source Project
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file 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.
 */

package com.android.settings.connecteddevice;

import android.content.Context;
import android.provider.Settings;
import android.util.FeatureFlagUtils;

import com.android.settings.core.FeatureFlags;
import com.android.settings.core.PreferenceControllerMixin;
import com.android.settings.core.TogglePreferenceController;

/** Handles a toggle for a setting to turn on Bluetooth while driving. * */
public class BluetoothOnWhileDrivingPreferenceController extends TogglePreferenceController
        implements PreferenceControllerMixin {
    static final String KEY_BLUETOOTH_ON_DRIVING = "bluetooth_on_while_driving";

    public BluetoothOnWhileDrivingPreferenceController(Context context) {
        super(context, KEY_BLUETOOTH_ON_DRIVING);
    }

    @Override
    public int getAvailabilityStatus() {
        if (FeatureFlagUtils.isEnabled(mContext, FeatureFlags.BLUETOOTH_WHILE_DRIVING)) {
            return AVAILABLE;
        }
        return DISABLED_UNSUPPORTED;
    }

    @Override
    public boolean isChecked() {
        return Settings.Secure.getInt(
                        mContext.getContentResolver(),
                        Settings.Secure.BLUETOOTH_ON_WHILE_DRIVING,
                        0)
                != 0;
    }

    @Override
    public boolean setChecked(boolean isChecked) {
        final int value = isChecked ? 1 : 0;
        return Settings.Secure.putInt(
                mContext.getContentResolver(), Settings.Secure.BLUETOOTH_ON_WHILE_DRIVING, value);
    }
}
+1 −0
Original line number Diff line number Diff line
@@ -28,4 +28,5 @@ public class FeatureFlags {
    public static final String ZONE_PICKER_V2 = "settings_zone_picker_v2";
    public static final String SUGGESTION_UI_V2 = "settings_suggestion_ui_v2";
    public static final String ABOUT_PHONE_V2 = "settings_about_phone_v2";
    public static final String BLUETOOTH_WHILE_DRIVING = "settings_bluetooth_while_driving";
}
Loading