Change Available Forums into Forum Invitations

This commit is contained in:
Torsten Grote
2016-07-07 14:47:20 -03:00
parent c577efacbe
commit 6301b2a9a2
12 changed files with 106 additions and 91 deletions

View File

@@ -99,8 +99,8 @@
</activity> </activity>
<activity <activity
android:name=".android.forum.AvailableForumsActivity" android:name=".android.forum.ForumInvitationsActivity"
android:label="@string/available_forums_title" android:label="@string/forum_invitations_title"
android:parentActivityName=".android.NavDrawerActivity"> android:parentActivityName=".android.NavDrawerActivity">
<meta-data <meta-data
android:name="android.support.PARENT_ACTIVITY" android:name="android.support.PARENT_ACTIVITY"

View File

@@ -6,8 +6,8 @@
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginLeft="@dimen/listitem_horizontal_margin" android:layout_marginLeft="@dimen/listitem_horizontal_margin"
android:layout_marginStart="@dimen/listitem_horizontal_margin" android:layout_marginStart="@dimen/listitem_horizontal_margin"
android:paddingTop="@dimen/listitem_horizontal_margin" android:background="?attr/selectableItemBackground"
android:background="?attr/selectableItemBackground"> android:paddingTop="@dimen/listitem_horizontal_margin">
<org.briarproject.android.util.TextAvatarView <org.briarproject.android.util.TextAvatarView
android:id="@+id/avatarView" android:id="@+id/avatarView"
@@ -22,10 +22,12 @@
android:id="@+id/forumNameView" android:id="@+id/forumNameView"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_marginEnd="@dimen/listitem_horizontal_margin"
android:layout_marginRight="@dimen/listitem_horizontal_margin"
android:layout_toEndOf="@+id/avatarView" android:layout_toEndOf="@+id/avatarView"
android:layout_toRightOf="@+id/avatarView" android:layout_toRightOf="@+id/avatarView"
android:maxLines="2" android:maxLines="2"
android:textColor="@android:color/primary_text_light" android:textColor="@color/briar_primary"
android:textSize="@dimen/text_size_medium" android:textSize="@dimen/text_size_medium"
tools:text="This is a name of a forum that is available"/> tools:text="This is a name of a forum that is available"/>
@@ -34,38 +36,55 @@
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:layout_below="@+id/forumNameView" android:layout_below="@+id/forumNameView"
android:layout_marginBottom="-8dp" android:layout_marginEnd="@dimen/listitem_horizontal_margin"
android:layout_marginRight="@dimen/listitem_horizontal_margin"
android:layout_toEndOf="@+id/avatarView" android:layout_toEndOf="@+id/avatarView"
android:layout_toRightOf="@+id/avatarView" android:layout_toRightOf="@+id/avatarView"
android:paddingTop="@dimen/margin_medium" android:paddingTop="@dimen/margin_medium"
android:textColor="@android:color/secondary_text_light" android:textColor="@color/briar_text_secondary"
android:textSize="@dimen/text_size_small" android:textSize="@dimen/text_size_small"
tools:text="Shared by Megalox"/> tools:text="Shared by Megalox"/>
<TextView
android:id="@+id/forumSubscribedView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/sharedByView"
android:layout_marginEnd="@dimen/listitem_horizontal_margin"
android:layout_marginRight="@dimen/listitem_horizontal_margin"
android:paddingTop="@dimen/margin_medium"
android:text="@string/forum_invitation_exists"
android:textColor="@color/briar_text_tertiary"
android:textSize="@dimen/text_size_small"
tools:visibility="visible"/>
<Button <Button
android:id="@+id/acceptButton" android:id="@+id/acceptButton"
style="@style/BriarButtonFlat.Positive" style="@style/BriarButtonFlat.Positive"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:text="@string/dialog_button_accept" android:layout_alignParentEnd="true"
android:layout_below="@+id/sharedByView"
android:layout_alignParentRight="true" android:layout_alignParentRight="true"
android:layout_alignParentEnd="true"/> android:layout_below="@+id/forumSubscribedView"
android:layout_marginTop="-8dp"
android:text="@string/dialog_button_accept"/>
<Button <Button
android:id="@+id/declineButton" android:id="@+id/declineButton"
style="@style/BriarButtonFlat.Negative" style="@style/BriarButtonFlat.Negative"
android:layout_width="wrap_content" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:layout_height="wrap_content"
android:text="@string/dialog_button_decline" android:layout_below="@+id/forumSubscribedView"
android:layout_below="@+id/sharedByView" android:layout_marginTop="-8dp"
android:layout_toLeftOf="@+id/acceptButton" android:layout_toLeftOf="@+id/acceptButton"
android:layout_toStartOf="@+id/acceptButton"/> android:layout_toStartOf="@+id/acceptButton"
android:text="@string/dialog_button_decline"/>
<View style="@style/Divider.ForumList" <View
android:layout_below="@+id/acceptButton" style="@style/Divider.ForumList"
android:layout_alignParentLeft="true" android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"/> android:layout_alignParentStart="true"
android:layout_below="@+id/acceptButton"/>
</RelativeLayout> </RelativeLayout>

