Improved day header handling

pull/147/head
M66B 6 years ago
parent 25ff074a86
commit 8492bc0b94

@ -440,10 +440,6 @@ public class AdapterMessage extends RecyclerView.Adapter<AdapterMessage.ViewHold
tvSubject.setTextSize(TypedValue.COMPLEX_UNIT_PX, textSize); tvSubject.setTextSize(TypedValue.COMPLEX_UNIT_PX, textSize);
} }
TupleMessageEx prev = null;
if (position > 0)
prev = differ.getItem(position - 1);
message.day = getDay(prev, message);
if (message.day) { if (message.day) {
Calendar cal = Calendar.getInstance(); Calendar cal = Calendar.getInstance();
cal.setTime(new Date()); cal.setTime(new Date());
@ -2229,33 +2225,30 @@ public class AdapterMessage extends RecyclerView.Adapter<AdapterMessage.ViewHold
this.hasWebView = Helper.hasWebView(context); this.hasWebView = Helper.hasWebView(context);
} }
void submitList(PagedList<TupleMessageEx> pagedList) { void submitList(PagedList<TupleMessageEx> list) {
if (date && "time".equals(sort)) {
TupleMessageEx prev = null; TupleMessageEx prev = null;
for (TupleMessageEx message : pagedList) { for (int i = 0; i < list.size(); i++) {
TupleMessageEx message = list.get(i);
if (message != null) if (message != null)
message.day = getDay(prev, message); if (i == 0)
prev = message; message.day = true;
} else if (prev != null) {
differ.submitList(pagedList);
}
boolean getDay(TupleMessageEx prev, TupleMessageEx cur) {
if (!(date && "time".equals(sort)))
return false;
if (prev == null)
return true;
Calendar cal0 = Calendar.getInstance(); Calendar cal0 = Calendar.getInstance();
Calendar cal1 = Calendar.getInstance(); Calendar cal1 = Calendar.getInstance();
cal0.setTimeInMillis(prev.received); cal0.setTimeInMillis(prev.received);
cal1.setTimeInMillis(cur.received); cal1.setTimeInMillis(message.received);
int year0 = cal0.get(Calendar.YEAR); int year0 = cal0.get(Calendar.YEAR);
int year1 = cal1.get(Calendar.YEAR); int year1 = cal1.get(Calendar.YEAR);
int day0 = cal0.get(Calendar.DAY_OF_YEAR); int day0 = cal0.get(Calendar.DAY_OF_YEAR);
int day1 = cal1.get(Calendar.DAY_OF_YEAR); int day1 = cal1.get(Calendar.DAY_OF_YEAR);
return (year0 != year1 || day0 != day1); message.day = (year0 != year1 || day0 != day1);
}
prev = message;
}
}
differ.submitList(list);
} }
PagedList<TupleMessageEx> getCurrentList() { PagedList<TupleMessageEx> getCurrentList() {

@ -137,7 +137,7 @@ public class EntityMessage implements Serializable {
public Long last_attempt; // send public Long last_attempt; // send
@Ignore @Ignore
public boolean day = false; boolean day = false;
static String generateMessageId() { static String generateMessageId() {
StringBuilder sb = new StringBuilder(); StringBuilder sb = new StringBuilder();

Loading…
Cancel
Save