1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
|
package it.niedermann.nextcloud.deck.ui.card.projectresources;
import android.content.Intent;
import android.content.res.Resources;
import androidx.annotation.NonNull;
import androidx.annotation.Nullable;
import androidx.lifecycle.LifecycleOwner;
import androidx.recyclerview.widget.RecyclerView;
import it.niedermann.nextcloud.deck.DeckLog;
import it.niedermann.nextcloud.deck.R;
import it.niedermann.nextcloud.deck.databinding.ItemProjectResourceBinding;
import it.niedermann.nextcloud.deck.model.Account;
import it.niedermann.nextcloud.deck.model.ocs.projects.OcsProjectResource;
import it.niedermann.nextcloud.deck.ui.card.EditActivity;
import it.niedermann.nextcloud.deck.ui.card.EditCardViewModel;
import it.niedermann.nextcloud.deck.util.ProjectUtil;
import static android.view.View.GONE;
import static android.view.View.VISIBLE;
import static it.niedermann.nextcloud.deck.util.ProjectUtil.getResourceUri;
public class CardProjectResourceViewHolder extends RecyclerView.ViewHolder {
@NonNull
private final ItemProjectResourceBinding binding;
public CardProjectResourceViewHolder(@NonNull ItemProjectResourceBinding binding) {
super(binding.getRoot());
this.binding = binding;
}
public void bind(@NonNull EditCardViewModel viewModel, @NonNull OcsProjectResource resource, @NonNull LifecycleOwner owner) {
final Account account = viewModel.getAccount();
final Resources resources = itemView.getResources();
binding.name.setText(resource.getName());
final @Nullable String link = resource.getLink();
binding.type.setVisibility(VISIBLE);
if (resource.getType() != null) {
switch (resource.getType()) {
case "deck": {
// TODO https://github.com/stefan-niedermann/nextcloud-deck/issues/671
linkifyViewHolder(account, link);
binding.type.setText(resources.getString(R.string.project_type_deck_board));
binding.image.setImageResource(R.drawable.project_deck_36dp);
break;
}
case "deck-card": {
try {
long[] ids = ProjectUtil.extractBoardIdAndCardIdFromUrl(link);
if (ids.length == 2) {
viewModel.getCardByRemoteID(account.getId(), ids[1]).observe(owner, (fullCard) -> {
if (fullCard != null) {
viewModel.getBoardByRemoteId(account.getId(), ids[0]).observe(owner, (board) -> {
if (board != null) {
binding.getRoot().setOnClickListener((v) -> itemView.getContext().startActivity(EditActivity.createEditCardIntent(itemView.getContext(), account, board.getLocalId(), fullCard.getLocalId())));
} else {
linkifyViewHolder(account, link);
}
});
} else {
linkifyViewHolder(account, link);
}
});
} else {
linkifyViewHolder(account, link);
}
} catch (IllegalArgumentException e) {
DeckLog.logError(e);
linkifyViewHolder(account, link);
}
binding.type.setText(resources.getString(R.string.project_type_deck_card));
binding.image.setImageResource(R.drawable.project_deck_36dp);
break;
}
case "file": {
binding.type.setText(resources.getString(R.string.project_type_file));
linkifyViewHolder(account, link);
binding.image.setImageResource(R.drawable.project_file_36dp);
break;
}
case "room": {
binding.type.setText(resources.getString(R.string.project_type_room));
linkifyViewHolder(account, link);
binding.image.setImageResource(R.drawable.project_talk_36dp);
break;
}
default: {
DeckLog.info("Unknown resource type for " + resource.getName() + ": " + resource.getType());
binding.type.setVisibility(GONE);
linkifyViewHolder(account, link);
break;
}
}
} else {
DeckLog.warn("Resource type for " + resource.getName() + " is null");
binding.type.setVisibility(GONE);
}
}
private void linkifyViewHolder(@NonNull Account account, @Nullable String link) {
if (link != null) {
try {
binding.getRoot().setOnClickListener((v) -> itemView.getContext().startActivity(new Intent(Intent.ACTION_VIEW).setData(getResourceUri(account, link))));
} catch (IllegalArgumentException e) {
DeckLog.logError(e);
}
}
}
}
|