/* * 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.widget; import com.android.settingslib.RestrictedLockUtils.EnforcedAdmin; /* * A controller class for general switch widget handling. We have different containers that provide * different forms of switch layout. Provide a centralized control for updating the switch widget. */ public abstract class SwitchWidgetController { protected OnSwitchChangeListener mListener; /** * Interface definition for a callback to be invoked when the switch has been toggled. */ public interface OnSwitchChangeListener { /** * Called when the checked state of the Switch has changed. * * @param isChecked The new checked state of switchView. * * @return true to update the state of the switch with the new value. */ boolean onSwitchToggled(boolean isChecked); } /** * Perform any view setup. */ public void setupView() { } /** * Perform any view teardown. */ public void teardownView() { } /** * Set the callback to be invoked when the switch is toggled by the user (but before the * internal state has been updated). * * @param listener the callback to be invoked */ public void setListener(OnSwitchChangeListener listener) { mListener = listener; } /** * Update the preference title associated with the switch. * * @param isChecked whether the switch is currently checked */ public abstract void updateTitle(boolean isChecked); /** * Start listening to switch toggling. */ public abstract void startListening(); /** * Stop listening to switch toggling. */ public abstract void stopListening(); /** * Set the checked state for the switch. * * @param checked whether the switch should be checked or not. */ public abstract void setChecked(boolean checked); /** * Get the checked state for the switch. * * @return true if the switch is currently checked, false otherwise. */ public abstract boolean isChecked(); /** * Set the enabled state for the switch. * * @param enabled whether the switch should be enabled or not. */ public abstract void setEnabled(boolean enabled); /** * Disable the switch based on the enforce admin. * * @param admin Details of the admin who enforced the restriction. If it * is {@code null}, then this preference will be enabled. Otherwise, it will be disabled. */ public abstract void setDisabledByAdmin(EnforcedAdmin admin); }