View File

@@ -51,7 +51,7 @@
android:layout_alignEnd="@+id/introductionText" android:layout_alignEnd="@+id/introductionText"
android:layout_alignRight="@+id/introductionText" android:layout_alignRight="@+id/introductionText"
android:layout_below="@+id/introductionText" android:layout_below="@+id/introductionText"
android:text="@string/forum_show_available"/> android:text="@string/forum_show_invitations"/>
</RelativeLayout> </RelativeLayout>

View File

@@ -99,7 +99,7 @@
<string name="forum_share_message">Você pode escrever um convite que será enviado aos contatos selecionados.</string> <string name="forum_share_message">Você pode escrever um convite que será enviado aos contatos selecionados.</string>
<string name="forum_invitation_received">%1$s compartilhou o fórum \"%2$s\" com você.</string> <string name="forum_invitation_received">%1$s compartilhou o fórum \"%2$s\" com você.</string>
<string name="forum_invitation_sent">Você compartilhou o fórum \"%1$s\" com %2$s.</string> <string name="forum_invitation_sent">Você compartilhou o fórum \"%1$s\" com %2$s.</string>
<string name="forum_show_available">Mostrar fóruns disponíveis</string> <string name="forum_show_invitations">Mostrar fóruns disponíveis</string>
<string name="forum_compose_post">Nova postagem em fórum</string> <string name="forum_compose_post">Nova postagem em fórum</string>
<string name="from">De:</string> <string name="from">De:</string>
<string name="anonymous">Anônimo</string> <string name="anonymous">Anônimo</string>

View File

@@ -101,7 +101,7 @@
<string name="forum_share_message">You may compose an optional invitation message that will be sent to the selected contacts.</string> <string name="forum_share_message">You may compose an optional invitation message that will be sent to the selected contacts.</string>
<string name="forum_invitation_received">%1$s has shared the forum \"%2$s\" with you.</string> <string name="forum_invitation_received">%1$s has shared the forum \"%2$s\" with you.</string>
<string name="forum_invitation_sent">You have shared the forum \"%1$s\" with %2$s.</string> <string name="forum_invitation_sent">You have shared the forum \"%1$s\" with %2$s.</string>
<string name="forum_show_available">Show Available Forums</string> <string name="forum_show_invitations">Show Forum Invitations</string>
<string name="forum_compose_post">New Forum Post</string> <string name="forum_compose_post">New Forum Post</string>
<string name="from">From:</string> <string name="from">From:</string>
<string name="anonymous">Anonymous</string> <string name="anonymous">Anonymous</string>
@@ -110,7 +110,8 @@
<string name="create_identity_button">Create Identity</string> <string name="create_identity_button">Create Identity</string>
<string name="identity_created_toast">Identity created</string> <string name="identity_created_toast">Identity created</string>
<string name="forum_post_hint">Type forum post</string> <string name="forum_post_hint">Type forum post</string>
<string name="available_forums_title">Available Forums</string> <string name="forum_invitations_title">Forum Invitations</string>
<string name="forum_invitation_exists">You accepted an invitation for this forum earlier, but you can accept more to strengthen the communication network of this forum.</string>
<string name="forum_joined_toast">Joined Forum</string> <string name="forum_joined_toast">Joined Forum</string>
<string name="forum_declined_toast">Forum Invitation Declined</string> <string name="forum_declined_toast">Forum Invitation Declined</string>
<string name="shared_by_format">Shared by %s</string> <string name="shared_by_format">Shared by %s</string>

