Merge pull request #3412 from ByteHamster/lock-queue
Added warning when locking the queue
This commit is contained in:
commit
c9a71b943d
|
@ -7,6 +7,7 @@ import android.os.Bundle;
|
||||||
import android.support.design.widget.Snackbar;
|
import android.support.design.widget.Snackbar;
|
||||||
import android.support.v4.app.Fragment;
|
import android.support.v4.app.Fragment;
|
||||||
import android.support.v4.view.MenuItemCompat;
|
import android.support.v4.view.MenuItemCompat;
|
||||||
|
import android.support.v7.app.AlertDialog;
|
||||||
import android.support.v7.widget.LinearLayoutManager;
|
import android.support.v7.widget.LinearLayoutManager;
|
||||||
import android.support.v7.widget.RecyclerView;
|
import android.support.v7.widget.RecyclerView;
|
||||||
import android.support.v7.widget.SearchView;
|
import android.support.v7.widget.SearchView;
|
||||||
|
@ -19,6 +20,8 @@ import android.view.MenuInflater;
|
||||||
import android.view.MenuItem;
|
import android.view.MenuItem;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
|
import android.widget.CheckBox;
|
||||||
|
import android.widget.LinearLayout;
|
||||||
import android.widget.ProgressBar;
|
import android.widget.ProgressBar;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
@ -91,10 +94,12 @@ public class QueueFragment extends Fragment {
|
||||||
private static final String PREFS = "QueueFragment";
|
private static final String PREFS = "QueueFragment";
|
||||||
private static final String PREF_SCROLL_POSITION = "scroll_position";
|
private static final String PREF_SCROLL_POSITION = "scroll_position";
|
||||||
private static final String PREF_SCROLL_OFFSET = "scroll_offset";
|
private static final String PREF_SCROLL_OFFSET = "scroll_offset";
|
||||||
|
private static final String PREF_SHOW_LOCK_WARNING = "show_lock_warning";
|
||||||
|
|
||||||
private Disposable disposable;
|
private Disposable disposable;
|
||||||
private LinearLayoutManager layoutManager;
|
private LinearLayoutManager layoutManager;
|
||||||
private ItemTouchHelper itemTouchHelper;
|
private ItemTouchHelper itemTouchHelper;
|
||||||
|
private SharedPreferences prefs;
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -102,6 +107,7 @@ public class QueueFragment extends Fragment {
|
||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
setRetainInstance(true);
|
setRetainInstance(true);
|
||||||
setHasOptionsMenu(true);
|
setHasOptionsMenu(true);
|
||||||
|
prefs = getActivity().getSharedPreferences(PREFS, Context.MODE_PRIVATE);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -219,15 +225,13 @@ public class QueueFragment extends Fragment {
|
||||||
topOffset = firstItemView.getTop();
|
topOffset = firstItemView.getTop();
|
||||||
}
|
}
|
||||||
|
|
||||||
SharedPreferences prefs = getActivity().getSharedPreferences(PREFS, Context.MODE_PRIVATE);
|
prefs.edit()
|
||||||
SharedPreferences.Editor editor = prefs.edit();
|
.putInt(PREF_SCROLL_POSITION, firstItem)
|
||||||
editor.putInt(PREF_SCROLL_POSITION, firstItem);
|
.putFloat(PREF_SCROLL_OFFSET, topOffset)
|
||||||
editor.putFloat(PREF_SCROLL_OFFSET, topOffset);
|
.apply();
|
||||||
editor.apply();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
private void restoreScrollPosition() {
|
private void restoreScrollPosition() {
|
||||||
SharedPreferences prefs = getActivity().getSharedPreferences(PREFS, Context.MODE_PRIVATE);
|
|
||||||
int position = prefs.getInt(PREF_SCROLL_POSITION, 0);
|
int position = prefs.getInt(PREF_SCROLL_POSITION, 0);
|
||||||
float offset = prefs.getFloat(PREF_SCROLL_OFFSET, 0.0f);
|
float offset = prefs.getFloat(PREF_SCROLL_OFFSET, 0.0f);
|
||||||
if (position > 0 || offset > 0) {
|
if (position > 0 || offset > 0) {
|
||||||
|
@ -299,19 +303,7 @@ public class QueueFragment extends Fragment {
|
||||||
if (!super.onOptionsItemSelected(item)) {
|
if (!super.onOptionsItemSelected(item)) {
|
||||||
switch (item.getItemId()) {
|
switch (item.getItemId()) {
|
||||||
case R.id.queue_lock:
|
case R.id.queue_lock:
|
||||||
boolean newLockState = !UserPreferences.isQueueLocked();
|
toggleQueueLock();
|
||||||
UserPreferences.setQueueLocked(newLockState);
|
|
||||||
getActivity().supportInvalidateOptionsMenu();
|
|
||||||
if (recyclerAdapter != null) {
|
|
||||||
recyclerAdapter.setLocked(newLockState);
|
|
||||||
}
|
|
||||||
if (newLockState) {
|
|
||||||
Snackbar.make(getActivity().findViewById(R.id.content), R.string
|
|
||||||
.queue_locked, Snackbar.LENGTH_SHORT).show();
|
|
||||||
} else {
|
|
||||||
Snackbar.make(getActivity().findViewById(R.id.content), R.string
|
|
||||||
.queue_unlocked, Snackbar.LENGTH_SHORT).show();
|
|
||||||
}
|
|
||||||
return true;
|
return true;
|
||||||
case R.id.refresh_item:
|
case R.id.refresh_item:
|
||||||
List<Feed> feeds = ((MainActivity) getActivity()).getFeeds();
|
List<Feed> feeds = ((MainActivity) getActivity()).getFeeds();
|
||||||
|
@ -394,6 +386,48 @@ public class QueueFragment extends Fragment {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void toggleQueueLock() {
|
||||||
|
boolean isLocked = UserPreferences.isQueueLocked();
|
||||||
|
if (isLocked) {
|
||||||
|
setQueueLocked(false);
|
||||||
|
} else {
|
||||||
|
boolean shouldShowLockWarning = prefs.getBoolean(PREF_SHOW_LOCK_WARNING, true);
|
||||||
|
if (!shouldShowLockWarning) {
|
||||||
|
setQueueLocked(true);
|
||||||
|
} else {
|
||||||
|
AlertDialog.Builder builder = new AlertDialog.Builder(getContext());
|
||||||
|
builder.setTitle(R.string.lock_queue);
|
||||||
|
builder.setMessage(R.string.queue_lock_warning);
|
||||||
|
|
||||||
|
View view = View.inflate(getContext(), R.layout.checkbox_do_not_show_again, null);
|
||||||
|
CheckBox checkDoNotShowAgain = view.findViewById(R.id.checkbox_do_not_show_again);
|
||||||
|
builder.setView(view);
|
||||||
|
|
||||||
|
builder.setPositiveButton(R.string.lock_queue, (dialog, which) -> {
|
||||||
|
prefs.edit().putBoolean(PREF_SHOW_LOCK_WARNING, !checkDoNotShowAgain.isChecked()).apply();
|
||||||
|
setQueueLocked(true);
|
||||||
|
});
|
||||||
|
builder.setNegativeButton(R.string.cancel_label, null);
|
||||||
|
builder.show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void setQueueLocked(boolean locked) {
|
||||||
|
UserPreferences.setQueueLocked(locked);
|
||||||
|
getActivity().supportInvalidateOptionsMenu();
|
||||||
|
if (recyclerAdapter != null) {
|
||||||
|
recyclerAdapter.setLocked(locked);
|
||||||
|
}
|
||||||
|
if (locked) {
|
||||||
|
Snackbar.make(getActivity().findViewById(R.id.content), R.string
|
||||||
|
.queue_locked, Snackbar.LENGTH_SHORT).show();
|
||||||
|
} else {
|
||||||
|
Snackbar.make(getActivity().findViewById(R.id.content), R.string
|
||||||
|
.queue_unlocked, Snackbar.LENGTH_SHORT).show();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This method is called if the user clicks on a sort order menu item.
|
* This method is called if the user clicks on a sort order menu item.
|
||||||
*
|
*
|
||||||
|
|
|
@ -62,5 +62,8 @@ public class PreferenceUpgrader {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (oldVersion < 1070400) {
|
||||||
|
UserPreferences.setQueueLocked(false);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1,17 @@
|
||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:orientation="vertical"
|
||||||
|
android:paddingLeft="16dp"
|
||||||
|
android:paddingRight="16dp"
|
||||||
|
android:paddingTop="8dp"
|
||||||
|
android:paddingBottom="8dp">
|
||||||
|
|
||||||
|
<CheckBox
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:id="@+id/checkbox_do_not_show_again"
|
||||||
|
android:text="@string/checkbox_do_not_show_again"/>
|
||||||
|
|
||||||
|
</LinearLayout>
|
|
@ -275,6 +275,8 @@
|
||||||
<string name="unlock_queue">Unlock Queue</string>
|
<string name="unlock_queue">Unlock Queue</string>
|
||||||
<string name="queue_locked">Queue locked</string>
|
<string name="queue_locked">Queue locked</string>
|
||||||
<string name="queue_unlocked">Queue unlocked</string>
|
<string name="queue_unlocked">Queue unlocked</string>
|
||||||
|
<string name="queue_lock_warning">If you lock the queue, you can no longer swipe or reorder episodes.</string>
|
||||||
|
<string name="checkbox_do_not_show_again">Do not show again</string>
|
||||||
<string name="clear_queue_label">Clear Queue</string>
|
<string name="clear_queue_label">Clear Queue</string>
|
||||||
<string name="undo">Undo</string>
|
<string name="undo">Undo</string>
|
||||||
<string name="move_to_top_label">Move to top</string>
|
<string name="move_to_top_label">Move to top</string>
|
||||||
|
|
Loading…
Reference in New Issue