Add labels to message detail view
This commit is contained in:
		| @@ -38,11 +38,12 @@ android { | ||||
|  | ||||
| //ext.jabitVersion = '2.0.4' | ||||
| ext.jabitVersion = 'feature-extended-encoding-SNAPSHOT' | ||||
| ext.supportVersion = '25.2.0' | ||||
| dependencies { | ||||
|     compile fileTree(dir: 'libs', include: ['*.jar']) | ||||
|     compile 'com.android.support:appcompat-v7:25.3.0' | ||||
|     compile 'com.android.support:support-v4:25.3.0' | ||||
|     compile 'com.android.support:design:25.3.0' | ||||
|     compile "com.android.support:appcompat-v7:$supportVersion" | ||||
|     compile "com.android.support:support-v4:$supportVersion" | ||||
|     compile "com.android.support:design:$supportVersion" | ||||
|  | ||||
|     compile "ch.dissem.jabit:jabit-core:$jabitVersion" | ||||
|     compile "ch.dissem.jabit:jabit-networking:$jabitVersion" | ||||
| @@ -59,7 +60,8 @@ dependencies { | ||||
|     compile('com.mikepenz:aboutlibraries:5.9.4@aar') { | ||||
|         transitive = true | ||||
|     } | ||||
|     compile 'com.mikepenz:iconics:1.6.2@aar' | ||||
|     compile "com.mikepenz:iconics-core:2.8.2@aar" | ||||
|     compile 'com.mikepenz:google-material-typeface:3.0.1.0.original@aar' | ||||
|     compile 'com.mikepenz:community-material-typeface:1.8.36.1@aar' | ||||
|  | ||||
|     compile 'com.journeyapps:zxing-android-embedded:3.3.0@aar' | ||||
| @@ -71,6 +73,7 @@ dependencies { | ||||
|     } | ||||
|     compile 'com.github.angads25:filepicker:1.1.0' | ||||
|     compile 'com.android.support.constraint:constraint-layout:1.0.2' | ||||
|     compile 'org.solovyev.android.views:linear-layout-manager:0.5@aar' | ||||
|  | ||||
|     testCompile 'junit:junit:4.12' | ||||
|     testCompile 'org.mockito:mockito-core:2.7.19' | ||||
|   | ||||
| @@ -48,14 +48,10 @@ import com.mikepenz.materialdrawer.model.interfaces.IDrawerItem; | ||||
| import com.mikepenz.materialdrawer.model.interfaces.IProfile; | ||||
| import com.mikepenz.materialdrawer.model.interfaces.Nameable; | ||||
|  | ||||
| import org.slf4j.Logger; | ||||
| import org.slf4j.LoggerFactory; | ||||
|  | ||||
| import java.io.Serializable; | ||||
| import java.lang.ref.WeakReference; | ||||
| import java.util.ArrayList; | ||||
| import java.util.List; | ||||
| import java.util.Objects; | ||||
|  | ||||
| import ch.dissem.apps.abit.dialog.AddIdentityDialogFragment; | ||||
| import ch.dissem.apps.abit.dialog.FullNodeDialogActivity; | ||||
| @@ -65,6 +61,7 @@ import ch.dissem.apps.abit.repository.AndroidMessageRepository; | ||||
| import ch.dissem.apps.abit.service.BitmessageService; | ||||
| import ch.dissem.apps.abit.service.Singleton; | ||||
| import ch.dissem.apps.abit.synchronization.SyncAdapter; | ||||
| import ch.dissem.apps.abit.util.Labels; | ||||
| import ch.dissem.apps.abit.util.Preferences; | ||||
| import ch.dissem.bitmessage.BitmessageContext; | ||||
| import ch.dissem.bitmessage.entity.BitmessageAddress; | ||||
| @@ -100,7 +97,6 @@ public class MainActivity extends AppCompatActivity | ||||
|     public static final String EXTRA_REPLY_TO_MESSAGE = "ch.dissem.abit.ReplyToMessage"; | ||||
|     public static final String ACTION_SHOW_INBOX = "ch.dissem.abit.ShowInbox"; | ||||
|  | ||||
|     private static final Logger LOG = LoggerFactory.getLogger(MainActivity.class); | ||||
|     private static final int ADD_IDENTITY = 1; | ||||
|     private static final int MANAGE_IDENTITY = 2; | ||||
|  | ||||
| @@ -437,37 +433,9 @@ public class MainActivity extends AppCompatActivity | ||||
|     public void addLabelEntry(Label label) { | ||||
|         PrimaryDrawerItem item = new PrimaryDrawerItem() | ||||
|             .withName(label.toString()) | ||||
|             .withTag(label); | ||||
|         if (label.getType() == null) { | ||||
|             item.withIcon(CommunityMaterial.Icon.cmd_label) | ||||
|                 .withIconColor(label.getColor()); | ||||
|         } else { | ||||
|             switch (label.getType()) { | ||||
|                 case INBOX: | ||||
|                     item.withIcon(GoogleMaterial.Icon.gmd_inbox); | ||||
|                     break; | ||||
|                 case DRAFT: | ||||
|                     item.withIcon(CommunityMaterial.Icon.cmd_file); | ||||
|                     break; | ||||
|                 case OUTBOX: | ||||
|                     item.withIcon(CommunityMaterial.Icon.cmd_inbox_arrow_up); | ||||
|                     break; | ||||
|                 case SENT: | ||||
|                     item.withIcon(CommunityMaterial.Icon.cmd_send); | ||||
|                     break; | ||||
|                 case BROADCAST: | ||||
|                     item.withIcon(CommunityMaterial.Icon.cmd_rss); | ||||
|                     break; | ||||
|                 case UNREAD: | ||||
|                     item.withIcon(GoogleMaterial.Icon.gmd_markunread_mailbox); | ||||
|                     break; | ||||
|                 case TRASH: | ||||
|                     item.withIcon(GoogleMaterial.Icon.gmd_delete); | ||||
|                     break; | ||||
|                 default: | ||||
|                     item.withIcon(CommunityMaterial.Icon.cmd_label); | ||||
|             } | ||||
|         } | ||||
|             .withTag(label) | ||||
|             .withIcon(Labels.getIcon(label)) | ||||
|             .withIconColor(Labels.getColor(label)); | ||||
|         drawer.addItemAtPosition(item, drawer.getDrawerItems().size() - 3); | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -16,8 +16,11 @@ | ||||
|  | ||||
| package ch.dissem.apps.abit; | ||||
|  | ||||
| import android.content.Context; | ||||
| import android.os.Bundle; | ||||
| import android.support.v4.app.Fragment; | ||||
| import android.support.v7.widget.GridLayoutManager; | ||||
| import android.support.v7.widget.RecyclerView; | ||||
| import android.text.util.Linkify; | ||||
| import android.view.LayoutInflater; | ||||
| import android.view.Menu; | ||||
| @@ -29,14 +32,19 @@ import android.widget.ImageView; | ||||
| import android.widget.TextView; | ||||
|  | ||||
| import com.mikepenz.google_material_typeface_library.GoogleMaterial; | ||||
| import com.mikepenz.iconics.view.IconicsImageView; | ||||
|  | ||||
| import java.util.ArrayList; | ||||
| import java.util.Iterator; | ||||
| import java.util.List; | ||||
| import java.util.Set; | ||||
| import java.util.regex.Matcher; | ||||
|  | ||||
| import ch.dissem.apps.abit.listener.ActionBarListener; | ||||
| import ch.dissem.apps.abit.service.Singleton; | ||||
| import ch.dissem.apps.abit.util.Assets; | ||||
| import ch.dissem.apps.abit.util.Drawables; | ||||
| import ch.dissem.apps.abit.util.Labels; | ||||
| import ch.dissem.bitmessage.entity.BitmessageAddress; | ||||
| import ch.dissem.bitmessage.entity.Plaintext; | ||||
| import ch.dissem.bitmessage.entity.valueobject.Label; | ||||
| @@ -106,6 +114,11 @@ public class MessageDetailFragment extends Fragment { | ||||
|             } else if (item.getType() == Plaintext.Type.BROADCAST) { | ||||
|                 ((TextView) rootView.findViewById(R.id.recipient)).setText(R.string.broadcast); | ||||
|             } | ||||
|             RecyclerView labelView = (RecyclerView) rootView.findViewById(R.id.labels); | ||||
|             LabelAdapter labelAdapter = new LabelAdapter(getActivity(), item.getLabels()); | ||||
|             labelView.setAdapter(labelAdapter); | ||||
|             labelView.setLayoutManager(new GridLayoutManager(getActivity(), 2)); | ||||
|  | ||||
|             TextView messageBody = (TextView) rootView.findViewById(R.id.text); | ||||
|             messageBody.setText(item.getText()); | ||||
|  | ||||
| @@ -197,4 +210,65 @@ public class MessageDetailFragment extends Fragment { | ||||
|         } | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     private static class LabelAdapter extends | ||||
|         RecyclerView.Adapter<LabelAdapter.ViewHolder> { | ||||
|  | ||||
|         private final List<Label> labels; | ||||
|         private final Context ctx; | ||||
|  | ||||
|         private LabelAdapter(Context ctx, Set<Label> labels) { | ||||
|             this.labels = new ArrayList<>(labels); | ||||
|             this.ctx = ctx; | ||||
|         } | ||||
|  | ||||
|         @Override | ||||
|         public LabelAdapter.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) { | ||||
|             Context context = parent.getContext(); | ||||
|             LayoutInflater inflater = LayoutInflater.from(context); | ||||
|  | ||||
|             // Inflate the custom layout | ||||
|             View contactView = inflater.inflate(R.layout.item_label, parent, false); | ||||
|  | ||||
|             // Return a new holder instance | ||||
|             return new ViewHolder(contactView); | ||||
|         } | ||||
|  | ||||
|         // Involves populating data into the item through holder | ||||
|         @Override | ||||
|         public void onBindViewHolder(LabelAdapter.ViewHolder viewHolder, int position) { | ||||
|             // Get the data model based on position | ||||
|             Label label = labels.get(position); | ||||
|  | ||||
|             viewHolder.icon.setColor(Labels.getColor(label)); | ||||
|             viewHolder.icon.setIcon(Labels.getIcon(label)); | ||||
|             viewHolder.label.setText(Labels.getText(label, ctx)); | ||||
|         } | ||||
|  | ||||
|         // Returns the total count of items in the list | ||||
|         @Override | ||||
|         public int getItemCount() { | ||||
|             return labels.size(); | ||||
|         } | ||||
|  | ||||
|         // Provide a direct reference to each of the views within a data item | ||||
|         // Used to cache the views within the item layout for fast access | ||||
|         static class ViewHolder extends RecyclerView.ViewHolder { | ||||
|             // Your holder should contain a member variable | ||||
|             // for any view that will be set as you render a row | ||||
|             public IconicsImageView icon; | ||||
|             public TextView label; | ||||
|  | ||||
|             // We also create a constructor that accepts the entire item row | ||||
|             // and does the view lookups to find each subview | ||||
|             ViewHolder(View itemView) { | ||||
|                 // Stores the itemView in a public final member variable that can be used | ||||
|                 // to access the context from any ViewHolder instance. | ||||
|                 super(itemView); | ||||
|  | ||||
|                 icon = (IconicsImageView) itemView.findViewById(R.id.icon); | ||||
|                 label = (TextView) itemView.findViewById(R.id.label); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -33,7 +33,7 @@ import java.util.LinkedList; | ||||
| import java.util.List; | ||||
| import java.util.UUID; | ||||
|  | ||||
| import ch.dissem.apps.abit.R; | ||||
| import ch.dissem.apps.abit.util.Labels; | ||||
| import ch.dissem.apps.abit.util.UuidUtils; | ||||
| import ch.dissem.bitmessage.entity.Plaintext; | ||||
| import ch.dissem.bitmessage.entity.valueobject.InventoryVector; | ||||
| @@ -129,35 +129,9 @@ public class AndroidMessageRepository extends AbstractMessageRepository { | ||||
|     private Label getLabel(Cursor c) { | ||||
|         String typeName = c.getString(c.getColumnIndex(LBL_COLUMN_TYPE)); | ||||
|         Label.Type type = typeName == null ? null : Label.Type.valueOf(typeName); | ||||
|         String text; | ||||
|         if (type == null) { | ||||
|         String text = Labels.getText(type, null, context); | ||||
|         if (text == null) { | ||||
|             text = c.getString(c.getColumnIndex(LBL_COLUMN_LABEL)); | ||||
|         } else { | ||||
|             switch (type) { | ||||
|                 case INBOX: | ||||
|                     text = context.getString(R.string.inbox); | ||||
|                     break; | ||||
|                 case DRAFT: | ||||
|                     text = context.getString(R.string.draft); | ||||
|                     break; | ||||
|                 case OUTBOX: | ||||
|                     text = context.getString(R.string.outbox); | ||||
|                     break; | ||||
|                 case SENT: | ||||
|                     text = context.getString(R.string.sent); | ||||
|                     break; | ||||
|                 case UNREAD: | ||||
|                     text = context.getString(R.string.unread); | ||||
|                     break; | ||||
|                 case TRASH: | ||||
|                     text = context.getString(R.string.trash); | ||||
|                     break; | ||||
|                 case BROADCAST: | ||||
|                     text = context.getString(R.string.broadcasts); | ||||
|                     break; | ||||
|                 default: | ||||
|                     text = c.getString(c.getColumnIndex(LBL_COLUMN_LABEL)); | ||||
|             } | ||||
|         } | ||||
|         Label label = new Label( | ||||
|             text, | ||||
|   | ||||
							
								
								
									
										77
									
								
								app/src/main/java/ch/dissem/apps/abit/util/Labels.java
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								app/src/main/java/ch/dissem/apps/abit/util/Labels.java
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,77 @@ | ||||
| package ch.dissem.apps.abit.util; | ||||
|  | ||||
| import android.content.Context; | ||||
| import android.support.annotation.ColorInt; | ||||
|  | ||||
| import com.mikepenz.community_material_typeface_library.CommunityMaterial; | ||||
| import com.mikepenz.google_material_typeface_library.GoogleMaterial; | ||||
| import com.mikepenz.iconics.typeface.IIcon; | ||||
|  | ||||
| import ch.dissem.apps.abit.R; | ||||
| import ch.dissem.bitmessage.entity.valueobject.Label; | ||||
|  | ||||
| /** | ||||
|  * Helper class to help with translating the default labels, getting label colors and so on. | ||||
|  */ | ||||
| public class Labels { | ||||
|     public static String getText(Label label, Context ctx) { | ||||
|         return getText(label.getType(), label.toString(), ctx); | ||||
|     } | ||||
|  | ||||
|     public static String getText(Label.Type type, String alternative, Context ctx) { | ||||
|         if (type == null) { | ||||
|             return alternative; | ||||
|         } else { | ||||
|             switch (type) { | ||||
|                 case INBOX: | ||||
|                     return ctx.getString(R.string.inbox); | ||||
|                 case DRAFT: | ||||
|                     return ctx.getString(R.string.draft); | ||||
|                 case OUTBOX: | ||||
|                     return ctx.getString(R.string.outbox); | ||||
|                 case SENT: | ||||
|                     return ctx.getString(R.string.sent); | ||||
|                 case UNREAD: | ||||
|                     return ctx.getString(R.string.unread); | ||||
|                 case TRASH: | ||||
|                     return ctx.getString(R.string.trash); | ||||
|                 case BROADCAST: | ||||
|                     return ctx.getString(R.string.broadcasts); | ||||
|                 default: | ||||
|                     return alternative; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public static IIcon getIcon(Label label) { | ||||
|         if (label.getType() == null) { | ||||
|             return CommunityMaterial.Icon.cmd_label; | ||||
|         } | ||||
|         switch (label.getType()) { | ||||
|             case INBOX: | ||||
|                 return GoogleMaterial.Icon.gmd_inbox; | ||||
|             case DRAFT: | ||||
|                 return CommunityMaterial.Icon.cmd_file; | ||||
|             case OUTBOX: | ||||
|                 return CommunityMaterial.Icon.cmd_inbox_arrow_up; | ||||
|             case SENT: | ||||
|                 return CommunityMaterial.Icon.cmd_send; | ||||
|             case BROADCAST: | ||||
|                 return CommunityMaterial.Icon.cmd_rss; | ||||
|             case UNREAD: | ||||
|                 return GoogleMaterial.Icon.gmd_markunread_mailbox; | ||||
|             case TRASH: | ||||
|                 return GoogleMaterial.Icon.gmd_delete; | ||||
|             default: | ||||
|                 return CommunityMaterial.Icon.cmd_label; | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @ColorInt | ||||
|     public static int getColor(Label label) { | ||||
|         if (label.getType() == null) { | ||||
|             return label.getColor(); | ||||
|         } | ||||
|         return 0xFF000000; | ||||
|     } | ||||
| } | ||||
| @@ -9,6 +9,7 @@ | ||||
|         android:layout_height="wrap_content" | ||||
|         android:fitsSystemWindows="true" | ||||
|         android:focusableInTouchMode="true" | ||||
|         android:paddingBottom="64dp" | ||||
|         android:orientation="vertical"> | ||||
|  | ||||
|         <TextView | ||||
| @@ -32,10 +33,10 @@ | ||||
|             android:layout_height="60dp" | ||||
|             android:layout_alignParentEnd="true" | ||||
|             android:layout_alignParentTop="true" | ||||
|             android:tint="@color/colorAccent" | ||||
|             tools:src="@drawable/ic_notification_proof_of_work" | ||||
|             android:padding="16dp" | ||||
|             tools:ignore="ContentDescription"/> | ||||
|             android:tint="@color/colorAccent" | ||||
|             tools:ignore="ContentDescription" | ||||
|             tools:src="@drawable/ic_notification_proof_of_work" /> | ||||
|  | ||||
|         <View | ||||
|             android:id="@+id/divider" | ||||
| @@ -86,8 +87,16 @@ | ||||
|             android:layout_marginLeft="16dp" | ||||
|             android:layout_marginRight="16dp" | ||||
|             android:layout_marginTop="32dp" | ||||
|             android:paddingBottom="64dp" | ||||
|             android:paddingBottom="16dp" | ||||
|             android:text="New Text" | ||||
|             android:textIsSelectable="true" /> | ||||
|  | ||||
|         <android.support.v7.widget.RecyclerView | ||||
|             android:id="@+id/labels" | ||||
|             android:layout_width="fill_parent" | ||||
|             android:layout_height="wrap_content" | ||||
|             android:layout_below="@+id/text" | ||||
|             android:paddingEnd="16dp" | ||||
|             android:paddingStart="16dp" /> | ||||
|     </RelativeLayout> | ||||
| </ScrollView> | ||||
|   | ||||
							
								
								
									
										28
									
								
								app/src/main/res/layout/item_label.xml
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								app/src/main/res/layout/item_label.xml
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,28 @@ | ||||
| <?xml version="1.0" encoding="utf-8"?> | ||||
| <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" | ||||
|     xmlns:app="http://schemas.android.com/apk/res-auto" | ||||
|     xmlns:tools="http://schemas.android.com/tools" | ||||
|     android:layout_width="wrap_content" | ||||
|     android:layout_height="wrap_content" | ||||
|     android:gravity="center_vertical" | ||||
|     android:orientation="horizontal"> | ||||
|  | ||||
|     <com.mikepenz.iconics.view.IconicsImageView | ||||
|         android:id="@+id/icon" | ||||
|         android:layout_width="16dp" | ||||
|         android:layout_height="16dp" | ||||
|         android:layout_alignParentStart="true" | ||||
|         android:layout_alignParentTop="true" | ||||
|         app:iiv_color="@android:color/black" | ||||
|         app:iiv_icon="cmd-label" /> | ||||
|  | ||||
|     <TextView | ||||
|         android:id="@+id/label" | ||||
|         android:layout_width="wrap_content" | ||||
|         android:layout_height="wrap_content" | ||||
|         android:paddingStart="8dp" | ||||
|         android:paddingEnd="24dp" | ||||
|         tools:text="Label" | ||||
|         android:layout_alignParentTop="true" | ||||
|         android:layout_toEndOf="@+id/icon" /> | ||||
| </RelativeLayout> | ||||
		Reference in New Issue
	
	Block a user