Show primary folders hierarchical

pull/178/head
M66B 5 years ago
parent a3b64e796e
commit ec2b4ff009

@ -78,6 +78,7 @@ import static android.app.Activity.RESULT_OK;
public class AdapterFolder extends RecyclerView.Adapter<AdapterFolder.ViewHolder> { public class AdapterFolder extends RecyclerView.Adapter<AdapterFolder.ViewHolder> {
private Fragment parentFragment; private Fragment parentFragment;
private long account; private long account;
private boolean primary;
private boolean show_compact; private boolean show_compact;
private boolean show_hidden; private boolean show_hidden;
private boolean subscribed_only; private boolean subscribed_only;
@ -241,18 +242,18 @@ public class AdapterFolder extends RecyclerView.Adapter<AdapterFolder.ViewHolder
} }
ViewGroup.LayoutParams lp = vwLevel.getLayoutParams(); ViewGroup.LayoutParams lp = vwLevel.getLayoutParams();
lp.width = (account < 0 ? 1 : folder.indentation) * dp12; lp.width = (account < 0 && !primary ? 1 : folder.indentation) * dp12;
vwLevel.setLayoutParams(lp); vwLevel.setLayoutParams(lp);
ibExpander.setImageLevel(folder.collapsed ? 1 /* more */ : 0 /* less */); ibExpander.setImageLevel(folder.collapsed ? 1 /* more */ : 0 /* less */);
ibExpander.setContentDescription(context.getString(folder.collapsed ? R.string.title_accessibility_expand : R.string.title_accessibility_collapse)); ibExpander.setContentDescription(context.getString(folder.collapsed ? R.string.title_accessibility_expand : R.string.title_accessibility_collapse));
ibExpander.setVisibility(account < 0 || !folder.expander ibExpander.setVisibility((account < 0 && !primary) || !folder.expander
? View.GONE ? View.GONE
: folder.child_refs != null && folder.child_refs.size() > 0 : folder.child_refs != null && folder.child_refs.size() > 0
? View.VISIBLE : View.INVISIBLE); ? View.VISIBLE : View.INVISIBLE);
if (listener == null && folder.selectable) { if (listener == null && folder.selectable) {
ivUnified.setVisibility(account > 0 && folder.unified ? View.VISIBLE : View.GONE); ivUnified.setVisibility((account > 0 || primary) && folder.unified ? View.VISIBLE : View.GONE);
ivSubscribed.setVisibility(subscriptions && folder.subscribed != null && folder.subscribed ? View.VISIBLE : View.GONE); ivSubscribed.setVisibility(subscriptions && folder.subscribed != null && folder.subscribed ? View.VISIBLE : View.GONE);
ivRule.setVisibility(folder.rules > 0 ? View.VISIBLE : View.GONE); ivRule.setVisibility(folder.rules > 0 ? View.VISIBLE : View.GONE);
ivNotify.setVisibility(folder.notify ? View.VISIBLE : View.GONE); ivNotify.setVisibility(folder.notify ? View.VISIBLE : View.GONE);
@ -292,7 +293,7 @@ public class AdapterFolder extends RecyclerView.Adapter<AdapterFolder.ViewHolder
ivType.setVisibility(folder.selectable ? View.VISIBLE : View.GONE); ivType.setVisibility(folder.selectable ? View.VISIBLE : View.GONE);
if (listener == null && folder.selectable) { if (listener == null && folder.selectable) {
if (account < 0) if (account < 0 && !primary)
tvType.setText(folder.accountName); tvType.setText(folder.accountName);
else else
tvType.setText(Helper.localizeFolderType(context, folder.type)); tvType.setText(Helper.localizeFolderType(context, folder.type));
@ -720,13 +721,14 @@ public class AdapterFolder extends RecyclerView.Adapter<AdapterFolder.ViewHolder
} }
} }
AdapterFolder(Fragment parentFragment, long account, boolean show_compact, boolean show_hidden, IFolderSelectedListener listener) { AdapterFolder(Fragment parentFragment, long account, boolean primary, boolean show_compact, boolean show_hidden, IFolderSelectedListener listener) {
this(parentFragment.getContext(), parentFragment.getViewLifecycleOwner(), account, show_compact, show_hidden, listener); this(parentFragment.getContext(), parentFragment.getViewLifecycleOwner(), account, primary, show_compact, show_hidden, listener);
this.parentFragment = parentFragment; this.parentFragment = parentFragment;
} }
AdapterFolder(Context context, LifecycleOwner owner, long account, boolean show_compact, boolean show_hidden, IFolderSelectedListener listener) { AdapterFolder(Context context, LifecycleOwner owner, long account, boolean primary, boolean show_compact, boolean show_hidden, IFolderSelectedListener listener) {
this.account = account; this.account = account;
this.primary = primary;
this.show_compact = show_compact; this.show_compact = show_compact;
this.show_hidden = show_hidden; this.show_hidden = show_hidden;
this.listener = listener; this.listener = listener;
@ -794,7 +796,7 @@ public class AdapterFolder extends RecyclerView.Adapter<AdapterFolder.ViewHolder
all = folders; all = folders;
List<TupleFolderEx> hierarchical; List<TupleFolderEx> hierarchical;
if (account < 0) { if (account < 0 && !primary) {
if (folders.size() > 0) if (folders.size() > 0)
Collections.sort(folders, folders.get(0).getComparator(context)); Collections.sort(folders, folders.get(0).getComparator(context));
hierarchical = folders; hierarchical = folders;

@ -119,7 +119,7 @@ public class FragmentDialogFolder extends FragmentDialogBase {
rvFolder.setLayoutManager(llm); rvFolder.setLayoutManager(llm);
final AdapterFolder adapter = new AdapterFolder(context, getViewLifecycleOwner(), final AdapterFolder adapter = new AdapterFolder(context, getViewLifecycleOwner(),
account, false, false, new AdapterFolder.IFolderSelectedListener() { account, false, false, false, new AdapterFolder.IFolderSelectedListener() {
@Override @Override
public void onFolderSelected(TupleFolderEx folder) { public void onFolderSelected(TupleFolderEx folder) {
String name = folder.getDisplayName(context, folder.parent_ref); String name = folder.getDisplayName(context, folder.parent_ref);

@ -175,7 +175,7 @@ public class FragmentFolders extends FragmentBase {
rvFolder.addItemDecoration(itemDecorator); rvFolder.addItemDecoration(itemDecorator);
} }
adapter = new AdapterFolder(this, account, compact, show_hidden, null); adapter = new AdapterFolder(this, account, primary, compact, show_hidden, null);
rvFolder.setAdapter(adapter); rvFolder.setAdapter(adapter);
fabAdd.setOnClickListener(new View.OnClickListener() { fabAdd.setOnClickListener(new View.OnClickListener() {

Loading…
Cancel
Save