Add an option to disable NSFW forever.

This commit is contained in:
Alex Ning 2021-04-08 19:17:26 +08:00
parent f22b649bee
commit 6282027334
4 changed files with 107 additions and 0 deletions

View File

@ -8,11 +8,14 @@ import android.view.LayoutInflater;
import android.view.View; import android.view.View;
import android.view.ViewGroup; import android.view.ViewGroup;
import android.widget.LinearLayout; import android.widget.LinearLayout;
import android.widget.TextView;
import androidx.annotation.NonNull; import androidx.annotation.NonNull;
import androidx.appcompat.app.AppCompatActivity; import androidx.appcompat.app.AppCompatActivity;
import androidx.core.content.ContextCompat;
import androidx.fragment.app.Fragment; import androidx.fragment.app.Fragment;
import com.google.android.material.dialog.MaterialAlertDialogBuilder;
import com.google.android.material.switchmaterial.SwitchMaterial; import com.google.android.material.switchmaterial.SwitchMaterial;
import org.greenrobot.eventbus.EventBus; import org.greenrobot.eventbus.EventBus;
@ -49,6 +52,15 @@ public class NsfwAndSpoilerFragment extends Fragment {
LinearLayout blurSpoilerLinearLayout; LinearLayout blurSpoilerLinearLayout;
@BindView(R.id.blur_spoiler_switch_nsfw_and_spoiler_fragment) @BindView(R.id.blur_spoiler_switch_nsfw_and_spoiler_fragment)
SwitchMaterial blurSpoilerSwitchMaterial; SwitchMaterial blurSpoilerSwitchMaterial;
@BindView(R.id.disable_nsfw_forever_linear_layout_nsfw_and_spoiler_fragment)
LinearLayout disableNsfwForeverLinearLayout;
@BindView(R.id.disable_nsfw_forever_text_view_nsfw_and_spoiler_fragment)
TextView disableNsfwForeverTextView;
@BindView(R.id.disable_nsfw_forever_switch_nsfw_and_spoiler_fragment)
SwitchMaterial disableNsfwForeverSwitchMaterial;
@Inject
@Named("default")
SharedPreferences sharedPreferences;
@Inject @Inject
@Named("nsfw_and_spoiler") @Named("nsfw_and_spoiler")
SharedPreferences nsfwAndBlurringSharedPreferences; SharedPreferences nsfwAndBlurringSharedPreferences;
@ -56,6 +68,8 @@ public class NsfwAndSpoilerFragment extends Fragment {
private Activity activity; private Activity activity;
private boolean blurNsfw; private boolean blurNsfw;
private boolean doNotBlurNsfwInNsfwSubreddits; private boolean doNotBlurNsfwInNsfwSubreddits;
private boolean disableNsfwForever;
private boolean manuallyCheckDisableNsfwForever = true;
public NsfwAndSpoilerFragment() { public NsfwAndSpoilerFragment() {
// Required empty public constructor // Required empty public constructor
@ -77,6 +91,7 @@ public class NsfwAndSpoilerFragment extends Fragment {
blurNsfw = nsfwAndBlurringSharedPreferences.getBoolean((accountName == null ? "" : accountName) + SharedPreferencesUtils.BLUR_NSFW_BASE, true); blurNsfw = nsfwAndBlurringSharedPreferences.getBoolean((accountName == null ? "" : accountName) + SharedPreferencesUtils.BLUR_NSFW_BASE, true);
doNotBlurNsfwInNsfwSubreddits = nsfwAndBlurringSharedPreferences.getBoolean((accountName == null ? "" : accountName) + SharedPreferencesUtils.DO_NOT_BLUR_NSFW_IN_NSFW_SUBREDDITS, false); doNotBlurNsfwInNsfwSubreddits = nsfwAndBlurringSharedPreferences.getBoolean((accountName == null ? "" : accountName) + SharedPreferencesUtils.DO_NOT_BLUR_NSFW_IN_NSFW_SUBREDDITS, false);
boolean blurSpoiler = nsfwAndBlurringSharedPreferences.getBoolean((accountName == null ? "" : accountName) + SharedPreferencesUtils.BLUR_SPOILER_BASE, false); boolean blurSpoiler = nsfwAndBlurringSharedPreferences.getBoolean((accountName == null ? "" : accountName) + SharedPreferencesUtils.BLUR_SPOILER_BASE, false);
disableNsfwForever = sharedPreferences.getBoolean(SharedPreferencesUtils.DISABLE_NSFW_FOREVER, false);
if (enableNsfw) { if (enableNsfw) {
blurNsfwLinearLayout.setVisibility(View.VISIBLE); blurNsfwLinearLayout.setVisibility(View.VISIBLE);
@ -87,6 +102,12 @@ public class NsfwAndSpoilerFragment extends Fragment {
blurNsfwSwitchMaterial.setChecked(blurNsfw); blurNsfwSwitchMaterial.setChecked(blurNsfw);
doNotBlurNsfwInNsfwSubredditsSwitch.setChecked(doNotBlurNsfwInNsfwSubreddits); doNotBlurNsfwInNsfwSubredditsSwitch.setChecked(doNotBlurNsfwInNsfwSubreddits);
blurSpoilerSwitchMaterial.setChecked(blurSpoiler); blurSpoilerSwitchMaterial.setChecked(blurSpoiler);
disableNsfwForeverSwitchMaterial.setChecked(disableNsfwForever);
disableNsfwForeverSwitchMaterial.setEnabled(!disableNsfwForever);
if (disableNsfwForever) {
disableNsfwForeverTextView.setTextColor(ContextCompat.getColor(activity, R.color.settingsSubtitleColor));
disableNsfwForeverLinearLayout.setEnabled(false);
}
enableNsfwLinearLayout.setOnClickListener(view -> enableNsfwSwitchMaterial.performClick()); enableNsfwLinearLayout.setOnClickListener(view -> enableNsfwSwitchMaterial.performClick());
enableNsfwSwitchMaterial.setOnCheckedChangeListener((compoundButton, b) -> { enableNsfwSwitchMaterial.setOnCheckedChangeListener((compoundButton, b) -> {
@ -120,6 +141,39 @@ public class NsfwAndSpoilerFragment extends Fragment {
nsfwAndBlurringSharedPreferences.edit().putBoolean((accountName == null ? "" : accountName) + SharedPreferencesUtils.BLUR_SPOILER_BASE, b).apply(); nsfwAndBlurringSharedPreferences.edit().putBoolean((accountName == null ? "" : accountName) + SharedPreferencesUtils.BLUR_SPOILER_BASE, b).apply();
EventBus.getDefault().post(new ChangeSpoilerBlurEvent(b)); EventBus.getDefault().post(new ChangeSpoilerBlurEvent(b));
}); });
disableNsfwForeverLinearLayout.setOnClickListener(view -> {
disableNsfwForeverSwitchMaterial.performClick();
});
disableNsfwForeverSwitchMaterial.setOnCheckedChangeListener((compoundButton, b) -> {
if (manuallyCheckDisableNsfwForever) {
manuallyCheckDisableNsfwForever = false;
new MaterialAlertDialogBuilder(activity, R.style.MaterialAlertDialogTheme)
.setTitle(R.string.warning)
.setMessage(R.string.disable_nsfw_forever_message)
.setPositiveButton(R.string.yes, (dialogInterface, i)
-> {
sharedPreferences.edit().putBoolean(SharedPreferencesUtils.DISABLE_NSFW_FOREVER, true).apply();
disableNsfwForever = true;
disableNsfwForeverSwitchMaterial.setEnabled(false);
disableNsfwForeverLinearLayout.setEnabled(false);
disableNsfwForeverSwitchMaterial.setChecked(true);
disableNsfwForeverTextView.setTextColor(ContextCompat.getColor(activity, R.color.settingsSubtitleColor));
EventBus.getDefault().post(new ChangeNSFWEvent(false));
})
.setNegativeButton(R.string.no, (dialogInterface, i) -> {
disableNsfwForeverSwitchMaterial.setChecked(false);
manuallyCheckDisableNsfwForever = true;
})
.setOnDismissListener(dialogInterface -> {
if (!disableNsfwForever) {
disableNsfwForeverSwitchMaterial.setChecked(false);
}
manuallyCheckDisableNsfwForever = true;
})
.show();
}
});
return rootView; return rootView;
} }

View File

@ -176,6 +176,7 @@ public class SharedPreferencesUtils {
public static final String SWIPE_BETWEEN_POSTS = "swipe_between_posts"; public static final String SWIPE_BETWEEN_POSTS = "swipe_between_posts";
public static final String NUMBER_OF_COLUMNS_IN_POST_FEED_PORTRAIT_CARD_LAYOUT_2 = "number_of_columns_in_post_feed_portrait_card_layout_2"; public static final String NUMBER_OF_COLUMNS_IN_POST_FEED_PORTRAIT_CARD_LAYOUT_2 = "number_of_columns_in_post_feed_portrait_card_layout_2";
public static final String NUMBER_OF_COLUMNS_IN_POST_FEED_LANDSCAPE_CARD_LAYOUT_2 = "number_of_columns_in_post_feed_landscape_card_layout_2"; public static final String NUMBER_OF_COLUMNS_IN_POST_FEED_LANDSCAPE_CARD_LAYOUT_2 = "number_of_columns_in_post_feed_landscape_card_layout_2";
public static final String DISABLE_NSFW_FOREVER = "disable_nsfw_forever";
public static final String DEFAULT_PREFERENCES_FILE = "ml.docilealligator.infinityforreddit_preferences"; public static final String DEFAULT_PREFERENCES_FILE = "ml.docilealligator.infinityforreddit_preferences";
public static final String MAIN_PAGE_TABS_SHARED_PREFERENCES_FILE = "ml.docilealligator.infinityforreddit.main_page_tabs"; public static final String MAIN_PAGE_TABS_SHARED_PREFERENCES_FILE = "ml.docilealligator.infinityforreddit.main_page_tabs";

View File

@ -141,6 +141,54 @@
</LinearLayout> </LinearLayout>
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:background="@color/dividerColor" />
<TextView
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="16dp"
android:paddingStart="72dp"
android:paddingEnd="16dp"
android:text="@string/settings_nsfw_and_spoiler_dangerous_group_title"
android:textColor="@color/colorAccent"
android:textSize="?attr/font_default"
android:fontFamily="?attr/font_family" />
<LinearLayout
android:id="@+id/disable_nsfw_forever_linear_layout_nsfw_and_spoiler_fragment"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:paddingTop="4dp"
android:paddingBottom="4dp"
android:paddingStart="72dp"
android:paddingEnd="16dp"
android:clickable="true"
android:focusable="true"
android:background="?attr/selectableItemBackground">
<TextView
android:id="@+id/disable_nsfw_forever_text_view_nsfw_and_spoiler_fragment"
android:layout_width="0dp"
android:layout_height="wrap_content"
android:layout_weight="1"
android:layout_marginEnd="16dp"
android:layout_gravity="center_vertical"
android:text="@string/settings_disable_nsfw_forever_title"
android:textColor="?attr/primaryTextColor"
android:textSize="?attr/font_16"
android:fontFamily="?attr/font_family" />
<com.google.android.material.switchmaterial.SwitchMaterial
android:id="@+id/disable_nsfw_forever_switch_nsfw_and_spoiler_fragment"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical" />
</LinearLayout>
</LinearLayout> </LinearLayout>
</androidx.core.widget.NestedScrollView> </androidx.core.widget.NestedScrollView>

View File

@ -559,6 +559,8 @@
<string name="settings_hide_subscribed_subreddits_sections_title">Hide Subscribed Subreddits Section</string> <string name="settings_hide_subscribed_subreddits_sections_title">Hide Subscribed Subreddits Section</string>
<string name="settings_default_search_result_tab">Default Search Result Tab</string> <string name="settings_default_search_result_tab">Default Search Result Tab</string>
<string name="settings_crash_reports_title">Crash Reports</string> <string name="settings_crash_reports_title">Crash Reports</string>
<string name="settings_nsfw_and_spoiler_dangerous_group_title">Dangerous</string>
<string name="settings_disable_nsfw_forever_title">Disable NSFW Forever</string>
<string name="no_link_available">Cannot get the link</string> <string name="no_link_available">Cannot get the link</string>
@ -1098,4 +1100,6 @@
<string name="crash_reports_deleted">Crash reports are deleted</string> <string name="crash_reports_deleted">Crash reports are deleted</string>
<string name="disable_nsfw_forever_message">Once enabled, NSFW will be permanently disabled, regardless of whether the NSFW setting is enabled or not. And this option is irreversible, the only way to re-enable NSFW is to clear the app data.\n\nStill want to enable it?</string>
</resources> </resources>