View File

@@ -5,7 +5,7 @@ import android.app.Activity;
import org.briarproject.android.blogs.MyBlogsFragment; import org.briarproject.android.blogs.MyBlogsFragment;
import org.briarproject.android.contact.ContactListFragment; import org.briarproject.android.contact.ContactListFragment;
import org.briarproject.android.contact.ConversationActivity; import org.briarproject.android.contact.ConversationActivity;
import org.briarproject.android.forum.AvailableForumsActivity; import org.briarproject.android.forum.ForumInvitationsActivity;
import org.briarproject.android.forum.ContactSelectorFragment; import org.briarproject.android.forum.ContactSelectorFragment;
import org.briarproject.android.forum.CreateForumActivity; import org.briarproject.android.forum.CreateForumActivity;
import org.briarproject.android.forum.ForumActivity; import org.briarproject.android.forum.ForumActivity;
@@ -54,7 +54,7 @@ public interface ActivityComponent {
void inject(CreateIdentityActivity activity); void inject(CreateIdentityActivity activity);
void inject(AvailableForumsActivity activity); void inject(ForumInvitationsActivity activity);
void inject(CreateForumActivity activity); void inject(CreateForumActivity activity);

View File

@@ -13,7 +13,7 @@ import android.widget.ImageView;
import android.widget.TextView; import android.widget.TextView;
import org.briarproject.R; import org.briarproject.R;
import org.briarproject.android.forum.AvailableForumsActivity; import org.briarproject.android.forum.ForumInvitationsActivity;
import org.briarproject.android.util.AndroidUtils; import org.briarproject.android.util.AndroidUtils;
import org.briarproject.api.clients.SessionId; import org.briarproject.api.clients.SessionId;
import org.briarproject.api.forum.ForumInvitationMessage; import org.briarproject.api.forum.ForumInvitationMessage;
@@ -322,7 +322,7 @@ class ConversationAdapter extends RecyclerView.Adapter {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
Intent intent = new Intent(ctx, Intent intent = new Intent(ctx,
AvailableForumsActivity.class); ForumInvitationsActivity.class);
ctx.startActivity(intent); ctx.startActivity(intent);
} }
}); });

View File

@@ -1,23 +0,0 @@
package org.briarproject.android.forum;
import org.briarproject.api.contact.Contact;
import org.briarproject.api.forum.Forum;
import java.util.Collection;
class AvailableForumsItem {
private final ForumContacts forumContacts;
AvailableForumsItem(ForumContacts forumContacts) {
this.forumContacts = forumContacts;
}
Forum getForum() {
return forumContacts.getForum();
}
Collection<Contact> getContacts() {
return forumContacts.getContacts();
}
}

View File

