X-Git-Url: https://git.ktnx.net/?p=mobile-ledger.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fui%2Faccount_summary%2FAccountSummaryViewModel.java;h=2234d3cd946c7cf3fbb158d20404086e927b7219;hp=dd7f0327634ef90d2ebbd01fe6453bad71b9c80c;hb=9e8a289a85a65d372b47ccd2c2261299972ae4dd;hpb=b4175624de863c7343de10db2436722e78e51cb1 diff --git a/app/src/main/java/net/ktnx/mobileledger/ui/account_summary/AccountSummaryViewModel.java b/app/src/main/java/net/ktnx/mobileledger/ui/account_summary/AccountSummaryViewModel.java index dd7f0327..2234d3cd 100644 --- a/app/src/main/java/net/ktnx/mobileledger/ui/account_summary/AccountSummaryViewModel.java +++ b/app/src/main/java/net/ktnx/mobileledger/ui/account_summary/AccountSummaryViewModel.java @@ -19,20 +19,8 @@ package net.ktnx.mobileledger.ui.account_summary; import android.arch.lifecycle.ViewModel; import android.content.Context; -import android.content.res.Resources; -import android.graphics.Typeface; -import android.os.Build; -import android.support.annotation.NonNull; -import android.support.v7.widget.RecyclerView; import android.util.Log; -import android.view.LayoutInflater; -import android.view.View; -import android.view.ViewGroup; -import android.widget.CheckBox; -import android.widget.LinearLayout; -import android.widget.TextView; -import net.ktnx.mobileledger.R; import net.ktnx.mobileledger.async.CommitAccountsTask; import net.ktnx.mobileledger.async.CommitAccountsTaskParams; import net.ktnx.mobileledger.async.UpdateAccountsTask; @@ -48,6 +36,8 @@ class AccountSummaryViewModel extends ViewModel { new CommitAccountsTaskParams(Data.accounts.get(), Data.optShowOnlyStarred.get())); } void scheduleAccountListReload() { + if (Data.profile.get() == null) return; + UAT task = new UAT(); task.execute(); @@ -76,106 +66,3 @@ class AccountSummaryViewModel extends ViewModel { } } -class AccountSummaryAdapter extends RecyclerView.Adapter { - private boolean selectionActive; - - AccountSummaryAdapter() { - this.selectionActive = false; - } - - public void onBindViewHolder(@NonNull LedgerRowHolder holder, int position) { - LedgerAccount acc = Data.accounts.get().get(position); - Context ctx = holder.row.getContext(); - Resources rm = ctx.getResources(); - - holder.tvAccountName.setText(acc.getShortName()); - holder.tvAccountName.setPadding( - acc.getLevel() * rm.getDimensionPixelSize(R.dimen.activity_horizontal_margin) / 2, - 0, 0, 0); - holder.tvAccountAmounts.setText(acc.getAmountsString()); - - if (acc.isHidden()) { - holder.tvAccountName.setTypeface(null, Typeface.ITALIC); - holder.tvAccountAmounts.setTypeface(null, Typeface.ITALIC); - } - else { - holder.tvAccountName.setTypeface(null, Typeface.NORMAL); - holder.tvAccountAmounts.setTypeface(null, Typeface.NORMAL); - } - - if (position % 2 == 0) { - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) holder.row - .setBackgroundColor(rm.getColor(R.color.table_row_even_bg, ctx.getTheme())); - else holder.row.setBackgroundColor(rm.getColor(R.color.table_row_even_bg)); - } - else { - if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.M) holder.row - .setBackgroundColor(rm.getColor(R.color.drawer_background, ctx.getTheme())); - else holder.row.setBackgroundColor(rm.getColor(R.color.drawer_background)); - } - - holder.selectionCb.setVisibility(selectionActive ? View.VISIBLE : View.GONE); - holder.selectionCb.setChecked(!acc.isHiddenToBe()); - - holder.row.setTag(R.id.POS, position); - } - - @NonNull - @Override - public LedgerRowHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) { - View row = LayoutInflater.from(parent.getContext()) - .inflate(R.layout.account_summary_row, parent, false); - return new LedgerRowHolder(row); - } - - @Override - public int getItemCount() { - return Data.accounts.get().size(); - } - public void startSelection() { - for (LedgerAccount acc : Data.accounts.get()) acc.setHiddenToBe(acc.isHidden()); - this.selectionActive = true; - notifyDataSetChanged(); - } - - public void stopSelection() { - this.selectionActive = false; - notifyDataSetChanged(); - } - - public boolean isSelectionActive() { - return selectionActive; - } - - public void selectItem(int position) { - LedgerAccount acc = Data.accounts.get().get(position); - acc.toggleHiddenToBe(); - toggleChildrenOf(acc, acc.isHiddenToBe(), position); - notifyItemChanged(position); - } - void toggleChildrenOf(LedgerAccount parent, boolean hiddenToBe, int parentPosition) { - int i = parentPosition + 1; - for (LedgerAccount acc : Data.accounts.get()) { - String acc_parent = acc.getParentName(); - if ((acc_parent != null) && acc.getParentName().equals(parent.getName())) { - acc.setHiddenToBe(hiddenToBe); - notifyItemChanged(i); - toggleChildrenOf(acc, hiddenToBe, i); - i++; - } - } - } - - class LedgerRowHolder extends RecyclerView.ViewHolder { - CheckBox selectionCb; - TextView tvAccountName, tvAccountAmounts; - LinearLayout row; - public LedgerRowHolder(@NonNull View itemView) { - super(itemView); - this.row = (LinearLayout) itemView; - this.tvAccountName = itemView.findViewById(R.id.account_row_acc_name); - this.tvAccountAmounts = itemView.findViewById(R.id.account_row_acc_amounts); - this.selectionCb = itemView.findViewById(R.id.account_row_check); - } - } -} \ No newline at end of file