1 /*
2  * Copyright (C) 2021 The Android Open Source Project
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  *      http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  */
16 
17 package com.android.settings.display;
18 
19 import android.content.Context;
20 import android.provider.Settings;
21 
22 import androidx.preference.Preference;
23 
24 import com.android.settings.R;
25 import com.android.settings.core.TogglePreferenceController;
26 
27 /**
28  * Preference to enable/disable the large double-line clock on lockscreen
29  */
30 public class LockscreenClockPreferenceController extends TogglePreferenceController {
31 
32     private static final String SETTING_KEY = Settings.Secure.LOCKSCREEN_USE_DOUBLE_LINE_CLOCK;
33 
LockscreenClockPreferenceController(Context context, String preferenceKey)34     public LockscreenClockPreferenceController(Context context, String preferenceKey) {
35         super(context, preferenceKey);
36     }
37 
38     @Override
isChecked()39     public boolean isChecked() {
40         return Settings.Secure.getInt(mContext.getContentResolver(), SETTING_KEY, 1) != 0;
41     }
42 
43     @Override
setChecked(boolean isChecked)44     public boolean setChecked(boolean isChecked) {
45         return Settings.Secure.putInt(mContext.getContentResolver(), SETTING_KEY,
46                 isChecked ? 1 : 0);
47     }
48 
49     @Override
getSummary()50     public CharSequence getSummary() {
51         return mContext.getText(R.string.lockscreen_double_line_clock_summary);
52     }
53 
54     @Override
getAvailabilityStatus()55     public int getAvailabilityStatus() {
56         return AVAILABLE;
57     }
58 
59     @Override
updateState(Preference preference)60     public void updateState(Preference preference) {
61         super.updateState(preference);
62         preference.setEnabled(true);
63         refreshSummary(preference);
64     }
65 
66     @Override
getSliceHighlightMenuRes()67     public int getSliceHighlightMenuRes() {
68         return R.string.menu_key_display;
69     }
70 }
71