Remove EarlyWarningTip and move the logic into LowBatteryTip
Fix: 263835342 Test: presubmit Change-Id: I256cd6f364979046ee87524751c3fe137a0524c2
This commit is contained in:
@@ -44,9 +44,7 @@ import com.android.settings.fuelgauge.batterytip.tips.UnrestrictAppTip;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* Utility class for {@link BatteryTip}
|
||||
*/
|
||||
/** Utility class for {@link BatteryTip} */
|
||||
public class BatteryTipUtils {
|
||||
private static final int REQUEST_CODE = 0;
|
||||
|
||||
@@ -85,6 +83,7 @@ public class BatteryTipUtils {
|
||||
|
||||
/**
|
||||
* Get a corresponding action based on {@code batteryTip}
|
||||
*
|
||||
* @param batteryTip used to detect which action to choose
|
||||
* @param settingsActivity used to populate {@link BatteryTipAction}
|
||||
* @param fragment used to populate {@link BatteryTipAction}
|
||||
|
@@ -1,104 +0,0 @@
|
||||
/*
|
||||
* 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.fuelgauge.batterytip.tips;
|
||||
|
||||
import android.app.settings.SettingsEnums;
|
||||
import android.content.Context;
|
||||
import android.os.Parcel;
|
||||
|
||||
import com.android.settings.R;
|
||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||
|
||||
/**
|
||||
* Tip to show early warning if battery couldn't make to usual charging time
|
||||
*/
|
||||
public class EarlyWarningTip extends BatteryTip {
|
||||
private boolean mPowerSaveModeOn;
|
||||
|
||||
public EarlyWarningTip(@StateType int state, boolean powerSaveModeOn) {
|
||||
super(TipType.BATTERY_SAVER, state, false /* showDialog */);
|
||||
mPowerSaveModeOn = powerSaveModeOn;
|
||||
}
|
||||
|
||||
public EarlyWarningTip(Parcel in) {
|
||||
super(in);
|
||||
mPowerSaveModeOn = in.readBoolean();
|
||||
}
|
||||
|
||||
@Override
|
||||
public CharSequence getTitle(Context context) {
|
||||
return context.getString(
|
||||
mState = R.string.battery_tip_early_heads_up_title);
|
||||
}
|
||||
|
||||
@Override
|
||||
public CharSequence getSummary(Context context) {
|
||||
return context.getString(
|
||||
mState = R.string.battery_tip_early_heads_up_summary);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getIconId() {
|
||||
return mState = R.drawable.ic_battery_status_bad_24dp;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getIconTintColorId() {
|
||||
return mState = R.color.battery_bad_color_light;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateState(BatteryTip tip) {
|
||||
final EarlyWarningTip earlyWarningTip = (EarlyWarningTip) tip;
|
||||
if (earlyWarningTip.mState == StateType.NEW) {
|
||||
// Display it if there is early warning
|
||||
mState = StateType.NEW;
|
||||
} else if (earlyWarningTip.mPowerSaveModeOn) {
|
||||
// If powerSaveMode is really on, dismiss it.
|
||||
mState = StateType.INVISIBLE;
|
||||
} else {
|
||||
mState = earlyWarningTip.getState();
|
||||
}
|
||||
mPowerSaveModeOn = earlyWarningTip.mPowerSaveModeOn;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void log(Context context, MetricsFeatureProvider metricsFeatureProvider) {
|
||||
metricsFeatureProvider.action(context, SettingsEnums.ACTION_EARLY_WARNING_TIP,
|
||||
mState);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void writeToParcel(Parcel dest, int flags) {
|
||||
super.writeToParcel(dest, flags);
|
||||
dest.writeBoolean(mPowerSaveModeOn);
|
||||
}
|
||||
|
||||
public boolean isPowerSaveModeOn() {
|
||||
return mPowerSaveModeOn;
|
||||
}
|
||||
|
||||
public static final Creator CREATOR = new Creator() {
|
||||
public BatteryTip createFromParcel(Parcel in) {
|
||||
return new EarlyWarningTip(in);
|
||||
}
|
||||
|
||||
public BatteryTip[] newArray(int size) {
|
||||
return new EarlyWarningTip[size];
|
||||
}
|
||||
};
|
||||
}
|
@@ -24,18 +24,19 @@ import android.os.Parcelable;
|
||||
import com.android.settings.R;
|
||||
import com.android.settingslib.core.instrumentation.MetricsFeatureProvider;
|
||||
|
||||
/**
|
||||
* Tip to show current battery level is low or remaining time is less than a certain period
|
||||
*/
|
||||
public class LowBatteryTip extends EarlyWarningTip {
|
||||
/** Tip to show current battery level is low */
|
||||
public class LowBatteryTip extends BatteryTip {
|
||||
|
||||
private boolean mPowerSaveModeOn;
|
||||
|
||||
public LowBatteryTip(@StateType int state, boolean powerSaveModeOn) {
|
||||
super(state, powerSaveModeOn);
|
||||
mType = TipType.LOW_BATTERY;
|
||||
super(TipType.LOW_BATTERY, state, false /* showDialog */);
|
||||
mPowerSaveModeOn = powerSaveModeOn;
|
||||
}
|
||||
|
||||
public LowBatteryTip(Parcel in) {
|
||||
super(in);
|
||||
mPowerSaveModeOn = in.readBoolean();
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -48,9 +49,20 @@ public class LowBatteryTip extends EarlyWarningTip {
|
||||
return context.getString(R.string.battery_tip_low_battery_summary);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getIconId() {
|
||||
return mState = R.drawable.ic_battery_status_bad_24dp;
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getIconTintColorId() {
|
||||
return mState = R.color.battery_bad_color_light;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void writeToParcel(Parcel dest, int flags) {
|
||||
super.writeToParcel(dest, flags);
|
||||
dest.writeBoolean(mPowerSaveModeOn);
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -59,6 +71,17 @@ public class LowBatteryTip extends EarlyWarningTip {
|
||||
mState);
|
||||
}
|
||||
|
||||
@Override
|
||||
public void updateState(BatteryTip tip) {
|
||||
final LowBatteryTip lowBatteryTip = (LowBatteryTip) tip;
|
||||
mState = lowBatteryTip.mPowerSaveModeOn
|
||||
? StateType.INVISIBLE : lowBatteryTip.getState();
|
||||
}
|
||||
|
||||
boolean isPowerSaveModeOn() {
|
||||
return mPowerSaveModeOn;
|
||||
}
|
||||
|
||||
public static final Parcelable.Creator CREATOR = new Parcelable.Creator() {
|
||||
public BatteryTip createFromParcel(Parcel in) {
|
||||
return new LowBatteryTip(in);
|
||||
|
Reference in New Issue
Block a user