diff --git a/res/values/cherish_strings.xml b/res/values/cherish_strings.xml index ed253be..d6da28a 100644 --- a/res/values/cherish_strings.xml +++ b/res/values/cherish_strings.xml @@ -197,5 +197,8 @@ Options Hide network traffic indicator if inactive Hide when network traffic indicator is below 1 KB/s + + + Invert 3 button navigation bar diff --git a/res/xml/cherish_settings_button.xml b/res/xml/cherish_settings_button.xml index 3179aad..756017c 100644 --- a/res/xml/cherish_settings_button.xml +++ b/res/xml/cherish_settings_button.xml @@ -17,6 +17,12 @@ xmlns:android="http://schemas.android.com/apk/res/android" android:title="@string/button_title" xmlns:settings="http://schemas.android.com/apk/res/com.android.settings"> + + \ No newline at end of file diff --git a/src/com/cherish/settings/fragments/NavBarInversePreferenceController.kt b/src/com/cherish/settings/fragments/NavBarInversePreferenceController.kt new file mode 100644 index 0000000..383c980 --- /dev/null +++ b/src/com/cherish/settings/fragments/NavBarInversePreferenceController.kt @@ -0,0 +1,42 @@ +/* + * Copyright (C) 2022 PixelPlusUI 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.cherish.settings.fragments + +import android.content.Context +import android.os.UserHandle +import android.provider.Settings + +import com.cherish.settings.CherishBasePreferenceController + +class NavBarInversePreferenceController( + context: Context, + key: String, +): CherishBasePreferenceController(context, key) { + + override fun getAvailabilityStatus(): Int { + val threeButtonMode = Settings.Secure.getIntForUser( + mContext.contentResolver, + Settings.Secure.NAVIGATION_MODE, + 0, + UserHandle.USER_CURRENT, + ) == 0 + return if (threeButtonMode) + AVAILABLE + else + DISABLED_DEPENDENT_SETTING + } +}