diff options
author | Thomas <tschneider.ac@gmail.com> | 2023-01-11 18:04:37 +0100 |
---|---|---|
committer | Thomas <tschneider.ac@gmail.com> | 2023-01-11 18:04:37 +0100 |
commit | edc4f1357ec344dbb173b3f53cbe08e3578f7d06 (patch) | |
tree | 5888b2d268fa7935597d8def4fc5c2eb9a73c9fd | |
parent | ac503cdf0cfb62470100c0085859c0d69aadf9a4 (diff) |
NSFW for Pixelfed view
-rw-r--r-- | app/src/main/java/app/fedilab/android/ui/drawer/SliderAdapter.java | 59 | ||||
-rw-r--r-- | src/fdroid/fastlane/metadata/android/en/changelogs/463.txt | 1 |
2 files changed, 47 insertions, 13 deletions
diff --git a/app/src/main/java/app/fedilab/android/ui/drawer/SliderAdapter.java b/app/src/main/java/app/fedilab/android/ui/drawer/SliderAdapter.java index de0975c47..e34051b74 100644 --- a/app/src/main/java/app/fedilab/android/ui/drawer/SliderAdapter.java +++ b/app/src/main/java/app/fedilab/android/ui/drawer/SliderAdapter.java @@ -17,23 +17,29 @@ package app.fedilab.android.ui.drawer; import android.app.Activity; import android.content.Context; import android.content.Intent; +import android.content.SharedPreferences; import android.os.Bundle; +import android.os.CountDownTimer; import android.view.LayoutInflater; import android.view.ViewGroup; import androidx.core.app.ActivityOptionsCompat; +import androidx.preference.PreferenceManager; import com.bumptech.glide.Glide; +import com.bumptech.glide.request.RequestOptions; import com.smarteist.autoimageslider.SliderViewAdapter; import java.util.ArrayList; import java.util.List; +import app.fedilab.android.R; import app.fedilab.android.activities.MediaActivity; import app.fedilab.android.client.entities.api.Attachment; import app.fedilab.android.client.entities.api.Status; import app.fedilab.android.databinding.DrawerSliderBinding; import app.fedilab.android.helper.Helper; +import jp.wasabeef.glide.transformations.BlurTransformation; public class SliderAdapter extends SliderViewAdapter<SliderAdapter.SliderAdapterVH> { @@ -63,21 +69,48 @@ public class SliderAdapter extends SliderViewAdapter<SliderAdapter.SliderAdapter public void onBindViewHolder(SliderAdapterVH viewHolder, final int position) { Attachment sliderItem = mSliderItems.get(position); + if (status.sensitive) { + Glide.with(viewHolder.itemView) + .load(sliderItem.preview_url) + .centerCrop() + .apply(new RequestOptions().transform(new BlurTransformation(50, 3))) + .into(viewHolder.binding.ivAutoImageSlider); + } else { + Glide.with(viewHolder.itemView) + .load(sliderItem.preview_url) + .centerCrop() + .into(viewHolder.binding.ivAutoImageSlider); + } + SharedPreferences sharedpreferences = PreferenceManager.getDefaultSharedPreferences(context); + final int timeout = sharedpreferences.getInt(context.getString(R.string.SET_NSFW_TIMEOUT), 5); + boolean expand_media = sharedpreferences.getBoolean(context.getString(R.string.SET_EXPAND_MEDIA), false); - Glide.with(viewHolder.itemView) - .load(sliderItem.preview_url) - .centerCrop() - .into(viewHolder.binding.ivAutoImageSlider); viewHolder.itemView.setOnClickListener(v -> { - Intent mediaIntent = new Intent(context, MediaActivity.class); - Bundle b = new Bundle(); - b.putInt(Helper.ARG_MEDIA_POSITION, position + 1); - b.putSerializable(Helper.ARG_MEDIA_ARRAY, new ArrayList<>(status.media_attachments)); - mediaIntent.putExtras(b); - ActivityOptionsCompat options = ActivityOptionsCompat - .makeSceneTransitionAnimation((Activity) context, viewHolder.binding.ivAutoImageSlider, status.media_attachments.get(0).url); - // start the new activity - context.startActivity(mediaIntent, options.toBundle()); + if (status.sensitive && !expand_media) { + status.sensitive = false; + notifyDataSetChanged(); + if (timeout > 0) { + new CountDownTimer((timeout * 1000L), 1000) { + public void onTick(long millisUntilFinished) { + } + + public void onFinish() { + status.sensitive = true; + notifyDataSetChanged(); + } + }.start(); + } + } else { + Intent mediaIntent = new Intent(context, MediaActivity.class); + Bundle b = new Bundle(); + b.putInt(Helper.ARG_MEDIA_POSITION, position + 1); + b.putSerializable(Helper.ARG_MEDIA_ARRAY, new ArrayList<>(status.media_attachments)); + mediaIntent.putExtras(b); + ActivityOptionsCompat options = ActivityOptionsCompat + .makeSceneTransitionAnimation((Activity) context, viewHolder.binding.ivAutoImageSlider, status.media_attachments.get(0).url); + // start the new activity + context.startActivity(mediaIntent, options.toBundle()); + } }); } diff --git a/src/fdroid/fastlane/metadata/android/en/changelogs/463.txt b/src/fdroid/fastlane/metadata/android/en/changelogs/463.txt index eaebdeb2d..4fe4c5fe5 100644 --- a/src/fdroid/fastlane/metadata/android/en/changelogs/463.txt +++ b/src/fdroid/fastlane/metadata/android/en/changelogs/463.txt @@ -9,4 +9,5 @@ Fixed: - Fix jumps with the fetch more feature - Fix videos cannot be saved - Tags cannot be pinned when there are no custom tabs +- PixelFed view: NSFW not honored - Fix crashes
\ No newline at end of file |