Update custom widget layouts to have a restricted icon.
Bug: 25603665 Bug: 27263775 Change-Id: Ic80377229de977b6f7c5f653974e8f926fb8ac1d
This commit is contained in:
@@ -1,57 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!-- Copyright (C) 2012 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.
|
|
||||||
-->
|
|
||||||
|
|
||||||
<!-- Used by UserPreference to show the trash icon -->
|
|
||||||
<LinearLayout
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="match_parent"
|
|
||||||
android:orientation="horizontal">
|
|
||||||
<View
|
|
||||||
android:id="@+id/divider_manage"
|
|
||||||
android:layout_width="2dip"
|
|
||||||
android:layout_height="match_parent"
|
|
||||||
android:layout_marginTop="5dip"
|
|
||||||
android:layout_marginBottom="5dip"
|
|
||||||
android:background="@android:drawable/divider_horizontal_dark" />
|
|
||||||
<ImageView
|
|
||||||
android:id="@+id/manage_user"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:paddingStart="16dip"
|
|
||||||
android:paddingEnd="16dip"
|
|
||||||
android:src="@drawable/ic_sysbar_quicksettings"
|
|
||||||
android:contentDescription="@string/settings_label"
|
|
||||||
android:layout_gravity="center"
|
|
||||||
android:background="?android:attr/selectableItemBackground" />
|
|
||||||
<View
|
|
||||||
android:id="@+id/divider_delete"
|
|
||||||
android:layout_width="2dip"
|
|
||||||
android:layout_height="match_parent"
|
|
||||||
android:layout_marginTop="5dip"
|
|
||||||
android:layout_marginBottom="5dip"
|
|
||||||
android:background="@android:drawable/divider_horizontal_dark" />
|
|
||||||
<ImageView
|
|
||||||
android:id="@+id/trash_user"
|
|
||||||
android:layout_width="wrap_content"
|
|
||||||
android:layout_height="fill_parent"
|
|
||||||
android:paddingStart="16dip"
|
|
||||||
android:paddingEnd="16dip"
|
|
||||||
android:src="@drawable/ic_menu_delete"
|
|
||||||
android:contentDescription="@string/user_delete_user_description"
|
|
||||||
android:layout_gravity="center"
|
|
||||||
android:background="?android:attr/selectableItemBackground" />
|
|
||||||
</LinearLayout>
|
|
@@ -30,14 +30,26 @@
|
|||||||
android:layout_marginTop="8dip"
|
android:layout_marginTop="8dip"
|
||||||
android:layout_marginBottom="8dip">
|
android:layout_marginBottom="8dip">
|
||||||
|
|
||||||
|
<LinearLayout
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content">
|
||||||
<TextView android:id="@android:id/title"
|
<TextView android:id="@android:id/title"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_weight="1"
|
||||||
android:singleLine="true"
|
android:singleLine="true"
|
||||||
android:textAppearance="@android:style/TextAppearance.Material.Subhead"
|
android:textAppearance="@android:style/TextAppearance.Material.Subhead"
|
||||||
android:textColor="?android:attr/textColorPrimary"
|
android:textColor="?android:attr/textColorPrimary"
|
||||||
android:ellipsize="marquee"
|
android:ellipsize="marquee"
|
||||||
android:fadingEdge="horizontal" />
|
android:fadingEdge="horizontal" />
|
||||||
|
<!-- Preference should place its actual preference widget here. -->
|
||||||
|
<LinearLayout android:id="@android:id/widget_frame"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:gravity="end|center_vertical"
|
||||||
|
android:paddingStart="16dp"
|
||||||
|
android:orientation="vertical" />
|
||||||
|
</LinearLayout>
|
||||||
|
|
||||||
<FrameLayout
|
<FrameLayout
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
|
60
res/layout/restricted_preference_user_delete_widget.xml
Normal file
60
res/layout/restricted_preference_user_delete_widget.xml
Normal file
@@ -0,0 +1,60 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<!-- 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.
|
||||||
|
-->
|
||||||
|
|
||||||
|
<!-- Used by UserPreference to show the trash icon -->
|
||||||
|
<merge xmlns:android="http://schemas.android.com/apk/res/android">
|
||||||
|
<include layout="@layout/restricted_icon" />
|
||||||
|
|
||||||
|
<LinearLayout android:id="@+id/user_delete_widget"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:orientation="horizontal">
|
||||||
|
<View
|
||||||
|
android:id="@+id/divider_manage"
|
||||||
|
android:layout_width="2dip"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_marginTop="5dip"
|
||||||
|
android:layout_marginBottom="5dip"
|
||||||
|
android:background="@android:drawable/divider_horizontal_dark" />
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/manage_user"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
android:paddingStart="16dip"
|
||||||
|
android:paddingEnd="16dip"
|
||||||
|
android:src="@drawable/ic_sysbar_quicksettings"
|
||||||
|
android:contentDescription="@string/settings_label"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
android:background="?android:attr/selectableItemBackground" />
|
||||||
|
<View
|
||||||
|
android:id="@+id/divider_delete"
|
||||||
|
android:layout_width="2dip"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_marginTop="5dip"
|
||||||
|
android:layout_marginBottom="5dip"
|
||||||
|
android:background="@android:drawable/divider_horizontal_dark" />
|
||||||
|
<ImageView
|
||||||
|
android:id="@+id/trash_user"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="fill_parent"
|
||||||
|
android:paddingStart="16dip"
|
||||||
|
android:paddingEnd="16dip"
|
||||||
|
android:src="@drawable/ic_menu_delete"
|
||||||
|
android:contentDescription="@string/user_delete_user_description"
|
||||||
|
android:layout_gravity="center"
|
||||||
|
android:background="?android:attr/selectableItemBackground" />
|
||||||
|
</LinearLayout>
|
||||||
|
</merge>
|
@@ -71,7 +71,7 @@ public class UserPreference extends RestrictedPreference {
|
|||||||
OnClickListener deleteListener) {
|
OnClickListener deleteListener) {
|
||||||
super(context, attrs);
|
super(context, attrs);
|
||||||
if (deleteListener != null || settingsListener != null) {
|
if (deleteListener != null || settingsListener != null) {
|
||||||
setWidgetLayoutResource(R.layout.preference_user_delete_widget);
|
setWidgetLayoutResource(R.layout.restricted_preference_user_delete_widget);
|
||||||
}
|
}
|
||||||
mDeleteClickListener = deleteListener;
|
mDeleteClickListener = deleteListener;
|
||||||
mSettingsClickListener = settingsListener;
|
mSettingsClickListener = settingsListener;
|
||||||
@@ -89,6 +89,14 @@ public class UserPreference extends RestrictedPreference {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onBindViewHolder(PreferenceViewHolder view) {
|
public void onBindViewHolder(PreferenceViewHolder view) {
|
||||||
|
super.onBindViewHolder(view);
|
||||||
|
final boolean disabledByAdmin = isDisabledByAdmin();
|
||||||
|
dimIcon(disabledByAdmin);
|
||||||
|
View userDeleteWidget = view.findViewById(R.id.user_delete_widget);
|
||||||
|
if (userDeleteWidget != null) {
|
||||||
|
userDeleteWidget.setVisibility(disabledByAdmin ? View.GONE : View.VISIBLE);
|
||||||
|
}
|
||||||
|
if (!disabledByAdmin) {
|
||||||
UserManager um = (UserManager) getContext().getSystemService(Context.USER_SERVICE);
|
UserManager um = (UserManager) getContext().getSystemService(Context.USER_SERVICE);
|
||||||
View deleteDividerView = view.findViewById(R.id.divider_delete);
|
View deleteDividerView = view.findViewById(R.id.divider_delete);
|
||||||
View manageDividerView = view.findViewById(R.id.divider_manage);
|
View manageDividerView = view.findViewById(R.id.divider_manage);
|
||||||
@@ -103,7 +111,6 @@ public class UserPreference extends RestrictedPreference {
|
|||||||
deleteDividerView.setVisibility(View.GONE);
|
deleteDividerView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
final boolean disabledByAdmin = isDisabledByAdmin();
|
|
||||||
ImageView manageView = (ImageView) view.findViewById(R.id.manage_user);
|
ImageView manageView = (ImageView) view.findViewById(R.id.manage_user);
|
||||||
if (manageView != null) {
|
if (manageView != null) {
|
||||||
if (mSettingsClickListener != null) {
|
if (mSettingsClickListener != null) {
|
||||||
@@ -116,10 +123,8 @@ public class UserPreference extends RestrictedPreference {
|
|||||||
manageView.setVisibility(View.GONE);
|
manageView.setVisibility(View.GONE);
|
||||||
manageDividerView.setVisibility(View.GONE);
|
manageDividerView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
manageView.setImageAlpha(disabledByAdmin ? ALPHA_DISABLED : ALPHA_ENABLED);
|
|
||||||
}
|
}
|
||||||
super.onBindViewHolder(view);
|
}
|
||||||
dimIcon(disabledByAdmin);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getSerialNumber() {
|
private int getSerialNumber() {
|
||||||
|
Reference in New Issue
Block a user