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

Commit bd16255e authored by Stefano Tommasini's avatar Stefano Tommasini Committed by Android (Google) Code Review
Browse files

Merge "Add SuggestionFeatureProvider interface." into nyc-mr2-dev

parents 2c570117 2eac39b3
Loading
Loading
Loading
Loading
+30 −0
Original line number Diff line number Diff line
/*
 * 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.dashboard;

import android.content.Context;

/** Interface should be implemented if you have added new suggestions */
public interface SuggestionFeatureProvider {

    /** Return true if className is the name of a class of one of your newly added suggestion. */
    boolean isPresent(String className);

    /** Return true if the suggestion has already been completed and does not need to be shown */
    boolean isSuggestionCompleted(Context context);

}
 No newline at end of file
+33 −0
Original line number Diff line number Diff line
/*
 * 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.dashboard;

import android.content.Context;

public class SuggestionFeatureProviderImpl implements SuggestionFeatureProvider {

    @Override
    public boolean isPresent(String className) {
        return false;
    }

    @Override
    public boolean isSuggestionCompleted(Context context) {
        return false;
    }

}
+8 −0
Original line number Diff line number Diff line
@@ -36,6 +36,7 @@ import com.android.settings.Settings.ScreenLockSuggestionActivity;
import com.android.settings.Settings.WifiCallingSuggestionActivity;
import com.android.settings.Settings.ZenModeAutomationSuggestionActivity;
import com.android.settings.WallpaperSuggestionActivity;
import com.android.settings.overlay.FeatureFactory;
import com.android.settingslib.drawer.Tile;

import java.util.Collection;
@@ -66,6 +67,13 @@ public class SuggestionsChecks {
        } else if (className.equals(FingerprintEnrollSuggestionActivity.class.getName())) {
            return isDeviceSecured() || !isFingerprintEnabled();
        }

        SuggestionFeatureProvider provider =
            FeatureFactory.getFactory(mContext).getSuggestionFeatureProvider();
        if (provider != null && provider.isPresent(className)) {
            return provider.isSuggestionCompleted(mContext);
        }

        return false;
    }

+3 −0
Original line number Diff line number Diff line
@@ -21,6 +21,7 @@ import android.text.TextUtils;
import android.util.Log;

import com.android.settings.R;
import com.android.settings.dashboard.SuggestionFeatureProvider;
import com.android.settings.fuelgauge.PowerUsageFeatureProvider;

/**
@@ -60,6 +61,8 @@ public abstract class FeatureFactory {
        return sFactory;
    }

    public abstract SuggestionFeatureProvider getSuggestionFeatureProvider();

    public abstract SupportFeatureProvider getSupportFeatureProvider(Context context);

    public abstract PowerUsageFeatureProvider getPowerUsageFeatureProvider(Context context);
+12 −0
Original line number Diff line number Diff line
@@ -18,6 +18,8 @@ package com.android.settings.overlay;

import android.content.Context;
import android.support.annotation.Keep;
import com.android.settings.dashboard.SuggestionFeatureProvider;
import com.android.settings.dashboard.SuggestionFeatureProviderImpl;
import com.android.settings.fuelgauge.PowerUsageFeatureProvider;

/**
@@ -26,6 +28,8 @@ import com.android.settings.fuelgauge.PowerUsageFeatureProvider;
@Keep
public class FeatureFactoryImpl extends FeatureFactory {

    private SuggestionFeatureProvider mSuggestionFeatureProvider;

    @Override
    public SupportFeatureProvider getSupportFeatureProvider(Context context) {
        return null;
@@ -41,4 +45,12 @@ public class FeatureFactoryImpl extends FeatureFactory {
        return null;
    }

    @Override
    public SuggestionFeatureProvider getSuggestionFeatureProvider() {
        if (mSuggestionFeatureProvider == null) {
            mSuggestionFeatureProvider = new SuggestionFeatureProviderImpl();
        }
        return mSuggestionFeatureProvider;
    }

}