X-Git-Url: https://git.ktnx.net/?p=mobile-ledger.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fui%2Ftransaction_list%2FTransactionListAdapter.java;h=f4a0bcbb11dd22682fc91206dde12d88a3791541;hp=0e79b7ae24223cb9d5669043f133d11688516a43;hb=6f8d7eb0ab9e5754047ac5bda47868860b5f71e2;hpb=d6a89986ed3ce01632c2b3313f55c60a8f0a5cc0 diff --git a/app/src/main/java/net/ktnx/mobileledger/ui/transaction_list/TransactionListAdapter.java b/app/src/main/java/net/ktnx/mobileledger/ui/transaction_list/TransactionListAdapter.java index 0e79b7ae..f4a0bcbb 100644 --- a/app/src/main/java/net/ktnx/mobileledger/ui/transaction_list/TransactionListAdapter.java +++ b/app/src/main/java/net/ktnx/mobileledger/ui/transaction_list/TransactionListAdapter.java @@ -24,6 +24,9 @@ import android.os.AsyncTask; import android.support.annotation.NonNull; import android.support.v7.widget.AppCompatTextView; import android.support.v7.widget.RecyclerView; +import android.text.Spannable; +import android.text.SpannableString; +import android.text.style.StyleSpan; import android.view.Gravity; import android.view.LayoutInflater; import android.view.View; @@ -48,49 +51,59 @@ public class TransactionListAdapter extends RecyclerView.Adapter 0) - previousItem = TransactionListViewModel.getTransactionListItem(position - 1); - -// Log.d("transactions", String.format("Filling position %d with %d accounts", position, -// tr.getAccounts().size())); - - TransactionLoader loader = new TransactionLoader(); - loader.execute( - new TransactionLoaderParams(tr, previous, holder, position, boldAccountName)); - - // WORKAROUND what seems to be a bug in CardHolder somewhere - // when a view that was previously holding a delimiter is re-purposed - // occasionally it stays too short (not high enough) - holder.vTransaction.measure(View.MeasureSpec - .makeMeasureSpec(holder.itemView.getWidth(), View.MeasureSpec.EXACTLY), - View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED)); - } - else { - Date date = item.getDate(); - holder.vTransaction.setVisibility(View.GONE); - holder.vDelimiter.setVisibility(View.VISIBLE); - holder.tvDelimiterDate.setText(DateFormat.getDateInstance().format(date)); - if (item.isMonthShown()) { - holder.tvDelimiterMonth.setText(Globals.monthNames[date.getMonth()]); - holder.tvDelimiterMonth.setVisibility(View.VISIBLE); - holder.vDelimiterLine.setBackgroundResource(R.drawable.dashed_border_8dp); - } - else { - holder.tvDelimiterMonth.setVisibility(View.GONE); - holder.vDelimiterLine.setBackgroundResource(R.drawable.dashed_border_1dp); - } + // in a race when transaction value is reduced, but the model hasn't been notified yet + // the view will disappear when the notifications reaches the model, so by simply omitting + // the out-of-range get() call nothing bad happens - just a to-be-deleted view remains + // a bit longer + if (item == null) return; + + switch (item.getType()) { + case TRANSACTION: + holder.vTransaction.setVisibility(View.VISIBLE); + holder.vDelimiter.setVisibility(View.GONE); + holder.vTrailer.setVisibility(View.GONE); + LedgerTransaction tr = item.getTransaction(); + + // Log.d("transactions", String.format("Filling position %d with %d accounts", position, + // tr.getAccounts().size())); + + TransactionLoader loader = new TransactionLoader(); + loader.execute(new TransactionLoaderParams(tr, holder, position, boldAccountName, + item.isOdd())); + + // WORKAROUND what seems to be a bug in CardHolder somewhere + // when a view that was previously holding a delimiter is re-purposed + // occasionally it stays too short (not high enough) + holder.vTransaction.measure(View.MeasureSpec + .makeMeasureSpec(holder.itemView.getWidth(), View.MeasureSpec.EXACTLY), + View.MeasureSpec.makeMeasureSpec(0, View.MeasureSpec.UNSPECIFIED)); + break; + case DELIMITER: + Date date = item.getDate(); + holder.vTransaction.setVisibility(View.GONE); + holder.vTrailer.setVisibility(View.GONE); + holder.vDelimiter.setVisibility(View.VISIBLE); + holder.tvDelimiterDate.setText(DateFormat.getDateInstance().format(date)); + if (item.isMonthShown()) { + holder.tvDelimiterMonth.setText(Globals.monthNames[date.getMonth()]); + holder.tvDelimiterMonth.setVisibility(View.VISIBLE); + // holder.vDelimiterLine.setBackgroundResource(R.drawable.dashed_border_8dp); + holder.vDelimiterLine.setVisibility(View.GONE); + holder.vDelimiterThick.setVisibility(View.VISIBLE); + } + else { + holder.tvDelimiterMonth.setVisibility(View.GONE); + // holder.vDelimiterLine.setBackgroundResource(R.drawable.dashed_border_1dp); + holder.vDelimiterLine.setVisibility(View.VISIBLE); + holder.vDelimiterThick.setVisibility(View.GONE); + } + break; + case TRAILER: + holder.vTransaction.setVisibility(View.GONE); + holder.vTrailer.setVisibility(View.VISIBLE); + holder.vDelimiter.setVisibility(View.GONE); + + break; } } @@ -105,7 +118,7 @@ public class TransactionListAdapter extends RecyclerView.Adapter