Refine the verified links preference
- Let UI look cleaner and reduce the confusion. Fixes: 246875492 Test: manual test Change-Id: Ic2c947c0e05e7f9d5307c43c022638ae4b6dec8f
This commit is contained in:
@@ -31,7 +31,7 @@
|
|||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:title="@string/app_launch_links_category">
|
android:title="@string/app_launch_links_category">
|
||||||
|
|
||||||
<com.android.settings.applications.intentpicker.VerifiedLinksPreference
|
<Preference
|
||||||
android:key="open_by_default_verified_links"
|
android:key="open_by_default_verified_links"
|
||||||
android:title="@string/summary_placeholder"
|
android:title="@string/summary_placeholder"
|
||||||
android:order="-100"
|
android:order="-100"
|
||||||
@@ -40,8 +40,7 @@
|
|||||||
<PreferenceCategory
|
<PreferenceCategory
|
||||||
android:layout="@layout/preference_category_no_label"
|
android:layout="@layout/preference_category_no_label"
|
||||||
android:key="open_by_default_selected_links_category"
|
android:key="open_by_default_selected_links_category"
|
||||||
android:order="100"
|
android:order="100"/>
|
||||||
settings:searchable="false"/>
|
|
||||||
|
|
||||||
<Preference
|
<Preference
|
||||||
android:key="open_by_default_add_link"
|
android:key="open_by_default_add_link"
|
||||||
|
@@ -246,15 +246,14 @@ public class AppLaunchSettings extends AppInfoBase implements
|
|||||||
|
|
||||||
/** Initialize verified links preference */
|
/** Initialize verified links preference */
|
||||||
private void initVerifiedLinksPreference() {
|
private void initVerifiedLinksPreference() {
|
||||||
final VerifiedLinksPreference verifiedLinksPreference =
|
final Preference verifiedLinksPreference = mMainPreferenceCategory.findPreference(
|
||||||
(VerifiedLinksPreference) mMainPreferenceCategory.findPreference(
|
VERIFIED_LINKS_PREF_KEY);
|
||||||
VERIFIED_LINKS_PREF_KEY);
|
verifiedLinksPreference.setOnPreferenceClickListener(preference -> {
|
||||||
verifiedLinksPreference.setWidgetFrameClickListener(l -> {
|
|
||||||
showVerifiedLinksDialog();
|
showVerifiedLinksDialog();
|
||||||
|
return true;
|
||||||
});
|
});
|
||||||
final int verifiedLinksNo = getLinksNumber(DOMAIN_STATE_VERIFIED);
|
final int verifiedLinksNo = getLinksNumber(DOMAIN_STATE_VERIFIED);
|
||||||
verifiedLinksPreference.setTitle(getVerifiedLinksTitle(verifiedLinksNo));
|
verifiedLinksPreference.setTitle(getVerifiedLinksTitle(verifiedLinksNo));
|
||||||
verifiedLinksPreference.setCheckBoxVisible(verifiedLinksNo > 0);
|
|
||||||
verifiedLinksPreference.setEnabled(verifiedLinksNo > 0);
|
verifiedLinksPreference.setEnabled(verifiedLinksNo > 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1,95 +0,0 @@
|
|||||||
/*
|
|
||||||
* Copyright (C) 2021 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.applications.intentpicker;
|
|
||||||
|
|
||||||
import android.content.Context;
|
|
||||||
import android.util.AttributeSet;
|
|
||||||
import android.view.View;
|
|
||||||
import android.widget.CheckBox;
|
|
||||||
|
|
||||||
import androidx.preference.PreferenceViewHolder;
|
|
||||||
|
|
||||||
import com.android.settings.R;
|
|
||||||
import com.android.settingslib.widget.TwoTargetPreference;
|
|
||||||
|
|
||||||
/** This customized VerifiedLinksPreference was belonged to Open by default page */
|
|
||||||
public class VerifiedLinksPreference extends TwoTargetPreference {
|
|
||||||
private Context mContext;
|
|
||||||
private View.OnClickListener mOnWidgetClickListener;
|
|
||||||
private boolean mShowCheckBox;
|
|
||||||
|
|
||||||
public VerifiedLinksPreference(Context context, AttributeSet attrs,
|
|
||||||
int defStyleAttr, int defStyleRes) {
|
|
||||||
super(context, attrs, defStyleAttr, defStyleRes);
|
|
||||||
init(context);
|
|
||||||
}
|
|
||||||
|
|
||||||
public VerifiedLinksPreference(Context context, AttributeSet attrs, int defStyleAttr) {
|
|
||||||
this(context, attrs, defStyleAttr, /* defStyleRes= */0);
|
|
||||||
}
|
|
||||||
|
|
||||||
public VerifiedLinksPreference(Context context, AttributeSet attrs) {
|
|
||||||
this(context, attrs, /* defStyleAttr= */ 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
public VerifiedLinksPreference(Context context) {
|
|
||||||
this(context, /* attrs= */ null);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void init(Context context) {
|
|
||||||
mContext = context;
|
|
||||||
mOnWidgetClickListener = null;
|
|
||||||
mShowCheckBox = true;
|
|
||||||
setLayoutResource(R.layout.preference_checkable_two_target);
|
|
||||||
setWidgetLayoutResource(R.layout.verified_links_widget);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Register a callback to be invoked when this widget is clicked.
|
|
||||||
*
|
|
||||||
* @param listener The callback that will run.
|
|
||||||
*/
|
|
||||||
public void setWidgetFrameClickListener(View.OnClickListener listener) {
|
|
||||||
mOnWidgetClickListener = listener;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** Determine the visibility of the {@link CheckBox}. */
|
|
||||||
public void setCheckBoxVisible(boolean isVisible) {
|
|
||||||
mShowCheckBox = isVisible;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onBindViewHolder(PreferenceViewHolder view) {
|
|
||||||
super.onBindViewHolder(view);
|
|
||||||
final View settingsWidget = view.findViewById(android.R.id.widget_frame);
|
|
||||||
final View divider = view.findViewById(R.id.two_target_divider);
|
|
||||||
divider.setVisibility(View.VISIBLE);
|
|
||||||
settingsWidget.setVisibility(View.VISIBLE);
|
|
||||||
if (mOnWidgetClickListener != null) {
|
|
||||||
settingsWidget.setOnClickListener(mOnWidgetClickListener);
|
|
||||||
}
|
|
||||||
final View checkboxContainer = view.findViewById(R.id.checkbox_container);
|
|
||||||
final View parentView = (View) checkboxContainer.getParent();
|
|
||||||
parentView.setEnabled(false);
|
|
||||||
parentView.setClickable(false);
|
|
||||||
CheckBox checkBox = (CheckBox) view.findViewById(com.android.internal.R.id.checkbox);
|
|
||||||
if (checkBox != null) {
|
|
||||||
checkBox.setChecked(true);
|
|
||||||
checkboxContainer.setVisibility(mShowCheckBox ? View.VISIBLE : View.GONE);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Reference in New Issue
Block a user