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
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
|
package cgeo.geocaching.enumerations;
import cgeo.geocaching.CgeoApplication;
import cgeo.geocaching.R;
import org.eclipse.jdt.annotation.NonNull;
import org.eclipse.jdt.annotation.Nullable;
import java.util.HashMap;
import java.util.Locale;
import java.util.Map;
/**
* Different log types
*/
public enum LogType {
FOUND_IT(2, "2", "found it", "Found it", R.string.log_found, R.drawable.mark_green),
DIDNT_FIND_IT(3, "3", "didn't find it", "Didn't find it", R.string.log_dnf, R.drawable.mark_red),
NOTE(4, "4", "write note", "Comment", R.string.log_note),
PUBLISH_LISTING(1003, "24", "publish listing", "", R.string.log_published, R.drawable.mark_green_more),
ENABLE_LISTING(23, "23", "enable listing", "Ready to search", R.string.log_enabled, R.drawable.mark_green_more),
ARCHIVE(5, "5", "archive", "Archived", R.string.log_archived, R.drawable.mark_red_more),
UNARCHIVE(12, "12", "unarchive", "", R.string.log_unarchived, R.drawable.mark_green_more),
TEMP_DISABLE_LISTING(22, "22", "temporarily disable listing", "Temporarily unavailable", R.string.log_disabled, R.drawable.mark_red_more),
NEEDS_ARCHIVE(7, "7", "needs archived", "", R.string.log_needs_archived, R.drawable.mark_red),
WILL_ATTEND(9, "9", "will attend", "Will attend", R.string.log_attend),
ATTENDED(10, "10", "attended", "Attended", R.string.log_attended, R.drawable.mark_green),
RETRIEVED_IT(13, "13", "retrieved it", "", R.string.log_retrieved, R.drawable.mark_green_more),
PLACED_IT(14, "14", "placed it", "", R.string.log_placed, R.drawable.mark_green_more),
GRABBED_IT(19, "19", "grabbed it", "", R.string.log_grabbed, R.drawable.mark_green_more),
NEEDS_MAINTENANCE(45, "45", "needs maintenance", "Needs maintenance", R.string.log_maintenance_needed, R.drawable.mark_red),
OWNER_MAINTENANCE(46, "46", "owner maintenance", "", R.string.log_maintained, R.drawable.mark_green_more),
UPDATE_COORDINATES(47, "47", "update coordinates", "Moved", R.string.log_update),
DISCOVERED_IT(48, "48", "discovered it", "", R.string.log_discovered, R.drawable.mark_green),
POST_REVIEWER_NOTE(18, "18", "post reviewer note", "", R.string.log_reviewer),
SUBMIT_FOR_REVIEW(76, "76", "submit for review", "", R.string.log_submit_for_review),
VISIT(1001, "75", "visit", "", R.string.log_tb_visit, R.drawable.mark_green),
WEBCAM_PHOTO_TAKEN(11, "11", "webcam photo taken", "", R.string.log_webcam, R.drawable.mark_green),
ANNOUNCEMENT(74, "74", "announcement", "", R.string.log_announcement),
MOVE_COLLECTION(69, "69", "unused_collection", "", R.string.log_movecollection),
MOVE_INVENTORY(70, "70", "unused_inventory", "", R.string.log_moveinventory),
RETRACT(25, "25", "retract listing", "", R.string.log_retractlisting),
MARKED_MISSING(16, "16", "marked missing", "", R.string.log_marked_missing, R.drawable.mark_red),
OC_TEAM_COMMENT(83, null, "X1", "OC Team comment", R.string.log_oc_team_comment),
UNKNOWN(0, "unknown", "", "", R.string.err_unknown, R.drawable.mark_red); // LogType not init. yet
public final int id;
@Nullable
public final String iconName;
@NonNull
public final String type;
@NonNull
public final String oc_type;
private final int stringId;
public final int markerId;
LogType(final int id, @Nullable final String iconName, @NonNull final String type, @NonNull final String oc_type, final int stringId, final int markerId) {
this.id = id;
this.iconName = iconName;
this.type = type;
this.oc_type = oc_type;
this.stringId = stringId;
this.markerId = markerId;
}
LogType(final int id, final String iconName, final String type, final String oc_type, final int stringId) {
this(id, iconName, type, oc_type, stringId, R.drawable.mark_gray);
}
private final static Map<String, LogType> FIND_BY_ICONNAME = new HashMap<>();
private final static Map<String, LogType> FIND_BY_TYPE = new HashMap<>();
static {
for (final LogType lt : values()) {
if (lt.iconName != null) {
FIND_BY_ICONNAME.put(lt.iconName, lt);
}
FIND_BY_TYPE.put(lt.type, lt);
}
}
@NonNull
public static LogType getById(final int id) {
for (final LogType logType : values()) {
if (logType.id == id) {
return logType;
}
}
return UNKNOWN;
}
@NonNull
public static LogType getByIconName(final String imageType) {
// Special case for post reviewer note, which appears sometimes as 18.png (in individual entries) or as 68.png
// (in logs counts).
if ("68".equals(imageType)) {
return POST_REVIEWER_NOTE;
}
final LogType result = imageType != null ? LogType.FIND_BY_ICONNAME.get(imageType.toLowerCase(Locale.US).trim()) : null;
if (result == null) {
return UNKNOWN;
}
return result;
}
@NonNull
public static LogType getByType(final String type) {
final LogType result = type != null ? LogType.FIND_BY_TYPE.get(type.toLowerCase(Locale.US).trim()) : null;
if (result == null) {
return UNKNOWN;
}
return result;
}
@NonNull
public final String getL10n() {
return CgeoApplication.getInstance().getBaseContext().getResources().getString(stringId);
}
public final boolean isFoundLog() {
return this == LogType.FOUND_IT || this == LogType.ATTENDED || this == LogType.WEBCAM_PHOTO_TAKEN;
}
public boolean mustConfirmLog() {
return this == ARCHIVE || this == NEEDS_ARCHIVE;
}
}
|