Added sync more to overflow menu

pull/194/head
M66B 5 years ago
parent f33e776501
commit 0f70d6009f

@ -33,17 +33,30 @@ import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.appcompat.app.AlertDialog;
import java.util.Arrays;
import java.util.List;
public class FragmentDialogSync extends FragmentDialogBase {
@NonNull
@Override
public Dialog onCreateDialog(@Nullable Bundle savedInstanceState) {
String name = getArguments().getString("name");
Bundle args = getArguments();
long fid = args.getLong("folder");
String name = args.getString("name");
String type = args.getString("type");
View view = LayoutInflater.from(getContext()).inflate(R.layout.dialog_sync, null);
final TextView tvFolder = view.findViewById(R.id.tvFolder);
final EditText etMonths = view.findViewById(R.id.etMonths);
tvFolder.setText(name);
if (fid < 0) {
if (TextUtils.isEmpty(type))
tvFolder.setText(R.string.title_folder_unified);
else
tvFolder.setText(EntityFolder.localizeType(getContext(), type));
} else
tvFolder.setText(name);
etMonths.setText(null);
return new AlertDialog.Builder(getContext())
@ -67,26 +80,35 @@ public class FragmentDialogSync extends FragmentDialogBase {
new SimpleTask<Void>() {
@Override
protected Void onExecute(Context context, Bundle args) {
int months = args.getInt("months", -1);
long fid = args.getLong("folder");
String type = args.getString("type");
int months = args.getInt("months", -1);
DB db = DB.getInstance(context);
try {
db.beginTransaction();
EntityFolder folder = db.folder().getFolder(fid);
if (folder == null || !folder.selectable)
return null;
if (months == 0) {
db.folder().setFolderInitialize(folder.id, Integer.MAX_VALUE);
db.folder().setFolderKeep(folder.id, Integer.MAX_VALUE);
} else if (months > 0) {
db.folder().setFolderInitialize(folder.id, months * 30);
db.folder().setFolderKeep(folder.id, Math.max(folder.keep_days, months * 30));
List<EntityFolder> folders;
if (fid < 0)
folders = db.folder().getFoldersUnified(type, false);
else {
EntityFolder folder = db.folder().getFolder(fid);
if (folder == null || !folder.selectable)
return null;
folders = Arrays.asList(folder);
}
EntityOperation.sync(context, folder.id, true);
for (EntityFolder folder : folders) {
if (months == 0) {
db.folder().setFolderInitialize(folder.id, Integer.MAX_VALUE);
db.folder().setFolderKeep(folder.id, Integer.MAX_VALUE);
} else if (months > 0) {
db.folder().setFolderInitialize(folder.id, months * 30);
db.folder().setFolderKeep(folder.id, Math.max(folder.keep_days, months * 30));
}
EntityOperation.sync(context, folder.id, true);
}
db.setTransactionSuccessful();
} finally {

@ -4149,6 +4149,7 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
menu.findItem(R.id.menu_select_found).setVisible(viewType == AdapterMessage.ViewType.SEARCH);
menu.findItem(R.id.menu_mark_all_read).setVisible(folder);
menu.findItem(R.id.menu_sync_more).setVisible(folder);
menu.findItem(R.id.menu_force_sync).setVisible(viewType == AdapterMessage.ViewType.UNIFIED);
menu.findItem(R.id.menu_force_send).setVisible(outbox);
@ -4250,6 +4251,9 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
} else if (itemId == R.id.menu_mark_all_read) {
onMenuMarkAllRead();
return true;
} else if (itemId == R.id.menu_sync_more) {
onMenuSyncMore();
return true;
} else if (itemId == R.id.menu_force_sync) {
onMenuForceSync();
return true;
@ -4512,6 +4516,40 @@ public class FragmentMessages extends FragmentBase implements SharedPreferences.
}.execute(FragmentMessages.this, args, "message:read");
}
private void onMenuSyncMore() {
Bundle args = new Bundle();
args.putLong("folder", folder);
args.putString("type", type);
new SimpleTask<Void>() {
@Override
protected Void onExecute(Context context, Bundle args) {
long fid = args.getLong("folder");
if (fid < 0)
return null;
DB db = DB.getInstance(context);
EntityFolder folder = db.folder().getFolder(fid);
if (folder != null)
args.putString("name", folder.getDisplayName(context));
return null;
}
@Override
protected void onExecuted(Bundle args, Void data) {
FragmentDialogSync sync = new FragmentDialogSync();
sync.setArguments(args);
sync.show(getParentFragmentManager(), "folder:months");
}
@Override
protected void onException(Bundle args, Throwable ex) {
Log.unexpectedError(getParentFragmentManager(), ex);
}
}.execute(this, args, "folder:months");
}
private void onMenuForceSync() {
ServiceSynchronize.reload(getContext(), null, true, "force sync");
ToastEx.makeText(getContext(), R.string.title_executing, Toast.LENGTH_LONG).show();

@ -138,6 +138,11 @@
android:title="@string/title_mark_all_read"
app:showAsAction="never" />
<item
android:id="@+id/menu_sync_more"
android:title="@string/title_synchronize_more"
app:showAsAction="never" />
<item
android:id="@+id/menu_force_sync"
android:title="@string/title_force_sync"

Loading…
Cancel
Save