Having consistent import order will reduce chance of merge conflict between internal and external master Test: rebuild Change-Id: I0b1a170967ddcce7f388603fd521f6ed1eeba30b
84 lines
3.2 KiB
Java
84 lines
3.2 KiB
Java
/*
|
|
* Copyright (C) 2016 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.survey;
|
|
|
|
import android.app.Activity;
|
|
import android.content.BroadcastReceiver;
|
|
|
|
import androidx.fragment.app.Fragment;
|
|
|
|
import com.android.settings.overlay.FeatureFactory;
|
|
import com.android.settings.overlay.SurveyFeatureProvider;
|
|
import com.android.settingslib.core.lifecycle.LifecycleObserver;
|
|
import com.android.settingslib.core.lifecycle.events.OnPause;
|
|
import com.android.settingslib.core.lifecycle.events.OnResume;
|
|
|
|
/**
|
|
* attaches extra, survey related work to the onResume method of registered observable classes
|
|
* in settings. This allows new classes to automatically support settings provided the extend
|
|
* one of the relevant classes in com.android.settings.lifecycle.
|
|
*/
|
|
public class SurveyMixin implements LifecycleObserver, OnResume, OnPause {
|
|
|
|
private String mName;
|
|
private Fragment mFragment;
|
|
private BroadcastReceiver mReceiver;
|
|
|
|
/**
|
|
* A mixin that attempts to perform survey related tasks right before onResume is called
|
|
* in a Settings PreferenceFragment. This will allow for remote updating and creation of
|
|
* surveys.
|
|
* @param fragment The fragment that this mixin will be attached to.
|
|
* @param fragmentName The simple name of the fragment.
|
|
*/
|
|
public SurveyMixin(Fragment fragment, String fragmentName) {
|
|
mName = fragmentName;
|
|
mFragment = fragment;
|
|
}
|
|
|
|
@Override
|
|
public void onResume() {
|
|
Activity activity = mFragment.getActivity();
|
|
|
|
// guard against the activity not existing yet or the feature being disabled
|
|
if (activity != null) {
|
|
SurveyFeatureProvider provider =
|
|
FeatureFactory.getFactory(activity).getSurveyFeatureProvider(activity);
|
|
if (provider != null) {
|
|
|
|
// Try to download a survey if there is none available, show the survey otherwise
|
|
String id = provider.getSurveyId(activity, mName);
|
|
if (provider.getSurveyExpirationDate(activity, id) <= -1) {
|
|
// register the receiver to show the survey on completion.
|
|
mReceiver = provider.createAndRegisterReceiver(activity);
|
|
provider.downloadSurvey(activity, id, null /* data */);
|
|
} else {
|
|
provider.showSurveyIfAvailable(activity, id);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void onPause() {
|
|
Activity activity = mFragment.getActivity();
|
|
if (mReceiver != null && activity != null) {
|
|
SurveyFeatureProvider.unregisterReceiver(activity, mReceiver);
|
|
mReceiver = null;
|
|
}
|
|
}
|
|
}
|