/* * Copyright (C) 2017 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.content.Context; import android.os.Parcel; import android.os.Parcelable; import android.util.SparseIntArray; import androidx.annotation.DrawableRes; import androidx.annotation.IntDef; import androidx.annotation.Nullable; import androidx.annotation.VisibleForTesting; import androidx.preference.Preference; import com.android.settings.widget.TipCardPreference; import com.android.settingslib.core.instrumentation.MetricsFeatureProvider; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; /** * Base model for a battery tip(e.g. suggest user to turn on battery saver) * *

Each {@link BatteryTip} contains basic data(e.g. title, summary, icon) as well as the * pre-defined action(e.g. turn on battery saver) */ public abstract class BatteryTip implements Comparable, Parcelable { @Retention(RetentionPolicy.SOURCE) @IntDef({StateType.NEW, StateType.HANDLED, StateType.INVISIBLE}) public @interface StateType { int NEW = 0; int HANDLED = 1; int INVISIBLE = 2; } @Retention(RetentionPolicy.SOURCE) @IntDef({ TipType.SUMMARY, TipType.BATTERY_SAVER, TipType.HIGH_DEVICE_USAGE, TipType.SMART_BATTERY_MANAGER, TipType.APP_RESTRICTION, TipType.REDUCED_BATTERY, TipType.LOW_BATTERY, TipType.REMOVE_APP_RESTRICTION, TipType.BATTERY_DEFENDER, TipType.DOCK_DEFENDER, TipType.INCOMPATIBLE_CHARGER, TipType.BATTERY_WARNING }) public @interface TipType { int SMART_BATTERY_MANAGER = 0; int APP_RESTRICTION = 1; int HIGH_DEVICE_USAGE = 2; int BATTERY_SAVER = 3; int REDUCED_BATTERY = 4; int LOW_BATTERY = 5; int SUMMARY = 6; int REMOVE_APP_RESTRICTION = 7; int BATTERY_DEFENDER = 8; int DOCK_DEFENDER = 9; int INCOMPATIBLE_CHARGER = 10; int BATTERY_WARNING = 11; } @VisibleForTesting static final SparseIntArray TIP_ORDER; static { TIP_ORDER = new SparseIntArray(); TIP_ORDER.append(TipType.BATTERY_SAVER, 0); TIP_ORDER.append(TipType.LOW_BATTERY, 1); TIP_ORDER.append(TipType.BATTERY_DEFENDER, 2); TIP_ORDER.append(TipType.DOCK_DEFENDER, 3); TIP_ORDER.append(TipType.INCOMPATIBLE_CHARGER, 4); TIP_ORDER.append(TipType.APP_RESTRICTION, 5); TIP_ORDER.append(TipType.HIGH_DEVICE_USAGE, 6); TIP_ORDER.append(TipType.SUMMARY, 7); TIP_ORDER.append(TipType.SMART_BATTERY_MANAGER, 8); TIP_ORDER.append(TipType.REDUCED_BATTERY, 9); TIP_ORDER.append(TipType.REMOVE_APP_RESTRICTION, 10); TIP_ORDER.append(TipType.BATTERY_WARNING, 11); } private static final String KEY_PREFIX = "key_battery_tip"; protected int mState; protected int mType; protected boolean mShowDialog; /** Whether we need to update battery tip when configuration change */ protected boolean mNeedUpdate; public BatteryTip(Parcel in) { mType = in.readInt(); mState = in.readInt(); mShowDialog = in.readBoolean(); mNeedUpdate = in.readBoolean(); } public BatteryTip(int type, int state, boolean showDialog) { mType = type; mState = state; mShowDialog = showDialog; mNeedUpdate = true; } @Override public int describeContents() { return 0; } @Override public void writeToParcel(Parcel dest, int flags) { dest.writeInt(mType); dest.writeInt(mState); dest.writeBoolean(mShowDialog); dest.writeBoolean(mNeedUpdate); } public abstract CharSequence getTitle(Context context); public abstract CharSequence getSummary(Context context); /** Gets the drawable resource id for the icon. */ @DrawableRes public abstract int getIconId(); /** * Update the current {@link #mState} using the new {@code tip}. * * @param tip used to update */ public abstract void updateState(BatteryTip tip); /** * Check whether data is still make sense. If not, try recover. * * @param context used to do validate check */ public void validateCheck(Context context) { // do nothing } /** Log the battery tip */ public abstract void log(Context context, MetricsFeatureProvider metricsFeatureProvider); public void updatePreference(Preference preference) { final Context context = preference.getContext(); preference.setTitle(getTitle(context)); preference.setSummary(getSummary(context)); preference.setIcon(getIconId()); final TipCardPreference cardPreference = castToTipCardPreferenceSafely(preference); if (cardPreference != null) { cardPreference.resetLayoutState(); } } public boolean shouldShowDialog() { return mShowDialog; } public boolean needUpdate() { return mNeedUpdate; } public String getKey() { return KEY_PREFIX + mType; } public int getType() { return mType; } @StateType public int getState() { return mState; } public boolean isVisible() { return mState != StateType.INVISIBLE; } @Override public int compareTo(BatteryTip o) { return TIP_ORDER.get(mType) - TIP_ORDER.get(o.mType); } @Override public String toString() { return "type=" + mType + " state=" + mState; } /** Returns the converted {@link TipCardPreference} if it is valid. */ @Nullable public TipCardPreference castToTipCardPreferenceSafely(Preference preference) { return preference instanceof TipCardPreference ? (TipCardPreference) preference : null; } }