@@ -17,16 +17,19 @@ import org.briarproject.util.StringUtils;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
class AvailableForumsAdapter extends import static android.view.View.GONE;
RecyclerView.Adapter<AvailableForumsAdapter.AvailableForumViewHolder> { import static android.view.View.VISIBLE;
class ForumInvitationAdapter extends
RecyclerView.Adapter<ForumInvitationAdapter.AvailableForumViewHolder> {
private final Context ctx; private final Context ctx;
private final AvailableForumClickListener listener; private final AvailableForumClickListener listener;
private final SortedList<AvailableForumsItem> forums = private final SortedList<ForumInvitationItem> forums =
new SortedList<>(AvailableForumsItem.class, new SortedList<>(ForumInvitationItem.class,
new SortedListCallBacks()); new SortedListCallBacks());
AvailableForumsAdapter(Context ctx, AvailableForumClickListener listener) { ForumInvitationAdapter(Context ctx, AvailableForumClickListener listener) {
this.ctx = ctx; this.ctx = ctx;
this.listener = listener; this.listener = listener;
} }
@@ -42,7 +45,7 @@ class AvailableForumsAdapter extends
@Override @Override
public void onBindViewHolder(AvailableForumViewHolder ui, int position) { public void onBindViewHolder(AvailableForumViewHolder ui, int position) {
final AvailableForumsItem item = getItem(position); final ForumInvitationItem item = getItem(position);
ui.avatar.setText(item.getForum().getName().substring(0, 1)); ui.avatar.setText(item.getForum().getName().substring(0, 1));
ui.avatar.setBackgroundBytes(item.getForum().getId().getBytes()); ui.avatar.setBackgroundBytes(item.getForum().getId().getBytes());
@@ -54,6 +57,12 @@ class AvailableForumsAdapter extends
ui.sharedBy.setText(ctx.getString(R.string.shared_by_format, ui.sharedBy.setText(ctx.getString(R.string.shared_by_format,
StringUtils.join(names, ", "))); StringUtils.join(names, ", ")));
if (item.isSubscribed()) {
ui.subscribed.setVisibility(VISIBLE);
} else {
ui.subscribed.setVisibility(GONE);
}
ui.accept.setOnClickListener(new View.OnClickListener() { ui.accept.setOnClickListener(new View.OnClickListener() {
@Override @Override
public void onClick(View v) { public void onClick(View v) {
@@ -73,15 +82,15 @@ class AvailableForumsAdapter extends
return forums.size(); return forums.size();
} }
public AvailableForumsItem getItem(int position) { public ForumInvitationItem getItem(int position) {
return forums.get(position); return forums.get(position);
} }
public void add(AvailableForumsItem item) { public void add(ForumInvitationItem item) {
forums.add(item); forums.add(item);
} }
public void addAll(Collection<AvailableForumsItem> list) { public void addAll(Collection<ForumInvitationItem> list) {
forums.addAll(list); forums.addAll(list);
} }
@@ -89,32 +98,34 @@ class AvailableForumsAdapter extends
forums.clear(); forums.clear();
} }
protected static class AvailableForumViewHolder static class AvailableForumViewHolder
extends RecyclerView.ViewHolder { extends RecyclerView.ViewHolder {
private final TextAvatarView avatar; private final TextAvatarView avatar;
private final TextView name; private final TextView name;
private final TextView sharedBy; private final TextView sharedBy;
private final TextView subscribed;
private final Button accept; private final Button accept;
private final Button decline; private final Button decline;
public AvailableForumViewHolder(View v) { AvailableForumViewHolder(View v) {
super(v); super(v);
avatar = (TextAvatarView) v.findViewById(R.id.avatarView); avatar = (TextAvatarView) v.findViewById(R.id.avatarView);
name = (TextView) v.findViewById(R.id.forumNameView); name = (TextView) v.findViewById(R.id.forumNameView);
sharedBy = (TextView) v.findViewById(R.id.sharedByView); sharedBy = (TextView) v.findViewById(R.id.sharedByView);
subscribed = (TextView) v.findViewById(R.id.forumSubscribedView);
accept = (Button) v.findViewById(R.id.acceptButton); accept = (Button) v.findViewById(R.id.acceptButton);
decline = (Button) v.findViewById(R.id.declineButton); decline = (Button) v.findViewById(R.id.declineButton);
} }
} }
private class SortedListCallBacks private class SortedListCallBacks
extends SortedList.Callback<AvailableForumsItem> { extends SortedList.Callback<ForumInvitationItem> {
@Override @Override
public int compare(AvailableForumsItem o1, public int compare(ForumInvitationItem o1,
AvailableForumsItem o2) { ForumInvitationItem o2) {
return String.CASE_INSENSITIVE_ORDER return String.CASE_INSENSITIVE_ORDER
.compare(o1.getForum().getName(), .compare(o1.getForum().getName(),
o2.getForum().getName()); o2.getForum().getName());
@@ -141,21 +152,21 @@ class AvailableForumsAdapter extends
} }
@Override @Override
public boolean areContentsTheSame(AvailableForumsItem oldItem, public boolean areContentsTheSame(ForumInvitationItem oldItem,
AvailableForumsItem newItem) { ForumInvitationItem newItem) {
return oldItem.getForum().equals(newItem.getForum()) && return oldItem.getForum().equals(newItem.getForum()) &&
oldItem.getContacts().equals(newItem.getContacts()); oldItem.getContacts().equals(newItem.getContacts());
} }
@Override @Override
public boolean areItemsTheSame(AvailableForumsItem oldItem, public boolean areItemsTheSame(ForumInvitationItem oldItem,
AvailableForumsItem newItem) { ForumInvitationItem newItem) {
return oldItem.getForum().equals(newItem.getForum()); return oldItem.getForum().equals(newItem.getForum());
} }
} }
interface AvailableForumClickListener { interface AvailableForumClickListener {
void onItemClick(AvailableForumsItem item, boolean accept); void onItemClick(ForumInvitationItem item, boolean accept);
} }
} }

View File

@@ -5,13 +5,17 @@ import org.briarproject.api.forum.Forum;
import java.util.Collection; import java.util.Collection;
class ForumContacts { class ForumInvitationItem {
private final Forum forum; private final Forum forum;
private final boolean subscribed;
private final Collection<Contact> contacts; private final Collection<Contact> contacts;
ForumContacts(Forum forum, Collection<Contact> contacts) { ForumInvitationItem(Forum forum, boolean subscribed,
Collection<Contact> contacts) {
this.forum = forum; this.forum = forum;
this.subscribed = subscribed;
this.contacts = contacts; this.contacts = contacts;
} }
@@ -19,6 +23,10 @@ class ForumContacts {
return forum; return forum;
} }
public boolean isSubscribed() {
return subscribed;
}
Collection<Contact> getContacts() { Collection<Contact> getContacts() {
return contacts; return contacts;
} }

View File

@@ -24,7 +24,6 @@ import org.briarproject.api.forum.ForumSharingManager;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.List;
import java.util.logging.Logger; import java.util.logging.Logger;
import javax.inject.Inject; import javax.inject.Inject;
@@ -32,15 +31,15 @@ import javax.inject.Inject;
import static android.widget.Toast.LENGTH_SHORT; import static android.widget.Toast.LENGTH_SHORT;
import static java.util.logging.Level.INFO; import static java.util.logging.Level.INFO;
import static java.util.logging.Level.WARNING; import static java.util.logging.Level.WARNING;
import static org.briarproject.android.forum.AvailableForumsAdapter.AvailableForumClickListener; import static org.briarproject.android.forum.ForumInvitationAdapter.AvailableForumClickListener;
public class AvailableForumsActivity extends BriarActivity public class ForumInvitationsActivity extends BriarActivity
implements EventListener, AvailableForumClickListener { implements EventListener, AvailableForumClickListener {
private static final Logger LOG = private static final Logger LOG =
Logger.getLogger(AvailableForumsActivity.class.getName()); Logger.getLogger(ForumInvitationsActivity.class.getName());
private AvailableForumsAdapter adapter; private ForumInvitationAdapter adapter;
// Fields that are accessed from background threads must be volatile // Fields that are accessed from background threads must be volatile
@Inject @Inject
@@ -56,7 +55,7 @@ public class AvailableForumsActivity extends BriarActivity
setContentView(R.layout.activity_available_forums); setContentView(R.layout.activity_available_forums);
adapter = new AvailableForumsAdapter(this, this); adapter = new ForumInvitationAdapter(this, this);
BriarRecyclerView list = BriarRecyclerView list =
(BriarRecyclerView) findViewById(R.id.availableForumsView); (BriarRecyclerView) findViewById(R.id.availableForumsView);
list.setLayoutManager(new LinearLayoutManager(this)); list.setLayoutManager(new LinearLayoutManager(this));
@@ -80,21 +79,25 @@ public class AvailableForumsActivity extends BriarActivity
@Override @Override
public void run() { public void run() {
try { try {
Collection<ForumContacts> available = new ArrayList<>(); Collection<ForumInvitationItem> forums = new ArrayList<>();
long now = System.currentTimeMillis(); long now = System.currentTimeMillis();
for (Forum f : forumSharingManager.getInvited()) { for (Forum f : forumSharingManager.getInvited()) {
boolean subscribed;
try { try {
Collection<Contact> c = forumManager.getForum(f.getId());
forumSharingManager.getSharedBy(f.getId()); subscribed = true;
available.add(new ForumContacts(f, c));
} catch (NoSuchGroupException e) { } catch (NoSuchGroupException e) {
// Continue subscribed = false;
} }
Collection<Contact> c =
forumSharingManager.getSharedBy(f.getId());
forums.add(
new ForumInvitationItem(f, subscribed, c));
} }
long duration = System.currentTimeMillis() - now; long duration = System.currentTimeMillis() - now;
if (LOG.isLoggable(INFO)) if (LOG.isLoggable(INFO))
LOG.info("Load took " + duration + " ms"); LOG.info("Load took " + duration + " ms");
displayForums(available); displayForums(forums);
} catch (DbException e) { } catch (DbException e) {
if (LOG.isLoggable(WARNING)) if (LOG.isLoggable(WARNING))
LOG.log(WARNING, e.toString(), e); LOG.log(WARNING, e.toString(), e);
@@ -103,20 +106,16 @@ public class AvailableForumsActivity extends BriarActivity
}); });
} }
private void displayForums(final Collection<ForumContacts> available) { private void displayForums(final Collection<ForumInvitationItem> forums) {
runOnUiThread(new Runnable() { runOnUiThread(new Runnable() {
@Override @Override
public void run() { public void run() {
if (available.isEmpty()) { if (forums.isEmpty()) {
LOG.info("No forums available, finishing"); LOG.info("No forums available, finishing");
finish(); finish();
} else { } else {
adapter.clear(); adapter.clear();
List<AvailableForumsItem> list = adapter.addAll(forums);
new ArrayList<>(available.size());
for (ForumContacts f : available)
list.add(new AvailableForumsItem(f));
adapter.addAll(list);
} }
} }
}); });
@@ -152,7 +151,7 @@ public class AvailableForumsActivity extends BriarActivity
} }
@Override @Override
public void onItemClick(AvailableForumsItem item, boolean accept) { public void onItemClick(ForumInvitationItem item, boolean accept) {
respondToInvitation(item, accept); respondToInvitation(item, accept);
// show toast // show toast
@@ -161,7 +160,7 @@ public class AvailableForumsActivity extends BriarActivity
Toast.makeText(this, res, LENGTH_SHORT).show(); Toast.makeText(this, res, LENGTH_SHORT).show();
} }
private void respondToInvitation(final AvailableForumsItem item, private void respondToInvitation(final ForumInvitationItem item,
final boolean accept) { final boolean accept) {
runOnDbThread(new Runnable() { runOnDbThread(new Runnable() {
@Override @Override

View File

@@ -290,6 +290,6 @@ public class ForumListFragment extends BaseEventFragment implements
@Override @Override
public void onClick(View view) { public void onClick(View view) {
// snackbar click // snackbar click
startActivity(new Intent(getContext(), AvailableForumsActivity.class)); startActivity(new Intent(getContext(), ForumInvitationsActivity.class));
} }
} }