• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 /*
2  * Copyright (C) 2019 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.datetime;
18 
19 import android.app.Dialog;
20 import android.app.settings.SettingsEnums;
21 import android.app.timedetector.TimeDetectorHelper;
22 import android.content.Context;
23 
24 import com.android.settings.R;
25 import com.android.settings.dashboard.DashboardFragment;
26 import com.android.settings.search.BaseSearchIndexProvider;
27 import com.android.settingslib.search.SearchIndexable;
28 
29 import com.google.android.setupcompat.util.WizardManagerHelper;
30 
31 @SearchIndexable
32 public class DateTimeSettings extends DashboardFragment implements
33         TimePreferenceController.TimePreferenceHost, DatePreferenceController.DatePreferenceHost {
34 
35     private static final String TAG = "DateTimeSettings";
36 
37     // have we been launched from the setup wizard?
38     protected static final String EXTRA_IS_FROM_SUW = "firstRun";
39 
40     @Override
getMetricsCategory()41     public int getMetricsCategory() {
42         return SettingsEnums.DATE_TIME;
43     }
44 
45     @Override
getLogTag()46     protected String getLogTag() {
47         return TAG;
48     }
49 
50     @Override
getPreferenceScreenResId()51     protected int getPreferenceScreenResId() {
52         return R.xml.date_time_prefs;
53     }
54 
55     @Override
onAttach(Context context)56     public void onAttach(Context context) {
57         super.onAttach(context);
58         boolean isFromSUW = WizardManagerHelper.isAnySetupWizard(getIntent());
59         getSettingsLifecycle().addObserver(new TimeChangeListenerMixin(context, this));
60         use(LocationTimeZoneDetectionPreferenceController.class).setFragment(this);
61         use(AutoTimePreferenceController.class).setDateAndTimeCallback(this);
62         use(DatePreferenceController.class).setHost(this);
63         use(TimePreferenceController.class).setHost(this);
64         use(AutoTimeZonePreferenceController.class)
65                 .setTimeAndDateCallback(this)
66                 .setFromSUW(isFromSUW);
67         use(TimeFormatPreferenceController.class)
68                 .setTimeAndDateCallback(this)
69                 .setFromSUW(isFromSUW);
70 
71         // All the elements in the category are optional, so we must ensure the category is only
72         // available if any of the elements are available.
73         TimeFeedbackPreferenceCategoryController helpAndFeedbackCategoryController =
74                 use(TimeFeedbackPreferenceCategoryController.class);
75         use(TimeFeedbackPreferenceController.class)
76                 .registerWithOptionalCategoryController(helpAndFeedbackCategoryController);
77 
78         // All the elements in the category are optional, so we must ensure the category is only
79         // available if any of the elements are available.
80         NotificationsPreferenceCategoryController
81                 notificationsPreferenceCategoryController =
82                 use(NotificationsPreferenceCategoryController.class);
83         use(TimeZoneNotificationsPreferenceController.class)
84                 .registerIn(
85                         notificationsPreferenceCategoryController);
86     }
87 
88     @Override
updateTimeAndDateDisplay(Context context)89     public void updateTimeAndDateDisplay(Context context) {
90         updatePreferenceStates();
91     }
92 
93     @Override
onCreateDialog(int id)94     public Dialog onCreateDialog(int id) {
95         switch (id) {
96             case DatePreferenceController.DIALOG_DATEPICKER:
97                 return use(DatePreferenceController.class)
98                         .buildDatePicker(getActivity(), TimeDetectorHelper.INSTANCE);
99             case TimePreferenceController.DIALOG_TIMEPICKER:
100                 return use(TimePreferenceController.class)
101                         .buildTimePicker(getActivity());
102             default:
103                 throw new IllegalArgumentException();
104         }
105     }
106 
107     @Override
getDialogMetricsCategory(int dialogId)108     public int getDialogMetricsCategory(int dialogId) {
109         switch (dialogId) {
110             case DatePreferenceController.DIALOG_DATEPICKER:
111                 return SettingsEnums.DIALOG_DATE_PICKER;
112             case TimePreferenceController.DIALOG_TIMEPICKER:
113                 return SettingsEnums.DIALOG_TIME_PICKER;
114             default:
115                 return 0;
116         }
117     }
118 
119     @Override
showTimePicker()120     public void showTimePicker() {
121         removeDialog(TimePreferenceController.DIALOG_TIMEPICKER);
122         showDialog(TimePreferenceController.DIALOG_TIMEPICKER);
123     }
124 
125     @Override
showDatePicker()126     public void showDatePicker() {
127         showDialog(DatePreferenceController.DIALOG_DATEPICKER);
128     }
129 
130     public static final BaseSearchIndexProvider SEARCH_INDEX_DATA_PROVIDER =
131             new BaseSearchIndexProvider(R.xml.date_time_prefs);
132 }
133