mirror of
https://code.briarproject.org/briar/briar.git
synced 2026-02-15 04:18:53 +01:00
Merge branch '579-unsubscribe-from-shared-blogs' into 'master'
Allow unsubscribing from shared blogs Only personal blogs from non-contacts can be removed. This also adds integration tests that check the conditions under which blogs can actually be removed. Closes #579 See merge request !268
This commit is contained in:
@@ -14,4 +14,10 @@
|
||||
android:title="@string/sharing_status"
|
||||
app:showAsAction="never"/>
|
||||
|
||||
<item
|
||||
android:id="@+id/action_blog_delete"
|
||||
android:icon="@drawable/action_delete_white"
|
||||
android:title="@string/blogs_remove_blog"
|
||||
app:showAsAction="never"/>
|
||||
|
||||
</menu>
|
||||
@@ -267,13 +267,12 @@ Ou o autor não não postou nada ainda, ou a pessoa que compartilhou esse Blog c
|
||||
<string name="blogs_feed_empty_state">Esse é o feed de blog global.
|
||||
Parece que ninguém postou nada, ainda.
|
||||
Seja o primeiro a postar e clique no ícone da caneta para escrever um novo Post pro Blog.</string>
|
||||
<string name="blogs_delete_blog">Deletar Blog</string>
|
||||
<string name="blogs_delete_blog_dialog_message">Você ter certeza que quer deletar esse Blog e todos seus Posts?
|
||||
Note que isso não irá deletar o Blog dos dispositivos de outras pessoas. </string>
|
||||
<string name="blogs_delete_blog_ok">Deletar Blog</string>
|
||||
<string name="blogs_delete_blog_cancel">Manter</string>
|
||||
<string name="blogs_blog_deleted">Blog Deletado</string>
|
||||
<string name="blogs_remove_blog">Remover Blog</string>
|
||||
<string name="blogs_remove_blog_dialog_message">Você ter certeza que quer deletar esse Blog e todos seus Posts?
|
||||
Note que isso não irá deletar o Blog dos dispositivos de outras pessoas. </string>
|
||||
<string name="blogs_remove_blog_ok">Deletar Blog</string>
|
||||
<string name="blogs_delete_blog_cancel">Manter</string>
|
||||
<string name="blogs_blog_removed">Blog Deletado</string>
|
||||
<string name="blogs_blog_list">Lista de blogs</string>
|
||||
<string name="blogs_available_blogs">Blogs Disponíveis </string>
|
||||
<string name="blogs_drafts">Rascunhos</string>
|
||||
|
||||
@@ -297,15 +297,13 @@
|
||||
<string name="blogs_blog_post_received">New Blog Post Received</string>
|
||||
<string name="blogs_blog_post_scroll_to">Scroll To</string>
|
||||
<string name="blogs_blog_failed_to_load">Blog failed to load</string>
|
||||
<string name="blogs_blog_post_failed_to_load">Blog Post failed to load</string>
|
||||
<string name="blogs_blog_post_failed_to_load">Blog post failed to load</string>
|
||||
<string name="blogs_feed_empty_state">This is the global blog feed.\n\nIt looks like nobody blogged anything, yet.\n\nBe the first and tap the pen icon to write a new blog post.</string>
|
||||
<string name="blogs_personal_blog">%s\'s Personal Blog</string>
|
||||
<string name="blogs_delete_blog">Delete Blog</string>
|
||||
<string name="blogs_delete_blog_dialog_message">Are you sure that you want to delete this Blog and all posts?\nNote that this will not delete the blog from other people\'s devices.</string>
|
||||
<string name="blogs_delete_blog_ok">Delete Blog</string>
|
||||
<string name="blogs_delete_blog_cancel">Keep</string>
|
||||
<string name="blogs_blog_deleted">Blog Deleted</string>
|
||||
<string name="blogs_remove_blog">Remove Blog</string>
|
||||
<string name="blogs_remove_blog_dialog_message">Are you sure that you want to remove this blog and all posts?\nNote that this will not remove the blog from other people\'s devices.</string>
|
||||
<string name="blogs_remove_blog_ok">Remove Blog</string>
|
||||
<string name="blogs_blog_removed">Blog Removed</string>
|
||||
<string name="blogs_sharing_share">Share Blog</string>
|
||||
<string name="blogs_sharing_error">There was an error sharing this blog.</string>
|
||||
<string name="blogs_sharing_button">Share Blog</string>
|
||||
|
||||
@@ -3,7 +3,9 @@ package org.briarproject.android.blogs;
|
||||
import android.support.annotation.Nullable;
|
||||
|
||||
import org.briarproject.android.controller.ActivityLifecycleController;
|
||||
import org.briarproject.android.controller.handler.ResultExceptionHandler;
|
||||
import org.briarproject.android.controller.handler.ResultHandler;
|
||||
import org.briarproject.api.db.DbException;
|
||||
import org.briarproject.api.sync.GroupId;
|
||||
import org.briarproject.api.sync.MessageId;
|
||||
|
||||
@@ -22,6 +24,9 @@ public interface BlogController extends ActivityLifecycleController {
|
||||
@Nullable
|
||||
MessageId getBlogPostId(int position);
|
||||
|
||||
void canDeleteBlog(GroupId groupId,
|
||||
ResultExceptionHandler<Boolean, DbException> resultHandler);
|
||||
|
||||
void deleteBlog(ResultHandler<Boolean> resultHandler);
|
||||
|
||||
interface BlogPostListener {
|
||||
|
||||
@@ -4,6 +4,7 @@ import android.app.Activity;
|
||||
import android.support.annotation.Nullable;
|
||||
|
||||
import org.briarproject.android.controller.DbControllerImpl;
|
||||
import org.briarproject.android.controller.handler.ResultExceptionHandler;
|
||||
import org.briarproject.android.controller.handler.ResultHandler;
|
||||
import org.briarproject.api.blogs.Blog;
|
||||
import org.briarproject.api.blogs.BlogManager;
|
||||
@@ -175,6 +176,27 @@ public class BlogControllerImpl extends DbControllerImpl
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void canDeleteBlog(final GroupId g,
|
||||
final ResultExceptionHandler<Boolean, DbException> resultHandler) {
|
||||
runOnDbThread(new Runnable() {
|
||||
@Override
|
||||
public void run() {
|
||||
if (groupId == null) {
|
||||
resultHandler.onResult(false);
|
||||
return;
|
||||
}
|
||||
try {
|
||||
resultHandler.onResult(blogManager.canBeRemoved(groupId));
|
||||
} catch (DbException e) {
|
||||
if (LOG.isLoggable(WARNING))
|
||||
LOG.log(WARNING, e.toString(), e);
|
||||
resultHandler.onException(e);
|
||||
}
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
@Override
|
||||
public void deleteBlog(final ResultHandler<Boolean> resultHandler) {
|
||||
runOnDbThread(new Runnable() {
|
||||
|
||||
@@ -21,11 +21,13 @@ import org.briarproject.R;
|
||||
import org.briarproject.android.ActivityComponent;
|
||||
import org.briarproject.android.blogs.BlogController.BlogPostListener;
|
||||
import org.briarproject.android.blogs.BlogPostAdapter.OnBlogPostClickListener;
|
||||
import org.briarproject.android.controller.handler.UiResultExceptionHandler;
|
||||
import org.briarproject.android.controller.handler.UiResultHandler;
|
||||
import org.briarproject.android.fragment.BaseFragment;
|
||||
import org.briarproject.android.sharing.ShareBlogActivity;
|
||||
import org.briarproject.android.sharing.SharingStatusBlogActivity;
|
||||
import org.briarproject.android.util.BriarRecyclerView;
|
||||
import org.briarproject.api.db.DbException;
|
||||
import org.briarproject.api.sync.GroupId;
|
||||
|
||||
import java.util.Collection;
|
||||
@@ -57,6 +59,7 @@ public class BlogFragment extends BaseFragment implements BlogPostListener {
|
||||
private boolean myBlog;
|
||||
private BlogPostAdapter adapter;
|
||||
private BriarRecyclerView list;
|
||||
private MenuItem deleteButton = null;
|
||||
|
||||
static BlogFragment newInstance(GroupId groupId, String name,
|
||||
boolean myBlog, boolean isNew) {
|
||||
@@ -124,6 +127,7 @@ public class BlogFragment extends BaseFragment implements BlogPostListener {
|
||||
public void onStart() {
|
||||
super.onStart();
|
||||
loadData(false);
|
||||
if (!myBlog) checkIfBlogCanBeDeleted();
|
||||
}
|
||||
|
||||
@Override
|
||||
@@ -144,6 +148,8 @@ public class BlogFragment extends BaseFragment implements BlogPostListener {
|
||||
inflater.inflate(R.menu.blogs_my_blog_actions, menu);
|
||||
} else {
|
||||
inflater.inflate(R.menu.blogs_blog_actions, menu);
|
||||
deleteButton = menu.findItem(R.id.action_blog_delete);
|
||||
deleteButton.setVisible(false);
|
||||
}
|
||||
super.onCreateOptionsMenu(menu, inflater);
|
||||
}
|
||||
@@ -179,6 +185,9 @@ public class BlogFragment extends BaseFragment implements BlogPostListener {
|
||||
i3.putExtra(GROUP_ID, groupId.getBytes());
|
||||
startActivity(i3, options.toBundle());
|
||||
return true;
|
||||
case R.id.action_blog_delete:
|
||||
showDeleteDialog();
|
||||
return true;
|
||||
default:
|
||||
return super.onOptionsItemSelected(item);
|
||||
}
|
||||
@@ -232,6 +241,28 @@ public class BlogFragment extends BaseFragment implements BlogPostListener {
|
||||
loadData(true);
|
||||
}
|
||||
|
||||
private void checkIfBlogCanBeDeleted() {
|
||||
blogController.canDeleteBlog(groupId,
|
||||
new UiResultExceptionHandler<Boolean, DbException>(
|
||||
getActivity()) {
|
||||
@Override
|
||||
public void onResultUi(Boolean canBeDeleted) {
|
||||
if (canBeDeleted) {
|
||||
showDeleteButton();
|
||||
}
|
||||
}
|
||||
@Override
|
||||
public void onExceptionUi(DbException exception) {
|
||||
// nothing to do here, delete button is already hidden
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
private void showDeleteButton() {
|
||||
if (deleteButton != null)
|
||||
deleteButton.setVisible(true);
|
||||
}
|
||||
|
||||
private void displaySnackbar(int stringId) {
|
||||
Snackbar snackbar =
|
||||
Snackbar.make(list, stringId, Snackbar.LENGTH_SHORT);
|
||||
@@ -249,11 +280,11 @@ public class BlogFragment extends BaseFragment implements BlogPostListener {
|
||||
};
|
||||
AlertDialog.Builder builder = new AlertDialog.Builder(getActivity(),
|
||||
R.style.BriarDialogTheme);
|
||||
builder.setTitle(getString(R.string.blogs_delete_blog));
|
||||
builder.setTitle(getString(R.string.blogs_remove_blog));
|
||||
builder.setMessage(
|
||||
getString(R.string.blogs_delete_blog_dialog_message));
|
||||
builder.setPositiveButton(R.string.blogs_delete_blog_cancel, null);
|
||||
builder.setNegativeButton(R.string.blogs_delete_blog_ok, okListener);
|
||||
getString(R.string.blogs_remove_blog_dialog_message));
|
||||
builder.setPositiveButton(R.string.cancel_button, null);
|
||||
builder.setNegativeButton(R.string.blogs_remove_blog_ok, okListener);
|
||||
builder.show();
|
||||
}
|
||||
|
||||
@@ -264,7 +295,7 @@ public class BlogFragment extends BaseFragment implements BlogPostListener {
|
||||
public void onResultUi(Boolean result) {
|
||||
if (!result) return;
|
||||
Toast.makeText(getActivity(),
|
||||
R.string.blogs_blog_deleted, LENGTH_SHORT)
|
||||
R.string.blogs_blog_removed, LENGTH_SHORT)
|
||||
.show();
|
||||
getActivity().supportFinishAfterTransition();
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user